From 0a72a170696abf1a14bb53f828b339ffc7a27680 Mon Sep 17 00:00:00 2001 From: Owlbot Bootstrapper Date: Thu, 9 Nov 2023 22:11:12 +0000 Subject: [PATCH 1/7] feat: initial commit From b619ad7cd15dcb299ab737b83402cfe07fceb60e Mon Sep 17 00:00:00 2001 From: Owlbot Bootstrapper Date: Thu, 9 Nov 2023 22:12:45 +0000 Subject: [PATCH 2/7] feat: initial generation of library Copy-Tag: eyJwIjoicGFja2FnZXMvZ29vZ2xlLWNsb3VkLWVkZ2VuZXR3b3JrLy5Pd2xCb3QueWFtbCIsImgiOiI0ZjA5MzBlYTM2MGNmNWQ1ZWQ0MTExYmQyOWZlNDAwZWFkYjIxZWE2In0= --- .../google-cloud-edgenetwork/.OwlBot.yaml | 19 ++ .../.repo-metadata.json | 17 ++ packages/google-cloud-edgenetwork/LICENSE | 202 ++++++++++++++++++ .../google-cloud-edgenetwork/package.json | 70 ++++++ .../samples/package.json | 24 +++ .../samples/test/quickstart.js | 39 ++++ 6 files changed, 371 insertions(+) create mode 100644 packages/google-cloud-edgenetwork/.OwlBot.yaml create mode 100644 packages/google-cloud-edgenetwork/.repo-metadata.json create mode 100644 packages/google-cloud-edgenetwork/LICENSE create mode 100644 packages/google-cloud-edgenetwork/package.json create mode 100644 packages/google-cloud-edgenetwork/samples/package.json create mode 100644 packages/google-cloud-edgenetwork/samples/test/quickstart.js diff --git a/packages/google-cloud-edgenetwork/.OwlBot.yaml b/packages/google-cloud-edgenetwork/.OwlBot.yaml new file mode 100644 index 000000000000..fbd016ba7d80 --- /dev/null +++ b/packages/google-cloud-edgenetwork/.OwlBot.yaml @@ -0,0 +1,19 @@ +# Copyright 2022 Google LLC +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +deep-copy-regex: + - source: /google/cloud/edgenetwork/(.*)/.*-nodejs + dest: /owl-bot-staging/google-cloud-edgenetwork/$1 + +api-name: edgenetwork \ No newline at end of file diff --git a/packages/google-cloud-edgenetwork/.repo-metadata.json b/packages/google-cloud-edgenetwork/.repo-metadata.json new file mode 100644 index 000000000000..7e714859c882 --- /dev/null +++ b/packages/google-cloud-edgenetwork/.repo-metadata.json @@ -0,0 +1,17 @@ +{ + "name": "edgenetwork", + "name_pretty": "Distributed Cloud Edge Network API", + "product_documentation": "https://cloud.google.com/distributed-cloud/edge/latest/docs/overview", + "client_documentation": "https://cloud.google.com/nodejs/docs/reference/edgenetwork/latest", + "issue_tracker": "https://github.com/googleapis/google-cloud-node/issues", + "release_level": "preview", + "language": "nodejs", + "repo": "googleapis/google-cloud-node", + "distribution_name": "@google-cloud/edgenetwork", + "api_id": "edgenetwork.googleapis.com", + "default_version": "v1", + "requires_billing": true, + "library_type": "GAPIC_AUTO", + "api_shortname": "edgenetwork" +} + diff --git a/packages/google-cloud-edgenetwork/LICENSE b/packages/google-cloud-edgenetwork/LICENSE new file mode 100644 index 000000000000..d64569567334 --- /dev/null +++ b/packages/google-cloud-edgenetwork/LICENSE @@ -0,0 +1,202 @@ + + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "[]" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright [yyyy] [name of copyright owner] + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/packages/google-cloud-edgenetwork/package.json b/packages/google-cloud-edgenetwork/package.json new file mode 100644 index 000000000000..601d88c963ea --- /dev/null +++ b/packages/google-cloud-edgenetwork/package.json @@ -0,0 +1,70 @@ +{ + "name": "@google-cloud/edgenetwork", + "version": "0.0.0", + "description": "Distributed Cloud Edge Network API client for Node.js", + "repository": { + "type": "git", + "url": "https://github.com/googleapis/google-cloud-node.git", + "directory": "packages/google-cloud-edgenetwork" + }, + "license": "Apache-2.0", + "author": "Google LLC", + "main": "build/src/index.js", + "files": [ + "build/src", + "build/protos" + ], + "homepage": "https://github.com/googleapis/google-cloud-node/tree/main/packages/google-cloud-edgenetwork", + "keywords": [ + "google apis client", + "google api client", + "google apis", + "google api", + "google", + "google cloud platform", + "google cloud", + "cloud", + "google edgenetwork", + "edgenetwork", + "Distributed Cloud Edge Network API" + ], + "scripts": { + "clean": "gts clean", + "compile": "tsc -p . && cp -r protos build/", + "compile-protos": "compileProtos src", + "docs": "jsdoc -c .jsdoc.js", + "predocs-test": "npm run docs", + "docs-test": "linkinator docs", + "fix": "gts fix", + "lint": "gts check", + "postpack": "minifyProtoJson", + "prepare": "npm run compile-protos && npm run compile", + "system-test": "c8 mocha build/system-test", + "test": "c8 mocha build/test", + "samples-test": "cd samples/ && npm link ../ && npm i && npm test", + "prelint": "cd samples; npm link ../; npm i" + }, + "dependencies": { + "google-gax": "^4.0.3" + }, + "devDependencies": { + "@types/mocha": "^9.0.0", + "@types/node": "^20.4.5", + "@types/sinon": "^10.0.0", + "c8": "^8.0.1", + "gapic-tools": "^0.2.0", + "gts": "^5.0.0", + "jsdoc": "^4.0.0", + "jsdoc-fresh": "^3.0.0", + "jsdoc-region-tag": "^3.0.0", + "linkinator": "4.1.2", + "long": "^5.2.3", + "mocha": "^9.2.2", + "pack-n-play": "^2.0.0", + "sinon": "^17.0.0", + "typescript": "^5.1.6" + }, + "engines": { + "node": ">=14.0.0" + } +} diff --git a/packages/google-cloud-edgenetwork/samples/package.json b/packages/google-cloud-edgenetwork/samples/package.json new file mode 100644 index 000000000000..979b8d51179b --- /dev/null +++ b/packages/google-cloud-edgenetwork/samples/package.json @@ -0,0 +1,24 @@ +{ + "name": "edgenetwork-samples", + "private": true, + "license": "Apache-2.0", + "author": "Google LLC", + "engines": { + "node": ">=14.0.0" + }, + "files": [ + "*.js" + ], + "scripts": { + "test": "c8 mocha --timeout 600000 test/*.js", + "publish": "echo 'sample test; do not publish'" + }, + "dependencies": { + "@google-cloud/edgenetwork": "0.0.0" + }, + "devDependencies": { + "c8": "^8.0.0", + "chai": "^4.2.0", + "mocha": "^8.0.0" + } +} diff --git a/packages/google-cloud-edgenetwork/samples/test/quickstart.js b/packages/google-cloud-edgenetwork/samples/test/quickstart.js new file mode 100644 index 000000000000..e61f3815c2b9 --- /dev/null +++ b/packages/google-cloud-edgenetwork/samples/test/quickstart.js @@ -0,0 +1,39 @@ +// Copyright 2022 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +'use strict'; + +const assert = require('assert'); +const path = require('path'); +const cp = require('child_process'); +const {describe, it, before} = require('mocha'); +const { Client } = require('@google-cloud/edgenetwork').v1; +const edgenetworkClient = new Client(); + +const execSync = cmd => cp.execSync(cmd, {encoding: 'utf-8'}); + +const cwd = path.join(__dirname, '..'); + +describe('Quickstart', () => { + let projectId; + + before(async () => { + projectId = await edgenetworkClient.getProjectId(); + }); + + it('should run quickstart', async () => { + const output = execSync(`node ./quickstart.js projects/${projectId}/locations/us-central1`, {cwd}); + assert(output !== null); + }); +}); From 23a580127aa4e400faa4919ef2ab20ff8a2e397a Mon Sep 17 00:00:00 2001 From: Owl Bot Date: Thu, 9 Nov 2023 22:20:10 +0000 Subject: [PATCH 3/7] Owl Bot copied code from https://github.com/googleapis/googleapis-gen/commit/4f0930ea360cf5d5ed4111bd29fe400eadb21ea6 --- .../google-cloud-edgenetwork/v1/.eslintignore | 7 + .../v1/.eslintrc.json | 3 + .../google-cloud-edgenetwork/v1/.gitignore | 14 + .../google-cloud-edgenetwork/v1/.jsdoc.js | 55 + .../google-cloud-edgenetwork/v1/.mocharc.js | 33 + .../v1/.prettierrc.js | 22 + .../google-cloud-edgenetwork/v1/README.md | 1 + .../google-cloud-edgenetwork/v1/package.json | 58 + .../cloud/edgenetwork/v1/resources.proto | 594 ++ .../google/cloud/edgenetwork/v1/service.proto | 1002 ++++ ..._network.create_interconnect_attachment.js | 88 + .../v1/edge_network.create_network.js | 88 + .../v1/edge_network.create_router.js | 88 + .../v1/edge_network.create_subnet.js | 88 + ..._network.delete_interconnect_attachment.js | 76 + .../v1/edge_network.delete_network.js | 76 + .../v1/edge_network.delete_router.js | 76 + .../v1/edge_network.delete_subnet.js | 76 + .../v1/edge_network.diagnose_interconnect.js | 61 + .../v1/edge_network.diagnose_network.js | 61 + .../v1/edge_network.diagnose_router.js | 61 + .../v1/edge_network.get_interconnect.js | 61 + ...dge_network.get_interconnect_attachment.js | 61 + .../generated/v1/edge_network.get_network.js | 61 + .../generated/v1/edge_network.get_router.js | 61 + .../generated/v1/edge_network.get_subnet.js | 61 + .../generated/v1/edge_network.get_zone.js | 61 + .../v1/edge_network.initialize_zone.js | 61 + ...e_network.list_interconnect_attachments.js | 80 + .../v1/edge_network.list_interconnects.js | 80 + .../v1/edge_network.list_networks.js | 80 + .../generated/v1/edge_network.list_routers.js | 80 + .../generated/v1/edge_network.list_subnets.js | 80 + .../generated/v1/edge_network.list_zones.js | 80 + .../v1/edge_network.update_router.js | 85 + .../v1/edge_network.update_subnet.js | 85 + ..._metadata_google.cloud.edgenetwork.v1.json | 1231 ++++ .../google-cloud-edgenetwork/v1/src/index.ts | 25 + .../v1/src/v1/edge_network_client.ts | 4016 +++++++++++++ .../v1/src/v1/edge_network_client_config.json | 165 + .../v1/src/v1/edge_network_proto_list.json | 4 + .../v1/src/v1/gapic_metadata.json | 307 + .../v1/src/v1/index.ts | 19 + .../system-test/fixtures/sample/src/index.js | 27 + .../system-test/fixtures/sample/src/index.ts | 32 + .../v1/system-test/install.ts | 49 + .../v1/test/gapic_edge_network_v1.ts | 5119 +++++++++++++++++ .../google-cloud-edgenetwork/v1/tsconfig.json | 19 + .../v1/webpack.config.js | 64 + 49 files changed, 14782 insertions(+) create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/.eslintignore create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/.eslintrc.json create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/.gitignore create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/.jsdoc.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/.mocharc.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/.prettierrc.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/README.md create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/package.json create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/protos/google/cloud/edgenetwork/v1/resources.proto create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/protos/google/cloud/edgenetwork/v1/service.proto create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_interconnect_attachment.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_network.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_router.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_subnet.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_interconnect_attachment.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_network.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_router.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_subnet.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_interconnect.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_network.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_router.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_interconnect.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_interconnect_attachment.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_network.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_router.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_subnet.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_zone.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.initialize_zone.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_interconnect_attachments.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_interconnects.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_networks.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_routers.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_subnets.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_zones.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.update_router.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.update_subnet.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/snippet_metadata_google.cloud.edgenetwork.v1.json create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/src/index.ts create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_client.ts create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_client_config.json create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_proto_list.json create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/gapic_metadata.json create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/index.ts create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/system-test/fixtures/sample/src/index.js create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/system-test/fixtures/sample/src/index.ts create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/system-test/install.ts create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/test/gapic_edge_network_v1.ts create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/tsconfig.json create mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/webpack.config.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/.eslintignore b/owl-bot-staging/google-cloud-edgenetwork/v1/.eslintignore new file mode 100644 index 000000000000..cfc348ec4d11 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/.eslintignore @@ -0,0 +1,7 @@ +**/node_modules +**/.coverage +build/ +docs/ +protos/ +system-test/ +samples/generated/ diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/.eslintrc.json b/owl-bot-staging/google-cloud-edgenetwork/v1/.eslintrc.json new file mode 100644 index 000000000000..782153495464 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/.eslintrc.json @@ -0,0 +1,3 @@ +{ + "extends": "./node_modules/gts" +} diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/.gitignore b/owl-bot-staging/google-cloud-edgenetwork/v1/.gitignore new file mode 100644 index 000000000000..d4f03a0df2e8 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/.gitignore @@ -0,0 +1,14 @@ +**/*.log +**/node_modules +/.coverage +/coverage +/.nyc_output +/docs/ +/out/ +/build/ +system-test/secrets.js +system-test/*key.json +*.lock +.DS_Store +package-lock.json +__pycache__ diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/.jsdoc.js b/owl-bot-staging/google-cloud-edgenetwork/v1/.jsdoc.js new file mode 100644 index 000000000000..b7c25744240f --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/.jsdoc.js @@ -0,0 +1,55 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + +'use strict'; + +module.exports = { + opts: { + readme: './README.md', + package: './package.json', + template: './node_modules/jsdoc-fresh', + recurse: true, + verbose: true, + destination: './docs/' + }, + plugins: [ + 'plugins/markdown', + 'jsdoc-region-tag' + ], + source: { + excludePattern: '(^|\\/|\\\\)[._]', + include: [ + 'build/src', + 'protos' + ], + includePattern: '\\.js$' + }, + templates: { + copyright: 'Copyright 2023 Google LLC', + includeDate: false, + sourceFiles: false, + systemName: '@google-cloud/edgenetwork', + theme: 'lumen', + default: { + outputSourceFiles: false + } + }, + markdown: { + idInHeadings: true + } +}; diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/.mocharc.js b/owl-bot-staging/google-cloud-edgenetwork/v1/.mocharc.js new file mode 100644 index 000000000000..1a38f257db70 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/.mocharc.js @@ -0,0 +1,33 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + +const config = { + "enable-source-maps": true, + "throw-deprecation": true, + "timeout": 10000 +} +if (process.env.MOCHA_THROW_DEPRECATION === 'false') { + delete config['throw-deprecation']; +} +if (process.env.MOCHA_REPORTER) { + config.reporter = process.env.MOCHA_REPORTER; +} +if (process.env.MOCHA_REPORTER_OUTPUT) { + config['reporter-option'] = `output=${process.env.MOCHA_REPORTER_OUTPUT}`; +} +module.exports = config diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/.prettierrc.js b/owl-bot-staging/google-cloud-edgenetwork/v1/.prettierrc.js new file mode 100644 index 000000000000..55639e70f9ea --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/.prettierrc.js @@ -0,0 +1,22 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + +module.exports = { + ...require('gts/.prettierrc.json') +} diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/README.md b/owl-bot-staging/google-cloud-edgenetwork/v1/README.md new file mode 100644 index 000000000000..fcd1db7e20ec --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/README.md @@ -0,0 +1 @@ +Edgenetwork: Nodejs Client diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/package.json b/owl-bot-staging/google-cloud-edgenetwork/v1/package.json new file mode 100644 index 000000000000..634e1815ed2a --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/package.json @@ -0,0 +1,58 @@ +{ + "name": "@google-cloud/edgenetwork", + "version": "0.1.0", + "description": "Edgenetwork client for Node.js", + "repository": "googleapis/nodejs-edgenetwork", + "license": "Apache-2.0", + "author": "Google LLC", + "main": "build/src/index.js", + "files": [ + "build/src", + "build/protos" + ], + "keywords": [ + "google apis client", + "google api client", + "google apis", + "google api", + "google", + "google cloud platform", + "google cloud", + "cloud", + "google edgenetwork", + "edgenetwork", + "edge network" + ], + "scripts": { + "clean": "gts clean", + "compile": "tsc -p . && cp -r protos build/ && minifyProtoJson", + "compile-protos": "compileProtos src", + "docs": "jsdoc -c .jsdoc.js", + "fix": "gts fix", + "lint": "gts check", + "prepare": "npm run compile-protos && npm run compile", + "system-test": "c8 mocha build/system-test", + "test": "c8 mocha build/test" + }, + "dependencies": { + "google-gax": "^4.0.4" + }, + "devDependencies": { + "@types/mocha": "^10.0.1", + "@types/node": "^18.11.18", + "@types/sinon": "^10.0.17", + "c8": "^8.0.1", + "gapic-tools": "^0.2.0", + "gts": "5.0.1", + "jsdoc": "^4.0.2", + "jsdoc-fresh": "^3.0.0", + "jsdoc-region-tag": "^3.0.0", + "mocha": "^10.2.0", + "pack-n-play": "^1.0.0-2", + "sinon": "^15.2.0", + "typescript": "5.1.6" + }, + "engines": { + "node": ">=v14" + } +} diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/protos/google/cloud/edgenetwork/v1/resources.proto b/owl-bot-staging/google-cloud-edgenetwork/v1/protos/google/cloud/edgenetwork/v1/resources.proto new file mode 100644 index 000000000000..604c1222a043 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/protos/google/cloud/edgenetwork/v1/resources.proto @@ -0,0 +1,594 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +syntax = "proto3"; + +package google.cloud.edgenetwork.v1; + +import "google/api/field_behavior.proto"; +import "google/api/resource.proto"; +import "google/protobuf/timestamp.proto"; + +option go_package = "cloud.google.com/go/edgenetwork/apiv1/edgenetworkpb;edgenetworkpb"; +option java_multiple_files = true; +option java_outer_classname = "ResourcesProto"; +option java_package = "google.cloud.edgenetwork.v1"; + +// ResourceState describes the state the resource. +// A normal lifecycle of a new resource being created would be: PENDING -> +// PROVISIONING -> RUNNING. A normal lifecycle of an existing resource being +// deleted would be: RUNNING -> DELETING. Any failures during processing will +// result the resource to be in a SUSPENDED state. +enum ResourceState { + // Unspecified state. + STATE_UNKNOWN = 0; + + // The resource is being prepared to be applied to the rack. + STATE_PENDING = 1; + + // The resource has started being applied to the rack. + STATE_PROVISIONING = 2; + + // The resource has been pushed to the rack. + STATE_RUNNING = 3; + + // The resource failed to push to the rack. + STATE_SUSPENDED = 4; + + // The resource is under deletion. + STATE_DELETING = 5; +} + +// A Google Edge Cloud zone. +message Zone { + option (google.api.resource) = { + type: "edgenetwork.googleapis.com/Zone" + pattern: "projects/{project}/locations/{location}/zones/{zone}" + }; + + // Required. The resource name of the zone. + string name = 1 [(google.api.field_behavior) = REQUIRED]; + + // Output only. The time when the zone was created. + google.protobuf.Timestamp create_time = 2 + [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Output only. The time when the zone was last updated. + google.protobuf.Timestamp update_time = 3 + [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Labels as key value pairs + map labels = 4; + + // The deployment layout type. + string layout_name = 5; +} + +// Message describing Network object +message Network { + option (google.api.resource) = { + type: "edgenetwork.googleapis.com/Network" + pattern: "projects/{project}/locations/{location}/zones/{zone}/networks/{network}" + }; + + // Required. The canonical resource name of the network. + string name = 1 [(google.api.field_behavior) = REQUIRED]; + + // Output only. The time when the network was created. + google.protobuf.Timestamp create_time = 2 + [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Output only. The time when the network was last updated. + google.protobuf.Timestamp update_time = 3 + [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Labels associated with this resource. + map labels = 4; + + // Optional. A free-text description of the resource. Max length 1024 + // characters. + string description = 5 [(google.api.field_behavior) = OPTIONAL]; + + // IP (L3) MTU value of the network. + // Valid values are: 1500 and 9000. + // Default to 1500 if not set. + int32 mtu = 6; +} + +// Message describing Subnet object +message Subnet { + option (google.api.resource) = { + type: "edgenetwork.googleapis.com/Subnet" + pattern: "projects/{project}/locations/{location}/zones/{zone}/subnets/{subnet}" + }; + + // Required. The canonical resource name of the subnet. + string name = 1 [(google.api.field_behavior) = REQUIRED]; + + // Output only. The time when the subnet was created. + google.protobuf.Timestamp create_time = 2 + [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Output only. The time when the subnet was last updated. + google.protobuf.Timestamp update_time = 3 + [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Labels associated with this resource. + map labels = 4; + + // Optional. A free-text description of the resource. Max length 1024 + // characters. + string description = 5 [(google.api.field_behavior) = OPTIONAL]; + + // Required. The network that this subnetwork belongs to. + string network = 6 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Network" + } + ]; + + // The ranges of ipv4 addresses that are owned by this subnetwork. + repeated string ipv4_cidr = 7; + + // The ranges of ipv6 addresses that are owned by this subnetwork. + repeated string ipv6_cidr = 8; + + // Optional. VLAN id provided by user. If not specified we assign one + // automatically. + int32 vlan_id = 9 [(google.api.field_behavior) = OPTIONAL]; + + // Output only. Current stage of the resource to the device by config push. + ResourceState state = 10 [(google.api.field_behavior) = OUTPUT_ONLY]; +} + +// Message describing Interconnect object +message Interconnect { + option (google.api.resource) = { + type: "edgenetwork.googleapis.com/Interconnect" + pattern: "projects/{project}/locations/{location}/zones/{zone}/interconnects/{interconnect}" + }; + + // Type of interconnect. + enum InterconnectType { + // Unspecified. + INTERCONNECT_TYPE_UNSPECIFIED = 0; + + // Dedicated Interconnect. + DEDICATED = 1; + } + + // Required. The canonical resource name of the interconnect. + string name = 1 [(google.api.field_behavior) = REQUIRED]; + + // Output only. The time when the subnet was created. + google.protobuf.Timestamp create_time = 2 + [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Output only. The time when the subnet was last updated. + google.protobuf.Timestamp update_time = 3 + [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Labels associated with this resource. + map labels = 4; + + // Optional. A free-text description of the resource. Max length 1024 + // characters. + string description = 5 [(google.api.field_behavior) = OPTIONAL]; + + // Optional. Type of interconnect, which takes only the value 'DEDICATED' for + // now. + InterconnectType interconnect_type = 6 + [(google.api.field_behavior) = OPTIONAL]; + + // Output only. Unique identifier for the link. + string uuid = 7 [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Output only. Cloud resource name of the switch device. + string device_cloud_resource_name = 8 + [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Output only. Physical ports (e.g., TenGigE0/0/0/1) that form the + // interconnect. + repeated string physical_ports = 9 + [(google.api.field_behavior) = OUTPUT_ONLY]; +} + +// Message describing InterconnectAttachment object +message InterconnectAttachment { + option (google.api.resource) = { + type: "edgenetwork.googleapis.com/InterconnectAttachment" + pattern: "projects/{project}/locations/{location}/zones/{zone}/interconnectAttachments/{interconnect_attachment}" + }; + + // Required. The canonical resource name of the interconnect attachment. + string name = 1 [(google.api.field_behavior) = REQUIRED]; + + // Output only. The time when the interconnect attachment was created. + google.protobuf.Timestamp create_time = 2 + [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Output only. The time when the interconnect attachment was last updated. + google.protobuf.Timestamp update_time = 3 + [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Labels associated with this resource. + map labels = 4; + + // Optional. A free-text description of the resource. Max length 1024 + // characters. + string description = 5 [(google.api.field_behavior) = OPTIONAL]; + + // Required. The canonical name of underlying Interconnect object that this + // attachment's traffic will traverse through. The name is in the form of + // `projects/{project}/locations/{location}/zones/{zone}/interconnects/{interconnect}`. + string interconnect = 6 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Interconnect" + } + ]; + + // Optional. The canonical Network name in the form of + // `projects/{project}/locations/{location}/zones/{zone}/networks/{network}`. + string network = 11 [ + (google.api.field_behavior) = OPTIONAL, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Network" + } + ]; + + // Required. VLAN id provided by user. Must be site-wise unique. + int32 vlan_id = 8 [(google.api.field_behavior) = REQUIRED]; + + // IP (L3) MTU value of the virtual edge cloud. + // Valid values are: 1500 and 9000. + // Default to 1500 if not set. + int32 mtu = 9; + + // Output only. Current stage of the resource to the device by config push. + ResourceState state = 10 [(google.api.field_behavior) = OUTPUT_ONLY]; +} + +// Message describing Router object +message Router { + option (google.api.resource) = { + type: "edgenetwork.googleapis.com/Router" + pattern: "projects/{project}/locations/{location}/zones/{zone}/routers/{router}" + }; + + // Router Interface defines the GDCE zone side layer-3 information for + // building the BGP session. + message Interface { + // Name of this interface entry. Unique within the Zones resource. + string name = 1; + + // IP address and range of the interface. + string ipv4_cidr = 3; + + // IPv6 address and range of the interface. + string ipv6_cidr = 6; + + // The canonical name of the linked Interconnect attachment. + string linked_interconnect_attachment = 2; + + // The canonical name of the subnetwork resource that this interface + // belongs to. + string subnetwork = 4; + + // Create loopback interface in the router when specified. + // The number of IP addresses must match the number of TOR devices. + repeated string loopback_ip_addresses = 5; + } + + // BGPPeer defines the peer side layer-3 information for building the BGP + // session. + message BgpPeer { + // Name of this BGP peer. Unique within the Zones resource. + string name = 1; + + // Name of the RouterInterface the BGP peer is associated with. + string interface = 2; + + // IP range of the interface within Google. + string interface_ipv4_cidr = 3; + + // IPv6 range of the interface within Google. + string interface_ipv6_cidr = 7; + + // IP range of the BGP interface outside Google. + string peer_ipv4_cidr = 4; + + // IPv6 range of the BGP interface outside Google. + string peer_ipv6_cidr = 6; + + // Peer BGP Autonomous System Number (ASN). Each BGP interface may use + // a different value. + uint32 peer_asn = 5; + + // Output only. Local BGP Autonomous System Number (ASN). + // This field is ST_NOT_REQUIRED because it stores private ASNs, which are + // meaningless outside the zone in which they are being used. + uint32 local_asn = 8 [(google.api.field_behavior) = OUTPUT_ONLY]; + } + + // BGP information specific to this router. + message Bgp { + // Locally assigned BGP ASN. + uint32 asn = 1; + + // The interval in seconds between BGP keepalive messages that are + // sent to the peer. Default is 20 with value between 20 and 60. + uint32 keepalive_interval_in_seconds = 2; + } + + // Required. The canonical resource name of the router. + string name = 1 [(google.api.field_behavior) = REQUIRED]; + + // Output only. The time when the router was created. + google.protobuf.Timestamp create_time = 2 + [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Output only. The time when the router was last updated. + google.protobuf.Timestamp update_time = 3 + [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Labels associated with this resource. + map labels = 4; + + // Optional. A free-text description of the resource. Max length 1024 + // characters. + string description = 5 [(google.api.field_behavior) = OPTIONAL]; + + // Required. The canonical name of the network to which this router belongs. + // The name is in the form of + // `projects/{project}/locations/{location}/zones/{zone}/networks/{network}`. + string network = 6 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Network" + } + ]; + + // Router interfaces. + repeated Interface interface = 7; + + // BGP peers. + repeated BgpPeer bgp_peer = 8; + + // BGP information specific to this router. + Bgp bgp = 9; + + // Output only. Current stage of the resource to the device by config push. + ResourceState state = 10 [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Optional. A list of CIDRs in IP/Length format to advertise northbound as + // static routes from this router. + repeated string route_advertisements = 11 + [(google.api.field_behavior) = OPTIONAL]; +} + +// LinkLayerAddress contains an IP address and corresponding link-layer address. +message LinkLayerAddress { + // The MAC address of this neighbor. + string mac_address = 1; + + // The IP address of this neighbor. + string ip_address = 2; +} + +// SubnetStatus contains detailed and current technical information about this +// subnet resource. +message SubnetStatus { + // The name of CCFE subnet resource. + string name = 1; + + // BVI MAC address. + string mac_address = 2; + + // A list of LinkLayerAddress, describing the ip address and corresponding + // link-layer address of the neighbors for this subnet. + repeated LinkLayerAddress link_layer_addresses = 3; +} + +// Diagnostics information about interconnect, contains detailed and current +// technical information about Google's side of the connection. +message InterconnectDiagnostics { + // Describing the status for each link on the Interconnect. + message LinkStatus { + // The unique ID for this link assigned during turn up by Google. + string circuit_id = 1; + + // Describing the state of a LACP link. + LinkLACPStatus lacp_status = 2; + + // A list of LinkLLDPStatus objects, used to describe LLDP status of each + // peer for each link on the Interconnect. + repeated LinkLLDPStatus lldp_statuses = 3; + + // Packet counts specific statistics for this link. + PacketCounts packet_counts = 4; + } + + // Containing a collection of interface-related statistics objects. + message PacketCounts { + // The number of packets that are delivered. + int64 inbound_unicast = 1; + + // The number of inbound packets that contained errors. + int64 inbound_errors = 2; + + // The number of inbound packets that were chosen to be discarded even + // though no errors had been detected to prevent their being deliverable. + int64 inbound_discards = 3; + + // The total number of packets that are requested be transmitted. + int64 outbound_unicast = 4; + + // The number of outbound packets that could not be transmitted because of + // errors. + int64 outbound_errors = 5; + + // The number of outbound packets that were chosen to be discarded even + // though no errors had been detected to prevent their being transmitted. + int64 outbound_discards = 6; + } + + // Describing the status of a LACP link. + message LinkLACPStatus { + // State enum for LACP link. + enum State { + // The default state indicating state is in unknown state. + UNKNOWN = 0; + + // The link is configured and active within the bundle. + ACTIVE = 1; + + // The link is not configured within the bundle, this means the rest of + // the object should be empty. + DETACHED = 2; + } + + // The state of a LACP link. + State state = 1; + + // System ID of the port on Google's side of the LACP exchange. + string google_system_id = 2; + + // System ID of the port on the neighbor's side of the LACP exchange. + string neighbor_system_id = 3; + + // A true value indicates that the participant will allow the link to be + // used as part of the aggregate. + // A false value indicates the link should be used as an individual link. + bool aggregatable = 4; + + // If true, the participant is collecting incoming frames on the link, + // otherwise false + bool collecting = 5; + + // When true, the participant is distributing outgoing frames; when false, + // distribution is disabled + bool distributing = 6; + } + + // Describing a LLDP link. + message LinkLLDPStatus { + // The peer system's administratively assigned name. + string peer_system_name = 1; + + // The textual description of the network entity of LLDP peer. + string peer_system_description = 2; + + // The peer chassis component of the endpoint identifier associated with the + // transmitting LLDP agent. + string peer_chassis_id = 3; + + // The format and source of the peer chassis identifier string. + string peer_chassis_id_type = 4; + + // The port component of the endpoint identifier associated with the + // transmitting LLDP agent. If the specified port is an IEEE 802.3 Repeater + // port, then this TLV is optional. + string peer_port_id = 5; + + // The format and source of the peer port identifier string. + string peer_port_id_type = 6; + } + + // The MAC address of the Interconnect's bundle interface. + string mac_address = 1; + + // A list of LinkLayerAddress, describing the ip address and corresponding + // link-layer address of the neighbors for this interconnect. + repeated LinkLayerAddress link_layer_addresses = 2; + + // A list of LinkStatus objects, used to describe the status for each link on + // the Interconnect. + repeated LinkStatus links = 3; +} + +// Describing the current status of a router. +message RouterStatus { + // Status of a BGP peer. + message BgpPeerStatus { + // Status of the BGP peer: {UP, DOWN} + enum BgpStatus { + // The default status indicating BGP session is in unknown state. + UNKNOWN = 0; + + // The UP status indicating BGP session is established. + UP = 1; + + // The DOWN state indicating BGP session is not established yet. + DOWN = 2; + } + + // Name of this BGP peer. Unique within the Routers resource. + string name = 1; + + // IP address of the local BGP interface. + string ip_address = 2; + + // IP address of the remote BGP interface. + string peer_ip_address = 3; + + // The current status of BGP. + BgpStatus status = 4; + + // BGP state as specified in RFC1771. + string state = 5; + + // Time this session has been up. + // Format: + // 14 years, 51 weeks, 6 days, 23 hours, 59 minutes, 59 seconds + string uptime = 6; + + // Time this session has been up, in seconds. + int64 uptime_seconds = 7; + + // A collection of counts for prefixes. + PrefixCounter prefix_counter = 8; + } + + // PrefixCounter contains a collection of prefixes related counts. + message PrefixCounter { + // Number of prefixes advertised. + int64 advertised = 1; + + // Number of prefixes denied. + int64 denied = 2; + + // Number of prefixes received. + int64 received = 3; + + // Number of prefixes sent. + int64 sent = 4; + + // Number of prefixes suppressed. + int64 suppressed = 5; + + // Number of prefixes withdrawn. + int64 withdrawn = 6; + } + + // The canonical name of the network to which this router belongs. + string network = 1 [(google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Network" + }]; + + // A list of BgpPeerStatus objects, describing all BGP peers related to this + // router. + repeated BgpPeerStatus bgp_peer_status = 2; +} diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/protos/google/cloud/edgenetwork/v1/service.proto b/owl-bot-staging/google-cloud-edgenetwork/v1/protos/google/cloud/edgenetwork/v1/service.proto new file mode 100644 index 000000000000..33a3e3f11bf7 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/protos/google/cloud/edgenetwork/v1/service.proto @@ -0,0 +1,1002 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +syntax = "proto3"; + +package google.cloud.edgenetwork.v1; + +import "google/api/annotations.proto"; +import "google/api/client.proto"; +import "google/api/field_behavior.proto"; +import "google/api/resource.proto"; +import "google/cloud/edgenetwork/v1/resources.proto"; +import "google/longrunning/operations.proto"; +import "google/protobuf/empty.proto"; +import "google/protobuf/field_mask.proto"; +import "google/protobuf/timestamp.proto"; + +option go_package = "cloud.google.com/go/edgenetwork/apiv1/edgenetworkpb;edgenetworkpb"; +option java_multiple_files = true; +option java_outer_classname = "ServiceProto"; +option java_package = "google.cloud.edgenetwork.v1"; + +// EdgeNetwork API provides managed, highly available cloud dynamic network +// configuration service to the GEC customer to enable edge application and +// network function solutions. This allows the customers to easily define and +// configure the network setup and property to meet the workload requirement. +service EdgeNetwork { + option (google.api.default_host) = "edgenetwork.googleapis.com"; + option (google.api.oauth_scopes) = + "https://www.googleapis.com/auth/cloud-platform"; + + // InitializeZone will initialize resources for a zone in a project. + rpc InitializeZone(InitializeZoneRequest) returns (InitializeZoneResponse) { + option (google.api.http) = { + post: "/v1/{name=projects/*/locations/*/zones/*}:initialize" + body: "*" + }; + option (google.api.method_signature) = "name"; + } + + // Lists Zones in a given project and location. + rpc ListZones(ListZonesRequest) returns (ListZonesResponse) { + option (google.api.http) = { + get: "/v1/{parent=projects/*/locations/*}/zones" + }; + option (google.api.method_signature) = "parent"; + } + + // Gets details of a single Zone. + rpc GetZone(GetZoneRequest) returns (Zone) { + option (google.api.http) = { + get: "/v1/{name=projects/*/locations/*/zones/*}" + }; + option (google.api.method_signature) = "name"; + } + + // Lists Networks in a given project and location. + rpc ListNetworks(ListNetworksRequest) returns (ListNetworksResponse) { + option (google.api.http) = { + get: "/v1/{parent=projects/*/locations/*/zones/*}/networks" + }; + option (google.api.method_signature) = "parent"; + } + + // Gets details of a single Network. + rpc GetNetwork(GetNetworkRequest) returns (Network) { + option (google.api.http) = { + get: "/v1/{name=projects/*/locations/*/zones/*/networks/*}" + }; + option (google.api.method_signature) = "name"; + } + + // Get the diagnostics of a single network resource. + rpc DiagnoseNetwork(DiagnoseNetworkRequest) + returns (DiagnoseNetworkResponse) { + option (google.api.http) = { + get: "/v1/{name=projects/*/locations/*/zones/*/networks/*}:diagnose" + }; + option (google.api.method_signature) = "name"; + } + + // Creates a new Network in a given project and location. + rpc CreateNetwork(CreateNetworkRequest) + returns (google.longrunning.Operation) { + option (google.api.http) = { + post: "/v1/{parent=projects/*/locations/*/zones/*}/networks" + body: "network" + }; + option (google.api.method_signature) = "parent,network,network_id"; + option (google.longrunning.operation_info) = { + response_type: "Network" + metadata_type: "OperationMetadata" + }; + } + + // Deletes a single Network. + rpc DeleteNetwork(DeleteNetworkRequest) + returns (google.longrunning.Operation) { + option (google.api.http) = { + delete: "/v1/{name=projects/*/locations/*/zones/*/networks/*}" + }; + option (google.api.method_signature) = "name"; + option (google.longrunning.operation_info) = { + response_type: "google.protobuf.Empty" + metadata_type: "OperationMetadata" + }; + } + + // Lists Subnets in a given project and location. + rpc ListSubnets(ListSubnetsRequest) returns (ListSubnetsResponse) { + option (google.api.http) = { + get: "/v1/{parent=projects/*/locations/*/zones/*}/subnets" + }; + option (google.api.method_signature) = "parent"; + } + + // Gets details of a single Subnet. + rpc GetSubnet(GetSubnetRequest) returns (Subnet) { + option (google.api.http) = { + get: "/v1/{name=projects/*/locations/*/zones/*/subnets/*}" + }; + option (google.api.method_signature) = "name"; + } + + // Creates a new Subnet in a given project and location. + rpc CreateSubnet(CreateSubnetRequest) returns (google.longrunning.Operation) { + option (google.api.http) = { + post: "/v1/{parent=projects/*/locations/*/zones/*}/subnets" + body: "subnet" + }; + option (google.api.method_signature) = "parent,subnet,subnet_id"; + option (google.longrunning.operation_info) = { + response_type: "Subnet" + metadata_type: "OperationMetadata" + }; + } + + // Updates the parameters of a single Subnet. + rpc UpdateSubnet(UpdateSubnetRequest) returns (google.longrunning.Operation) { + option (google.api.http) = { + patch: "/v1/{subnet.name=projects/*/locations/*/zones/*/subnets/*}" + body: "subnet" + }; + option (google.api.method_signature) = "subnet,update_mask"; + option (google.longrunning.operation_info) = { + response_type: "Subnet" + metadata_type: "OperationMetadata" + }; + } + + // Deletes a single Subnet. + rpc DeleteSubnet(DeleteSubnetRequest) returns (google.longrunning.Operation) { + option (google.api.http) = { + delete: "/v1/{name=projects/*/locations/*/zones/*/subnets/*}" + }; + option (google.api.method_signature) = "name"; + option (google.longrunning.operation_info) = { + response_type: "google.protobuf.Empty" + metadata_type: "OperationMetadata" + }; + } + + // Lists Interconnects in a given project and location. + rpc ListInterconnects(ListInterconnectsRequest) + returns (ListInterconnectsResponse) { + option (google.api.http) = { + get: "/v1/{parent=projects/*/locations/*/zones/*}/interconnects" + }; + option (google.api.method_signature) = "parent"; + } + + // Gets details of a single Interconnect. + rpc GetInterconnect(GetInterconnectRequest) returns (Interconnect) { + option (google.api.http) = { + get: "/v1/{name=projects/*/locations/*/zones/*/interconnects/*}" + }; + option (google.api.method_signature) = "name"; + } + + // Get the diagnostics of a single interconnect resource. + rpc DiagnoseInterconnect(DiagnoseInterconnectRequest) + returns (DiagnoseInterconnectResponse) { + option (google.api.http) = { + get: "/v1/{name=projects/*/locations/*/zones/*/interconnects/*}:diagnose" + }; + option (google.api.method_signature) = "name"; + } + + // Lists InterconnectAttachments in a given project and location. + rpc ListInterconnectAttachments(ListInterconnectAttachmentsRequest) + returns (ListInterconnectAttachmentsResponse) { + option (google.api.http) = { + get: "/v1/{parent=projects/*/locations/*/zones/*}/interconnectAttachments" + }; + option (google.api.method_signature) = "parent"; + } + + // Gets details of a single InterconnectAttachment. + rpc GetInterconnectAttachment(GetInterconnectAttachmentRequest) + returns (InterconnectAttachment) { + option (google.api.http) = { + get: "/v1/{name=projects/*/locations/*/zones/*/interconnectAttachments/*}" + }; + option (google.api.method_signature) = "name"; + } + + // Creates a new InterconnectAttachment in a given project and location. + rpc CreateInterconnectAttachment(CreateInterconnectAttachmentRequest) + returns (google.longrunning.Operation) { + option (google.api.http) = { + post: "/v1/{parent=projects/*/locations/*/zones/*}/interconnectAttachments" + body: "interconnect_attachment" + }; + option (google.api.method_signature) = + "parent,interconnect_attachment,interconnect_attachment_id"; + option (google.longrunning.operation_info) = { + response_type: "InterconnectAttachment" + metadata_type: "OperationMetadata" + }; + } + + // Deletes a single InterconnectAttachment. + rpc DeleteInterconnectAttachment(DeleteInterconnectAttachmentRequest) + returns (google.longrunning.Operation) { + option (google.api.http) = { + delete: "/v1/{name=projects/*/locations/*/zones/*/interconnectAttachments/*}" + }; + option (google.api.method_signature) = "name"; + option (google.longrunning.operation_info) = { + response_type: "google.protobuf.Empty" + metadata_type: "OperationMetadata" + }; + } + + // Lists Routers in a given project and location. + rpc ListRouters(ListRoutersRequest) returns (ListRoutersResponse) { + option (google.api.http) = { + get: "/v1/{parent=projects/*/locations/*/zones/*}/routers" + }; + option (google.api.method_signature) = "parent"; + } + + // Gets details of a single Router. + rpc GetRouter(GetRouterRequest) returns (Router) { + option (google.api.http) = { + get: "/v1/{name=projects/*/locations/*/zones/*/routers/*}" + }; + option (google.api.method_signature) = "name"; + } + + // Get the diagnostics of a single router resource. + rpc DiagnoseRouter(DiagnoseRouterRequest) returns (DiagnoseRouterResponse) { + option (google.api.http) = { + get: "/v1/{name=projects/*/locations/*/zones/*/routers/*}:diagnose" + }; + option (google.api.method_signature) = "name"; + } + + // Creates a new Router in a given project and location. + rpc CreateRouter(CreateRouterRequest) returns (google.longrunning.Operation) { + option (google.api.http) = { + post: "/v1/{parent=projects/*/locations/*/zones/*}/routers" + body: "router" + }; + option (google.api.method_signature) = "parent,router,router_id"; + option (google.longrunning.operation_info) = { + response_type: "Router" + metadata_type: "OperationMetadata" + }; + } + + // Updates the parameters of a single Router. + rpc UpdateRouter(UpdateRouterRequest) returns (google.longrunning.Operation) { + option (google.api.http) = { + patch: "/v1/{router.name=projects/*/locations/*/zones/*/routers/*}" + body: "router" + }; + option (google.api.method_signature) = "router,update_mask"; + option (google.longrunning.operation_info) = { + response_type: "Router" + metadata_type: "OperationMetadata" + }; + } + + // Deletes a single Router. + rpc DeleteRouter(DeleteRouterRequest) returns (google.longrunning.Operation) { + option (google.api.http) = { + delete: "/v1/{name=projects/*/locations/*/zones/*/routers/*}" + }; + option (google.api.method_signature) = "name"; + option (google.longrunning.operation_info) = { + response_type: "google.protobuf.Empty" + metadata_type: "OperationMetadata" + }; + } +} + +// Message for requesting list of Zones +message ListZonesRequest { + // Required. Parent value for ListZonesRequest + string parent = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + child_type: "edgenetwork.googleapis.com/Zone" + } + ]; + + // Requested page size. Server may return fewer items than requested. + // If unspecified, server will pick an appropriate default. + int32 page_size = 2; + + // A token identifying a page of results the server should return. + string page_token = 3; + + // Filtering results + string filter = 4; + + // Hint for how to order the results + string order_by = 5; +} + +// Message for response to listing Zones +message ListZonesResponse { + // The list of Zone + repeated Zone zones = 1; + + // A token identifying a page of results the server should return. + string next_page_token = 2; + + // Locations that could not be reached. + repeated string unreachable = 3; +} + +// Message for getting a Zone +message GetZoneRequest { + // Required. Name of the resource + string name = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Zone" + } + ]; +} + +// Message for requesting list of Networks +message ListNetworksRequest { + // Required. Parent value for ListNetworksRequest + string parent = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + child_type: "edgenetwork.googleapis.com/Network" + } + ]; + + // Requested page size. Server may return fewer items than requested. + // If unspecified, server will pick an appropriate default. + int32 page_size = 2; + + // A token identifying a page of results the server should return. + string page_token = 3; + + // Filtering results + string filter = 4; + + // Hint for how to order the results + string order_by = 5; +} + +// Message for response to listing Networks +message ListNetworksResponse { + // The list of Network + repeated Network networks = 1; + + // A token identifying a page of results the server should return. + string next_page_token = 2; + + // Locations that could not be reached. + repeated string unreachable = 3; +} + +// Message for getting a Network +message GetNetworkRequest { + // Required. Name of the resource + string name = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Network" + } + ]; +} + +// Message for creating a Network +message CreateNetworkRequest { + // Required. Value for parent. + string parent = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + child_type: "edgenetwork.googleapis.com/Network" + } + ]; + + // Required. Id of the requesting object + // If auto-generating Id server-side, remove this field and + // network_id from the method_signature of Create RPC + string network_id = 2 [(google.api.field_behavior) = REQUIRED]; + + // Required. The resource being created + Network network = 3 [(google.api.field_behavior) = REQUIRED]; + + // Optional. An optional request ID to identify requests. Specify a unique + // request ID so that if you must retry your request, the server will know to + // ignore the request if it has already been completed. The server will + // guarantee that for at least 60 minutes since the first request. + // + // For example, consider a situation where you make an initial request and + // the request times out. If you make the request again with the same request + // ID, the server can check if original operation with the same request ID + // was received, and if so, will ignore the second request. This prevents + // clients from accidentally creating duplicate commitments. + // + // The request ID must be a valid UUID with the exception that zero UUID is + // not supported (00000000-0000-0000-0000-000000000000). + string request_id = 4 [(google.api.field_behavior) = OPTIONAL]; +} + +// Message for deleting a Network +message DeleteNetworkRequest { + // Required. Name of the resource + string name = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Network" + } + ]; + + // Optional. An optional request ID to identify requests. Specify a unique + // request ID so that if you must retry your request, the server will know to + // ignore the request if it has already been completed. The server will + // guarantee that for at least 60 minutes after the first request. + // + // For example, consider a situation where you make an initial request and + // the request times out. If you make the request again with the same request + // ID, the server can check if original operation with the same request ID + // was received, and if so, will ignore the second request. This prevents + // clients from accidentally creating duplicate commitments. + // + // The request ID must be a valid UUID with the exception that zero UUID is + // not supported (00000000-0000-0000-0000-000000000000). + string request_id = 2 [(google.api.field_behavior) = OPTIONAL]; +} + +// Message for requesting list of Subnets +message ListSubnetsRequest { + // Required. Parent value for ListSubnetsRequest + string parent = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + child_type: "edgenetwork.googleapis.com/Subnet" + } + ]; + + // Requested page size. Server may return fewer items than requested. + // If unspecified, server will pick an appropriate default. + int32 page_size = 2; + + // A token identifying a page of results the server should return. + string page_token = 3; + + // Filtering results + string filter = 4; + + // Hint for how to order the results + string order_by = 5; +} + +// Message for response to listing Subnets +message ListSubnetsResponse { + // The list of Subnet + repeated Subnet subnets = 1; + + // A token identifying a page of results the server should return. + string next_page_token = 2; + + // Locations that could not be reached. + repeated string unreachable = 3; +} + +// Message for getting a Subnet +message GetSubnetRequest { + // Required. Name of the resource + string name = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Subnet" + } + ]; +} + +// Message for creating a Subnet +message CreateSubnetRequest { + // Required. Value for parent. + string parent = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + child_type: "edgenetwork.googleapis.com/Subnet" + } + ]; + + // Required. Id of the requesting object + // If auto-generating Id server-side, remove this field and + // subnet_id from the method_signature of Create RPC + string subnet_id = 2 [(google.api.field_behavior) = REQUIRED]; + + // Required. The resource being created + Subnet subnet = 3 [(google.api.field_behavior) = REQUIRED]; + + // Optional. An optional request ID to identify requests. Specify a unique + // request ID so that if you must retry your request, the server will know to + // ignore the request if it has already been completed. The server will + // guarantee that for at least 60 minutes since the first request. + // + // For example, consider a situation where you make an initial request and + // the request times out. If you make the request again with the same request + // ID, the server can check if original operation with the same request ID + // was received, and if so, will ignore the second request. This prevents + // clients from accidentally creating duplicate commitments. + // + // The request ID must be a valid UUID with the exception that zero UUID is + // not supported (00000000-0000-0000-0000-000000000000). + string request_id = 4 [(google.api.field_behavior) = OPTIONAL]; +} + +// Message for updating a Subnet +message UpdateSubnetRequest { + // Required. Field mask is used to specify the fields to be overwritten in the + // Subnet resource by the update. + // The fields specified in the update_mask are relative to the resource, not + // the full request. A field will be overwritten if it is in the mask. If the + // user does not provide a mask then all fields will be overwritten. + google.protobuf.FieldMask update_mask = 1 + [(google.api.field_behavior) = REQUIRED]; + + // Required. The resource being updated + Subnet subnet = 2 [(google.api.field_behavior) = REQUIRED]; + + // Optional. An optional request ID to identify requests. Specify a unique + // request ID so that if you must retry your request, the server will know to + // ignore the request if it has already been completed. The server will + // guarantee that for at least 60 minutes since the first request. + // + // For example, consider a situation where you make an initial request and + // the request times out. If you make the request again with the same request + // ID, the server can check if original operation with the same request ID + // was received, and if so, will ignore the second request. This prevents + // clients from accidentally creating duplicate commitments. + // + // The request ID must be a valid UUID with the exception that zero UUID is + // not supported (00000000-0000-0000-0000-000000000000). + string request_id = 3 [(google.api.field_behavior) = OPTIONAL]; +} + +// Message for deleting a Subnet +message DeleteSubnetRequest { + // Required. Name of the resource + string name = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Subnet" + } + ]; + + // Optional. An optional request ID to identify requests. Specify a unique + // request ID so that if you must retry your request, the server will know to + // ignore the request if it has already been completed. The server will + // guarantee that for at least 60 minutes after the first request. + // + // For example, consider a situation where you make an initial request and + // the request times out. If you make the request again with the same request + // ID, the server can check if original operation with the same request ID + // was received, and if so, will ignore the second request. This prevents + // clients from accidentally creating duplicate commitments. + // + // The request ID must be a valid UUID with the exception that zero UUID is + // not supported (00000000-0000-0000-0000-000000000000). + string request_id = 2 [(google.api.field_behavior) = OPTIONAL]; +} + +// Message for requesting list of Interconnects +message ListInterconnectsRequest { + // Required. Parent value for ListInterconnectsRequest + string parent = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + child_type: "edgenetwork.googleapis.com/Interconnect" + } + ]; + + // Requested page size. Server may return fewer items than requested. + // If unspecified, server will pick an appropriate default. + int32 page_size = 2; + + // A token identifying a page of results the server should return. + string page_token = 3; + + // Filtering results + string filter = 4; + + // Hint for how to order the results + string order_by = 5; +} + +// Message for response to listing Interconnects +message ListInterconnectsResponse { + // The list of Interconnect + repeated Interconnect interconnects = 1; + + // A token identifying a page of results the server should return. + string next_page_token = 2; + + // Locations that could not be reached. + repeated string unreachable = 3; +} + +// Message for getting a Interconnect +message GetInterconnectRequest { + // Required. Name of the resource + string name = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Interconnect" + } + ]; +} + +// Message for requesting list of InterconnectAttachments +message ListInterconnectAttachmentsRequest { + // Required. Parent value for ListInterconnectAttachmentsRequest + string parent = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + child_type: "edgenetwork.googleapis.com/InterconnectAttachment" + } + ]; + + // Requested page size. Server may return fewer items than requested. + // If unspecified, server will pick an appropriate default. + int32 page_size = 2; + + // A token identifying a page of results the server should return. + string page_token = 3; + + // Filtering results + string filter = 4; + + // Hint for how to order the results + string order_by = 5; +} + +// Message for response to listing InterconnectAttachments +message ListInterconnectAttachmentsResponse { + // The list of InterconnectAttachment + repeated InterconnectAttachment interconnect_attachments = 1; + + // A token identifying a page of results the server should return. + string next_page_token = 2; + + // Locations that could not be reached. + repeated string unreachable = 3; +} + +// Message for getting a InterconnectAttachment +message GetInterconnectAttachmentRequest { + // Required. Name of the resource + string name = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/InterconnectAttachment" + } + ]; +} + +// Message for creating a InterconnectAttachment +message CreateInterconnectAttachmentRequest { + // Required. Value for parent. + string parent = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + child_type: "edgenetwork.googleapis.com/InterconnectAttachment" + } + ]; + + // Required. Id of the requesting object + // If auto-generating Id server-side, remove this field and + // interconnect_attachment_id from the method_signature of Create RPC + string interconnect_attachment_id = 2 + [(google.api.field_behavior) = REQUIRED]; + + // Required. The resource being created + InterconnectAttachment interconnect_attachment = 3 + [(google.api.field_behavior) = REQUIRED]; + + // Optional. An optional request ID to identify requests. Specify a unique + // request ID so that if you must retry your request, the server will know to + // ignore the request if it has already been completed. The server will + // guarantee that for at least 60 minutes since the first request. + // + // For example, consider a situation where you make an initial request and + // the request times out. If you make the request again with the same request + // ID, the server can check if original operation with the same request ID + // was received, and if so, will ignore the second request. This prevents + // clients from accidentally creating duplicate commitments. + // + // The request ID must be a valid UUID with the exception that zero UUID is + // not supported (00000000-0000-0000-0000-000000000000). + string request_id = 4 [(google.api.field_behavior) = OPTIONAL]; +} + +// Message for deleting a InterconnectAttachment +message DeleteInterconnectAttachmentRequest { + // Required. Name of the resource + string name = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/InterconnectAttachment" + } + ]; + + // Optional. An optional request ID to identify requests. Specify a unique + // request ID so that if you must retry your request, the server will know to + // ignore the request if it has already been completed. The server will + // guarantee that for at least 60 minutes after the first request. + // + // For example, consider a situation where you make an initial request and + // the request times out. If you make the request again with the same request + // ID, the server can check if original operation with the same request ID + // was received, and if so, will ignore the second request. This prevents + // clients from accidentally creating duplicate commitments. + // + // The request ID must be a valid UUID with the exception that zero UUID is + // not supported (00000000-0000-0000-0000-000000000000). + string request_id = 2 [(google.api.field_behavior) = OPTIONAL]; +} + +// Message for requesting list of Routers +message ListRoutersRequest { + // Required. Parent value for ListRoutersRequest + string parent = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + child_type: "edgenetwork.googleapis.com/Router" + } + ]; + + // Requested page size. Server may return fewer items than requested. + // If unspecified, server will pick an appropriate default. + int32 page_size = 2; + + // A token identifying a page of results the server should return. + string page_token = 3; + + // Filtering results + string filter = 4; + + // Hint for how to order the results + string order_by = 5; +} + +// Message for response to listing Routers +message ListRoutersResponse { + // The list of Router + repeated Router routers = 1; + + // A token identifying a page of results the server should return. + string next_page_token = 2; + + // Locations that could not be reached. + repeated string unreachable = 3; +} + +// Message for getting a Router +message GetRouterRequest { + // Required. Name of the resource + string name = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Router" + } + ]; +} + +// Message for creating a Router +message CreateRouterRequest { + // Required. Value for parent. + string parent = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + child_type: "edgenetwork.googleapis.com/Router" + } + ]; + + // Required. Id of the requesting object + // If auto-generating Id server-side, remove this field and + // router_id from the method_signature of Create RPC + string router_id = 2 [(google.api.field_behavior) = REQUIRED]; + + // Required. The resource being created + Router router = 3 [(google.api.field_behavior) = REQUIRED]; + + // Optional. An optional request ID to identify requests. Specify a unique + // request ID so that if you must retry your request, the server will know to + // ignore the request if it has already been completed. The server will + // guarantee that for at least 60 minutes since the first request. + // + // For example, consider a situation where you make an initial request and + // the request times out. If you make the request again with the same request + // ID, the server can check if original operation with the same request ID + // was received, and if so, will ignore the second request. This prevents + // clients from accidentally creating duplicate commitments. + // + // The request ID must be a valid UUID with the exception that zero UUID is + // not supported (00000000-0000-0000-0000-000000000000). + string request_id = 4 [(google.api.field_behavior) = OPTIONAL]; +} + +// Message for updating a Router +message UpdateRouterRequest { + // Required. Field mask is used to specify the fields to be overwritten in the + // Router resource by the update. + // The fields specified in the update_mask are relative to the resource, not + // the full request. A field will be overwritten if it is in the mask. If the + // user does not provide a mask then all fields will be overwritten. + google.protobuf.FieldMask update_mask = 1 + [(google.api.field_behavior) = REQUIRED]; + + // Required. The resource being updated + Router router = 2 [(google.api.field_behavior) = REQUIRED]; + + // Optional. An optional request ID to identify requests. Specify a unique + // request ID so that if you must retry your request, the server will know to + // ignore the request if it has already been completed. The server will + // guarantee that for at least 60 minutes since the first request. + // + // For example, consider a situation where you make an initial request and + // the request times out. If you make the request again with the same request + // ID, the server can check if original operation with the same request ID + // was received, and if so, will ignore the second request. This prevents + // clients from accidentally creating duplicate commitments. + // + // The request ID must be a valid UUID with the exception that zero UUID is + // not supported (00000000-0000-0000-0000-000000000000). + string request_id = 3 [(google.api.field_behavior) = OPTIONAL]; +} + +// Message for deleting a Router +message DeleteRouterRequest { + // Required. Name of the resource + string name = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Router" + } + ]; + + // Optional. An optional request ID to identify requests. Specify a unique + // request ID so that if you must retry your request, the server will know to + // ignore the request if it has already been completed. The server will + // guarantee that for at least 60 minutes after the first request. + // + // For example, consider a situation where you make an initial request and + // the request times out. If you make the request again with the same request + // ID, the server can check if original operation with the same request ID + // was received, and if so, will ignore the second request. This prevents + // clients from accidentally creating duplicate commitments. + // + // The request ID must be a valid UUID with the exception that zero UUID is + // not supported (00000000-0000-0000-0000-000000000000). + string request_id = 2 [(google.api.field_behavior) = OPTIONAL]; +} + +// Represents the metadata of the long-running operation. +message OperationMetadata { + // Output only. The time the operation was created. + google.protobuf.Timestamp create_time = 1 + [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Output only. The time the operation finished running. + google.protobuf.Timestamp end_time = 2 + [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Output only. Server-defined resource path for the target of the operation. + string target = 3 [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Output only. Name of the verb executed by the operation. + string verb = 4 [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Output only. Human-readable status of the operation, if any. + string status_message = 5 [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Output only. Identifies whether the user has requested cancellation + // of the operation. Operations that have been cancelled successfully + // have [Operation.error][] value with a + // [google.rpc.Status.code][google.rpc.Status.code] of 1, corresponding to + // `Code.CANCELLED`. + bool requested_cancellation = 6 [(google.api.field_behavior) = OUTPUT_ONLY]; + + // Output only. API version used to start the operation. + string api_version = 7 [(google.api.field_behavior) = OUTPUT_ONLY]; +} + +// Message for requesting the diagnostics of a network within a specific zone. +message DiagnoseNetworkRequest { + // Required. The name of the network resource. + string name = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Network" + } + ]; +} + +// DiagnoseNetworkResponse contains the current status for a specific network. +message DiagnoseNetworkResponse { + // NetworkStatus has a list of status for the subnets under the current + // network. + message NetworkStatus { + // A list of status for the subnets under the current network. + repeated SubnetStatus subnet_status = 1; + } + + // The time when the network status was last updated. + google.protobuf.Timestamp update_time = 1; + + // The network status of a specific network. + NetworkStatus result = 2; +} + +// Message for requesting the diagnostics of an interconnect within a specific +// zone. +message DiagnoseInterconnectRequest { + // Required. The name of the interconnect resource. + string name = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Interconnect" + } + ]; +} + +// DiagnoseInterconnectResponse contains the current diagnostics for a +// specific interconnect. +message DiagnoseInterconnectResponse { + // The time when the interconnect diagnostics was last updated. + google.protobuf.Timestamp update_time = 1; + + // The network status of a specific interconnect. + InterconnectDiagnostics result = 2; +} + +// Message for requesting diagnositcs of a router within a specific zone. +message DiagnoseRouterRequest { + // Required. The name of the router resource. + string name = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Router" + } + ]; +} + +// DiagnoseRouterResponse contains the current status for a specific router. +message DiagnoseRouterResponse { + // The time when the router status was last updated. + google.protobuf.Timestamp update_time = 1; + + // The network status of a specific router. + RouterStatus result = 2; +} + +// Message for initializing a specified zone +message InitializeZoneRequest { + // Required. The name of the zone resource. + string name = 1 [ + (google.api.field_behavior) = REQUIRED, + (google.api.resource_reference) = { + type: "edgenetwork.googleapis.com/Zone" + } + ]; +} + +// The response of initializing a zone +message InitializeZoneResponse {} diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_interconnect_attachment.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_interconnect_attachment.js new file mode 100644 index 000000000000..30f5c02b1a17 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_interconnect_attachment.js @@ -0,0 +1,88 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(parent, interconnectAttachmentId, interconnectAttachment) { + // [START edgenetwork_v1_generated_EdgeNetwork_CreateInterconnectAttachment_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Value for parent. + */ + // const parent = 'abc123' + /** + * Required. Id of the requesting object + * If auto-generating Id server-side, remove this field and + * interconnect_attachment_id from the method_signature of Create RPC + */ + // const interconnectAttachmentId = 'abc123' + /** + * Required. The resource being created + */ + // const interconnectAttachment = {} + /** + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + */ + // const requestId = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callCreateInterconnectAttachment() { + // Construct request + const request = { + parent, + interconnectAttachmentId, + interconnectAttachment, + }; + + // Run request + const [operation] = await edgenetworkClient.createInterconnectAttachment(request); + const [response] = await operation.promise(); + console.log(response); + } + + callCreateInterconnectAttachment(); + // [END edgenetwork_v1_generated_EdgeNetwork_CreateInterconnectAttachment_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_network.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_network.js new file mode 100644 index 000000000000..caed945320e8 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_network.js @@ -0,0 +1,88 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(parent, networkId, network) { + // [START edgenetwork_v1_generated_EdgeNetwork_CreateNetwork_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Value for parent. + */ + // const parent = 'abc123' + /** + * Required. Id of the requesting object + * If auto-generating Id server-side, remove this field and + * network_id from the method_signature of Create RPC + */ + // const networkId = 'abc123' + /** + * Required. The resource being created + */ + // const network = {} + /** + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + */ + // const requestId = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callCreateNetwork() { + // Construct request + const request = { + parent, + networkId, + network, + }; + + // Run request + const [operation] = await edgenetworkClient.createNetwork(request); + const [response] = await operation.promise(); + console.log(response); + } + + callCreateNetwork(); + // [END edgenetwork_v1_generated_EdgeNetwork_CreateNetwork_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_router.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_router.js new file mode 100644 index 000000000000..1c15785a7b47 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_router.js @@ -0,0 +1,88 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(parent, routerId, router) { + // [START edgenetwork_v1_generated_EdgeNetwork_CreateRouter_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Value for parent. + */ + // const parent = 'abc123' + /** + * Required. Id of the requesting object + * If auto-generating Id server-side, remove this field and + * router_id from the method_signature of Create RPC + */ + // const routerId = 'abc123' + /** + * Required. The resource being created + */ + // const router = {} + /** + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + */ + // const requestId = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callCreateRouter() { + // Construct request + const request = { + parent, + routerId, + router, + }; + + // Run request + const [operation] = await edgenetworkClient.createRouter(request); + const [response] = await operation.promise(); + console.log(response); + } + + callCreateRouter(); + // [END edgenetwork_v1_generated_EdgeNetwork_CreateRouter_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_subnet.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_subnet.js new file mode 100644 index 000000000000..fa79e63f7b04 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_subnet.js @@ -0,0 +1,88 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(parent, subnetId, subnet) { + // [START edgenetwork_v1_generated_EdgeNetwork_CreateSubnet_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Value for parent. + */ + // const parent = 'abc123' + /** + * Required. Id of the requesting object + * If auto-generating Id server-side, remove this field and + * subnet_id from the method_signature of Create RPC + */ + // const subnetId = 'abc123' + /** + * Required. The resource being created + */ + // const subnet = {} + /** + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + */ + // const requestId = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callCreateSubnet() { + // Construct request + const request = { + parent, + subnetId, + subnet, + }; + + // Run request + const [operation] = await edgenetworkClient.createSubnet(request); + const [response] = await operation.promise(); + console.log(response); + } + + callCreateSubnet(); + // [END edgenetwork_v1_generated_EdgeNetwork_CreateSubnet_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_interconnect_attachment.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_interconnect_attachment.js new file mode 100644 index 000000000000..4c2a7ba08448 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_interconnect_attachment.js @@ -0,0 +1,76 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(name) { + // [START edgenetwork_v1_generated_EdgeNetwork_DeleteInterconnectAttachment_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Name of the resource + */ + // const name = 'abc123' + /** + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes after the first request. + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + */ + // const requestId = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callDeleteInterconnectAttachment() { + // Construct request + const request = { + name, + }; + + // Run request + const [operation] = await edgenetworkClient.deleteInterconnectAttachment(request); + const [response] = await operation.promise(); + console.log(response); + } + + callDeleteInterconnectAttachment(); + // [END edgenetwork_v1_generated_EdgeNetwork_DeleteInterconnectAttachment_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_network.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_network.js new file mode 100644 index 000000000000..eb307e60af30 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_network.js @@ -0,0 +1,76 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(name) { + // [START edgenetwork_v1_generated_EdgeNetwork_DeleteNetwork_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Name of the resource + */ + // const name = 'abc123' + /** + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes after the first request. + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + */ + // const requestId = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callDeleteNetwork() { + // Construct request + const request = { + name, + }; + + // Run request + const [operation] = await edgenetworkClient.deleteNetwork(request); + const [response] = await operation.promise(); + console.log(response); + } + + callDeleteNetwork(); + // [END edgenetwork_v1_generated_EdgeNetwork_DeleteNetwork_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_router.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_router.js new file mode 100644 index 000000000000..31c7d74bd745 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_router.js @@ -0,0 +1,76 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(name) { + // [START edgenetwork_v1_generated_EdgeNetwork_DeleteRouter_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Name of the resource + */ + // const name = 'abc123' + /** + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes after the first request. + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + */ + // const requestId = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callDeleteRouter() { + // Construct request + const request = { + name, + }; + + // Run request + const [operation] = await edgenetworkClient.deleteRouter(request); + const [response] = await operation.promise(); + console.log(response); + } + + callDeleteRouter(); + // [END edgenetwork_v1_generated_EdgeNetwork_DeleteRouter_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_subnet.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_subnet.js new file mode 100644 index 000000000000..f89e8754d351 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_subnet.js @@ -0,0 +1,76 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(name) { + // [START edgenetwork_v1_generated_EdgeNetwork_DeleteSubnet_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Name of the resource + */ + // const name = 'abc123' + /** + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes after the first request. + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + */ + // const requestId = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callDeleteSubnet() { + // Construct request + const request = { + name, + }; + + // Run request + const [operation] = await edgenetworkClient.deleteSubnet(request); + const [response] = await operation.promise(); + console.log(response); + } + + callDeleteSubnet(); + // [END edgenetwork_v1_generated_EdgeNetwork_DeleteSubnet_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_interconnect.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_interconnect.js new file mode 100644 index 000000000000..a01e3949e5cf --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_interconnect.js @@ -0,0 +1,61 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(name) { + // [START edgenetwork_v1_generated_EdgeNetwork_DiagnoseInterconnect_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. The name of the interconnect resource. + */ + // const name = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callDiagnoseInterconnect() { + // Construct request + const request = { + name, + }; + + // Run request + const response = await edgenetworkClient.diagnoseInterconnect(request); + console.log(response); + } + + callDiagnoseInterconnect(); + // [END edgenetwork_v1_generated_EdgeNetwork_DiagnoseInterconnect_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_network.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_network.js new file mode 100644 index 000000000000..74926afacec5 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_network.js @@ -0,0 +1,61 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(name) { + // [START edgenetwork_v1_generated_EdgeNetwork_DiagnoseNetwork_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. The name of the network resource. + */ + // const name = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callDiagnoseNetwork() { + // Construct request + const request = { + name, + }; + + // Run request + const response = await edgenetworkClient.diagnoseNetwork(request); + console.log(response); + } + + callDiagnoseNetwork(); + // [END edgenetwork_v1_generated_EdgeNetwork_DiagnoseNetwork_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_router.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_router.js new file mode 100644 index 000000000000..91d4b55741ae --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_router.js @@ -0,0 +1,61 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(name) { + // [START edgenetwork_v1_generated_EdgeNetwork_DiagnoseRouter_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. The name of the router resource. + */ + // const name = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callDiagnoseRouter() { + // Construct request + const request = { + name, + }; + + // Run request + const response = await edgenetworkClient.diagnoseRouter(request); + console.log(response); + } + + callDiagnoseRouter(); + // [END edgenetwork_v1_generated_EdgeNetwork_DiagnoseRouter_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_interconnect.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_interconnect.js new file mode 100644 index 000000000000..9fe45b0ad0c0 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_interconnect.js @@ -0,0 +1,61 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(name) { + // [START edgenetwork_v1_generated_EdgeNetwork_GetInterconnect_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Name of the resource + */ + // const name = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callGetInterconnect() { + // Construct request + const request = { + name, + }; + + // Run request + const response = await edgenetworkClient.getInterconnect(request); + console.log(response); + } + + callGetInterconnect(); + // [END edgenetwork_v1_generated_EdgeNetwork_GetInterconnect_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_interconnect_attachment.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_interconnect_attachment.js new file mode 100644 index 000000000000..ba12aeee9be0 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_interconnect_attachment.js @@ -0,0 +1,61 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(name) { + // [START edgenetwork_v1_generated_EdgeNetwork_GetInterconnectAttachment_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Name of the resource + */ + // const name = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callGetInterconnectAttachment() { + // Construct request + const request = { + name, + }; + + // Run request + const response = await edgenetworkClient.getInterconnectAttachment(request); + console.log(response); + } + + callGetInterconnectAttachment(); + // [END edgenetwork_v1_generated_EdgeNetwork_GetInterconnectAttachment_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_network.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_network.js new file mode 100644 index 000000000000..49ca8b7c6dfe --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_network.js @@ -0,0 +1,61 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(name) { + // [START edgenetwork_v1_generated_EdgeNetwork_GetNetwork_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Name of the resource + */ + // const name = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callGetNetwork() { + // Construct request + const request = { + name, + }; + + // Run request + const response = await edgenetworkClient.getNetwork(request); + console.log(response); + } + + callGetNetwork(); + // [END edgenetwork_v1_generated_EdgeNetwork_GetNetwork_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_router.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_router.js new file mode 100644 index 000000000000..2a525ae829c7 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_router.js @@ -0,0 +1,61 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(name) { + // [START edgenetwork_v1_generated_EdgeNetwork_GetRouter_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Name of the resource + */ + // const name = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callGetRouter() { + // Construct request + const request = { + name, + }; + + // Run request + const response = await edgenetworkClient.getRouter(request); + console.log(response); + } + + callGetRouter(); + // [END edgenetwork_v1_generated_EdgeNetwork_GetRouter_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_subnet.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_subnet.js new file mode 100644 index 000000000000..566107228cb7 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_subnet.js @@ -0,0 +1,61 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(name) { + // [START edgenetwork_v1_generated_EdgeNetwork_GetSubnet_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Name of the resource + */ + // const name = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callGetSubnet() { + // Construct request + const request = { + name, + }; + + // Run request + const response = await edgenetworkClient.getSubnet(request); + console.log(response); + } + + callGetSubnet(); + // [END edgenetwork_v1_generated_EdgeNetwork_GetSubnet_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_zone.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_zone.js new file mode 100644 index 000000000000..ec6a8aaba94c --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_zone.js @@ -0,0 +1,61 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(name) { + // [START edgenetwork_v1_generated_EdgeNetwork_GetZone_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Name of the resource + */ + // const name = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callGetZone() { + // Construct request + const request = { + name, + }; + + // Run request + const response = await edgenetworkClient.getZone(request); + console.log(response); + } + + callGetZone(); + // [END edgenetwork_v1_generated_EdgeNetwork_GetZone_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.initialize_zone.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.initialize_zone.js new file mode 100644 index 000000000000..54055769ca67 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.initialize_zone.js @@ -0,0 +1,61 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(name) { + // [START edgenetwork_v1_generated_EdgeNetwork_InitializeZone_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. The name of the zone resource. + */ + // const name = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callInitializeZone() { + // Construct request + const request = { + name, + }; + + // Run request + const response = await edgenetworkClient.initializeZone(request); + console.log(response); + } + + callInitializeZone(); + // [END edgenetwork_v1_generated_EdgeNetwork_InitializeZone_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_interconnect_attachments.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_interconnect_attachments.js new file mode 100644 index 000000000000..d2aea30c96d5 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_interconnect_attachments.js @@ -0,0 +1,80 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(parent) { + // [START edgenetwork_v1_generated_EdgeNetwork_ListInterconnectAttachments_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Parent value for ListInterconnectAttachmentsRequest + */ + // const parent = 'abc123' + /** + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + */ + // const pageSize = 1234 + /** + * A token identifying a page of results the server should return. + */ + // const pageToken = 'abc123' + /** + * Filtering results + */ + // const filter = 'abc123' + /** + * Hint for how to order the results + */ + // const orderBy = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callListInterconnectAttachments() { + // Construct request + const request = { + parent, + }; + + // Run request + const iterable = await edgenetworkClient.listInterconnectAttachmentsAsync(request); + for await (const response of iterable) { + console.log(response); + } + } + + callListInterconnectAttachments(); + // [END edgenetwork_v1_generated_EdgeNetwork_ListInterconnectAttachments_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_interconnects.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_interconnects.js new file mode 100644 index 000000000000..09123963f4d5 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_interconnects.js @@ -0,0 +1,80 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(parent) { + // [START edgenetwork_v1_generated_EdgeNetwork_ListInterconnects_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Parent value for ListInterconnectsRequest + */ + // const parent = 'abc123' + /** + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + */ + // const pageSize = 1234 + /** + * A token identifying a page of results the server should return. + */ + // const pageToken = 'abc123' + /** + * Filtering results + */ + // const filter = 'abc123' + /** + * Hint for how to order the results + */ + // const orderBy = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callListInterconnects() { + // Construct request + const request = { + parent, + }; + + // Run request + const iterable = await edgenetworkClient.listInterconnectsAsync(request); + for await (const response of iterable) { + console.log(response); + } + } + + callListInterconnects(); + // [END edgenetwork_v1_generated_EdgeNetwork_ListInterconnects_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_networks.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_networks.js new file mode 100644 index 000000000000..28e612f6feb4 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_networks.js @@ -0,0 +1,80 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(parent) { + // [START edgenetwork_v1_generated_EdgeNetwork_ListNetworks_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Parent value for ListNetworksRequest + */ + // const parent = 'abc123' + /** + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + */ + // const pageSize = 1234 + /** + * A token identifying a page of results the server should return. + */ + // const pageToken = 'abc123' + /** + * Filtering results + */ + // const filter = 'abc123' + /** + * Hint for how to order the results + */ + // const orderBy = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callListNetworks() { + // Construct request + const request = { + parent, + }; + + // Run request + const iterable = await edgenetworkClient.listNetworksAsync(request); + for await (const response of iterable) { + console.log(response); + } + } + + callListNetworks(); + // [END edgenetwork_v1_generated_EdgeNetwork_ListNetworks_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_routers.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_routers.js new file mode 100644 index 000000000000..128620253fea --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_routers.js @@ -0,0 +1,80 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(parent) { + // [START edgenetwork_v1_generated_EdgeNetwork_ListRouters_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Parent value for ListRoutersRequest + */ + // const parent = 'abc123' + /** + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + */ + // const pageSize = 1234 + /** + * A token identifying a page of results the server should return. + */ + // const pageToken = 'abc123' + /** + * Filtering results + */ + // const filter = 'abc123' + /** + * Hint for how to order the results + */ + // const orderBy = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callListRouters() { + // Construct request + const request = { + parent, + }; + + // Run request + const iterable = await edgenetworkClient.listRoutersAsync(request); + for await (const response of iterable) { + console.log(response); + } + } + + callListRouters(); + // [END edgenetwork_v1_generated_EdgeNetwork_ListRouters_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_subnets.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_subnets.js new file mode 100644 index 000000000000..d3758b91f99a --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_subnets.js @@ -0,0 +1,80 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(parent) { + // [START edgenetwork_v1_generated_EdgeNetwork_ListSubnets_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Parent value for ListSubnetsRequest + */ + // const parent = 'abc123' + /** + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + */ + // const pageSize = 1234 + /** + * A token identifying a page of results the server should return. + */ + // const pageToken = 'abc123' + /** + * Filtering results + */ + // const filter = 'abc123' + /** + * Hint for how to order the results + */ + // const orderBy = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callListSubnets() { + // Construct request + const request = { + parent, + }; + + // Run request + const iterable = await edgenetworkClient.listSubnetsAsync(request); + for await (const response of iterable) { + console.log(response); + } + } + + callListSubnets(); + // [END edgenetwork_v1_generated_EdgeNetwork_ListSubnets_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_zones.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_zones.js new file mode 100644 index 000000000000..a7e67c71530f --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_zones.js @@ -0,0 +1,80 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(parent) { + // [START edgenetwork_v1_generated_EdgeNetwork_ListZones_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Parent value for ListZonesRequest + */ + // const parent = 'abc123' + /** + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + */ + // const pageSize = 1234 + /** + * A token identifying a page of results the server should return. + */ + // const pageToken = 'abc123' + /** + * Filtering results + */ + // const filter = 'abc123' + /** + * Hint for how to order the results + */ + // const orderBy = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callListZones() { + // Construct request + const request = { + parent, + }; + + // Run request + const iterable = await edgenetworkClient.listZonesAsync(request); + for await (const response of iterable) { + console.log(response); + } + } + + callListZones(); + // [END edgenetwork_v1_generated_EdgeNetwork_ListZones_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.update_router.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.update_router.js new file mode 100644 index 000000000000..42eacfee99a7 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.update_router.js @@ -0,0 +1,85 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(updateMask, router) { + // [START edgenetwork_v1_generated_EdgeNetwork_UpdateRouter_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Field mask is used to specify the fields to be overwritten in the + * Router resource by the update. + * The fields specified in the update_mask are relative to the resource, not + * the full request. A field will be overwritten if it is in the mask. If the + * user does not provide a mask then all fields will be overwritten. + */ + // const updateMask = {} + /** + * Required. The resource being updated + */ + // const router = {} + /** + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + */ + // const requestId = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callUpdateRouter() { + // Construct request + const request = { + updateMask, + router, + }; + + // Run request + const [operation] = await edgenetworkClient.updateRouter(request); + const [response] = await operation.promise(); + console.log(response); + } + + callUpdateRouter(); + // [END edgenetwork_v1_generated_EdgeNetwork_UpdateRouter_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.update_subnet.js b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.update_subnet.js new file mode 100644 index 000000000000..cd1a63b6ddac --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.update_subnet.js @@ -0,0 +1,85 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + + +'use strict'; + +function main(updateMask, subnet) { + // [START edgenetwork_v1_generated_EdgeNetwork_UpdateSubnet_async] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Field mask is used to specify the fields to be overwritten in the + * Subnet resource by the update. + * The fields specified in the update_mask are relative to the resource, not + * the full request. A field will be overwritten if it is in the mask. If the + * user does not provide a mask then all fields will be overwritten. + */ + // const updateMask = {} + /** + * Required. The resource being updated + */ + // const subnet = {} + /** + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + */ + // const requestId = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callUpdateSubnet() { + // Construct request + const request = { + updateMask, + subnet, + }; + + // Run request + const [operation] = await edgenetworkClient.updateSubnet(request); + const [response] = await operation.promise(); + console.log(response); + } + + callUpdateSubnet(); + // [END edgenetwork_v1_generated_EdgeNetwork_UpdateSubnet_async] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/snippet_metadata_google.cloud.edgenetwork.v1.json b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/snippet_metadata_google.cloud.edgenetwork.v1.json new file mode 100644 index 000000000000..4a7d18f8e81a --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/snippet_metadata_google.cloud.edgenetwork.v1.json @@ -0,0 +1,1231 @@ +{ + "clientLibrary": { + "name": "nodejs-edgenetwork", + "version": "0.1.0", + "language": "TYPESCRIPT", + "apis": [ + { + "id": "google.cloud.edgenetwork.v1", + "version": "v1" + } + ] + }, + "snippets": [ + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_InitializeZone_async", + "title": "EdgeNetwork initializeZone Sample", + "origin": "API_DEFINITION", + "description": " InitializeZone will initialize resources for a zone in a project.", + "canonical": true, + "file": "edge_network.initialize_zone.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "InitializeZone", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.InitializeZone", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.InitializeZoneResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "InitializeZone", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.InitializeZone", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListZones_async", + "title": "EdgeNetwork listZones Sample", + "origin": "API_DEFINITION", + "description": " Lists Zones in a given project and location.", + "canonical": true, + "file": "edge_network.list_zones.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 72, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "ListZones", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListZones", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "page_size", + "type": "TYPE_INT32" + }, + { + "name": "page_token", + "type": "TYPE_STRING" + }, + { + "name": "filter", + "type": "TYPE_STRING" + }, + { + "name": "order_by", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.ListZonesResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "ListZones", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListZones", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetZone_async", + "title": "EdgeNetwork getZone Sample", + "origin": "API_DEFINITION", + "description": " Gets details of a single Zone.", + "canonical": true, + "file": "edge_network.get_zone.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "GetZone", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetZone", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.Zone", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "GetZone", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetZone", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListNetworks_async", + "title": "EdgeNetwork listNetworks Sample", + "origin": "API_DEFINITION", + "description": " Lists Networks in a given project and location.", + "canonical": true, + "file": "edge_network.list_networks.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 72, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "ListNetworks", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListNetworks", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "page_size", + "type": "TYPE_INT32" + }, + { + "name": "page_token", + "type": "TYPE_STRING" + }, + { + "name": "filter", + "type": "TYPE_STRING" + }, + { + "name": "order_by", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.ListNetworksResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "ListNetworks", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListNetworks", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetNetwork_async", + "title": "EdgeNetwork getNetwork Sample", + "origin": "API_DEFINITION", + "description": " Gets details of a single Network.", + "canonical": true, + "file": "edge_network.get_network.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "GetNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetNetwork", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.Network", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "GetNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetNetwork", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DiagnoseNetwork_async", + "title": "EdgeNetwork diagnoseNetwork Sample", + "origin": "API_DEFINITION", + "description": " Get the diagnostics of a single network resource.", + "canonical": true, + "file": "edge_network.diagnose_network.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "DiagnoseNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseNetwork", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.DiagnoseNetworkResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "DiagnoseNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseNetwork", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_CreateNetwork_async", + "title": "EdgeNetwork createNetwork Sample", + "origin": "API_DEFINITION", + "description": " Creates a new Network in a given project and location.", + "canonical": true, + "file": "edge_network.create_network.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 80, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "CreateNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateNetwork", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "network_id", + "type": "TYPE_STRING" + }, + { + "name": "network", + "type": ".google.cloud.edgenetwork.v1.Network" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "CreateNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateNetwork", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DeleteNetwork_async", + "title": "EdgeNetwork deleteNetwork Sample", + "origin": "API_DEFINITION", + "description": " Deletes a single Network.", + "canonical": true, + "file": "edge_network.delete_network.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 68, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "DeleteNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteNetwork", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "DeleteNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteNetwork", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListSubnets_async", + "title": "EdgeNetwork listSubnets Sample", + "origin": "API_DEFINITION", + "description": " Lists Subnets in a given project and location.", + "canonical": true, + "file": "edge_network.list_subnets.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 72, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "ListSubnets", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListSubnets", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "page_size", + "type": "TYPE_INT32" + }, + { + "name": "page_token", + "type": "TYPE_STRING" + }, + { + "name": "filter", + "type": "TYPE_STRING" + }, + { + "name": "order_by", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.ListSubnetsResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "ListSubnets", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListSubnets", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetSubnet_async", + "title": "EdgeNetwork getSubnet Sample", + "origin": "API_DEFINITION", + "description": " Gets details of a single Subnet.", + "canonical": true, + "file": "edge_network.get_subnet.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "GetSubnet", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetSubnet", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.Subnet", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "GetSubnet", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetSubnet", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_CreateSubnet_async", + "title": "EdgeNetwork createSubnet Sample", + "origin": "API_DEFINITION", + "description": " Creates a new Subnet in a given project and location.", + "canonical": true, + "file": "edge_network.create_subnet.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 80, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "CreateSubnet", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateSubnet", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "subnet_id", + "type": "TYPE_STRING" + }, + { + "name": "subnet", + "type": ".google.cloud.edgenetwork.v1.Subnet" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "CreateSubnet", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateSubnet", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_UpdateSubnet_async", + "title": "EdgeNetwork updateSubnet Sample", + "origin": "API_DEFINITION", + "description": " Updates the parameters of a single Subnet.", + "canonical": true, + "file": "edge_network.update_subnet.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 77, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "UpdateSubnet", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.UpdateSubnet", + "async": true, + "parameters": [ + { + "name": "update_mask", + "type": ".google.protobuf.FieldMask" + }, + { + "name": "subnet", + "type": ".google.cloud.edgenetwork.v1.Subnet" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "UpdateSubnet", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.UpdateSubnet", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DeleteSubnet_async", + "title": "EdgeNetwork deleteSubnet Sample", + "origin": "API_DEFINITION", + "description": " Deletes a single Subnet.", + "canonical": true, + "file": "edge_network.delete_subnet.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 68, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "DeleteSubnet", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteSubnet", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "DeleteSubnet", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteSubnet", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListInterconnects_async", + "title": "EdgeNetwork listInterconnects Sample", + "origin": "API_DEFINITION", + "description": " Lists Interconnects in a given project and location.", + "canonical": true, + "file": "edge_network.list_interconnects.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 72, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "ListInterconnects", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListInterconnects", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "page_size", + "type": "TYPE_INT32" + }, + { + "name": "page_token", + "type": "TYPE_STRING" + }, + { + "name": "filter", + "type": "TYPE_STRING" + }, + { + "name": "order_by", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.ListInterconnectsResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "ListInterconnects", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListInterconnects", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetInterconnect_async", + "title": "EdgeNetwork getInterconnect Sample", + "origin": "API_DEFINITION", + "description": " Gets details of a single Interconnect.", + "canonical": true, + "file": "edge_network.get_interconnect.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "GetInterconnect", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetInterconnect", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.Interconnect", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "GetInterconnect", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetInterconnect", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DiagnoseInterconnect_async", + "title": "EdgeNetwork diagnoseInterconnect Sample", + "origin": "API_DEFINITION", + "description": " Get the diagnostics of a single interconnect resource.", + "canonical": true, + "file": "edge_network.diagnose_interconnect.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "DiagnoseInterconnect", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseInterconnect", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "DiagnoseInterconnect", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseInterconnect", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListInterconnectAttachments_async", + "title": "EdgeNetwork listInterconnectAttachments Sample", + "origin": "API_DEFINITION", + "description": " Lists InterconnectAttachments in a given project and location.", + "canonical": true, + "file": "edge_network.list_interconnect_attachments.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 72, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "ListInterconnectAttachments", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListInterconnectAttachments", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "page_size", + "type": "TYPE_INT32" + }, + { + "name": "page_token", + "type": "TYPE_STRING" + }, + { + "name": "filter", + "type": "TYPE_STRING" + }, + { + "name": "order_by", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "ListInterconnectAttachments", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListInterconnectAttachments", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetInterconnectAttachment_async", + "title": "EdgeNetwork getInterconnectAttachment Sample", + "origin": "API_DEFINITION", + "description": " Gets details of a single InterconnectAttachment.", + "canonical": true, + "file": "edge_network.get_interconnect_attachment.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "GetInterconnectAttachment", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetInterconnectAttachment", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.InterconnectAttachment", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "GetInterconnectAttachment", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetInterconnectAttachment", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_CreateInterconnectAttachment_async", + "title": "EdgeNetwork createInterconnectAttachment Sample", + "origin": "API_DEFINITION", + "description": " Creates a new InterconnectAttachment in a given project and location.", + "canonical": true, + "file": "edge_network.create_interconnect_attachment.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 80, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "CreateInterconnectAttachment", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateInterconnectAttachment", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "interconnect_attachment_id", + "type": "TYPE_STRING" + }, + { + "name": "interconnect_attachment", + "type": ".google.cloud.edgenetwork.v1.InterconnectAttachment" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "CreateInterconnectAttachment", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateInterconnectAttachment", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DeleteInterconnectAttachment_async", + "title": "EdgeNetwork deleteInterconnectAttachment Sample", + "origin": "API_DEFINITION", + "description": " Deletes a single InterconnectAttachment.", + "canonical": true, + "file": "edge_network.delete_interconnect_attachment.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 68, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "DeleteInterconnectAttachment", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteInterconnectAttachment", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "DeleteInterconnectAttachment", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteInterconnectAttachment", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListRouters_async", + "title": "EdgeNetwork listRouters Sample", + "origin": "API_DEFINITION", + "description": " Lists Routers in a given project and location.", + "canonical": true, + "file": "edge_network.list_routers.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 72, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "ListRouters", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListRouters", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "page_size", + "type": "TYPE_INT32" + }, + { + "name": "page_token", + "type": "TYPE_STRING" + }, + { + "name": "filter", + "type": "TYPE_STRING" + }, + { + "name": "order_by", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.ListRoutersResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "ListRouters", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListRouters", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetRouter_async", + "title": "EdgeNetwork getRouter Sample", + "origin": "API_DEFINITION", + "description": " Gets details of a single Router.", + "canonical": true, + "file": "edge_network.get_router.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "GetRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetRouter", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.Router", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "GetRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetRouter", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DiagnoseRouter_async", + "title": "EdgeNetwork diagnoseRouter Sample", + "origin": "API_DEFINITION", + "description": " Get the diagnostics of a single router resource.", + "canonical": true, + "file": "edge_network.diagnose_router.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "DiagnoseRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseRouter", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.DiagnoseRouterResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "DiagnoseRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseRouter", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_CreateRouter_async", + "title": "EdgeNetwork createRouter Sample", + "origin": "API_DEFINITION", + "description": " Creates a new Router in a given project and location.", + "canonical": true, + "file": "edge_network.create_router.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 80, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "CreateRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateRouter", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "router_id", + "type": "TYPE_STRING" + }, + { + "name": "router", + "type": ".google.cloud.edgenetwork.v1.Router" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "CreateRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateRouter", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_UpdateRouter_async", + "title": "EdgeNetwork updateRouter Sample", + "origin": "API_DEFINITION", + "description": " Updates the parameters of a single Router.", + "canonical": true, + "file": "edge_network.update_router.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 77, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "UpdateRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.UpdateRouter", + "async": true, + "parameters": [ + { + "name": "update_mask", + "type": ".google.protobuf.FieldMask" + }, + { + "name": "router", + "type": ".google.cloud.edgenetwork.v1.Router" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "UpdateRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.UpdateRouter", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DeleteRouter_async", + "title": "EdgeNetwork deleteRouter Sample", + "origin": "API_DEFINITION", + "description": " Deletes a single Router.", + "canonical": true, + "file": "edge_network.delete_router.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 68, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "DeleteRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteRouter", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "DeleteRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteRouter", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + } + ] +} diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/src/index.ts b/owl-bot-staging/google-cloud-edgenetwork/v1/src/index.ts new file mode 100644 index 000000000000..9145aaaffd11 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/src/index.ts @@ -0,0 +1,25 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + +import * as v1 from './v1'; +const EdgeNetworkClient = v1.EdgeNetworkClient; +type EdgeNetworkClient = v1.EdgeNetworkClient; +export {v1, EdgeNetworkClient}; +export default {v1, EdgeNetworkClient}; +import * as protos from '../protos/protos'; +export {protos} diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_client.ts b/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_client.ts new file mode 100644 index 000000000000..4ada68d316e5 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_client.ts @@ -0,0 +1,4016 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + +/* global window */ +import type * as gax from 'google-gax'; +import type {Callback, CallOptions, Descriptors, ClientOptions, GrpcClientOptions, LROperation, PaginationCallback, GaxCall, LocationsClient, LocationProtos} from 'google-gax'; +import {Transform} from 'stream'; +import * as protos from '../../protos/protos'; +import jsonProtos = require('../../protos/protos.json'); +/** + * Client JSON configuration object, loaded from + * `src/v1/edge_network_client_config.json`. + * This file defines retry strategy and timeouts for all API methods in this library. + */ +import * as gapicConfig from './edge_network_client_config.json'; +const version = require('../../../package.json').version; + +/** + * EdgeNetwork API provides managed, highly available cloud dynamic network + * configuration service to the GEC customer to enable edge application and + * network function solutions. This allows the customers to easily define and + * configure the network setup and property to meet the workload requirement. + * @class + * @memberof v1 + */ +export class EdgeNetworkClient { + private _terminated = false; + private _opts: ClientOptions; + private _providedCustomServicePath: boolean; + private _gaxModule: typeof gax | typeof gax.fallback; + private _gaxGrpc: gax.GrpcClient | gax.fallback.GrpcClient; + private _protos: {}; + private _defaults: {[method: string]: gax.CallSettings}; + auth: gax.GoogleAuth; + descriptors: Descriptors = { + page: {}, + stream: {}, + longrunning: {}, + batching: {}, + }; + warn: (code: string, message: string, warnType?: string) => void; + innerApiCalls: {[name: string]: Function}; + locationsClient: LocationsClient; + pathTemplates: {[name: string]: gax.PathTemplate}; + operationsClient: gax.OperationsClient; + edgeNetworkStub?: Promise<{[name: string]: Function}>; + + /** + * Construct an instance of EdgeNetworkClient. + * + * @param {object} [options] - The configuration object. + * The options accepted by the constructor are described in detail + * in [this document](https://github.com/googleapis/gax-nodejs/blob/main/client-libraries.md#creating-the-client-instance). + * The common options are: + * @param {object} [options.credentials] - Credentials object. + * @param {string} [options.credentials.client_email] + * @param {string} [options.credentials.private_key] + * @param {string} [options.email] - Account email address. Required when + * using a .pem or .p12 keyFilename. + * @param {string} [options.keyFilename] - Full path to the a .json, .pem, or + * .p12 key downloaded from the Google Developers Console. If you provide + * a path to a JSON file, the projectId option below is not necessary. + * NOTE: .pem and .p12 require you to specify options.email as well. + * @param {number} [options.port] - The port on which to connect to + * the remote host. + * @param {string} [options.projectId] - The project ID from the Google + * Developer's Console, e.g. 'grape-spaceship-123'. We will also check + * the environment variable GCLOUD_PROJECT for your project ID. If your + * app is running in an environment which supports + * {@link https://developers.google.com/identity/protocols/application-default-credentials Application Default Credentials}, + * your project ID will be detected automatically. + * @param {string} [options.apiEndpoint] - The domain name of the + * API remote host. + * @param {gax.ClientConfig} [options.clientConfig] - Client configuration override. + * Follows the structure of {@link gapicConfig}. + * @param {boolean} [options.fallback] - Use HTTP/1.1 REST mode. + * For more information, please check the + * {@link https://github.com/googleapis/gax-nodejs/blob/main/client-libraries.md#http11-rest-api-mode documentation}. + * @param {gax} [gaxInstance]: loaded instance of `google-gax`. Useful if you + * need to avoid loading the default gRPC version and want to use the fallback + * HTTP implementation. Load only fallback version and pass it to the constructor: + * ``` + * const gax = require('google-gax/build/src/fallback'); // avoids loading google-gax with gRPC + * const client = new EdgeNetworkClient({fallback: true}, gax); + * ``` + */ + constructor(opts?: ClientOptions, gaxInstance?: typeof gax | typeof gax.fallback) { + // Ensure that options include all the required fields. + const staticMembers = this.constructor as typeof EdgeNetworkClient; + const servicePath = opts?.servicePath || opts?.apiEndpoint || staticMembers.servicePath; + this._providedCustomServicePath = !!(opts?.servicePath || opts?.apiEndpoint); + const port = opts?.port || staticMembers.port; + const clientConfig = opts?.clientConfig ?? {}; + const fallback = opts?.fallback ?? (typeof window !== 'undefined' && typeof window?.fetch === 'function'); + opts = Object.assign({servicePath, port, clientConfig, fallback}, opts); + + // Request numeric enum values if REST transport is used. + opts.numericEnums = true; + + // If scopes are unset in options and we're connecting to a non-default endpoint, set scopes just in case. + if (servicePath !== staticMembers.servicePath && !('scopes' in opts)) { + opts['scopes'] = staticMembers.scopes; + } + + // Load google-gax module synchronously if needed + if (!gaxInstance) { + gaxInstance = require('google-gax') as typeof gax; + } + + // Choose either gRPC or proto-over-HTTP implementation of google-gax. + this._gaxModule = opts.fallback ? gaxInstance.fallback : gaxInstance; + + // Create a `gaxGrpc` object, with any grpc-specific options sent to the client. + this._gaxGrpc = new this._gaxModule.GrpcClient(opts); + + // Save options to use in initialize() method. + this._opts = opts; + + // Save the auth object to the client, for use by other methods. + this.auth = (this._gaxGrpc.auth as gax.GoogleAuth); + + // Set useJWTAccessWithScope on the auth object. + this.auth.useJWTAccessWithScope = true; + + // Set defaultServicePath on the auth object. + this.auth.defaultServicePath = staticMembers.servicePath; + + // Set the default scopes in auth client if needed. + if (servicePath === staticMembers.servicePath) { + this.auth.defaultScopes = staticMembers.scopes; + } + this.locationsClient = new this._gaxModule.LocationsClient( + this._gaxGrpc, + opts + ); + + + // Determine the client header string. + const clientHeader = [ + `gax/${this._gaxModule.version}`, + `gapic/${version}`, + ]; + if (typeof process !== 'undefined' && 'versions' in process) { + clientHeader.push(`gl-node/${process.versions.node}`); + } else { + clientHeader.push(`gl-web/${this._gaxModule.version}`); + } + if (!opts.fallback) { + clientHeader.push(`grpc/${this._gaxGrpc.grpcVersion}`); + } else { + clientHeader.push(`rest/${this._gaxGrpc.grpcVersion}`); + } + if (opts.libName && opts.libVersion) { + clientHeader.push(`${opts.libName}/${opts.libVersion}`); + } + // Load the applicable protos. + this._protos = this._gaxGrpc.loadProtoJSON(jsonProtos); + + // This API contains "path templates"; forward-slash-separated + // identifiers to uniquely identify resources within the API. + // Create useful helper objects for these. + this.pathTemplates = { + interconnectPathTemplate: new this._gaxModule.PathTemplate( + 'projects/{project}/locations/{location}/zones/{zone}/interconnects/{interconnect}' + ), + interconnectAttachmentPathTemplate: new this._gaxModule.PathTemplate( + 'projects/{project}/locations/{location}/zones/{zone}/interconnectAttachments/{interconnect_attachment}' + ), + locationPathTemplate: new this._gaxModule.PathTemplate( + 'projects/{project}/locations/{location}' + ), + networkPathTemplate: new this._gaxModule.PathTemplate( + 'projects/{project}/locations/{location}/zones/{zone}/networks/{network}' + ), + projectPathTemplate: new this._gaxModule.PathTemplate( + 'projects/{project}' + ), + routerPathTemplate: new this._gaxModule.PathTemplate( + 'projects/{project}/locations/{location}/zones/{zone}/routers/{router}' + ), + subnetPathTemplate: new this._gaxModule.PathTemplate( + 'projects/{project}/locations/{location}/zones/{zone}/subnets/{subnet}' + ), + zonePathTemplate: new this._gaxModule.PathTemplate( + 'projects/{project}/locations/{location}/zones/{zone}' + ), + }; + + // Some of the methods on this service return "paged" results, + // (e.g. 50 results at a time, with tokens to get subsequent + // pages). Denote the keys used for pagination and results. + this.descriptors.page = { + listZones: + new this._gaxModule.PageDescriptor('pageToken', 'nextPageToken', 'zones'), + listNetworks: + new this._gaxModule.PageDescriptor('pageToken', 'nextPageToken', 'networks'), + listSubnets: + new this._gaxModule.PageDescriptor('pageToken', 'nextPageToken', 'subnets'), + listInterconnects: + new this._gaxModule.PageDescriptor('pageToken', 'nextPageToken', 'interconnects'), + listInterconnectAttachments: + new this._gaxModule.PageDescriptor('pageToken', 'nextPageToken', 'interconnectAttachments'), + listRouters: + new this._gaxModule.PageDescriptor('pageToken', 'nextPageToken', 'routers') + }; + + const protoFilesRoot = this._gaxModule.protobuf.Root.fromJSON(jsonProtos); + // This API contains "long-running operations", which return a + // an Operation object that allows for tracking of the operation, + // rather than holding a request open. + const lroOptions: GrpcClientOptions = { + auth: this.auth, + grpc: 'grpc' in this._gaxGrpc ? this._gaxGrpc.grpc : undefined + }; + if (opts.fallback) { + lroOptions.protoJson = protoFilesRoot; + lroOptions.httpRules = [{selector: 'google.cloud.location.Locations.GetLocation',get: '/v1/{name=projects/*/locations/*}',},{selector: 'google.cloud.location.Locations.ListLocations',get: '/v1/{name=projects/*}/locations',},{selector: 'google.longrunning.Operations.CancelOperation',post: '/v1/{name=projects/*/locations/*/operations/*}:cancel',body: '*',},{selector: 'google.longrunning.Operations.DeleteOperation',delete: '/v1/{name=projects/*/locations/*/operations/*}',},{selector: 'google.longrunning.Operations.GetOperation',get: '/v1/{name=projects/*/locations/*/operations/*}',},{selector: 'google.longrunning.Operations.ListOperations',get: '/v1/{name=projects/*/locations/*}/operations',}]; + } + this.operationsClient = this._gaxModule.lro(lroOptions).operationsClient(opts); + const createNetworkResponse = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.Network') as gax.protobuf.Type; + const createNetworkMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; + const deleteNetworkResponse = protoFilesRoot.lookup( + '.google.protobuf.Empty') as gax.protobuf.Type; + const deleteNetworkMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; + const createSubnetResponse = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.Subnet') as gax.protobuf.Type; + const createSubnetMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; + const updateSubnetResponse = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.Subnet') as gax.protobuf.Type; + const updateSubnetMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; + const deleteSubnetResponse = protoFilesRoot.lookup( + '.google.protobuf.Empty') as gax.protobuf.Type; + const deleteSubnetMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; + const createInterconnectAttachmentResponse = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.InterconnectAttachment') as gax.protobuf.Type; + const createInterconnectAttachmentMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; + const deleteInterconnectAttachmentResponse = protoFilesRoot.lookup( + '.google.protobuf.Empty') as gax.protobuf.Type; + const deleteInterconnectAttachmentMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; + const createRouterResponse = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.Router') as gax.protobuf.Type; + const createRouterMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; + const updateRouterResponse = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.Router') as gax.protobuf.Type; + const updateRouterMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; + const deleteRouterResponse = protoFilesRoot.lookup( + '.google.protobuf.Empty') as gax.protobuf.Type; + const deleteRouterMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; + + this.descriptors.longrunning = { + createNetwork: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + createNetworkResponse.decode.bind(createNetworkResponse), + createNetworkMetadata.decode.bind(createNetworkMetadata)), + deleteNetwork: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + deleteNetworkResponse.decode.bind(deleteNetworkResponse), + deleteNetworkMetadata.decode.bind(deleteNetworkMetadata)), + createSubnet: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + createSubnetResponse.decode.bind(createSubnetResponse), + createSubnetMetadata.decode.bind(createSubnetMetadata)), + updateSubnet: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + updateSubnetResponse.decode.bind(updateSubnetResponse), + updateSubnetMetadata.decode.bind(updateSubnetMetadata)), + deleteSubnet: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + deleteSubnetResponse.decode.bind(deleteSubnetResponse), + deleteSubnetMetadata.decode.bind(deleteSubnetMetadata)), + createInterconnectAttachment: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + createInterconnectAttachmentResponse.decode.bind(createInterconnectAttachmentResponse), + createInterconnectAttachmentMetadata.decode.bind(createInterconnectAttachmentMetadata)), + deleteInterconnectAttachment: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + deleteInterconnectAttachmentResponse.decode.bind(deleteInterconnectAttachmentResponse), + deleteInterconnectAttachmentMetadata.decode.bind(deleteInterconnectAttachmentMetadata)), + createRouter: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + createRouterResponse.decode.bind(createRouterResponse), + createRouterMetadata.decode.bind(createRouterMetadata)), + updateRouter: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + updateRouterResponse.decode.bind(updateRouterResponse), + updateRouterMetadata.decode.bind(updateRouterMetadata)), + deleteRouter: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + deleteRouterResponse.decode.bind(deleteRouterResponse), + deleteRouterMetadata.decode.bind(deleteRouterMetadata)) + }; + + // Put together the default options sent with requests. + this._defaults = this._gaxGrpc.constructSettings( + 'google.cloud.edgenetwork.v1.EdgeNetwork', gapicConfig as gax.ClientConfig, + opts.clientConfig || {}, {'x-goog-api-client': clientHeader.join(' ')}); + + // Set up a dictionary of "inner API calls"; the core implementation + // of calling the API is handled in `google-gax`, with this code + // merely providing the destination and request information. + this.innerApiCalls = {}; + + // Add a warn function to the client constructor so it can be easily tested. + this.warn = this._gaxModule.warn; + } + + /** + * Initialize the client. + * Performs asynchronous operations (such as authentication) and prepares the client. + * This function will be called automatically when any class method is called for the + * first time, but if you need to initialize it before calling an actual method, + * feel free to call initialize() directly. + * + * You can await on this method if you want to make sure the client is initialized. + * + * @returns {Promise} A promise that resolves to an authenticated service stub. + */ + initialize() { + // If the client stub promise is already initialized, return immediately. + if (this.edgeNetworkStub) { + return this.edgeNetworkStub; + } + + // Put together the "service stub" for + // google.cloud.edgenetwork.v1.EdgeNetwork. + this.edgeNetworkStub = this._gaxGrpc.createStub( + this._opts.fallback ? + (this._protos as protobuf.Root).lookupService('google.cloud.edgenetwork.v1.EdgeNetwork') : + // eslint-disable-next-line @typescript-eslint/no-explicit-any + (this._protos as any).google.cloud.edgenetwork.v1.EdgeNetwork, + this._opts, this._providedCustomServicePath) as Promise<{[method: string]: Function}>; + + // Iterate over each of the methods that the service provides + // and create an API call method for each. + const edgeNetworkStubMethods = + ['initializeZone', 'listZones', 'getZone', 'listNetworks', 'getNetwork', 'diagnoseNetwork', 'createNetwork', 'deleteNetwork', 'listSubnets', 'getSubnet', 'createSubnet', 'updateSubnet', 'deleteSubnet', 'listInterconnects', 'getInterconnect', 'diagnoseInterconnect', 'listInterconnectAttachments', 'getInterconnectAttachment', 'createInterconnectAttachment', 'deleteInterconnectAttachment', 'listRouters', 'getRouter', 'diagnoseRouter', 'createRouter', 'updateRouter', 'deleteRouter']; + for (const methodName of edgeNetworkStubMethods) { + const callPromise = this.edgeNetworkStub.then( + stub => (...args: Array<{}>) => { + if (this._terminated) { + return Promise.reject('The client has already been closed.'); + } + const func = stub[methodName]; + return func.apply(stub, args); + }, + (err: Error|null|undefined) => () => { + throw err; + }); + + const descriptor = + this.descriptors.page[methodName] || + this.descriptors.longrunning[methodName] || + undefined; + const apiCall = this._gaxModule.createApiCall( + callPromise, + this._defaults[methodName], + descriptor, + this._opts.fallback + ); + + this.innerApiCalls[methodName] = apiCall; + } + + return this.edgeNetworkStub; + } + + /** + * The DNS address for this API service. + * @returns {string} The DNS address for this service. + */ + static get servicePath() { + return 'edgenetwork.googleapis.com'; + } + + /** + * The DNS address for this API service - same as servicePath(), + * exists for compatibility reasons. + * @returns {string} The DNS address for this service. + */ + static get apiEndpoint() { + return 'edgenetwork.googleapis.com'; + } + + /** + * The port for this API service. + * @returns {number} The default port for this service. + */ + static get port() { + return 443; + } + + /** + * The scopes needed to make gRPC calls for every method defined + * in this service. + * @returns {string[]} List of default scopes. + */ + static get scopes() { + return [ + 'https://www.googleapis.com/auth/cloud-platform' + ]; + } + + getProjectId(): Promise; + getProjectId(callback: Callback): void; + /** + * Return the project ID used by this class. + * @returns {Promise} A promise that resolves to string containing the project ID. + */ + getProjectId(callback?: Callback): + Promise|void { + if (callback) { + this.auth.getProjectId(callback); + return; + } + return this.auth.getProjectId(); + } + + // ------------------- + // -- Service calls -- + // ------------------- +/** + * InitializeZone will initialize resources for a zone in a project. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. The name of the zone resource. + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.InitializeZoneResponse|InitializeZoneResponse}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.initialize_zone.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_InitializeZone_async + */ + initializeZone( + request?: protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest, + options?: CallOptions): + Promise<[ + protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, + protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest|undefined, {}|undefined + ]>; + initializeZone( + request: protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, + protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest|null|undefined, + {}|null|undefined>): void; + initializeZone( + request: protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, + protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest|null|undefined, + {}|null|undefined>): void; + initializeZone( + request?: protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest, + optionsOrCallback?: CallOptions|Callback< + protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, + protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest|null|undefined, + {}|null|undefined>, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, + protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest|null|undefined, + {}|null|undefined>): + Promise<[ + protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, + protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'name': request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.initializeZone(request, options, callback); + } +/** + * Gets details of a single Zone. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.Zone|Zone}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.get_zone.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetZone_async + */ + getZone( + request?: protos.google.cloud.edgenetwork.v1.IGetZoneRequest, + options?: CallOptions): + Promise<[ + protos.google.cloud.edgenetwork.v1.IZone, + protos.google.cloud.edgenetwork.v1.IGetZoneRequest|undefined, {}|undefined + ]>; + getZone( + request: protos.google.cloud.edgenetwork.v1.IGetZoneRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IZone, + protos.google.cloud.edgenetwork.v1.IGetZoneRequest|null|undefined, + {}|null|undefined>): void; + getZone( + request: protos.google.cloud.edgenetwork.v1.IGetZoneRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IZone, + protos.google.cloud.edgenetwork.v1.IGetZoneRequest|null|undefined, + {}|null|undefined>): void; + getZone( + request?: protos.google.cloud.edgenetwork.v1.IGetZoneRequest, + optionsOrCallback?: CallOptions|Callback< + protos.google.cloud.edgenetwork.v1.IZone, + protos.google.cloud.edgenetwork.v1.IGetZoneRequest|null|undefined, + {}|null|undefined>, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.IZone, + protos.google.cloud.edgenetwork.v1.IGetZoneRequest|null|undefined, + {}|null|undefined>): + Promise<[ + protos.google.cloud.edgenetwork.v1.IZone, + protos.google.cloud.edgenetwork.v1.IGetZoneRequest|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'name': request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.getZone(request, options, callback); + } +/** + * Gets details of a single Network. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.Network|Network}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.get_network.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetNetwork_async + */ + getNetwork( + request?: protos.google.cloud.edgenetwork.v1.IGetNetworkRequest, + options?: CallOptions): + Promise<[ + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IGetNetworkRequest|undefined, {}|undefined + ]>; + getNetwork( + request: protos.google.cloud.edgenetwork.v1.IGetNetworkRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IGetNetworkRequest|null|undefined, + {}|null|undefined>): void; + getNetwork( + request: protos.google.cloud.edgenetwork.v1.IGetNetworkRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IGetNetworkRequest|null|undefined, + {}|null|undefined>): void; + getNetwork( + request?: protos.google.cloud.edgenetwork.v1.IGetNetworkRequest, + optionsOrCallback?: CallOptions|Callback< + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IGetNetworkRequest|null|undefined, + {}|null|undefined>, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IGetNetworkRequest|null|undefined, + {}|null|undefined>): + Promise<[ + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IGetNetworkRequest|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'name': request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.getNetwork(request, options, callback); + } +/** + * Get the diagnostics of a single network resource. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. The name of the network resource. + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse|DiagnoseNetworkResponse}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.diagnose_network.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DiagnoseNetwork_async + */ + diagnoseNetwork( + request?: protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest, + options?: CallOptions): + Promise<[ + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest|undefined, {}|undefined + ]>; + diagnoseNetwork( + request: protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest|null|undefined, + {}|null|undefined>): void; + diagnoseNetwork( + request: protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest|null|undefined, + {}|null|undefined>): void; + diagnoseNetwork( + request?: protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest, + optionsOrCallback?: CallOptions|Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest|null|undefined, + {}|null|undefined>, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest|null|undefined, + {}|null|undefined>): + Promise<[ + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'name': request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.diagnoseNetwork(request, options, callback); + } +/** + * Gets details of a single Subnet. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.Subnet|Subnet}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.get_subnet.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetSubnet_async + */ + getSubnet( + request?: protos.google.cloud.edgenetwork.v1.IGetSubnetRequest, + options?: CallOptions): + Promise<[ + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IGetSubnetRequest|undefined, {}|undefined + ]>; + getSubnet( + request: protos.google.cloud.edgenetwork.v1.IGetSubnetRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IGetSubnetRequest|null|undefined, + {}|null|undefined>): void; + getSubnet( + request: protos.google.cloud.edgenetwork.v1.IGetSubnetRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IGetSubnetRequest|null|undefined, + {}|null|undefined>): void; + getSubnet( + request?: protos.google.cloud.edgenetwork.v1.IGetSubnetRequest, + optionsOrCallback?: CallOptions|Callback< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IGetSubnetRequest|null|undefined, + {}|null|undefined>, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IGetSubnetRequest|null|undefined, + {}|null|undefined>): + Promise<[ + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IGetSubnetRequest|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'name': request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.getSubnet(request, options, callback); + } +/** + * Gets details of a single Interconnect. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.Interconnect|Interconnect}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.get_interconnect.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetInterconnect_async + */ + getInterconnect( + request?: protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest, + options?: CallOptions): + Promise<[ + protos.google.cloud.edgenetwork.v1.IInterconnect, + protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest|undefined, {}|undefined + ]>; + getInterconnect( + request: protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IInterconnect, + protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest|null|undefined, + {}|null|undefined>): void; + getInterconnect( + request: protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IInterconnect, + protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest|null|undefined, + {}|null|undefined>): void; + getInterconnect( + request?: protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest, + optionsOrCallback?: CallOptions|Callback< + protos.google.cloud.edgenetwork.v1.IInterconnect, + protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest|null|undefined, + {}|null|undefined>, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.IInterconnect, + protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest|null|undefined, + {}|null|undefined>): + Promise<[ + protos.google.cloud.edgenetwork.v1.IInterconnect, + protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'name': request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.getInterconnect(request, options, callback); + } +/** + * Get the diagnostics of a single interconnect resource. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. The name of the interconnect resource. + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse|DiagnoseInterconnectResponse}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.diagnose_interconnect.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DiagnoseInterconnect_async + */ + diagnoseInterconnect( + request?: protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest, + options?: CallOptions): + Promise<[ + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest|undefined, {}|undefined + ]>; + diagnoseInterconnect( + request: protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest|null|undefined, + {}|null|undefined>): void; + diagnoseInterconnect( + request: protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest|null|undefined, + {}|null|undefined>): void; + diagnoseInterconnect( + request?: protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest, + optionsOrCallback?: CallOptions|Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest|null|undefined, + {}|null|undefined>, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest|null|undefined, + {}|null|undefined>): + Promise<[ + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'name': request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.diagnoseInterconnect(request, options, callback); + } +/** + * Gets details of a single InterconnectAttachment. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.InterconnectAttachment|InterconnectAttachment}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.get_interconnect_attachment.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetInterconnectAttachment_async + */ + getInterconnectAttachment( + request?: protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest, + options?: CallOptions): + Promise<[ + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest|undefined, {}|undefined + ]>; + getInterconnectAttachment( + request: protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest|null|undefined, + {}|null|undefined>): void; + getInterconnectAttachment( + request: protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest|null|undefined, + {}|null|undefined>): void; + getInterconnectAttachment( + request?: protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest, + optionsOrCallback?: CallOptions|Callback< + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest|null|undefined, + {}|null|undefined>, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest|null|undefined, + {}|null|undefined>): + Promise<[ + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'name': request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.getInterconnectAttachment(request, options, callback); + } +/** + * Gets details of a single Router. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.Router|Router}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.get_router.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetRouter_async + */ + getRouter( + request?: protos.google.cloud.edgenetwork.v1.IGetRouterRequest, + options?: CallOptions): + Promise<[ + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IGetRouterRequest|undefined, {}|undefined + ]>; + getRouter( + request: protos.google.cloud.edgenetwork.v1.IGetRouterRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IGetRouterRequest|null|undefined, + {}|null|undefined>): void; + getRouter( + request: protos.google.cloud.edgenetwork.v1.IGetRouterRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IGetRouterRequest|null|undefined, + {}|null|undefined>): void; + getRouter( + request?: protos.google.cloud.edgenetwork.v1.IGetRouterRequest, + optionsOrCallback?: CallOptions|Callback< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IGetRouterRequest|null|undefined, + {}|null|undefined>, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IGetRouterRequest|null|undefined, + {}|null|undefined>): + Promise<[ + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IGetRouterRequest|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'name': request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.getRouter(request, options, callback); + } +/** + * Get the diagnostics of a single router resource. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. The name of the router resource. + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.DiagnoseRouterResponse|DiagnoseRouterResponse}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.diagnose_router.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DiagnoseRouter_async + */ + diagnoseRouter( + request?: protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest, + options?: CallOptions): + Promise<[ + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest|undefined, {}|undefined + ]>; + diagnoseRouter( + request: protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest|null|undefined, + {}|null|undefined>): void; + diagnoseRouter( + request: protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest|null|undefined, + {}|null|undefined>): void; + diagnoseRouter( + request?: protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest, + optionsOrCallback?: CallOptions|Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest|null|undefined, + {}|null|undefined>, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest|null|undefined, + {}|null|undefined>): + Promise<[ + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'name': request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.diagnoseRouter(request, options, callback); + } + +/** + * Creates a new Network in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Value for parent. + * @param {string} request.networkId + * Required. Id of the requesting object + * If auto-generating Id server-side, remove this field and + * network_id from the method_signature of Create RPC + * @param {google.cloud.edgenetwork.v1.Network} request.network + * Required. The resource being created + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.create_network.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateNetwork_async + */ + createNetwork( + request?: protos.google.cloud.edgenetwork.v1.ICreateNetworkRequest, + options?: CallOptions): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>; + createNetwork( + request: protos.google.cloud.edgenetwork.v1.ICreateNetworkRequest, + options: CallOptions, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + createNetwork( + request: protos.google.cloud.edgenetwork.v1.ICreateNetworkRequest, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + createNetwork( + request?: protos.google.cloud.edgenetwork.v1.ICreateNetworkRequest, + optionsOrCallback?: CallOptions|Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>, + callback?: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.createNetwork(request, options, callback); + } +/** + * Check the status of the long running operation returned by `createNetwork()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.create_network.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateNetwork_async + */ + async checkCreateNetworkProgress(name: string): Promise>{ + const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.createNetwork, this._gaxModule.createDefaultBackoffSettings()); + return decodeOperation as LROperation; + } +/** + * Deletes a single Network. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes after the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.delete_network.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteNetwork_async + */ + deleteNetwork( + request?: protos.google.cloud.edgenetwork.v1.IDeleteNetworkRequest, + options?: CallOptions): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>; + deleteNetwork( + request: protos.google.cloud.edgenetwork.v1.IDeleteNetworkRequest, + options: CallOptions, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + deleteNetwork( + request: protos.google.cloud.edgenetwork.v1.IDeleteNetworkRequest, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + deleteNetwork( + request?: protos.google.cloud.edgenetwork.v1.IDeleteNetworkRequest, + optionsOrCallback?: CallOptions|Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>, + callback?: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'name': request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.deleteNetwork(request, options, callback); + } +/** + * Check the status of the long running operation returned by `deleteNetwork()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.delete_network.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteNetwork_async + */ + async checkDeleteNetworkProgress(name: string): Promise>{ + const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.deleteNetwork, this._gaxModule.createDefaultBackoffSettings()); + return decodeOperation as LROperation; + } +/** + * Creates a new Subnet in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Value for parent. + * @param {string} request.subnetId + * Required. Id of the requesting object + * If auto-generating Id server-side, remove this field and + * subnet_id from the method_signature of Create RPC + * @param {google.cloud.edgenetwork.v1.Subnet} request.subnet + * Required. The resource being created + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.create_subnet.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateSubnet_async + */ + createSubnet( + request?: protos.google.cloud.edgenetwork.v1.ICreateSubnetRequest, + options?: CallOptions): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>; + createSubnet( + request: protos.google.cloud.edgenetwork.v1.ICreateSubnetRequest, + options: CallOptions, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + createSubnet( + request: protos.google.cloud.edgenetwork.v1.ICreateSubnetRequest, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + createSubnet( + request?: protos.google.cloud.edgenetwork.v1.ICreateSubnetRequest, + optionsOrCallback?: CallOptions|Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>, + callback?: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.createSubnet(request, options, callback); + } +/** + * Check the status of the long running operation returned by `createSubnet()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.create_subnet.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateSubnet_async + */ + async checkCreateSubnetProgress(name: string): Promise>{ + const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.createSubnet, this._gaxModule.createDefaultBackoffSettings()); + return decodeOperation as LROperation; + } +/** + * Updates the parameters of a single Subnet. + * + * @param {Object} request + * The request object that will be sent. + * @param {google.protobuf.FieldMask} request.updateMask + * Required. Field mask is used to specify the fields to be overwritten in the + * Subnet resource by the update. + * The fields specified in the update_mask are relative to the resource, not + * the full request. A field will be overwritten if it is in the mask. If the + * user does not provide a mask then all fields will be overwritten. + * @param {google.cloud.edgenetwork.v1.Subnet} request.subnet + * Required. The resource being updated + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.update_subnet.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_UpdateSubnet_async + */ + updateSubnet( + request?: protos.google.cloud.edgenetwork.v1.IUpdateSubnetRequest, + options?: CallOptions): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>; + updateSubnet( + request: protos.google.cloud.edgenetwork.v1.IUpdateSubnetRequest, + options: CallOptions, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + updateSubnet( + request: protos.google.cloud.edgenetwork.v1.IUpdateSubnetRequest, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + updateSubnet( + request?: protos.google.cloud.edgenetwork.v1.IUpdateSubnetRequest, + optionsOrCallback?: CallOptions|Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>, + callback?: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'subnet.name': request.subnet!.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.updateSubnet(request, options, callback); + } +/** + * Check the status of the long running operation returned by `updateSubnet()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.update_subnet.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_UpdateSubnet_async + */ + async checkUpdateSubnetProgress(name: string): Promise>{ + const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.updateSubnet, this._gaxModule.createDefaultBackoffSettings()); + return decodeOperation as LROperation; + } +/** + * Deletes a single Subnet. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes after the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.delete_subnet.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteSubnet_async + */ + deleteSubnet( + request?: protos.google.cloud.edgenetwork.v1.IDeleteSubnetRequest, + options?: CallOptions): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>; + deleteSubnet( + request: protos.google.cloud.edgenetwork.v1.IDeleteSubnetRequest, + options: CallOptions, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + deleteSubnet( + request: protos.google.cloud.edgenetwork.v1.IDeleteSubnetRequest, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + deleteSubnet( + request?: protos.google.cloud.edgenetwork.v1.IDeleteSubnetRequest, + optionsOrCallback?: CallOptions|Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>, + callback?: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'name': request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.deleteSubnet(request, options, callback); + } +/** + * Check the status of the long running operation returned by `deleteSubnet()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.delete_subnet.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteSubnet_async + */ + async checkDeleteSubnetProgress(name: string): Promise>{ + const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.deleteSubnet, this._gaxModule.createDefaultBackoffSettings()); + return decodeOperation as LROperation; + } +/** + * Creates a new InterconnectAttachment in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Value for parent. + * @param {string} request.interconnectAttachmentId + * Required. Id of the requesting object + * If auto-generating Id server-side, remove this field and + * interconnect_attachment_id from the method_signature of Create RPC + * @param {google.cloud.edgenetwork.v1.InterconnectAttachment} request.interconnectAttachment + * Required. The resource being created + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.create_interconnect_attachment.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateInterconnectAttachment_async + */ + createInterconnectAttachment( + request?: protos.google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest, + options?: CallOptions): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>; + createInterconnectAttachment( + request: protos.google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest, + options: CallOptions, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + createInterconnectAttachment( + request: protos.google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + createInterconnectAttachment( + request?: protos.google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest, + optionsOrCallback?: CallOptions|Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>, + callback?: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.createInterconnectAttachment(request, options, callback); + } +/** + * Check the status of the long running operation returned by `createInterconnectAttachment()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.create_interconnect_attachment.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateInterconnectAttachment_async + */ + async checkCreateInterconnectAttachmentProgress(name: string): Promise>{ + const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.createInterconnectAttachment, this._gaxModule.createDefaultBackoffSettings()); + return decodeOperation as LROperation; + } +/** + * Deletes a single InterconnectAttachment. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes after the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.delete_interconnect_attachment.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteInterconnectAttachment_async + */ + deleteInterconnectAttachment( + request?: protos.google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest, + options?: CallOptions): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>; + deleteInterconnectAttachment( + request: protos.google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest, + options: CallOptions, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + deleteInterconnectAttachment( + request: protos.google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + deleteInterconnectAttachment( + request?: protos.google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest, + optionsOrCallback?: CallOptions|Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>, + callback?: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'name': request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.deleteInterconnectAttachment(request, options, callback); + } +/** + * Check the status of the long running operation returned by `deleteInterconnectAttachment()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.delete_interconnect_attachment.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteInterconnectAttachment_async + */ + async checkDeleteInterconnectAttachmentProgress(name: string): Promise>{ + const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.deleteInterconnectAttachment, this._gaxModule.createDefaultBackoffSettings()); + return decodeOperation as LROperation; + } +/** + * Creates a new Router in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Value for parent. + * @param {string} request.routerId + * Required. Id of the requesting object + * If auto-generating Id server-side, remove this field and + * router_id from the method_signature of Create RPC + * @param {google.cloud.edgenetwork.v1.Router} request.router + * Required. The resource being created + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.create_router.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateRouter_async + */ + createRouter( + request?: protos.google.cloud.edgenetwork.v1.ICreateRouterRequest, + options?: CallOptions): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>; + createRouter( + request: protos.google.cloud.edgenetwork.v1.ICreateRouterRequest, + options: CallOptions, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + createRouter( + request: protos.google.cloud.edgenetwork.v1.ICreateRouterRequest, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + createRouter( + request?: protos.google.cloud.edgenetwork.v1.ICreateRouterRequest, + optionsOrCallback?: CallOptions|Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>, + callback?: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.createRouter(request, options, callback); + } +/** + * Check the status of the long running operation returned by `createRouter()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.create_router.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateRouter_async + */ + async checkCreateRouterProgress(name: string): Promise>{ + const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.createRouter, this._gaxModule.createDefaultBackoffSettings()); + return decodeOperation as LROperation; + } +/** + * Updates the parameters of a single Router. + * + * @param {Object} request + * The request object that will be sent. + * @param {google.protobuf.FieldMask} request.updateMask + * Required. Field mask is used to specify the fields to be overwritten in the + * Router resource by the update. + * The fields specified in the update_mask are relative to the resource, not + * the full request. A field will be overwritten if it is in the mask. If the + * user does not provide a mask then all fields will be overwritten. + * @param {google.cloud.edgenetwork.v1.Router} request.router + * Required. The resource being updated + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.update_router.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_UpdateRouter_async + */ + updateRouter( + request?: protos.google.cloud.edgenetwork.v1.IUpdateRouterRequest, + options?: CallOptions): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>; + updateRouter( + request: protos.google.cloud.edgenetwork.v1.IUpdateRouterRequest, + options: CallOptions, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + updateRouter( + request: protos.google.cloud.edgenetwork.v1.IUpdateRouterRequest, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + updateRouter( + request?: protos.google.cloud.edgenetwork.v1.IUpdateRouterRequest, + optionsOrCallback?: CallOptions|Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>, + callback?: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'router.name': request.router!.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.updateRouter(request, options, callback); + } +/** + * Check the status of the long running operation returned by `updateRouter()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.update_router.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_UpdateRouter_async + */ + async checkUpdateRouterProgress(name: string): Promise>{ + const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.updateRouter, this._gaxModule.createDefaultBackoffSettings()); + return decodeOperation as LROperation; + } +/** + * Deletes a single Router. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes after the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.delete_router.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteRouter_async + */ + deleteRouter( + request?: protos.google.cloud.edgenetwork.v1.IDeleteRouterRequest, + options?: CallOptions): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>; + deleteRouter( + request: protos.google.cloud.edgenetwork.v1.IDeleteRouterRequest, + options: CallOptions, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + deleteRouter( + request: protos.google.cloud.edgenetwork.v1.IDeleteRouterRequest, + callback: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): void; + deleteRouter( + request?: protos.google.cloud.edgenetwork.v1.IDeleteRouterRequest, + optionsOrCallback?: CallOptions|Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>, + callback?: Callback< + LROperation, + protos.google.longrunning.IOperation|null|undefined, + {}|null|undefined>): + Promise<[ + LROperation, + protos.google.longrunning.IOperation|undefined, {}|undefined + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'name': request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.deleteRouter(request, options, callback); + } +/** + * Check the status of the long running operation returned by `deleteRouter()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.delete_router.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteRouter_async + */ + async checkDeleteRouterProgress(name: string): Promise>{ + const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.deleteRouter, this._gaxModule.createDefaultBackoffSettings()); + return decodeOperation as LROperation; + } + /** + * Lists Zones in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListZonesRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.Zone|Zone}. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed and will merge results from all the pages into this array. + * Note that it can affect your quota. + * We recommend using `listZonesAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listZones( + request?: protos.google.cloud.edgenetwork.v1.IListZonesRequest, + options?: CallOptions): + Promise<[ + protos.google.cloud.edgenetwork.v1.IZone[], + protos.google.cloud.edgenetwork.v1.IListZonesRequest|null, + protos.google.cloud.edgenetwork.v1.IListZonesResponse + ]>; + listZones( + request: protos.google.cloud.edgenetwork.v1.IListZonesRequest, + options: CallOptions, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListZonesRequest, + protos.google.cloud.edgenetwork.v1.IListZonesResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.IZone>): void; + listZones( + request: protos.google.cloud.edgenetwork.v1.IListZonesRequest, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListZonesRequest, + protos.google.cloud.edgenetwork.v1.IListZonesResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.IZone>): void; + listZones( + request?: protos.google.cloud.edgenetwork.v1.IListZonesRequest, + optionsOrCallback?: CallOptions|PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListZonesRequest, + protos.google.cloud.edgenetwork.v1.IListZonesResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.IZone>, + callback?: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListZonesRequest, + protos.google.cloud.edgenetwork.v1.IListZonesResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.IZone>): + Promise<[ + protos.google.cloud.edgenetwork.v1.IZone[], + protos.google.cloud.edgenetwork.v1.IListZonesRequest|null, + protos.google.cloud.edgenetwork.v1.IListZonesResponse + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.listZones(request, options, callback); + } + +/** + * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListZonesRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Stream} + * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.Zone|Zone} on 'data' event. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed. Note that it can affect your quota. + * We recommend using `listZonesAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listZonesStream( + request?: protos.google.cloud.edgenetwork.v1.IListZonesRequest, + options?: CallOptions): + Transform{ + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listZones']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listZones.createStream( + this.innerApiCalls.listZones as GaxCall, + request, + callSettings + ); + } + +/** + * Equivalent to `listZones`, but returns an iterable object. + * + * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListZonesRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Object} + * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. + * When you iterate the returned iterable, each element will be an object representing + * {@link protos.google.cloud.edgenetwork.v1.Zone|Zone}. The API will be called under the hood as needed, once per the page, + * so you can stop the iteration when you don't need more results. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.list_zones.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListZones_async + */ + listZonesAsync( + request?: protos.google.cloud.edgenetwork.v1.IListZonesRequest, + options?: CallOptions): + AsyncIterable{ + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listZones']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listZones.asyncIterate( + this.innerApiCalls['listZones'] as GaxCall, + request as {}, + callSettings + ) as AsyncIterable; + } + /** + * Lists Networks in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListNetworksRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.Network|Network}. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed and will merge results from all the pages into this array. + * Note that it can affect your quota. + * We recommend using `listNetworksAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listNetworks( + request?: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + options?: CallOptions): + Promise<[ + protos.google.cloud.edgenetwork.v1.INetwork[], + protos.google.cloud.edgenetwork.v1.IListNetworksRequest|null, + protos.google.cloud.edgenetwork.v1.IListNetworksResponse + ]>; + listNetworks( + request: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + options: CallOptions, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + protos.google.cloud.edgenetwork.v1.IListNetworksResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.INetwork>): void; + listNetworks( + request: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + protos.google.cloud.edgenetwork.v1.IListNetworksResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.INetwork>): void; + listNetworks( + request?: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + optionsOrCallback?: CallOptions|PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + protos.google.cloud.edgenetwork.v1.IListNetworksResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.INetwork>, + callback?: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + protos.google.cloud.edgenetwork.v1.IListNetworksResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.INetwork>): + Promise<[ + protos.google.cloud.edgenetwork.v1.INetwork[], + protos.google.cloud.edgenetwork.v1.IListNetworksRequest|null, + protos.google.cloud.edgenetwork.v1.IListNetworksResponse + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.listNetworks(request, options, callback); + } + +/** + * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListNetworksRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Stream} + * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.Network|Network} on 'data' event. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed. Note that it can affect your quota. + * We recommend using `listNetworksAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listNetworksStream( + request?: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + options?: CallOptions): + Transform{ + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listNetworks']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listNetworks.createStream( + this.innerApiCalls.listNetworks as GaxCall, + request, + callSettings + ); + } + +/** + * Equivalent to `listNetworks`, but returns an iterable object. + * + * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListNetworksRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Object} + * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. + * When you iterate the returned iterable, each element will be an object representing + * {@link protos.google.cloud.edgenetwork.v1.Network|Network}. The API will be called under the hood as needed, once per the page, + * so you can stop the iteration when you don't need more results. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.list_networks.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListNetworks_async + */ + listNetworksAsync( + request?: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + options?: CallOptions): + AsyncIterable{ + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listNetworks']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listNetworks.asyncIterate( + this.innerApiCalls['listNetworks'] as GaxCall, + request as {}, + callSettings + ) as AsyncIterable; + } + /** + * Lists Subnets in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListSubnetsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.Subnet|Subnet}. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed and will merge results from all the pages into this array. + * Note that it can affect your quota. + * We recommend using `listSubnetsAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listSubnets( + request?: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + options?: CallOptions): + Promise<[ + protos.google.cloud.edgenetwork.v1.ISubnet[], + protos.google.cloud.edgenetwork.v1.IListSubnetsRequest|null, + protos.google.cloud.edgenetwork.v1.IListSubnetsResponse + ]>; + listSubnets( + request: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + options: CallOptions, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + protos.google.cloud.edgenetwork.v1.IListSubnetsResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.ISubnet>): void; + listSubnets( + request: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + protos.google.cloud.edgenetwork.v1.IListSubnetsResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.ISubnet>): void; + listSubnets( + request?: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + optionsOrCallback?: CallOptions|PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + protos.google.cloud.edgenetwork.v1.IListSubnetsResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.ISubnet>, + callback?: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + protos.google.cloud.edgenetwork.v1.IListSubnetsResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.ISubnet>): + Promise<[ + protos.google.cloud.edgenetwork.v1.ISubnet[], + protos.google.cloud.edgenetwork.v1.IListSubnetsRequest|null, + protos.google.cloud.edgenetwork.v1.IListSubnetsResponse + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.listSubnets(request, options, callback); + } + +/** + * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListSubnetsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Stream} + * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.Subnet|Subnet} on 'data' event. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed. Note that it can affect your quota. + * We recommend using `listSubnetsAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listSubnetsStream( + request?: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + options?: CallOptions): + Transform{ + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listSubnets']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listSubnets.createStream( + this.innerApiCalls.listSubnets as GaxCall, + request, + callSettings + ); + } + +/** + * Equivalent to `listSubnets`, but returns an iterable object. + * + * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListSubnetsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Object} + * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. + * When you iterate the returned iterable, each element will be an object representing + * {@link protos.google.cloud.edgenetwork.v1.Subnet|Subnet}. The API will be called under the hood as needed, once per the page, + * so you can stop the iteration when you don't need more results. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.list_subnets.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListSubnets_async + */ + listSubnetsAsync( + request?: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + options?: CallOptions): + AsyncIterable{ + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listSubnets']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listSubnets.asyncIterate( + this.innerApiCalls['listSubnets'] as GaxCall, + request as {}, + callSettings + ) as AsyncIterable; + } + /** + * Lists Interconnects in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListInterconnectsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.Interconnect|Interconnect}. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed and will merge results from all the pages into this array. + * Note that it can affect your quota. + * We recommend using `listInterconnectsAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listInterconnects( + request?: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + options?: CallOptions): + Promise<[ + protos.google.cloud.edgenetwork.v1.IInterconnect[], + protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest|null, + protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse + ]>; + listInterconnects( + request: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + options: CallOptions, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.IInterconnect>): void; + listInterconnects( + request: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.IInterconnect>): void; + listInterconnects( + request?: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + optionsOrCallback?: CallOptions|PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.IInterconnect>, + callback?: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.IInterconnect>): + Promise<[ + protos.google.cloud.edgenetwork.v1.IInterconnect[], + protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest|null, + protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.listInterconnects(request, options, callback); + } + +/** + * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListInterconnectsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Stream} + * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.Interconnect|Interconnect} on 'data' event. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed. Note that it can affect your quota. + * We recommend using `listInterconnectsAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listInterconnectsStream( + request?: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + options?: CallOptions): + Transform{ + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listInterconnects']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listInterconnects.createStream( + this.innerApiCalls.listInterconnects as GaxCall, + request, + callSettings + ); + } + +/** + * Equivalent to `listInterconnects`, but returns an iterable object. + * + * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListInterconnectsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Object} + * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. + * When you iterate the returned iterable, each element will be an object representing + * {@link protos.google.cloud.edgenetwork.v1.Interconnect|Interconnect}. The API will be called under the hood as needed, once per the page, + * so you can stop the iteration when you don't need more results. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.list_interconnects.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListInterconnects_async + */ + listInterconnectsAsync( + request?: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + options?: CallOptions): + AsyncIterable{ + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listInterconnects']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listInterconnects.asyncIterate( + this.innerApiCalls['listInterconnects'] as GaxCall, + request as {}, + callSettings + ) as AsyncIterable; + } + /** + * Lists InterconnectAttachments in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListInterconnectAttachmentsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.InterconnectAttachment|InterconnectAttachment}. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed and will merge results from all the pages into this array. + * Note that it can affect your quota. + * We recommend using `listInterconnectAttachmentsAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listInterconnectAttachments( + request?: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + options?: CallOptions): + Promise<[ + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment[], + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest|null, + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse + ]>; + listInterconnectAttachments( + request: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + options: CallOptions, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment>): void; + listInterconnectAttachments( + request: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment>): void; + listInterconnectAttachments( + request?: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + optionsOrCallback?: CallOptions|PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment>, + callback?: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment>): + Promise<[ + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment[], + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest|null, + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.listInterconnectAttachments(request, options, callback); + } + +/** + * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListInterconnectAttachmentsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Stream} + * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.InterconnectAttachment|InterconnectAttachment} on 'data' event. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed. Note that it can affect your quota. + * We recommend using `listInterconnectAttachmentsAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listInterconnectAttachmentsStream( + request?: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + options?: CallOptions): + Transform{ + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listInterconnectAttachments']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listInterconnectAttachments.createStream( + this.innerApiCalls.listInterconnectAttachments as GaxCall, + request, + callSettings + ); + } + +/** + * Equivalent to `listInterconnectAttachments`, but returns an iterable object. + * + * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListInterconnectAttachmentsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Object} + * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. + * When you iterate the returned iterable, each element will be an object representing + * {@link protos.google.cloud.edgenetwork.v1.InterconnectAttachment|InterconnectAttachment}. The API will be called under the hood as needed, once per the page, + * so you can stop the iteration when you don't need more results. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.list_interconnect_attachments.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListInterconnectAttachments_async + */ + listInterconnectAttachmentsAsync( + request?: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + options?: CallOptions): + AsyncIterable{ + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listInterconnectAttachments']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listInterconnectAttachments.asyncIterate( + this.innerApiCalls['listInterconnectAttachments'] as GaxCall, + request as {}, + callSettings + ) as AsyncIterable; + } + /** + * Lists Routers in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListRoutersRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.Router|Router}. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed and will merge results from all the pages into this array. + * Note that it can affect your quota. + * We recommend using `listRoutersAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listRouters( + request?: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + options?: CallOptions): + Promise<[ + protos.google.cloud.edgenetwork.v1.IRouter[], + protos.google.cloud.edgenetwork.v1.IListRoutersRequest|null, + protos.google.cloud.edgenetwork.v1.IListRoutersResponse + ]>; + listRouters( + request: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + options: CallOptions, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + protos.google.cloud.edgenetwork.v1.IListRoutersResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.IRouter>): void; + listRouters( + request: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + protos.google.cloud.edgenetwork.v1.IListRoutersResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.IRouter>): void; + listRouters( + request?: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + optionsOrCallback?: CallOptions|PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + protos.google.cloud.edgenetwork.v1.IListRoutersResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.IRouter>, + callback?: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + protos.google.cloud.edgenetwork.v1.IListRoutersResponse|null|undefined, + protos.google.cloud.edgenetwork.v1.IRouter>): + Promise<[ + protos.google.cloud.edgenetwork.v1.IRouter[], + protos.google.cloud.edgenetwork.v1.IListRoutersRequest|null, + protos.google.cloud.edgenetwork.v1.IListRoutersResponse + ]>|void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } + else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.listRouters(request, options, callback); + } + +/** + * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListRoutersRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Stream} + * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.Router|Router} on 'data' event. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed. Note that it can affect your quota. + * We recommend using `listRoutersAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listRoutersStream( + request?: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + options?: CallOptions): + Transform{ + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listRouters']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listRouters.createStream( + this.innerApiCalls.listRouters as GaxCall, + request, + callSettings + ); + } + +/** + * Equivalent to `listRouters`, but returns an iterable object. + * + * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListRoutersRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Object} + * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. + * When you iterate the returned iterable, each element will be an object representing + * {@link protos.google.cloud.edgenetwork.v1.Router|Router}. The API will be called under the hood as needed, once per the page, + * so you can stop the iteration when you don't need more results. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.list_routers.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListRouters_async + */ + listRoutersAsync( + request?: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + options?: CallOptions): + AsyncIterable{ + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers[ + 'x-goog-request-params' + ] = this._gaxModule.routingHeader.fromParams({ + 'parent': request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listRouters']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listRouters.asyncIterate( + this.innerApiCalls['listRouters'] as GaxCall, + request as {}, + callSettings + ) as AsyncIterable; + } +/** + * Gets information about a location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Resource name for the location. + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html | CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link google.cloud.location.Location | Location}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example + * ``` + * const [response] = await client.getLocation(request); + * ``` + */ + getLocation( + request: LocationProtos.google.cloud.location.IGetLocationRequest, + options?: + | gax.CallOptions + | Callback< + LocationProtos.google.cloud.location.ILocation, + | LocationProtos.google.cloud.location.IGetLocationRequest + | null + | undefined, + {} | null | undefined + >, + callback?: Callback< + LocationProtos.google.cloud.location.ILocation, + | LocationProtos.google.cloud.location.IGetLocationRequest + | null + | undefined, + {} | null | undefined + > + ): Promise { + return this.locationsClient.getLocation(request, options, callback); + } + +/** + * Lists information about the supported locations for this service. Returns an iterable object. + * + * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * The resource that owns the locations collection, if applicable. + * @param {string} request.filter + * The standard list filter. + * @param {number} request.pageSize + * The standard list page size. + * @param {string} request.pageToken + * The standard list page token. + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Object} + * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. + * When you iterate the returned iterable, each element will be an object representing + * {@link google.cloud.location.Location | Location}. The API will be called under the hood as needed, once per the page, + * so you can stop the iteration when you don't need more results. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + * @example + * ``` + * const iterable = client.listLocationsAsync(request); + * for await (const response of iterable) { + * // process response + * } + * ``` + */ + listLocationsAsync( + request: LocationProtos.google.cloud.location.IListLocationsRequest, + options?: CallOptions + ): AsyncIterable { + return this.locationsClient.listLocationsAsync(request, options); + } + +/** + * Gets the latest state of a long-running operation. Clients can use this + * method to poll the operation result at intervals as recommended by the API + * service. + * + * @param {Object} request - The request object that will be sent. + * @param {string} request.name - The name of the operation resource. + * @param {Object=} options + * Optional parameters. You can override the default settings for this call, + * e.g, timeout, retries, paginations, etc. See {@link + * https://googleapis.github.io/gax-nodejs/global.html#CallOptions | gax.CallOptions} + * for the details. + * @param {function(?Error, ?Object)=} callback + * The function which will be called with the result of the API call. + * + * The second parameter to the callback is an object representing + * {@link google.longrunning.Operation | google.longrunning.Operation}. + * @return {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * {@link google.longrunning.Operation | google.longrunning.Operation}. + * The promise has a method named "cancel" which cancels the ongoing API call. + * + * @example + * ``` + * const client = longrunning.operationsClient(); + * const name = ''; + * const [response] = await client.getOperation({name}); + * // doThingsWith(response) + * ``` + */ + getOperation( + request: protos.google.longrunning.GetOperationRequest, + options?: + | gax.CallOptions + | Callback< + protos.google.longrunning.Operation, + protos.google.longrunning.GetOperationRequest, + {} | null | undefined + >, + callback?: Callback< + protos.google.longrunning.Operation, + protos.google.longrunning.GetOperationRequest, + {} | null | undefined + > + ): Promise<[protos.google.longrunning.Operation]> { + return this.operationsClient.getOperation(request, options, callback); + } + /** + * Lists operations that match the specified filter in the request. If the + * server doesn't support this method, it returns `UNIMPLEMENTED`. Returns an iterable object. + * + * For-await-of syntax is used with the iterable to recursively get response element on-demand. + * + * @param {Object} request - The request object that will be sent. + * @param {string} request.name - The name of the operation collection. + * @param {string} request.filter - The standard list filter. + * @param {number=} request.pageSize - + * The maximum number of resources contained in the underlying API + * response. If page streaming is performed per-resource, this + * parameter does not affect the return value. If page streaming is + * performed per-page, this determines the maximum number of + * resources in a page. + * @param {Object=} options + * Optional parameters. You can override the default settings for this call, + * e.g, timeout, retries, paginations, etc. See {@link + * https://googleapis.github.io/gax-nodejs/global.html#CallOptions | gax.CallOptions} for the + * details. + * @returns {Object} + * An iterable Object that conforms to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | iteration protocols}. + * + * @example + * ``` + * const client = longrunning.operationsClient(); + * for await (const response of client.listOperationsAsync(request)); + * // doThingsWith(response) + * ``` + */ + listOperationsAsync( + request: protos.google.longrunning.ListOperationsRequest, + options?: gax.CallOptions + ): AsyncIterable { + return this.operationsClient.listOperationsAsync(request, options); + } + /** + * Starts asynchronous cancellation on a long-running operation. The server + * makes a best effort to cancel the operation, but success is not + * guaranteed. If the server doesn't support this method, it returns + * `google.rpc.Code.UNIMPLEMENTED`. Clients can use + * {@link Operations.GetOperation} or + * other methods to check whether the cancellation succeeded or whether the + * operation completed despite cancellation. On successful cancellation, + * the operation is not deleted; instead, it becomes an operation with + * an {@link Operation.error} value with a {@link google.rpc.Status.code} of + * 1, corresponding to `Code.CANCELLED`. + * + * @param {Object} request - The request object that will be sent. + * @param {string} request.name - The name of the operation resource to be cancelled. + * @param {Object=} options + * Optional parameters. You can override the default settings for this call, + * e.g, timeout, retries, paginations, etc. See {@link + * https://googleapis.github.io/gax-nodejs/global.html#CallOptions | gax.CallOptions} for the + * details. + * @param {function(?Error)=} callback + * The function which will be called with the result of the API call. + * @return {Promise} - The promise which resolves when API call finishes. + * The promise has a method named "cancel" which cancels the ongoing API + * call. + * + * @example + * ``` + * const client = longrunning.operationsClient(); + * await client.cancelOperation({name: ''}); + * ``` + */ + cancelOperation( + request: protos.google.longrunning.CancelOperationRequest, + options?: + | gax.CallOptions + | Callback< + protos.google.protobuf.Empty, + protos.google.longrunning.CancelOperationRequest, + {} | undefined | null + >, + callback?: Callback< + protos.google.longrunning.CancelOperationRequest, + protos.google.protobuf.Empty, + {} | undefined | null + > + ): Promise { + return this.operationsClient.cancelOperation(request, options, callback); + } + + /** + * Deletes a long-running operation. This method indicates that the client is + * no longer interested in the operation result. It does not cancel the + * operation. If the server doesn't support this method, it returns + * `google.rpc.Code.UNIMPLEMENTED`. + * + * @param {Object} request - The request object that will be sent. + * @param {string} request.name - The name of the operation resource to be deleted. + * @param {Object=} options + * Optional parameters. You can override the default settings for this call, + * e.g, timeout, retries, paginations, etc. See {@link + * https://googleapis.github.io/gax-nodejs/global.html#CallOptions | gax.CallOptions} + * for the details. + * @param {function(?Error)=} callback + * The function which will be called with the result of the API call. + * @return {Promise} - The promise which resolves when API call finishes. + * The promise has a method named "cancel" which cancels the ongoing API + * call. + * + * @example + * ``` + * const client = longrunning.operationsClient(); + * await client.deleteOperation({name: ''}); + * ``` + */ + deleteOperation( + request: protos.google.longrunning.DeleteOperationRequest, + options?: + | gax.CallOptions + | Callback< + protos.google.protobuf.Empty, + protos.google.longrunning.DeleteOperationRequest, + {} | null | undefined + >, + callback?: Callback< + protos.google.protobuf.Empty, + protos.google.longrunning.DeleteOperationRequest, + {} | null | undefined + > + ): Promise { + return this.operationsClient.deleteOperation(request, options, callback); + } + + // -------------------- + // -- Path templates -- + // -------------------- + + /** + * Return a fully-qualified interconnect resource name string. + * + * @param {string} project + * @param {string} location + * @param {string} zone + * @param {string} interconnect + * @returns {string} Resource name string. + */ + interconnectPath(project:string,location:string,zone:string,interconnect:string) { + return this.pathTemplates.interconnectPathTemplate.render({ + project: project, + location: location, + zone: zone, + interconnect: interconnect, + }); + } + + /** + * Parse the project from Interconnect resource. + * + * @param {string} interconnectName + * A fully-qualified path representing Interconnect resource. + * @returns {string} A string representing the project. + */ + matchProjectFromInterconnectName(interconnectName: string) { + return this.pathTemplates.interconnectPathTemplate.match(interconnectName).project; + } + + /** + * Parse the location from Interconnect resource. + * + * @param {string} interconnectName + * A fully-qualified path representing Interconnect resource. + * @returns {string} A string representing the location. + */ + matchLocationFromInterconnectName(interconnectName: string) { + return this.pathTemplates.interconnectPathTemplate.match(interconnectName).location; + } + + /** + * Parse the zone from Interconnect resource. + * + * @param {string} interconnectName + * A fully-qualified path representing Interconnect resource. + * @returns {string} A string representing the zone. + */ + matchZoneFromInterconnectName(interconnectName: string) { + return this.pathTemplates.interconnectPathTemplate.match(interconnectName).zone; + } + + /** + * Parse the interconnect from Interconnect resource. + * + * @param {string} interconnectName + * A fully-qualified path representing Interconnect resource. + * @returns {string} A string representing the interconnect. + */ + matchInterconnectFromInterconnectName(interconnectName: string) { + return this.pathTemplates.interconnectPathTemplate.match(interconnectName).interconnect; + } + + /** + * Return a fully-qualified interconnectAttachment resource name string. + * + * @param {string} project + * @param {string} location + * @param {string} zone + * @param {string} interconnect_attachment + * @returns {string} Resource name string. + */ + interconnectAttachmentPath(project:string,location:string,zone:string,interconnectAttachment:string) { + return this.pathTemplates.interconnectAttachmentPathTemplate.render({ + project: project, + location: location, + zone: zone, + interconnect_attachment: interconnectAttachment, + }); + } + + /** + * Parse the project from InterconnectAttachment resource. + * + * @param {string} interconnectAttachmentName + * A fully-qualified path representing InterconnectAttachment resource. + * @returns {string} A string representing the project. + */ + matchProjectFromInterconnectAttachmentName(interconnectAttachmentName: string) { + return this.pathTemplates.interconnectAttachmentPathTemplate.match(interconnectAttachmentName).project; + } + + /** + * Parse the location from InterconnectAttachment resource. + * + * @param {string} interconnectAttachmentName + * A fully-qualified path representing InterconnectAttachment resource. + * @returns {string} A string representing the location. + */ + matchLocationFromInterconnectAttachmentName(interconnectAttachmentName: string) { + return this.pathTemplates.interconnectAttachmentPathTemplate.match(interconnectAttachmentName).location; + } + + /** + * Parse the zone from InterconnectAttachment resource. + * + * @param {string} interconnectAttachmentName + * A fully-qualified path representing InterconnectAttachment resource. + * @returns {string} A string representing the zone. + */ + matchZoneFromInterconnectAttachmentName(interconnectAttachmentName: string) { + return this.pathTemplates.interconnectAttachmentPathTemplate.match(interconnectAttachmentName).zone; + } + + /** + * Parse the interconnect_attachment from InterconnectAttachment resource. + * + * @param {string} interconnectAttachmentName + * A fully-qualified path representing InterconnectAttachment resource. + * @returns {string} A string representing the interconnect_attachment. + */ + matchInterconnectAttachmentFromInterconnectAttachmentName(interconnectAttachmentName: string) { + return this.pathTemplates.interconnectAttachmentPathTemplate.match(interconnectAttachmentName).interconnect_attachment; + } + + /** + * Return a fully-qualified location resource name string. + * + * @param {string} project + * @param {string} location + * @returns {string} Resource name string. + */ + locationPath(project:string,location:string) { + return this.pathTemplates.locationPathTemplate.render({ + project: project, + location: location, + }); + } + + /** + * Parse the project from Location resource. + * + * @param {string} locationName + * A fully-qualified path representing Location resource. + * @returns {string} A string representing the project. + */ + matchProjectFromLocationName(locationName: string) { + return this.pathTemplates.locationPathTemplate.match(locationName).project; + } + + /** + * Parse the location from Location resource. + * + * @param {string} locationName + * A fully-qualified path representing Location resource. + * @returns {string} A string representing the location. + */ + matchLocationFromLocationName(locationName: string) { + return this.pathTemplates.locationPathTemplate.match(locationName).location; + } + + /** + * Return a fully-qualified network resource name string. + * + * @param {string} project + * @param {string} location + * @param {string} zone + * @param {string} network + * @returns {string} Resource name string. + */ + networkPath(project:string,location:string,zone:string,network:string) { + return this.pathTemplates.networkPathTemplate.render({ + project: project, + location: location, + zone: zone, + network: network, + }); + } + + /** + * Parse the project from Network resource. + * + * @param {string} networkName + * A fully-qualified path representing Network resource. + * @returns {string} A string representing the project. + */ + matchProjectFromNetworkName(networkName: string) { + return this.pathTemplates.networkPathTemplate.match(networkName).project; + } + + /** + * Parse the location from Network resource. + * + * @param {string} networkName + * A fully-qualified path representing Network resource. + * @returns {string} A string representing the location. + */ + matchLocationFromNetworkName(networkName: string) { + return this.pathTemplates.networkPathTemplate.match(networkName).location; + } + + /** + * Parse the zone from Network resource. + * + * @param {string} networkName + * A fully-qualified path representing Network resource. + * @returns {string} A string representing the zone. + */ + matchZoneFromNetworkName(networkName: string) { + return this.pathTemplates.networkPathTemplate.match(networkName).zone; + } + + /** + * Parse the network from Network resource. + * + * @param {string} networkName + * A fully-qualified path representing Network resource. + * @returns {string} A string representing the network. + */ + matchNetworkFromNetworkName(networkName: string) { + return this.pathTemplates.networkPathTemplate.match(networkName).network; + } + + /** + * Return a fully-qualified project resource name string. + * + * @param {string} project + * @returns {string} Resource name string. + */ + projectPath(project:string) { + return this.pathTemplates.projectPathTemplate.render({ + project: project, + }); + } + + /** + * Parse the project from Project resource. + * + * @param {string} projectName + * A fully-qualified path representing Project resource. + * @returns {string} A string representing the project. + */ + matchProjectFromProjectName(projectName: string) { + return this.pathTemplates.projectPathTemplate.match(projectName).project; + } + + /** + * Return a fully-qualified router resource name string. + * + * @param {string} project + * @param {string} location + * @param {string} zone + * @param {string} router + * @returns {string} Resource name string. + */ + routerPath(project:string,location:string,zone:string,router:string) { + return this.pathTemplates.routerPathTemplate.render({ + project: project, + location: location, + zone: zone, + router: router, + }); + } + + /** + * Parse the project from Router resource. + * + * @param {string} routerName + * A fully-qualified path representing Router resource. + * @returns {string} A string representing the project. + */ + matchProjectFromRouterName(routerName: string) { + return this.pathTemplates.routerPathTemplate.match(routerName).project; + } + + /** + * Parse the location from Router resource. + * + * @param {string} routerName + * A fully-qualified path representing Router resource. + * @returns {string} A string representing the location. + */ + matchLocationFromRouterName(routerName: string) { + return this.pathTemplates.routerPathTemplate.match(routerName).location; + } + + /** + * Parse the zone from Router resource. + * + * @param {string} routerName + * A fully-qualified path representing Router resource. + * @returns {string} A string representing the zone. + */ + matchZoneFromRouterName(routerName: string) { + return this.pathTemplates.routerPathTemplate.match(routerName).zone; + } + + /** + * Parse the router from Router resource. + * + * @param {string} routerName + * A fully-qualified path representing Router resource. + * @returns {string} A string representing the router. + */ + matchRouterFromRouterName(routerName: string) { + return this.pathTemplates.routerPathTemplate.match(routerName).router; + } + + /** + * Return a fully-qualified subnet resource name string. + * + * @param {string} project + * @param {string} location + * @param {string} zone + * @param {string} subnet + * @returns {string} Resource name string. + */ + subnetPath(project:string,location:string,zone:string,subnet:string) { + return this.pathTemplates.subnetPathTemplate.render({ + project: project, + location: location, + zone: zone, + subnet: subnet, + }); + } + + /** + * Parse the project from Subnet resource. + * + * @param {string} subnetName + * A fully-qualified path representing Subnet resource. + * @returns {string} A string representing the project. + */ + matchProjectFromSubnetName(subnetName: string) { + return this.pathTemplates.subnetPathTemplate.match(subnetName).project; + } + + /** + * Parse the location from Subnet resource. + * + * @param {string} subnetName + * A fully-qualified path representing Subnet resource. + * @returns {string} A string representing the location. + */ + matchLocationFromSubnetName(subnetName: string) { + return this.pathTemplates.subnetPathTemplate.match(subnetName).location; + } + + /** + * Parse the zone from Subnet resource. + * + * @param {string} subnetName + * A fully-qualified path representing Subnet resource. + * @returns {string} A string representing the zone. + */ + matchZoneFromSubnetName(subnetName: string) { + return this.pathTemplates.subnetPathTemplate.match(subnetName).zone; + } + + /** + * Parse the subnet from Subnet resource. + * + * @param {string} subnetName + * A fully-qualified path representing Subnet resource. + * @returns {string} A string representing the subnet. + */ + matchSubnetFromSubnetName(subnetName: string) { + return this.pathTemplates.subnetPathTemplate.match(subnetName).subnet; + } + + /** + * Return a fully-qualified zone resource name string. + * + * @param {string} project + * @param {string} location + * @param {string} zone + * @returns {string} Resource name string. + */ + zonePath(project:string,location:string,zone:string) { + return this.pathTemplates.zonePathTemplate.render({ + project: project, + location: location, + zone: zone, + }); + } + + /** + * Parse the project from Zone resource. + * + * @param {string} zoneName + * A fully-qualified path representing Zone resource. + * @returns {string} A string representing the project. + */ + matchProjectFromZoneName(zoneName: string) { + return this.pathTemplates.zonePathTemplate.match(zoneName).project; + } + + /** + * Parse the location from Zone resource. + * + * @param {string} zoneName + * A fully-qualified path representing Zone resource. + * @returns {string} A string representing the location. + */ + matchLocationFromZoneName(zoneName: string) { + return this.pathTemplates.zonePathTemplate.match(zoneName).location; + } + + /** + * Parse the zone from Zone resource. + * + * @param {string} zoneName + * A fully-qualified path representing Zone resource. + * @returns {string} A string representing the zone. + */ + matchZoneFromZoneName(zoneName: string) { + return this.pathTemplates.zonePathTemplate.match(zoneName).zone; + } + + /** + * Terminate the gRPC channel and close the client. + * + * The client will no longer be usable and all future behavior is undefined. + * @returns {Promise} A promise that resolves when the client is closed. + */ + close(): Promise { + if (this.edgeNetworkStub && !this._terminated) { + return this.edgeNetworkStub.then(stub => { + this._terminated = true; + stub.close(); + this.locationsClient.close(); + this.operationsClient.close(); + }); + } + return Promise.resolve(); + } +} diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_client_config.json b/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_client_config.json new file mode 100644 index 000000000000..5c008c176bce --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_client_config.json @@ -0,0 +1,165 @@ +{ + "interfaces": { + "google.cloud.edgenetwork.v1.EdgeNetwork": { + "retry_codes": { + "non_idempotent": [], + "idempotent": [ + "DEADLINE_EXCEEDED", + "UNAVAILABLE" + ], + "unavailable": [ + "UNAVAILABLE" + ] + }, + "retry_params": { + "default": { + "initial_retry_delay_millis": 100, + "retry_delay_multiplier": 1.3, + "max_retry_delay_millis": 60000, + "initial_rpc_timeout_millis": 60000, + "rpc_timeout_multiplier": 1, + "max_rpc_timeout_millis": 60000, + "total_timeout_millis": 600000 + }, + "ce5b960a6ed052e690863808e4f0deff3dc7d49f": { + "initial_retry_delay_millis": 1000, + "retry_delay_multiplier": 1.3, + "max_retry_delay_millis": 10000, + "initial_rpc_timeout_millis": 60000, + "rpc_timeout_multiplier": 1, + "max_rpc_timeout_millis": 60000, + "total_timeout_millis": 600000 + } + }, + "methods": { + "InitializeZone": { + "timeout_millis": 60000, + "retry_codes_name": "non_idempotent", + "retry_params_name": "default" + }, + "ListZones": { + "retry_codes_name": "non_idempotent", + "retry_params_name": "default" + }, + "GetZone": { + "retry_codes_name": "non_idempotent", + "retry_params_name": "default" + }, + "ListNetworks": { + "timeout_millis": 60000, + "retry_codes_name": "unavailable", + "retry_params_name": "ce5b960a6ed052e690863808e4f0deff3dc7d49f" + }, + "GetNetwork": { + "timeout_millis": 60000, + "retry_codes_name": "unavailable", + "retry_params_name": "ce5b960a6ed052e690863808e4f0deff3dc7d49f" + }, + "DiagnoseNetwork": { + "timeout_millis": 60000, + "retry_codes_name": "unavailable", + "retry_params_name": "ce5b960a6ed052e690863808e4f0deff3dc7d49f" + }, + "CreateNetwork": { + "timeout_millis": 60000, + "retry_codes_name": "non_idempotent", + "retry_params_name": "default" + }, + "DeleteNetwork": { + "timeout_millis": 60000, + "retry_codes_name": "non_idempotent", + "retry_params_name": "default" + }, + "ListSubnets": { + "timeout_millis": 60000, + "retry_codes_name": "unavailable", + "retry_params_name": "ce5b960a6ed052e690863808e4f0deff3dc7d49f" + }, + "GetSubnet": { + "timeout_millis": 60000, + "retry_codes_name": "unavailable", + "retry_params_name": "ce5b960a6ed052e690863808e4f0deff3dc7d49f" + }, + "CreateSubnet": { + "timeout_millis": 60000, + "retry_codes_name": "non_idempotent", + "retry_params_name": "default" + }, + "UpdateSubnet": { + "retry_codes_name": "non_idempotent", + "retry_params_name": "default" + }, + "DeleteSubnet": { + "timeout_millis": 60000, + "retry_codes_name": "non_idempotent", + "retry_params_name": "default" + }, + "ListInterconnects": { + "timeout_millis": 60000, + "retry_codes_name": "unavailable", + "retry_params_name": "ce5b960a6ed052e690863808e4f0deff3dc7d49f" + }, + "GetInterconnect": { + "timeout_millis": 60000, + "retry_codes_name": "unavailable", + "retry_params_name": "ce5b960a6ed052e690863808e4f0deff3dc7d49f" + }, + "DiagnoseInterconnect": { + "timeout_millis": 60000, + "retry_codes_name": "unavailable", + "retry_params_name": "ce5b960a6ed052e690863808e4f0deff3dc7d49f" + }, + "ListInterconnectAttachments": { + "timeout_millis": 60000, + "retry_codes_name": "unavailable", + "retry_params_name": "ce5b960a6ed052e690863808e4f0deff3dc7d49f" + }, + "GetInterconnectAttachment": { + "timeout_millis": 60000, + "retry_codes_name": "unavailable", + "retry_params_name": "ce5b960a6ed052e690863808e4f0deff3dc7d49f" + }, + "CreateInterconnectAttachment": { + "timeout_millis": 60000, + "retry_codes_name": "non_idempotent", + "retry_params_name": "default" + }, + "DeleteInterconnectAttachment": { + "timeout_millis": 60000, + "retry_codes_name": "non_idempotent", + "retry_params_name": "default" + }, + "ListRouters": { + "timeout_millis": 60000, + "retry_codes_name": "unavailable", + "retry_params_name": "ce5b960a6ed052e690863808e4f0deff3dc7d49f" + }, + "GetRouter": { + "timeout_millis": 60000, + "retry_codes_name": "unavailable", + "retry_params_name": "ce5b960a6ed052e690863808e4f0deff3dc7d49f" + }, + "DiagnoseRouter": { + "timeout_millis": 60000, + "retry_codes_name": "unavailable", + "retry_params_name": "ce5b960a6ed052e690863808e4f0deff3dc7d49f" + }, + "CreateRouter": { + "timeout_millis": 60000, + "retry_codes_name": "non_idempotent", + "retry_params_name": "default" + }, + "UpdateRouter": { + "timeout_millis": 60000, + "retry_codes_name": "non_idempotent", + "retry_params_name": "default" + }, + "DeleteRouter": { + "timeout_millis": 60000, + "retry_codes_name": "non_idempotent", + "retry_params_name": "default" + } + } + } + } +} diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_proto_list.json b/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_proto_list.json new file mode 100644 index 000000000000..8680425e9838 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_proto_list.json @@ -0,0 +1,4 @@ +[ + "../../protos/google/cloud/edgenetwork/v1/resources.proto", + "../../protos/google/cloud/edgenetwork/v1/service.proto" +] diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/gapic_metadata.json b/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/gapic_metadata.json new file mode 100644 index 000000000000..18ac05d1b637 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/gapic_metadata.json @@ -0,0 +1,307 @@ +{ + "schema": "1.0", + "comment": "This file maps proto services/RPCs to the corresponding library clients/methods", + "language": "typescript", + "protoPackage": "google.cloud.edgenetwork.v1", + "libraryPackage": "@google-cloud/edgenetwork", + "services": { + "EdgeNetwork": { + "clients": { + "grpc": { + "libraryClient": "EdgeNetworkClient", + "rpcs": { + "InitializeZone": { + "methods": [ + "initializeZone" + ] + }, + "GetZone": { + "methods": [ + "getZone" + ] + }, + "GetNetwork": { + "methods": [ + "getNetwork" + ] + }, + "DiagnoseNetwork": { + "methods": [ + "diagnoseNetwork" + ] + }, + "GetSubnet": { + "methods": [ + "getSubnet" + ] + }, + "GetInterconnect": { + "methods": [ + "getInterconnect" + ] + }, + "DiagnoseInterconnect": { + "methods": [ + "diagnoseInterconnect" + ] + }, + "GetInterconnectAttachment": { + "methods": [ + "getInterconnectAttachment" + ] + }, + "GetRouter": { + "methods": [ + "getRouter" + ] + }, + "DiagnoseRouter": { + "methods": [ + "diagnoseRouter" + ] + }, + "CreateNetwork": { + "methods": [ + "createNetwork" + ] + }, + "DeleteNetwork": { + "methods": [ + "deleteNetwork" + ] + }, + "CreateSubnet": { + "methods": [ + "createSubnet" + ] + }, + "UpdateSubnet": { + "methods": [ + "updateSubnet" + ] + }, + "DeleteSubnet": { + "methods": [ + "deleteSubnet" + ] + }, + "CreateInterconnectAttachment": { + "methods": [ + "createInterconnectAttachment" + ] + }, + "DeleteInterconnectAttachment": { + "methods": [ + "deleteInterconnectAttachment" + ] + }, + "CreateRouter": { + "methods": [ + "createRouter" + ] + }, + "UpdateRouter": { + "methods": [ + "updateRouter" + ] + }, + "DeleteRouter": { + "methods": [ + "deleteRouter" + ] + }, + "ListZones": { + "methods": [ + "listZones", + "listZonesStream", + "listZonesAsync" + ] + }, + "ListNetworks": { + "methods": [ + "listNetworks", + "listNetworksStream", + "listNetworksAsync" + ] + }, + "ListSubnets": { + "methods": [ + "listSubnets", + "listSubnetsStream", + "listSubnetsAsync" + ] + }, + "ListInterconnects": { + "methods": [ + "listInterconnects", + "listInterconnectsStream", + "listInterconnectsAsync" + ] + }, + "ListInterconnectAttachments": { + "methods": [ + "listInterconnectAttachments", + "listInterconnectAttachmentsStream", + "listInterconnectAttachmentsAsync" + ] + }, + "ListRouters": { + "methods": [ + "listRouters", + "listRoutersStream", + "listRoutersAsync" + ] + } + } + }, + "grpc-fallback": { + "libraryClient": "EdgeNetworkClient", + "rpcs": { + "InitializeZone": { + "methods": [ + "initializeZone" + ] + }, + "GetZone": { + "methods": [ + "getZone" + ] + }, + "GetNetwork": { + "methods": [ + "getNetwork" + ] + }, + "DiagnoseNetwork": { + "methods": [ + "diagnoseNetwork" + ] + }, + "GetSubnet": { + "methods": [ + "getSubnet" + ] + }, + "GetInterconnect": { + "methods": [ + "getInterconnect" + ] + }, + "DiagnoseInterconnect": { + "methods": [ + "diagnoseInterconnect" + ] + }, + "GetInterconnectAttachment": { + "methods": [ + "getInterconnectAttachment" + ] + }, + "GetRouter": { + "methods": [ + "getRouter" + ] + }, + "DiagnoseRouter": { + "methods": [ + "diagnoseRouter" + ] + }, + "CreateNetwork": { + "methods": [ + "createNetwork" + ] + }, + "DeleteNetwork": { + "methods": [ + "deleteNetwork" + ] + }, + "CreateSubnet": { + "methods": [ + "createSubnet" + ] + }, + "UpdateSubnet": { + "methods": [ + "updateSubnet" + ] + }, + "DeleteSubnet": { + "methods": [ + "deleteSubnet" + ] + }, + "CreateInterconnectAttachment": { + "methods": [ + "createInterconnectAttachment" + ] + }, + "DeleteInterconnectAttachment": { + "methods": [ + "deleteInterconnectAttachment" + ] + }, + "CreateRouter": { + "methods": [ + "createRouter" + ] + }, + "UpdateRouter": { + "methods": [ + "updateRouter" + ] + }, + "DeleteRouter": { + "methods": [ + "deleteRouter" + ] + }, + "ListZones": { + "methods": [ + "listZones", + "listZonesStream", + "listZonesAsync" + ] + }, + "ListNetworks": { + "methods": [ + "listNetworks", + "listNetworksStream", + "listNetworksAsync" + ] + }, + "ListSubnets": { + "methods": [ + "listSubnets", + "listSubnetsStream", + "listSubnetsAsync" + ] + }, + "ListInterconnects": { + "methods": [ + "listInterconnects", + "listInterconnectsStream", + "listInterconnectsAsync" + ] + }, + "ListInterconnectAttachments": { + "methods": [ + "listInterconnectAttachments", + "listInterconnectAttachmentsStream", + "listInterconnectAttachmentsAsync" + ] + }, + "ListRouters": { + "methods": [ + "listRouters", + "listRoutersStream", + "listRoutersAsync" + ] + } + } + } + } + } + } +} diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/index.ts b/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/index.ts new file mode 100644 index 000000000000..7449d1bb6dd0 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/index.ts @@ -0,0 +1,19 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + +export {EdgeNetworkClient} from './edge_network_client'; diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/system-test/fixtures/sample/src/index.js b/owl-bot-staging/google-cloud-edgenetwork/v1/system-test/fixtures/sample/src/index.js new file mode 100644 index 000000000000..7616467dcfc2 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/system-test/fixtures/sample/src/index.js @@ -0,0 +1,27 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + + +/* eslint-disable node/no-missing-require, no-unused-vars */ +const edgenetwork = require('@google-cloud/edgenetwork'); + +function main() { + const edgeNetworkClient = new edgenetwork.EdgeNetworkClient(); +} + +main(); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/system-test/fixtures/sample/src/index.ts b/owl-bot-staging/google-cloud-edgenetwork/v1/system-test/fixtures/sample/src/index.ts new file mode 100644 index 000000000000..2cd40e376a88 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/system-test/fixtures/sample/src/index.ts @@ -0,0 +1,32 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + +import {EdgeNetworkClient} from '@google-cloud/edgenetwork'; + +// check that the client class type name can be used +function doStuffWithEdgeNetworkClient(client: EdgeNetworkClient) { + client.close(); +} + +function main() { + // check that the client instance can be created + const edgeNetworkClient = new EdgeNetworkClient(); + doStuffWithEdgeNetworkClient(edgeNetworkClient); +} + +main(); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/system-test/install.ts b/owl-bot-staging/google-cloud-edgenetwork/v1/system-test/install.ts new file mode 100644 index 000000000000..c8f81b25a865 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/system-test/install.ts @@ -0,0 +1,49 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + +import {packNTest} from 'pack-n-play'; +import {readFileSync} from 'fs'; +import {describe, it} from 'mocha'; + +describe('📦 pack-n-play test', () => { + + it('TypeScript code', async function() { + this.timeout(300000); + const options = { + packageDir: process.cwd(), + sample: { + description: 'TypeScript user can use the type definitions', + ts: readFileSync('./system-test/fixtures/sample/src/index.ts').toString() + } + }; + await packNTest(options); + }); + + it('JavaScript code', async function() { + this.timeout(300000); + const options = { + packageDir: process.cwd(), + sample: { + description: 'JavaScript user can use the library', + ts: readFileSync('./system-test/fixtures/sample/src/index.js').toString() + } + }; + await packNTest(options); + }); + +}); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/test/gapic_edge_network_v1.ts b/owl-bot-staging/google-cloud-edgenetwork/v1/test/gapic_edge_network_v1.ts new file mode 100644 index 000000000000..b1880de9d1a2 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/test/gapic_edge_network_v1.ts @@ -0,0 +1,5119 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + +import * as protos from '../protos/protos'; +import * as assert from 'assert'; +import * as sinon from 'sinon'; +import {SinonStub} from 'sinon'; +import {describe, it} from 'mocha'; +import * as edgenetworkModule from '../src'; + +import {PassThrough} from 'stream'; + +import {protobuf, LROperation, operationsProtos, LocationProtos} from 'google-gax'; + +// Dynamically loaded proto JSON is needed to get the type information +// to fill in default values for request objects +const root = protobuf.Root.fromJSON(require('../protos/protos.json')).resolveAll(); + +// eslint-disable-next-line @typescript-eslint/no-unused-vars +function getTypeDefaultValue(typeName: string, fields: string[]) { + let type = root.lookupType(typeName) as protobuf.Type; + for (const field of fields.slice(0, -1)) { + type = type.fields[field]?.resolvedType as protobuf.Type; + } + return type.fields[fields[fields.length - 1]]?.defaultValue; +} + +function generateSampleMessage(instance: T) { + const filledObject = (instance.constructor as typeof protobuf.Message) + .toObject(instance as protobuf.Message, {defaults: true}); + return (instance.constructor as typeof protobuf.Message).fromObject(filledObject) as T; +} + +function stubSimpleCall(response?: ResponseType, error?: Error) { + return error ? sinon.stub().rejects(error) : sinon.stub().resolves([response]); +} + +function stubSimpleCallWithCallback(response?: ResponseType, error?: Error) { + return error ? sinon.stub().callsArgWith(2, error) : sinon.stub().callsArgWith(2, null, response); +} + +function stubLongRunningCall(response?: ResponseType, callError?: Error, lroError?: Error) { + const innerStub = lroError ? sinon.stub().rejects(lroError) : sinon.stub().resolves([response]); + const mockOperation = { + promise: innerStub, + }; + return callError ? sinon.stub().rejects(callError) : sinon.stub().resolves([mockOperation]); +} + +function stubLongRunningCallWithCallback(response?: ResponseType, callError?: Error, lroError?: Error) { + const innerStub = lroError ? sinon.stub().rejects(lroError) : sinon.stub().resolves([response]); + const mockOperation = { + promise: innerStub, + }; + return callError ? sinon.stub().callsArgWith(2, callError) : sinon.stub().callsArgWith(2, null, mockOperation); +} + +function stubPageStreamingCall(responses?: ResponseType[], error?: Error) { + const pagingStub = sinon.stub(); + if (responses) { + for (let i = 0; i < responses.length; ++i) { + pagingStub.onCall(i).callsArgWith(2, null, responses[i]); + } + } + const transformStub = error ? sinon.stub().callsArgWith(2, error) : pagingStub; + const mockStream = new PassThrough({ + objectMode: true, + transform: transformStub, + }); + // trigger as many responses as needed + if (responses) { + for (let i = 0; i < responses.length; ++i) { + setImmediate(() => { mockStream.write({}); }); + } + setImmediate(() => { mockStream.end(); }); + } else { + setImmediate(() => { mockStream.write({}); }); + setImmediate(() => { mockStream.end(); }); + } + return sinon.stub().returns(mockStream); +} + +function stubAsyncIterationCall(responses?: ResponseType[], error?: Error) { + let counter = 0; + const asyncIterable = { + [Symbol.asyncIterator]() { + return { + async next() { + if (error) { + return Promise.reject(error); + } + if (counter >= responses!.length) { + return Promise.resolve({done: true, value: undefined}); + } + return Promise.resolve({done: false, value: responses![counter++]}); + } + }; + } + }; + return sinon.stub().returns(asyncIterable); +} + +describe('v1.EdgeNetworkClient', () => { + describe('Common methods', () => { + it('has servicePath', () => { + const servicePath = edgenetworkModule.v1.EdgeNetworkClient.servicePath; + assert(servicePath); + }); + + it('has apiEndpoint', () => { + const apiEndpoint = edgenetworkModule.v1.EdgeNetworkClient.apiEndpoint; + assert(apiEndpoint); + }); + + it('has port', () => { + const port = edgenetworkModule.v1.EdgeNetworkClient.port; + assert(port); + assert(typeof port === 'number'); + }); + + it('should create a client with no option', () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient(); + assert(client); + }); + + it('should create a client with gRPC fallback', () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + fallback: true, + }); + assert(client); + }); + + it('has initialize method and supports deferred initialization', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + assert.strictEqual(client.edgeNetworkStub, undefined); + await client.initialize(); + assert(client.edgeNetworkStub); + }); + + it('has close method for the initialized client', done => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + assert(client.edgeNetworkStub); + client.close().then(() => { + done(); + }); + }); + + it('has close method for the non-initialized client', done => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + assert.strictEqual(client.edgeNetworkStub, undefined); + client.close().then(() => { + done(); + }); + }); + + it('has getProjectId method', async () => { + const fakeProjectId = 'fake-project-id'; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.auth.getProjectId = sinon.stub().resolves(fakeProjectId); + const result = await client.getProjectId(); + assert.strictEqual(result, fakeProjectId); + assert((client.auth.getProjectId as SinonStub).calledWithExactly()); + }); + + it('has getProjectId method with callback', async () => { + const fakeProjectId = 'fake-project-id'; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.auth.getProjectId = sinon.stub().callsArgWith(0, null, fakeProjectId); + const promise = new Promise((resolve, reject) => { + client.getProjectId((err?: Error|null, projectId?: string|null) => { + if (err) { + reject(err); + } else { + resolve(projectId); + } + }); + }); + const result = await promise; + assert.strictEqual(result, fakeProjectId); + }); + }); + + describe('initializeZone', () => { + it('invokes initializeZone without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InitializeZoneRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.InitializeZoneRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InitializeZoneResponse() + ); + client.innerApiCalls.initializeZone = stubSimpleCall(expectedResponse); + const [response] = await client.initializeZone(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.initializeZone as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.initializeZone as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes initializeZone without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InitializeZoneRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.InitializeZoneRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InitializeZoneResponse() + ); + client.innerApiCalls.initializeZone = stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.initializeZone( + request, + (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse|null) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.initializeZone as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.initializeZone as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes initializeZone with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InitializeZoneRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.InitializeZoneRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.initializeZone = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.initializeZone(request), expectedError); + const actualRequest = (client.innerApiCalls.initializeZone as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.initializeZone as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes initializeZone with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InitializeZoneRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.InitializeZoneRequest', ['name']); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.initializeZone(request), expectedError); + }); + }); + + describe('getZone', () => { + it('invokes getZone without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetZoneRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetZoneRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Zone() + ); + client.innerApiCalls.getZone = stubSimpleCall(expectedResponse); + const [response] = await client.getZone(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.getZone as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getZone as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getZone without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetZoneRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetZoneRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Zone() + ); + client.innerApiCalls.getZone = stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.getZone( + request, + (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IZone|null) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.getZone as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getZone as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getZone with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetZoneRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetZoneRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.getZone = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.getZone(request), expectedError); + const actualRequest = (client.innerApiCalls.getZone as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getZone as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getZone with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetZoneRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetZoneRequest', ['name']); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.getZone(request), expectedError); + }); + }); + + describe('getNetwork', () => { + it('invokes getNetwork without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetNetworkRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetNetworkRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Network() + ); + client.innerApiCalls.getNetwork = stubSimpleCall(expectedResponse); + const [response] = await client.getNetwork(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.getNetwork as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getNetwork as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getNetwork without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetNetworkRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetNetworkRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Network() + ); + client.innerApiCalls.getNetwork = stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.getNetwork( + request, + (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.INetwork|null) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.getNetwork as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getNetwork as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getNetwork with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetNetworkRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetNetworkRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.getNetwork = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.getNetwork(request), expectedError); + const actualRequest = (client.innerApiCalls.getNetwork as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getNetwork as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getNetwork with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetNetworkRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetNetworkRequest', ['name']); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.getNetwork(request), expectedError); + }); + }); + + describe('diagnoseNetwork', () => { + it('invokes diagnoseNetwork without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse() + ); + client.innerApiCalls.diagnoseNetwork = stubSimpleCall(expectedResponse); + const [response] = await client.diagnoseNetwork(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.diagnoseNetwork as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.diagnoseNetwork as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseNetwork without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse() + ); + client.innerApiCalls.diagnoseNetwork = stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.diagnoseNetwork( + request, + (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse|null) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.diagnoseNetwork as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.diagnoseNetwork as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseNetwork with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.diagnoseNetwork = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.diagnoseNetwork(request), expectedError); + const actualRequest = (client.innerApiCalls.diagnoseNetwork as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.diagnoseNetwork as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseNetwork with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest', ['name']); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.diagnoseNetwork(request), expectedError); + }); + }); + + describe('getSubnet', () => { + it('invokes getSubnet without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetSubnetRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetSubnetRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Subnet() + ); + client.innerApiCalls.getSubnet = stubSimpleCall(expectedResponse); + const [response] = await client.getSubnet(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.getSubnet as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getSubnet as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getSubnet without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetSubnetRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetSubnetRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Subnet() + ); + client.innerApiCalls.getSubnet = stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.getSubnet( + request, + (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.ISubnet|null) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.getSubnet as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getSubnet as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getSubnet with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetSubnetRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetSubnetRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.getSubnet = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.getSubnet(request), expectedError); + const actualRequest = (client.innerApiCalls.getSubnet as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getSubnet as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getSubnet with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetSubnetRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetSubnetRequest', ['name']); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.getSubnet(request), expectedError); + }); + }); + + describe('getInterconnect', () => { + it('invokes getInterconnect without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetInterconnectRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetInterconnectRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Interconnect() + ); + client.innerApiCalls.getInterconnect = stubSimpleCall(expectedResponse); + const [response] = await client.getInterconnect(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.getInterconnect as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getInterconnect as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getInterconnect without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetInterconnectRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetInterconnectRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Interconnect() + ); + client.innerApiCalls.getInterconnect = stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.getInterconnect( + request, + (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IInterconnect|null) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.getInterconnect as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getInterconnect as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getInterconnect with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetInterconnectRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetInterconnectRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.getInterconnect = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.getInterconnect(request), expectedError); + const actualRequest = (client.innerApiCalls.getInterconnect as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getInterconnect as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getInterconnect with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetInterconnectRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetInterconnectRequest', ['name']); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.getInterconnect(request), expectedError); + }); + }); + + describe('diagnoseInterconnect', () => { + it('invokes diagnoseInterconnect without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse() + ); + client.innerApiCalls.diagnoseInterconnect = stubSimpleCall(expectedResponse); + const [response] = await client.diagnoseInterconnect(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.diagnoseInterconnect as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.diagnoseInterconnect as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseInterconnect without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse() + ); + client.innerApiCalls.diagnoseInterconnect = stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.diagnoseInterconnect( + request, + (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse|null) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.diagnoseInterconnect as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.diagnoseInterconnect as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseInterconnect with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.diagnoseInterconnect = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.diagnoseInterconnect(request), expectedError); + const actualRequest = (client.innerApiCalls.diagnoseInterconnect as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.diagnoseInterconnect as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseInterconnect with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest', ['name']); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.diagnoseInterconnect(request), expectedError); + }); + }); + + describe('getInterconnectAttachment', () => { + it('invokes getInterconnectAttachment without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() + ); + client.innerApiCalls.getInterconnectAttachment = stubSimpleCall(expectedResponse); + const [response] = await client.getInterconnectAttachment(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.getInterconnectAttachment as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getInterconnectAttachment as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getInterconnectAttachment without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() + ); + client.innerApiCalls.getInterconnectAttachment = stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.getInterconnectAttachment( + request, + (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IInterconnectAttachment|null) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.getInterconnectAttachment as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getInterconnectAttachment as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getInterconnectAttachment with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.getInterconnectAttachment = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.getInterconnectAttachment(request), expectedError); + const actualRequest = (client.innerApiCalls.getInterconnectAttachment as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getInterconnectAttachment as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getInterconnectAttachment with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest', ['name']); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.getInterconnectAttachment(request), expectedError); + }); + }); + + describe('getRouter', () => { + it('invokes getRouter without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetRouterRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetRouterRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Router() + ); + client.innerApiCalls.getRouter = stubSimpleCall(expectedResponse); + const [response] = await client.getRouter(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.getRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getRouter without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetRouterRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetRouterRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Router() + ); + client.innerApiCalls.getRouter = stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.getRouter( + request, + (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IRouter|null) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.getRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getRouter with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetRouterRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetRouterRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.getRouter = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.getRouter(request), expectedError); + const actualRequest = (client.innerApiCalls.getRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.getRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getRouter with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetRouterRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetRouterRequest', ['name']); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.getRouter(request), expectedError); + }); + }); + + describe('diagnoseRouter', () => { + it('invokes diagnoseRouter without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseRouterRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseRouterRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseRouterResponse() + ); + client.innerApiCalls.diagnoseRouter = stubSimpleCall(expectedResponse); + const [response] = await client.diagnoseRouter(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.diagnoseRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.diagnoseRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseRouter without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseRouterRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseRouterRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseRouterResponse() + ); + client.innerApiCalls.diagnoseRouter = stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.diagnoseRouter( + request, + (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse|null) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.diagnoseRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.diagnoseRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseRouter with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseRouterRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseRouterRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.diagnoseRouter = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.diagnoseRouter(request), expectedError); + const actualRequest = (client.innerApiCalls.diagnoseRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.diagnoseRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseRouter with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseRouterRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseRouterRequest', ['name']); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.diagnoseRouter(request), expectedError); + }); + }); + + describe('createNetwork', () => { + it('invokes createNetwork without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateNetworkRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateNetworkRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.createNetwork = stubLongRunningCall(expectedResponse); + const [operation] = await client.createNetwork(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.createNetwork as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.createNetwork as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createNetwork without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateNetworkRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateNetworkRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.createNetwork = stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.createNetwork( + request, + (err?: Error|null, + result?: LROperation|null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const operation = await promise as LROperation; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.createNetwork as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.createNetwork as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createNetwork with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateNetworkRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateNetworkRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.createNetwork = stubLongRunningCall(undefined, expectedError); + await assert.rejects(client.createNetwork(request), expectedError); + const actualRequest = (client.innerApiCalls.createNetwork as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.createNetwork as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createNetwork with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateNetworkRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateNetworkRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.createNetwork = stubLongRunningCall(undefined, undefined, expectedError); + const [operation] = await client.createNetwork(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = (client.innerApiCalls.createNetwork as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.createNetwork as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkCreateNetworkProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkCreateNetworkProgress(expectedResponse.name); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkCreateNetworkProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.checkCreateNetworkProgress(''), expectedError); + assert((client.operationsClient.getOperation as SinonStub) + .getCall(0)); + }); + }); + + describe('deleteNetwork', () => { + it('invokes deleteNetwork without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteNetworkRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteNetworkRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.deleteNetwork = stubLongRunningCall(expectedResponse); + const [operation] = await client.deleteNetwork(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.deleteNetwork as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.deleteNetwork as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteNetwork without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteNetworkRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteNetworkRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.deleteNetwork = stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.deleteNetwork( + request, + (err?: Error|null, + result?: LROperation|null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const operation = await promise as LROperation; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.deleteNetwork as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.deleteNetwork as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteNetwork with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteNetworkRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteNetworkRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.deleteNetwork = stubLongRunningCall(undefined, expectedError); + await assert.rejects(client.deleteNetwork(request), expectedError); + const actualRequest = (client.innerApiCalls.deleteNetwork as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.deleteNetwork as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteNetwork with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteNetworkRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteNetworkRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.deleteNetwork = stubLongRunningCall(undefined, undefined, expectedError); + const [operation] = await client.deleteNetwork(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = (client.innerApiCalls.deleteNetwork as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.deleteNetwork as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkDeleteNetworkProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkDeleteNetworkProgress(expectedResponse.name); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkDeleteNetworkProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.checkDeleteNetworkProgress(''), expectedError); + assert((client.operationsClient.getOperation as SinonStub) + .getCall(0)); + }); + }); + + describe('createSubnet', () => { + it('invokes createSubnet without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateSubnetRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateSubnetRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.createSubnet = stubLongRunningCall(expectedResponse); + const [operation] = await client.createSubnet(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.createSubnet as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.createSubnet as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createSubnet without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateSubnetRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateSubnetRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.createSubnet = stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.createSubnet( + request, + (err?: Error|null, + result?: LROperation|null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const operation = await promise as LROperation; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.createSubnet as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.createSubnet as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createSubnet with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateSubnetRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateSubnetRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.createSubnet = stubLongRunningCall(undefined, expectedError); + await assert.rejects(client.createSubnet(request), expectedError); + const actualRequest = (client.innerApiCalls.createSubnet as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.createSubnet as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createSubnet with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateSubnetRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateSubnetRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.createSubnet = stubLongRunningCall(undefined, undefined, expectedError); + const [operation] = await client.createSubnet(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = (client.innerApiCalls.createSubnet as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.createSubnet as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkCreateSubnetProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkCreateSubnetProgress(expectedResponse.name); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkCreateSubnetProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.checkCreateSubnetProgress(''), expectedError); + assert((client.operationsClient.getOperation as SinonStub) + .getCall(0)); + }); + }); + + describe('updateSubnet', () => { + it('invokes updateSubnet without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.UpdateSubnetRequest() + ); + request.subnet ??= {}; + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.UpdateSubnetRequest', ['subnet', 'name']); + request.subnet.name = defaultValue1; + const expectedHeaderRequestParams = `subnet.name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.updateSubnet = stubLongRunningCall(expectedResponse); + const [operation] = await client.updateSubnet(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.updateSubnet as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.updateSubnet as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes updateSubnet without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.UpdateSubnetRequest() + ); + request.subnet ??= {}; + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.UpdateSubnetRequest', ['subnet', 'name']); + request.subnet.name = defaultValue1; + const expectedHeaderRequestParams = `subnet.name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.updateSubnet = stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.updateSubnet( + request, + (err?: Error|null, + result?: LROperation|null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const operation = await promise as LROperation; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.updateSubnet as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.updateSubnet as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes updateSubnet with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.UpdateSubnetRequest() + ); + request.subnet ??= {}; + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.UpdateSubnetRequest', ['subnet', 'name']); + request.subnet.name = defaultValue1; + const expectedHeaderRequestParams = `subnet.name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.updateSubnet = stubLongRunningCall(undefined, expectedError); + await assert.rejects(client.updateSubnet(request), expectedError); + const actualRequest = (client.innerApiCalls.updateSubnet as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.updateSubnet as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes updateSubnet with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.UpdateSubnetRequest() + ); + request.subnet ??= {}; + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.UpdateSubnetRequest', ['subnet', 'name']); + request.subnet.name = defaultValue1; + const expectedHeaderRequestParams = `subnet.name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.updateSubnet = stubLongRunningCall(undefined, undefined, expectedError); + const [operation] = await client.updateSubnet(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = (client.innerApiCalls.updateSubnet as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.updateSubnet as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkUpdateSubnetProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkUpdateSubnetProgress(expectedResponse.name); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkUpdateSubnetProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.checkUpdateSubnetProgress(''), expectedError); + assert((client.operationsClient.getOperation as SinonStub) + .getCall(0)); + }); + }); + + describe('deleteSubnet', () => { + it('invokes deleteSubnet without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteSubnetRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteSubnetRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.deleteSubnet = stubLongRunningCall(expectedResponse); + const [operation] = await client.deleteSubnet(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.deleteSubnet as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.deleteSubnet as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteSubnet without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteSubnetRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteSubnetRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.deleteSubnet = stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.deleteSubnet( + request, + (err?: Error|null, + result?: LROperation|null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const operation = await promise as LROperation; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.deleteSubnet as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.deleteSubnet as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteSubnet with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteSubnetRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteSubnetRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.deleteSubnet = stubLongRunningCall(undefined, expectedError); + await assert.rejects(client.deleteSubnet(request), expectedError); + const actualRequest = (client.innerApiCalls.deleteSubnet as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.deleteSubnet as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteSubnet with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteSubnetRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteSubnetRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.deleteSubnet = stubLongRunningCall(undefined, undefined, expectedError); + const [operation] = await client.deleteSubnet(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = (client.innerApiCalls.deleteSubnet as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.deleteSubnet as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkDeleteSubnetProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkDeleteSubnetProgress(expectedResponse.name); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkDeleteSubnetProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.checkDeleteSubnetProgress(''), expectedError); + assert((client.operationsClient.getOperation as SinonStub) + .getCall(0)); + }); + }); + + describe('createInterconnectAttachment', () => { + it('invokes createInterconnectAttachment without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.createInterconnectAttachment = stubLongRunningCall(expectedResponse); + const [operation] = await client.createInterconnectAttachment(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.createInterconnectAttachment as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.createInterconnectAttachment as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createInterconnectAttachment without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.createInterconnectAttachment = stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.createInterconnectAttachment( + request, + (err?: Error|null, + result?: LROperation|null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const operation = await promise as LROperation; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.createInterconnectAttachment as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.createInterconnectAttachment as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createInterconnectAttachment with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.createInterconnectAttachment = stubLongRunningCall(undefined, expectedError); + await assert.rejects(client.createInterconnectAttachment(request), expectedError); + const actualRequest = (client.innerApiCalls.createInterconnectAttachment as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.createInterconnectAttachment as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createInterconnectAttachment with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.createInterconnectAttachment = stubLongRunningCall(undefined, undefined, expectedError); + const [operation] = await client.createInterconnectAttachment(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = (client.innerApiCalls.createInterconnectAttachment as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.createInterconnectAttachment as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkCreateInterconnectAttachmentProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkCreateInterconnectAttachmentProgress(expectedResponse.name); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkCreateInterconnectAttachmentProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.checkCreateInterconnectAttachmentProgress(''), expectedError); + assert((client.operationsClient.getOperation as SinonStub) + .getCall(0)); + }); + }); + + describe('deleteInterconnectAttachment', () => { + it('invokes deleteInterconnectAttachment without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.deleteInterconnectAttachment = stubLongRunningCall(expectedResponse); + const [operation] = await client.deleteInterconnectAttachment(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.deleteInterconnectAttachment as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.deleteInterconnectAttachment as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteInterconnectAttachment without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.deleteInterconnectAttachment = stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.deleteInterconnectAttachment( + request, + (err?: Error|null, + result?: LROperation|null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const operation = await promise as LROperation; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.deleteInterconnectAttachment as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.deleteInterconnectAttachment as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteInterconnectAttachment with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.deleteInterconnectAttachment = stubLongRunningCall(undefined, expectedError); + await assert.rejects(client.deleteInterconnectAttachment(request), expectedError); + const actualRequest = (client.innerApiCalls.deleteInterconnectAttachment as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.deleteInterconnectAttachment as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteInterconnectAttachment with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.deleteInterconnectAttachment = stubLongRunningCall(undefined, undefined, expectedError); + const [operation] = await client.deleteInterconnectAttachment(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = (client.innerApiCalls.deleteInterconnectAttachment as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.deleteInterconnectAttachment as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkDeleteInterconnectAttachmentProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkDeleteInterconnectAttachmentProgress(expectedResponse.name); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkDeleteInterconnectAttachmentProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.checkDeleteInterconnectAttachmentProgress(''), expectedError); + assert((client.operationsClient.getOperation as SinonStub) + .getCall(0)); + }); + }); + + describe('createRouter', () => { + it('invokes createRouter without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateRouterRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateRouterRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.createRouter = stubLongRunningCall(expectedResponse); + const [operation] = await client.createRouter(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.createRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.createRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createRouter without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateRouterRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateRouterRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.createRouter = stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.createRouter( + request, + (err?: Error|null, + result?: LROperation|null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const operation = await promise as LROperation; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.createRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.createRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createRouter with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateRouterRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateRouterRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.createRouter = stubLongRunningCall(undefined, expectedError); + await assert.rejects(client.createRouter(request), expectedError); + const actualRequest = (client.innerApiCalls.createRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.createRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createRouter with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateRouterRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateRouterRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.createRouter = stubLongRunningCall(undefined, undefined, expectedError); + const [operation] = await client.createRouter(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = (client.innerApiCalls.createRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.createRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkCreateRouterProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkCreateRouterProgress(expectedResponse.name); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkCreateRouterProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.checkCreateRouterProgress(''), expectedError); + assert((client.operationsClient.getOperation as SinonStub) + .getCall(0)); + }); + }); + + describe('updateRouter', () => { + it('invokes updateRouter without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.UpdateRouterRequest() + ); + request.router ??= {}; + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.UpdateRouterRequest', ['router', 'name']); + request.router.name = defaultValue1; + const expectedHeaderRequestParams = `router.name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.updateRouter = stubLongRunningCall(expectedResponse); + const [operation] = await client.updateRouter(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.updateRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.updateRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes updateRouter without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.UpdateRouterRequest() + ); + request.router ??= {}; + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.UpdateRouterRequest', ['router', 'name']); + request.router.name = defaultValue1; + const expectedHeaderRequestParams = `router.name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.updateRouter = stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.updateRouter( + request, + (err?: Error|null, + result?: LROperation|null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const operation = await promise as LROperation; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.updateRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.updateRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes updateRouter with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.UpdateRouterRequest() + ); + request.router ??= {}; + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.UpdateRouterRequest', ['router', 'name']); + request.router.name = defaultValue1; + const expectedHeaderRequestParams = `router.name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.updateRouter = stubLongRunningCall(undefined, expectedError); + await assert.rejects(client.updateRouter(request), expectedError); + const actualRequest = (client.innerApiCalls.updateRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.updateRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes updateRouter with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.UpdateRouterRequest() + ); + request.router ??= {}; + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.UpdateRouterRequest', ['router', 'name']); + request.router.name = defaultValue1; + const expectedHeaderRequestParams = `router.name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.updateRouter = stubLongRunningCall(undefined, undefined, expectedError); + const [operation] = await client.updateRouter(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = (client.innerApiCalls.updateRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.updateRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkUpdateRouterProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkUpdateRouterProgress(expectedResponse.name); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkUpdateRouterProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.checkUpdateRouterProgress(''), expectedError); + assert((client.operationsClient.getOperation as SinonStub) + .getCall(0)); + }); + }); + + describe('deleteRouter', () => { + it('invokes deleteRouter without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteRouterRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteRouterRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.deleteRouter = stubLongRunningCall(expectedResponse); + const [operation] = await client.deleteRouter(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.deleteRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.deleteRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteRouter without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteRouterRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteRouterRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.deleteRouter = stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.deleteRouter( + request, + (err?: Error|null, + result?: LROperation|null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const operation = await promise as LROperation; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.deleteRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.deleteRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteRouter with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteRouterRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteRouterRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.deleteRouter = stubLongRunningCall(undefined, expectedError); + await assert.rejects(client.deleteRouter(request), expectedError); + const actualRequest = (client.innerApiCalls.deleteRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.deleteRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteRouter with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteRouterRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteRouterRequest', ['name']); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.deleteRouter = stubLongRunningCall(undefined, undefined, expectedError); + const [operation] = await client.deleteRouter(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = (client.innerApiCalls.deleteRouter as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.deleteRouter as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkDeleteRouterProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkDeleteRouterProgress(expectedResponse.name); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkDeleteRouterProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.checkDeleteRouterProgress(''), expectedError); + assert((client.operationsClient.getOperation as SinonStub) + .getCall(0)); + }); + }); + + describe('listZones', () => { + it('invokes listZones without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListZonesRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListZonesRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + ]; + client.innerApiCalls.listZones = stubSimpleCall(expectedResponse); + const [response] = await client.listZones(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.listZones as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listZones as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listZones without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListZonesRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListZonesRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + ]; + client.innerApiCalls.listZones = stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.listZones( + request, + (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IZone[]|null) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.listZones as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listZones as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listZones with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListZonesRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListZonesRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.listZones = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.listZones(request), expectedError); + const actualRequest = (client.innerApiCalls.listZones as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listZones as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listZonesStream without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListZonesRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListZonesRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + ]; + client.descriptors.page.listZones.createStream = stubPageStreamingCall(expectedResponse); + const stream = client.listZonesStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Zone[] = []; + stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Zone) => { + responses.push(response); + }); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + const responses = await promise; + assert.deepStrictEqual(responses, expectedResponse); + assert((client.descriptors.page.listZones.createStream as SinonStub) + .getCall(0).calledWith(client.innerApiCalls.listZones, request)); + assert( + (client.descriptors.page.listZones.createStream as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('invokes listZonesStream with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListZonesRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListZonesRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listZones.createStream = stubPageStreamingCall(undefined, expectedError); + const stream = client.listZonesStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Zone[] = []; + stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Zone) => { + responses.push(response); + }); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + await assert.rejects(promise, expectedError); + assert((client.descriptors.page.listZones.createStream as SinonStub) + .getCall(0).calledWith(client.innerApiCalls.listZones, request)); + assert( + (client.descriptors.page.listZones.createStream as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listZones without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListZonesRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListZonesRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + ]; + client.descriptors.page.listZones.asyncIterate = stubAsyncIterationCall(expectedResponse); + const responses: protos.google.cloud.edgenetwork.v1.IZone[] = []; + const iterable = client.listZonesAsync(request); + for await (const resource of iterable) { + responses.push(resource!); + } + assert.deepStrictEqual(responses, expectedResponse); + assert.deepStrictEqual( + (client.descriptors.page.listZones.asyncIterate as SinonStub) + .getCall(0).args[1], request); + assert( + (client.descriptors.page.listZones.asyncIterate as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listZones with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListZonesRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListZonesRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listZones.asyncIterate = stubAsyncIterationCall(undefined, expectedError); + const iterable = client.listZonesAsync(request); + await assert.rejects(async () => { + const responses: protos.google.cloud.edgenetwork.v1.IZone[] = []; + for await (const resource of iterable) { + responses.push(resource!); + } + }); + assert.deepStrictEqual( + (client.descriptors.page.listZones.asyncIterate as SinonStub) + .getCall(0).args[1], request); + assert( + (client.descriptors.page.listZones.asyncIterate as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + }); + + describe('listNetworks', () => { + it('invokes listNetworks without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListNetworksRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + ]; + client.innerApiCalls.listNetworks = stubSimpleCall(expectedResponse); + const [response] = await client.listNetworks(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.listNetworks as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listNetworks as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listNetworks without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListNetworksRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + ]; + client.innerApiCalls.listNetworks = stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.listNetworks( + request, + (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.INetwork[]|null) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.listNetworks as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listNetworks as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listNetworks with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListNetworksRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.listNetworks = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.listNetworks(request), expectedError); + const actualRequest = (client.innerApiCalls.listNetworks as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listNetworks as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listNetworksStream without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListNetworksRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + ]; + client.descriptors.page.listNetworks.createStream = stubPageStreamingCall(expectedResponse); + const stream = client.listNetworksStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Network[] = []; + stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Network) => { + responses.push(response); + }); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + const responses = await promise; + assert.deepStrictEqual(responses, expectedResponse); + assert((client.descriptors.page.listNetworks.createStream as SinonStub) + .getCall(0).calledWith(client.innerApiCalls.listNetworks, request)); + assert( + (client.descriptors.page.listNetworks.createStream as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('invokes listNetworksStream with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListNetworksRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listNetworks.createStream = stubPageStreamingCall(undefined, expectedError); + const stream = client.listNetworksStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Network[] = []; + stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Network) => { + responses.push(response); + }); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + await assert.rejects(promise, expectedError); + assert((client.descriptors.page.listNetworks.createStream as SinonStub) + .getCall(0).calledWith(client.innerApiCalls.listNetworks, request)); + assert( + (client.descriptors.page.listNetworks.createStream as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listNetworks without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListNetworksRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + ]; + client.descriptors.page.listNetworks.asyncIterate = stubAsyncIterationCall(expectedResponse); + const responses: protos.google.cloud.edgenetwork.v1.INetwork[] = []; + const iterable = client.listNetworksAsync(request); + for await (const resource of iterable) { + responses.push(resource!); + } + assert.deepStrictEqual(responses, expectedResponse); + assert.deepStrictEqual( + (client.descriptors.page.listNetworks.asyncIterate as SinonStub) + .getCall(0).args[1], request); + assert( + (client.descriptors.page.listNetworks.asyncIterate as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listNetworks with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListNetworksRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listNetworks.asyncIterate = stubAsyncIterationCall(undefined, expectedError); + const iterable = client.listNetworksAsync(request); + await assert.rejects(async () => { + const responses: protos.google.cloud.edgenetwork.v1.INetwork[] = []; + for await (const resource of iterable) { + responses.push(resource!); + } + }); + assert.deepStrictEqual( + (client.descriptors.page.listNetworks.asyncIterate as SinonStub) + .getCall(0).args[1], request); + assert( + (client.descriptors.page.listNetworks.asyncIterate as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + }); + + describe('listSubnets', () => { + it('invokes listSubnets without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListSubnetsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + ]; + client.innerApiCalls.listSubnets = stubSimpleCall(expectedResponse); + const [response] = await client.listSubnets(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.listSubnets as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listSubnets as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listSubnets without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListSubnetsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + ]; + client.innerApiCalls.listSubnets = stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.listSubnets( + request, + (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.ISubnet[]|null) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.listSubnets as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listSubnets as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listSubnets with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListSubnetsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.listSubnets = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.listSubnets(request), expectedError); + const actualRequest = (client.innerApiCalls.listSubnets as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listSubnets as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listSubnetsStream without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListSubnetsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + ]; + client.descriptors.page.listSubnets.createStream = stubPageStreamingCall(expectedResponse); + const stream = client.listSubnetsStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Subnet[] = []; + stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Subnet) => { + responses.push(response); + }); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + const responses = await promise; + assert.deepStrictEqual(responses, expectedResponse); + assert((client.descriptors.page.listSubnets.createStream as SinonStub) + .getCall(0).calledWith(client.innerApiCalls.listSubnets, request)); + assert( + (client.descriptors.page.listSubnets.createStream as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('invokes listSubnetsStream with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListSubnetsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listSubnets.createStream = stubPageStreamingCall(undefined, expectedError); + const stream = client.listSubnetsStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Subnet[] = []; + stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Subnet) => { + responses.push(response); + }); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + await assert.rejects(promise, expectedError); + assert((client.descriptors.page.listSubnets.createStream as SinonStub) + .getCall(0).calledWith(client.innerApiCalls.listSubnets, request)); + assert( + (client.descriptors.page.listSubnets.createStream as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listSubnets without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListSubnetsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + ]; + client.descriptors.page.listSubnets.asyncIterate = stubAsyncIterationCall(expectedResponse); + const responses: protos.google.cloud.edgenetwork.v1.ISubnet[] = []; + const iterable = client.listSubnetsAsync(request); + for await (const resource of iterable) { + responses.push(resource!); + } + assert.deepStrictEqual(responses, expectedResponse); + assert.deepStrictEqual( + (client.descriptors.page.listSubnets.asyncIterate as SinonStub) + .getCall(0).args[1], request); + assert( + (client.descriptors.page.listSubnets.asyncIterate as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listSubnets with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListSubnetsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listSubnets.asyncIterate = stubAsyncIterationCall(undefined, expectedError); + const iterable = client.listSubnetsAsync(request); + await assert.rejects(async () => { + const responses: protos.google.cloud.edgenetwork.v1.ISubnet[] = []; + for await (const resource of iterable) { + responses.push(resource!); + } + }); + assert.deepStrictEqual( + (client.descriptors.page.listSubnets.asyncIterate as SinonStub) + .getCall(0).args[1], request); + assert( + (client.descriptors.page.listSubnets.asyncIterate as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + }); + + describe('listInterconnects', () => { + it('invokes listInterconnects without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), + ]; + client.innerApiCalls.listInterconnects = stubSimpleCall(expectedResponse); + const [response] = await client.listInterconnects(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.listInterconnects as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listInterconnects as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listInterconnects without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), + ]; + client.innerApiCalls.listInterconnects = stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.listInterconnects( + request, + (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IInterconnect[]|null) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.listInterconnects as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listInterconnects as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listInterconnects with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.listInterconnects = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.listInterconnects(request), expectedError); + const actualRequest = (client.innerApiCalls.listInterconnects as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listInterconnects as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listInterconnectsStream without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), + ]; + client.descriptors.page.listInterconnects.createStream = stubPageStreamingCall(expectedResponse); + const stream = client.listInterconnectsStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Interconnect[] = []; + stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Interconnect) => { + responses.push(response); + }); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + const responses = await promise; + assert.deepStrictEqual(responses, expectedResponse); + assert((client.descriptors.page.listInterconnects.createStream as SinonStub) + .getCall(0).calledWith(client.innerApiCalls.listInterconnects, request)); + assert( + (client.descriptors.page.listInterconnects.createStream as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('invokes listInterconnectsStream with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listInterconnects.createStream = stubPageStreamingCall(undefined, expectedError); + const stream = client.listInterconnectsStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Interconnect[] = []; + stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Interconnect) => { + responses.push(response); + }); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + await assert.rejects(promise, expectedError); + assert((client.descriptors.page.listInterconnects.createStream as SinonStub) + .getCall(0).calledWith(client.innerApiCalls.listInterconnects, request)); + assert( + (client.descriptors.page.listInterconnects.createStream as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listInterconnects without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), + ]; + client.descriptors.page.listInterconnects.asyncIterate = stubAsyncIterationCall(expectedResponse); + const responses: protos.google.cloud.edgenetwork.v1.IInterconnect[] = []; + const iterable = client.listInterconnectsAsync(request); + for await (const resource of iterable) { + responses.push(resource!); + } + assert.deepStrictEqual(responses, expectedResponse); + assert.deepStrictEqual( + (client.descriptors.page.listInterconnects.asyncIterate as SinonStub) + .getCall(0).args[1], request); + assert( + (client.descriptors.page.listInterconnects.asyncIterate as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listInterconnects with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listInterconnects.asyncIterate = stubAsyncIterationCall(undefined, expectedError); + const iterable = client.listInterconnectsAsync(request); + await assert.rejects(async () => { + const responses: protos.google.cloud.edgenetwork.v1.IInterconnect[] = []; + for await (const resource of iterable) { + responses.push(resource!); + } + }); + assert.deepStrictEqual( + (client.descriptors.page.listInterconnects.asyncIterate as SinonStub) + .getCall(0).args[1], request); + assert( + (client.descriptors.page.listInterconnects.asyncIterate as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + }); + + describe('listInterconnectAttachments', () => { + it('invokes listInterconnectAttachments without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), + ]; + client.innerApiCalls.listInterconnectAttachments = stubSimpleCall(expectedResponse); + const [response] = await client.listInterconnectAttachments(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.listInterconnectAttachments as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listInterconnectAttachments as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listInterconnectAttachments without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), + ]; + client.innerApiCalls.listInterconnectAttachments = stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.listInterconnectAttachments( + request, + (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IInterconnectAttachment[]|null) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.listInterconnectAttachments as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listInterconnectAttachments as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listInterconnectAttachments with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.listInterconnectAttachments = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.listInterconnectAttachments(request), expectedError); + const actualRequest = (client.innerApiCalls.listInterconnectAttachments as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listInterconnectAttachments as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listInterconnectAttachmentsStream without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), + ]; + client.descriptors.page.listInterconnectAttachments.createStream = stubPageStreamingCall(expectedResponse); + const stream = client.listInterconnectAttachmentsStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.InterconnectAttachment[] = []; + stream.on('data', (response: protos.google.cloud.edgenetwork.v1.InterconnectAttachment) => { + responses.push(response); + }); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + const responses = await promise; + assert.deepStrictEqual(responses, expectedResponse); + assert((client.descriptors.page.listInterconnectAttachments.createStream as SinonStub) + .getCall(0).calledWith(client.innerApiCalls.listInterconnectAttachments, request)); + assert( + (client.descriptors.page.listInterconnectAttachments.createStream as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('invokes listInterconnectAttachmentsStream with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listInterconnectAttachments.createStream = stubPageStreamingCall(undefined, expectedError); + const stream = client.listInterconnectAttachmentsStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.InterconnectAttachment[] = []; + stream.on('data', (response: protos.google.cloud.edgenetwork.v1.InterconnectAttachment) => { + responses.push(response); + }); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + await assert.rejects(promise, expectedError); + assert((client.descriptors.page.listInterconnectAttachments.createStream as SinonStub) + .getCall(0).calledWith(client.innerApiCalls.listInterconnectAttachments, request)); + assert( + (client.descriptors.page.listInterconnectAttachments.createStream as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listInterconnectAttachments without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), + ]; + client.descriptors.page.listInterconnectAttachments.asyncIterate = stubAsyncIterationCall(expectedResponse); + const responses: protos.google.cloud.edgenetwork.v1.IInterconnectAttachment[] = []; + const iterable = client.listInterconnectAttachmentsAsync(request); + for await (const resource of iterable) { + responses.push(resource!); + } + assert.deepStrictEqual(responses, expectedResponse); + assert.deepStrictEqual( + (client.descriptors.page.listInterconnectAttachments.asyncIterate as SinonStub) + .getCall(0).args[1], request); + assert( + (client.descriptors.page.listInterconnectAttachments.asyncIterate as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listInterconnectAttachments with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listInterconnectAttachments.asyncIterate = stubAsyncIterationCall(undefined, expectedError); + const iterable = client.listInterconnectAttachmentsAsync(request); + await assert.rejects(async () => { + const responses: protos.google.cloud.edgenetwork.v1.IInterconnectAttachment[] = []; + for await (const resource of iterable) { + responses.push(resource!); + } + }); + assert.deepStrictEqual( + (client.descriptors.page.listInterconnectAttachments.asyncIterate as SinonStub) + .getCall(0).args[1], request); + assert( + (client.descriptors.page.listInterconnectAttachments.asyncIterate as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + }); + + describe('listRouters', () => { + it('invokes listRouters without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListRoutersRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + ]; + client.innerApiCalls.listRouters = stubSimpleCall(expectedResponse); + const [response] = await client.listRouters(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.listRouters as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listRouters as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listRouters without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListRoutersRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + ]; + client.innerApiCalls.listRouters = stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.listRouters( + request, + (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IRouter[]|null) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.listRouters as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listRouters as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listRouters with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListRoutersRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.listRouters = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.listRouters(request), expectedError); + const actualRequest = (client.innerApiCalls.listRouters as SinonStub) + .getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = (client.innerApiCalls.listRouters as SinonStub) + .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listRoutersStream without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListRoutersRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + ]; + client.descriptors.page.listRouters.createStream = stubPageStreamingCall(expectedResponse); + const stream = client.listRoutersStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Router[] = []; + stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Router) => { + responses.push(response); + }); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + const responses = await promise; + assert.deepStrictEqual(responses, expectedResponse); + assert((client.descriptors.page.listRouters.createStream as SinonStub) + .getCall(0).calledWith(client.innerApiCalls.listRouters, request)); + assert( + (client.descriptors.page.listRouters.createStream as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('invokes listRoutersStream with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListRoutersRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listRouters.createStream = stubPageStreamingCall(undefined, expectedError); + const stream = client.listRoutersStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Router[] = []; + stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Router) => { + responses.push(response); + }); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + await assert.rejects(promise, expectedError); + assert((client.descriptors.page.listRouters.createStream as SinonStub) + .getCall(0).calledWith(client.innerApiCalls.listRouters, request)); + assert( + (client.descriptors.page.listRouters.createStream as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listRouters without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListRoutersRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + ]; + client.descriptors.page.listRouters.asyncIterate = stubAsyncIterationCall(expectedResponse); + const responses: protos.google.cloud.edgenetwork.v1.IRouter[] = []; + const iterable = client.listRoutersAsync(request); + for await (const resource of iterable) { + responses.push(resource!); + } + assert.deepStrictEqual(responses, expectedResponse); + assert.deepStrictEqual( + (client.descriptors.page.listRouters.asyncIterate as SinonStub) + .getCall(0).args[1], request); + assert( + (client.descriptors.page.listRouters.asyncIterate as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listRouters with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() + ); + const defaultValue1 = + getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListRoutersRequest', ['parent']); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listRouters.asyncIterate = stubAsyncIterationCall(undefined, expectedError); + const iterable = client.listRoutersAsync(request); + await assert.rejects(async () => { + const responses: protos.google.cloud.edgenetwork.v1.IRouter[] = []; + for await (const resource of iterable) { + responses.push(resource!); + } + }); + assert.deepStrictEqual( + (client.descriptors.page.listRouters.asyncIterate as SinonStub) + .getCall(0).args[1], request); + assert( + (client.descriptors.page.listRouters.asyncIterate as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + }); + describe('getLocation', () => { + it('invokes getLocation without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new LocationProtos.google.cloud.location.GetLocationRequest() + ); + request.name = ''; + const expectedHeaderRequestParams = 'name='; + const expectedOptions = { + otherArgs: { + headers: { + 'x-goog-request-params': expectedHeaderRequestParams, + }, + }, + }; + const expectedResponse = generateSampleMessage( + new LocationProtos.google.cloud.location.Location() + ); + client.locationsClient.getLocation = stubSimpleCall(expectedResponse); + const response = await client.getLocation(request, expectedOptions); + assert.deepStrictEqual(response, [expectedResponse]); + assert((client.locationsClient.getLocation as SinonStub) + .getCall(0).calledWith(request, expectedOptions, undefined)); + }); + it('invokes getLocation without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new LocationProtos.google.cloud.location.GetLocationRequest() + ); + request.name = ''; + const expectedHeaderRequestParams = 'name='; + const expectedOptions = { + otherArgs: { + headers: { + 'x-goog-request-params': expectedHeaderRequestParams, + }, + }, + }; + const expectedResponse = generateSampleMessage( + new LocationProtos.google.cloud.location.Location() + ); + client.locationsClient.getLocation = sinon.stub().callsArgWith(2, null, expectedResponse); + const promise = new Promise((resolve, reject) => { + client.getLocation( + request, + expectedOptions, + ( + err?: Error | null, + result?: LocationProtos.google.cloud.location.ILocation | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + assert((client.locationsClient.getLocation as SinonStub) + .getCall(0)); + }); + it('invokes getLocation with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new LocationProtos.google.cloud.location.GetLocationRequest() + ); + request.name = ''; + const expectedHeaderRequestParams = 'name='; + const expectedOptions = { + otherArgs: { + headers: { + 'x-goog-request-params': expectedHeaderRequestParams, + }, + }, + }; + const expectedError = new Error('expected'); + client.locationsClient.getLocation = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.getLocation(request, expectedOptions), expectedError); + assert((client.locationsClient.getLocation as SinonStub) + .getCall(0).calledWith(request, expectedOptions, undefined)); + }); + }); + describe('listLocationsAsync', () => { + it('uses async iteration with listLocations without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new LocationProtos.google.cloud.location.ListLocationsRequest() + ); + request.name = ''; + const expectedHeaderRequestParams = 'name='; + const expectedResponse = [ + generateSampleMessage( + new LocationProtos.google.cloud.location.Location() + ), + generateSampleMessage( + new LocationProtos.google.cloud.location.Location() + ), + generateSampleMessage( + new LocationProtos.google.cloud.location.Location() + ), + ]; + client.locationsClient.descriptors.page.listLocations.asyncIterate = stubAsyncIterationCall(expectedResponse); + const responses: LocationProtos.google.cloud.location.ILocation[] = []; + const iterable = client.listLocationsAsync(request); + for await (const resource of iterable) { + responses.push(resource!); + } + assert.deepStrictEqual(responses, expectedResponse); + assert.deepStrictEqual( + (client.locationsClient.descriptors.page.listLocations.asyncIterate as SinonStub) + .getCall(0).args[1], request); + assert( + (client.locationsClient.descriptors.page.listLocations.asyncIterate as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + it('uses async iteration with listLocations with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new LocationProtos.google.cloud.location.ListLocationsRequest() + ); + request.name = ''; + const expectedHeaderRequestParams = 'name='; + const expectedError = new Error('expected'); + client.locationsClient.descriptors.page.listLocations.asyncIterate = stubAsyncIterationCall(undefined, expectedError); + const iterable = client.listLocationsAsync(request); + await assert.rejects(async () => { + const responses: LocationProtos.google.cloud.location.ILocation[] = []; + for await (const resource of iterable) { + responses.push(resource!); + } + }); + assert.deepStrictEqual( + (client.locationsClient.descriptors.page.listLocations.asyncIterate as SinonStub) + .getCall(0).args[1], request); + assert( + (client.locationsClient.descriptors.page.listLocations.asyncIterate as SinonStub) + .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + }); + describe('getOperation', () => { + it('invokes getOperation without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.GetOperationRequest() + ); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const response = await client.getOperation(request); + assert.deepStrictEqual(response, [expectedResponse]); + assert((client.operationsClient.getOperation as SinonStub) + .getCall(0).calledWith(request) + ); + }); + it('invokes getOperation without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.GetOperationRequest() + ); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + client.operationsClient.getOperation = sinon.stub().callsArgWith(2, null, expectedResponse); + const promise = new Promise((resolve, reject) => { + client.operationsClient.getOperation( + request, + undefined, + ( + err?: Error | null, + result?: operationsProtos.google.longrunning.Operation | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + assert((client.operationsClient.getOperation as SinonStub) + .getCall(0)); + }); + it('invokes getOperation with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.GetOperationRequest() + ); + const expectedError = new Error('expected'); + client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); + await assert.rejects(async () => {await client.getOperation(request)}, expectedError); + assert((client.operationsClient.getOperation as SinonStub) + .getCall(0).calledWith(request)); + }); + }); + describe('cancelOperation', () => { + it('invokes cancelOperation without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.CancelOperationRequest() + ); + const expectedResponse = generateSampleMessage( + new protos.google.protobuf.Empty() + ); + client.operationsClient.cancelOperation = stubSimpleCall(expectedResponse); + const response = await client.cancelOperation(request); + assert.deepStrictEqual(response, [expectedResponse]); + assert((client.operationsClient.cancelOperation as SinonStub) + .getCall(0).calledWith(request) + ); + }); + it('invokes cancelOperation without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.CancelOperationRequest() + ); + const expectedResponse = generateSampleMessage( + new protos.google.protobuf.Empty() + ); + client.operationsClient.cancelOperation = sinon.stub().callsArgWith(2, null, expectedResponse); + const promise = new Promise((resolve, reject) => { + client.operationsClient.cancelOperation( + request, + undefined, + ( + err?: Error | null, + result?: protos.google.protobuf.Empty | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + assert((client.operationsClient.cancelOperation as SinonStub) + .getCall(0)); + }); + it('invokes cancelOperation with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.CancelOperationRequest() + ); + const expectedError = new Error('expected'); + client.operationsClient.cancelOperation = stubSimpleCall(undefined, expectedError); + await assert.rejects(async () => {await client.cancelOperation(request)}, expectedError); + assert((client.operationsClient.cancelOperation as SinonStub) + .getCall(0).calledWith(request)); + }); + }); + describe('deleteOperation', () => { + it('invokes deleteOperation without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.DeleteOperationRequest() + ); + const expectedResponse = generateSampleMessage( + new protos.google.protobuf.Empty() + ); + client.operationsClient.deleteOperation = stubSimpleCall(expectedResponse); + const response = await client.deleteOperation(request); + assert.deepStrictEqual(response, [expectedResponse]); + assert((client.operationsClient.deleteOperation as SinonStub) + .getCall(0).calledWith(request) + ); + }); + it('invokes deleteOperation without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.DeleteOperationRequest() + ); + const expectedResponse = generateSampleMessage( + new protos.google.protobuf.Empty() + ); + client.operationsClient.deleteOperation = sinon.stub().callsArgWith(2, null, expectedResponse); + const promise = new Promise((resolve, reject) => { + client.operationsClient.deleteOperation( + request, + undefined, + ( + err?: Error | null, + result?: protos.google.protobuf.Empty | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + }); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + assert((client.operationsClient.deleteOperation as SinonStub) + .getCall(0)); + }); + it('invokes deleteOperation with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.DeleteOperationRequest() + ); + const expectedError = new Error('expected'); + client.operationsClient.deleteOperation = stubSimpleCall(undefined, expectedError); + await assert.rejects(async () => {await client.deleteOperation(request)}, expectedError); + assert((client.operationsClient.deleteOperation as SinonStub) + .getCall(0).calledWith(request)); + }); + }); + describe('listOperationsAsync', () => { + it('uses async iteration with listOperations without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.ListOperationsRequest() + ); + const expectedResponse = [ + generateSampleMessage( + new operationsProtos.google.longrunning.ListOperationsResponse() + ), + generateSampleMessage( + new operationsProtos.google.longrunning.ListOperationsResponse() + ), + generateSampleMessage( + new operationsProtos.google.longrunning.ListOperationsResponse() + ), + ]; + client.operationsClient.descriptor.listOperations.asyncIterate = stubAsyncIterationCall(expectedResponse); + const responses: operationsProtos.google.longrunning.ListOperationsResponse[] = []; + const iterable = client.operationsClient.listOperationsAsync(request); + for await (const resource of iterable) { + responses.push(resource!); + } + assert.deepStrictEqual(responses, expectedResponse); + assert.deepStrictEqual( + (client.operationsClient.descriptor.listOperations.asyncIterate as SinonStub) + .getCall(0).args[1], request); + }); + it('uses async iteration with listOperations with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.ListOperationsRequest() + ); + const expectedError = new Error('expected'); + client.operationsClient.descriptor.listOperations.asyncIterate = stubAsyncIterationCall(undefined, expectedError); + const iterable = client.operationsClient.listOperationsAsync(request); + await assert.rejects(async () => { + const responses: operationsProtos.google.longrunning.ListOperationsResponse[] = []; + for await (const resource of iterable) { + responses.push(resource!); + } + }); + assert.deepStrictEqual( + (client.operationsClient.descriptor.listOperations.asyncIterate as SinonStub) + .getCall(0).args[1], request); + }); + }); + + describe('Path templates', () => { + + describe('interconnect', () => { + const fakePath = "/rendered/path/interconnect"; + const expectedParameters = { + project: "projectValue", + location: "locationValue", + zone: "zoneValue", + interconnect: "interconnectValue", + }; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + client.pathTemplates.interconnectPathTemplate.render = + sinon.stub().returns(fakePath); + client.pathTemplates.interconnectPathTemplate.match = + sinon.stub().returns(expectedParameters); + + it('interconnectPath', () => { + const result = client.interconnectPath("projectValue", "locationValue", "zoneValue", "interconnectValue"); + assert.strictEqual(result, fakePath); + assert((client.pathTemplates.interconnectPathTemplate.render as SinonStub) + .getCall(-1).calledWith(expectedParameters)); + }); + + it('matchProjectFromInterconnectName', () => { + const result = client.matchProjectFromInterconnectName(fakePath); + assert.strictEqual(result, "projectValue"); + assert((client.pathTemplates.interconnectPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchLocationFromInterconnectName', () => { + const result = client.matchLocationFromInterconnectName(fakePath); + assert.strictEqual(result, "locationValue"); + assert((client.pathTemplates.interconnectPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchZoneFromInterconnectName', () => { + const result = client.matchZoneFromInterconnectName(fakePath); + assert.strictEqual(result, "zoneValue"); + assert((client.pathTemplates.interconnectPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchInterconnectFromInterconnectName', () => { + const result = client.matchInterconnectFromInterconnectName(fakePath); + assert.strictEqual(result, "interconnectValue"); + assert((client.pathTemplates.interconnectPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + }); + + describe('interconnectAttachment', () => { + const fakePath = "/rendered/path/interconnectAttachment"; + const expectedParameters = { + project: "projectValue", + location: "locationValue", + zone: "zoneValue", + interconnect_attachment: "interconnectAttachmentValue", + }; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + client.pathTemplates.interconnectAttachmentPathTemplate.render = + sinon.stub().returns(fakePath); + client.pathTemplates.interconnectAttachmentPathTemplate.match = + sinon.stub().returns(expectedParameters); + + it('interconnectAttachmentPath', () => { + const result = client.interconnectAttachmentPath("projectValue", "locationValue", "zoneValue", "interconnectAttachmentValue"); + assert.strictEqual(result, fakePath); + assert((client.pathTemplates.interconnectAttachmentPathTemplate.render as SinonStub) + .getCall(-1).calledWith(expectedParameters)); + }); + + it('matchProjectFromInterconnectAttachmentName', () => { + const result = client.matchProjectFromInterconnectAttachmentName(fakePath); + assert.strictEqual(result, "projectValue"); + assert((client.pathTemplates.interconnectAttachmentPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchLocationFromInterconnectAttachmentName', () => { + const result = client.matchLocationFromInterconnectAttachmentName(fakePath); + assert.strictEqual(result, "locationValue"); + assert((client.pathTemplates.interconnectAttachmentPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchZoneFromInterconnectAttachmentName', () => { + const result = client.matchZoneFromInterconnectAttachmentName(fakePath); + assert.strictEqual(result, "zoneValue"); + assert((client.pathTemplates.interconnectAttachmentPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchInterconnectAttachmentFromInterconnectAttachmentName', () => { + const result = client.matchInterconnectAttachmentFromInterconnectAttachmentName(fakePath); + assert.strictEqual(result, "interconnectAttachmentValue"); + assert((client.pathTemplates.interconnectAttachmentPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + }); + + describe('location', () => { + const fakePath = "/rendered/path/location"; + const expectedParameters = { + project: "projectValue", + location: "locationValue", + }; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + client.pathTemplates.locationPathTemplate.render = + sinon.stub().returns(fakePath); + client.pathTemplates.locationPathTemplate.match = + sinon.stub().returns(expectedParameters); + + it('locationPath', () => { + const result = client.locationPath("projectValue", "locationValue"); + assert.strictEqual(result, fakePath); + assert((client.pathTemplates.locationPathTemplate.render as SinonStub) + .getCall(-1).calledWith(expectedParameters)); + }); + + it('matchProjectFromLocationName', () => { + const result = client.matchProjectFromLocationName(fakePath); + assert.strictEqual(result, "projectValue"); + assert((client.pathTemplates.locationPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchLocationFromLocationName', () => { + const result = client.matchLocationFromLocationName(fakePath); + assert.strictEqual(result, "locationValue"); + assert((client.pathTemplates.locationPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + }); + + describe('network', () => { + const fakePath = "/rendered/path/network"; + const expectedParameters = { + project: "projectValue", + location: "locationValue", + zone: "zoneValue", + network: "networkValue", + }; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + client.pathTemplates.networkPathTemplate.render = + sinon.stub().returns(fakePath); + client.pathTemplates.networkPathTemplate.match = + sinon.stub().returns(expectedParameters); + + it('networkPath', () => { + const result = client.networkPath("projectValue", "locationValue", "zoneValue", "networkValue"); + assert.strictEqual(result, fakePath); + assert((client.pathTemplates.networkPathTemplate.render as SinonStub) + .getCall(-1).calledWith(expectedParameters)); + }); + + it('matchProjectFromNetworkName', () => { + const result = client.matchProjectFromNetworkName(fakePath); + assert.strictEqual(result, "projectValue"); + assert((client.pathTemplates.networkPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchLocationFromNetworkName', () => { + const result = client.matchLocationFromNetworkName(fakePath); + assert.strictEqual(result, "locationValue"); + assert((client.pathTemplates.networkPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchZoneFromNetworkName', () => { + const result = client.matchZoneFromNetworkName(fakePath); + assert.strictEqual(result, "zoneValue"); + assert((client.pathTemplates.networkPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchNetworkFromNetworkName', () => { + const result = client.matchNetworkFromNetworkName(fakePath); + assert.strictEqual(result, "networkValue"); + assert((client.pathTemplates.networkPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + }); + + describe('project', () => { + const fakePath = "/rendered/path/project"; + const expectedParameters = { + project: "projectValue", + }; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + client.pathTemplates.projectPathTemplate.render = + sinon.stub().returns(fakePath); + client.pathTemplates.projectPathTemplate.match = + sinon.stub().returns(expectedParameters); + + it('projectPath', () => { + const result = client.projectPath("projectValue"); + assert.strictEqual(result, fakePath); + assert((client.pathTemplates.projectPathTemplate.render as SinonStub) + .getCall(-1).calledWith(expectedParameters)); + }); + + it('matchProjectFromProjectName', () => { + const result = client.matchProjectFromProjectName(fakePath); + assert.strictEqual(result, "projectValue"); + assert((client.pathTemplates.projectPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + }); + + describe('router', () => { + const fakePath = "/rendered/path/router"; + const expectedParameters = { + project: "projectValue", + location: "locationValue", + zone: "zoneValue", + router: "routerValue", + }; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + client.pathTemplates.routerPathTemplate.render = + sinon.stub().returns(fakePath); + client.pathTemplates.routerPathTemplate.match = + sinon.stub().returns(expectedParameters); + + it('routerPath', () => { + const result = client.routerPath("projectValue", "locationValue", "zoneValue", "routerValue"); + assert.strictEqual(result, fakePath); + assert((client.pathTemplates.routerPathTemplate.render as SinonStub) + .getCall(-1).calledWith(expectedParameters)); + }); + + it('matchProjectFromRouterName', () => { + const result = client.matchProjectFromRouterName(fakePath); + assert.strictEqual(result, "projectValue"); + assert((client.pathTemplates.routerPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchLocationFromRouterName', () => { + const result = client.matchLocationFromRouterName(fakePath); + assert.strictEqual(result, "locationValue"); + assert((client.pathTemplates.routerPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchZoneFromRouterName', () => { + const result = client.matchZoneFromRouterName(fakePath); + assert.strictEqual(result, "zoneValue"); + assert((client.pathTemplates.routerPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchRouterFromRouterName', () => { + const result = client.matchRouterFromRouterName(fakePath); + assert.strictEqual(result, "routerValue"); + assert((client.pathTemplates.routerPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + }); + + describe('subnet', () => { + const fakePath = "/rendered/path/subnet"; + const expectedParameters = { + project: "projectValue", + location: "locationValue", + zone: "zoneValue", + subnet: "subnetValue", + }; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + client.pathTemplates.subnetPathTemplate.render = + sinon.stub().returns(fakePath); + client.pathTemplates.subnetPathTemplate.match = + sinon.stub().returns(expectedParameters); + + it('subnetPath', () => { + const result = client.subnetPath("projectValue", "locationValue", "zoneValue", "subnetValue"); + assert.strictEqual(result, fakePath); + assert((client.pathTemplates.subnetPathTemplate.render as SinonStub) + .getCall(-1).calledWith(expectedParameters)); + }); + + it('matchProjectFromSubnetName', () => { + const result = client.matchProjectFromSubnetName(fakePath); + assert.strictEqual(result, "projectValue"); + assert((client.pathTemplates.subnetPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchLocationFromSubnetName', () => { + const result = client.matchLocationFromSubnetName(fakePath); + assert.strictEqual(result, "locationValue"); + assert((client.pathTemplates.subnetPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchZoneFromSubnetName', () => { + const result = client.matchZoneFromSubnetName(fakePath); + assert.strictEqual(result, "zoneValue"); + assert((client.pathTemplates.subnetPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchSubnetFromSubnetName', () => { + const result = client.matchSubnetFromSubnetName(fakePath); + assert.strictEqual(result, "subnetValue"); + assert((client.pathTemplates.subnetPathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + }); + + describe('zone', () => { + const fakePath = "/rendered/path/zone"; + const expectedParameters = { + project: "projectValue", + location: "locationValue", + zone: "zoneValue", + }; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + client.pathTemplates.zonePathTemplate.render = + sinon.stub().returns(fakePath); + client.pathTemplates.zonePathTemplate.match = + sinon.stub().returns(expectedParameters); + + it('zonePath', () => { + const result = client.zonePath("projectValue", "locationValue", "zoneValue"); + assert.strictEqual(result, fakePath); + assert((client.pathTemplates.zonePathTemplate.render as SinonStub) + .getCall(-1).calledWith(expectedParameters)); + }); + + it('matchProjectFromZoneName', () => { + const result = client.matchProjectFromZoneName(fakePath); + assert.strictEqual(result, "projectValue"); + assert((client.pathTemplates.zonePathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchLocationFromZoneName', () => { + const result = client.matchLocationFromZoneName(fakePath); + assert.strictEqual(result, "locationValue"); + assert((client.pathTemplates.zonePathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + + it('matchZoneFromZoneName', () => { + const result = client.matchZoneFromZoneName(fakePath); + assert.strictEqual(result, "zoneValue"); + assert((client.pathTemplates.zonePathTemplate.match as SinonStub) + .getCall(-1).calledWith(fakePath)); + }); + }); + }); +}); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/tsconfig.json b/owl-bot-staging/google-cloud-edgenetwork/v1/tsconfig.json new file mode 100644 index 000000000000..c78f1c884ef6 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/tsconfig.json @@ -0,0 +1,19 @@ +{ + "extends": "./node_modules/gts/tsconfig-google.json", + "compilerOptions": { + "rootDir": ".", + "outDir": "build", + "resolveJsonModule": true, + "lib": [ + "es2018", + "dom" + ] + }, + "include": [ + "src/*.ts", + "src/**/*.ts", + "test/*.ts", + "test/**/*.ts", + "system-test/*.ts" + ] +} diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/webpack.config.js b/owl-bot-staging/google-cloud-edgenetwork/v1/webpack.config.js new file mode 100644 index 000000000000..7c40e326dca7 --- /dev/null +++ b/owl-bot-staging/google-cloud-edgenetwork/v1/webpack.config.js @@ -0,0 +1,64 @@ +// Copyright 2021 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +const path = require('path'); + +module.exports = { + entry: './src/index.ts', + output: { + library: 'EdgeNetwork', + filename: './edge-network.js', + }, + node: { + child_process: 'empty', + fs: 'empty', + crypto: 'empty', + }, + resolve: { + alias: { + '../../../package.json': path.resolve(__dirname, 'package.json'), + }, + extensions: ['.js', '.json', '.ts'], + }, + module: { + rules: [ + { + test: /\.tsx?$/, + use: 'ts-loader', + exclude: /node_modules/ + }, + { + test: /node_modules[\\/]@grpc[\\/]grpc-js/, + use: 'null-loader' + }, + { + test: /node_modules[\\/]grpc/, + use: 'null-loader' + }, + { + test: /node_modules[\\/]retry-request/, + use: 'null-loader' + }, + { + test: /node_modules[\\/]https?-proxy-agent/, + use: 'null-loader' + }, + { + test: /node_modules[\\/]gtoken/, + use: 'null-loader' + }, + ], + }, + mode: 'production', +}; From f80128cc4f3e09fafb2e72b58cc7d8fcf38c467d Mon Sep 17 00:00:00 2001 From: Owl Bot Date: Thu, 9 Nov 2023 22:26:33 +0000 Subject: [PATCH 4/7] =?UTF-8?q?=F0=9F=A6=89=20Updates=20from=20OwlBot=20po?= =?UTF-8?q?st-processor?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit See https://github.com/googleapis/repo-automation-bots/blob/main/packages/owl-bot/README.md --- .../google-cloud-edgenetwork/v1/README.md | 1 - .../google-cloud-edgenetwork/v1/package.json | 58 - ..._metadata_google.cloud.edgenetwork.v1.json | 1231 - .../v1/src/v1/edge_network_client.ts | 4016 -- .../v1/test/gapic_edge_network_v1.ts | 5119 --- .../google-cloud-edgenetwork}/.eslintignore | 4 +- .../google-cloud-edgenetwork}/.eslintrc.json | 0 .../google-cloud-edgenetwork/.gitattributes | 4 + .../google-cloud-edgenetwork}/.gitignore | 0 .../google-cloud-edgenetwork}/.jsdoc.js | 0 .../google-cloud-edgenetwork}/.mocharc.js | 10 +- packages/google-cloud-edgenetwork/.nycrc | 24 + .../google-cloud-edgenetwork/.prettierignore | 6 + .../google-cloud-edgenetwork}/.prettierrc.js | 7 +- .../CODE_OF_CONDUCT.md | 94 + .../google-cloud-edgenetwork/CONTRIBUTING.md | 76 + packages/google-cloud-edgenetwork/README.md | 214 + .../cloud/edgenetwork/v1/resources.proto | 0 .../google/cloud/edgenetwork/v1/service.proto | 0 .../protos/protos.d.ts | 14182 ++++++ .../google-cloud-edgenetwork/protos/protos.js | 36000 ++++++++++++++++ .../protos/protos.json | 3814 ++ .../samples/README.md | 518 + ..._network.create_interconnect_attachment.js | 0 .../v1/edge_network.create_network.js | 0 .../v1/edge_network.create_router.js | 0 .../v1/edge_network.create_subnet.js | 0 ..._network.delete_interconnect_attachment.js | 0 .../v1/edge_network.delete_network.js | 0 .../v1/edge_network.delete_router.js | 0 .../v1/edge_network.delete_subnet.js | 0 .../v1/edge_network.diagnose_interconnect.js | 0 .../v1/edge_network.diagnose_network.js | 0 .../v1/edge_network.diagnose_router.js | 0 .../v1/edge_network.get_interconnect.js | 0 ...dge_network.get_interconnect_attachment.js | 0 .../generated/v1/edge_network.get_network.js | 0 .../generated/v1/edge_network.get_router.js | 0 .../generated/v1/edge_network.get_subnet.js | 0 .../generated/v1/edge_network.get_zone.js | 0 .../v1/edge_network.initialize_zone.js | 0 ...e_network.list_interconnect_attachments.js | 0 .../v1/edge_network.list_interconnects.js | 0 .../v1/edge_network.list_networks.js | 0 .../generated/v1/edge_network.list_routers.js | 0 .../generated/v1/edge_network.list_subnets.js | 0 .../generated/v1/edge_network.list_zones.js | 0 .../v1/edge_network.update_router.js | 0 .../v1/edge_network.update_subnet.js | 0 ..._metadata_google.cloud.edgenetwork.v1.json | 1231 + .../samples/quickstart.js | 78 + .../samples/test/quickstart.js | 7 +- .../google-cloud-edgenetwork}/src/index.ts | 8 +- .../src/v1/edge_network_client.ts | 4944 +++ .../src/v1/edge_network_client_config.json | 0 .../src/v1/edge_network_proto_list.json | 0 .../src/v1/gapic_metadata.json | 0 .../google-cloud-edgenetwork}/src/v1/index.ts | 0 .../system-test/fixtures/sample/src/index.js | 1 - .../system-test/fixtures/sample/src/index.ts | 0 .../system-test/install.ts | 18 +- .../test/gapic_edge_network_v1.ts | 6449 +++ .../google-cloud-edgenetwork}/tsconfig.json | 0 .../webpack.config.js | 12 +- release-please-config.json | 3 +- 65 files changed, 67668 insertions(+), 10461 deletions(-) delete mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/README.md delete mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/package.json delete mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/snippet_metadata_google.cloud.edgenetwork.v1.json delete mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_client.ts delete mode 100644 owl-bot-staging/google-cloud-edgenetwork/v1/test/gapic_edge_network_v1.ts rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/.eslintignore (68%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/.eslintrc.json (100%) create mode 100644 packages/google-cloud-edgenetwork/.gitattributes rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/.gitignore (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/.jsdoc.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/.mocharc.js (77%) create mode 100644 packages/google-cloud-edgenetwork/.nycrc create mode 100644 packages/google-cloud-edgenetwork/.prettierignore rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/.prettierrc.js (70%) create mode 100644 packages/google-cloud-edgenetwork/CODE_OF_CONDUCT.md create mode 100644 packages/google-cloud-edgenetwork/CONTRIBUTING.md create mode 100644 packages/google-cloud-edgenetwork/README.md rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/protos/google/cloud/edgenetwork/v1/resources.proto (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/protos/google/cloud/edgenetwork/v1/service.proto (100%) create mode 100644 packages/google-cloud-edgenetwork/protos/protos.d.ts create mode 100644 packages/google-cloud-edgenetwork/protos/protos.js create mode 100644 packages/google-cloud-edgenetwork/protos/protos.json create mode 100644 packages/google-cloud-edgenetwork/samples/README.md rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.create_interconnect_attachment.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.create_network.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.create_router.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.create_subnet.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.delete_interconnect_attachment.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.delete_network.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.delete_router.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.delete_subnet.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.diagnose_interconnect.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.diagnose_network.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.diagnose_router.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.get_interconnect.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.get_interconnect_attachment.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.get_network.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.get_router.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.get_subnet.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.get_zone.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.initialize_zone.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.list_interconnect_attachments.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.list_interconnects.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.list_networks.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.list_routers.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.list_subnets.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.list_zones.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.update_router.js (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/samples/generated/v1/edge_network.update_subnet.js (100%) create mode 100644 packages/google-cloud-edgenetwork/samples/generated/v1/snippet_metadata_google.cloud.edgenetwork.v1.json create mode 100644 packages/google-cloud-edgenetwork/samples/quickstart.js rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/src/index.ts (84%) create mode 100644 packages/google-cloud-edgenetwork/src/v1/edge_network_client.ts rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/src/v1/edge_network_client_config.json (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/src/v1/edge_network_proto_list.json (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/src/v1/gapic_metadata.json (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/src/v1/index.ts (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/system-test/fixtures/sample/src/index.js (99%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/system-test/fixtures/sample/src/index.ts (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/system-test/install.ts (81%) create mode 100644 packages/google-cloud-edgenetwork/test/gapic_edge_network_v1.ts rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/tsconfig.json (100%) rename {owl-bot-staging/google-cloud-edgenetwork/v1 => packages/google-cloud-edgenetwork}/webpack.config.js (89%) diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/README.md b/owl-bot-staging/google-cloud-edgenetwork/v1/README.md deleted file mode 100644 index fcd1db7e20ec..000000000000 --- a/owl-bot-staging/google-cloud-edgenetwork/v1/README.md +++ /dev/null @@ -1 +0,0 @@ -Edgenetwork: Nodejs Client diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/package.json b/owl-bot-staging/google-cloud-edgenetwork/v1/package.json deleted file mode 100644 index 634e1815ed2a..000000000000 --- a/owl-bot-staging/google-cloud-edgenetwork/v1/package.json +++ /dev/null @@ -1,58 +0,0 @@ -{ - "name": "@google-cloud/edgenetwork", - "version": "0.1.0", - "description": "Edgenetwork client for Node.js", - "repository": "googleapis/nodejs-edgenetwork", - "license": "Apache-2.0", - "author": "Google LLC", - "main": "build/src/index.js", - "files": [ - "build/src", - "build/protos" - ], - "keywords": [ - "google apis client", - "google api client", - "google apis", - "google api", - "google", - "google cloud platform", - "google cloud", - "cloud", - "google edgenetwork", - "edgenetwork", - "edge network" - ], - "scripts": { - "clean": "gts clean", - "compile": "tsc -p . && cp -r protos build/ && minifyProtoJson", - "compile-protos": "compileProtos src", - "docs": "jsdoc -c .jsdoc.js", - "fix": "gts fix", - "lint": "gts check", - "prepare": "npm run compile-protos && npm run compile", - "system-test": "c8 mocha build/system-test", - "test": "c8 mocha build/test" - }, - "dependencies": { - "google-gax": "^4.0.4" - }, - "devDependencies": { - "@types/mocha": "^10.0.1", - "@types/node": "^18.11.18", - "@types/sinon": "^10.0.17", - "c8": "^8.0.1", - "gapic-tools": "^0.2.0", - "gts": "5.0.1", - "jsdoc": "^4.0.2", - "jsdoc-fresh": "^3.0.0", - "jsdoc-region-tag": "^3.0.0", - "mocha": "^10.2.0", - "pack-n-play": "^1.0.0-2", - "sinon": "^15.2.0", - "typescript": "5.1.6" - }, - "engines": { - "node": ">=v14" - } -} diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/snippet_metadata_google.cloud.edgenetwork.v1.json b/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/snippet_metadata_google.cloud.edgenetwork.v1.json deleted file mode 100644 index 4a7d18f8e81a..000000000000 --- a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/snippet_metadata_google.cloud.edgenetwork.v1.json +++ /dev/null @@ -1,1231 +0,0 @@ -{ - "clientLibrary": { - "name": "nodejs-edgenetwork", - "version": "0.1.0", - "language": "TYPESCRIPT", - "apis": [ - { - "id": "google.cloud.edgenetwork.v1", - "version": "v1" - } - ] - }, - "snippets": [ - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_InitializeZone_async", - "title": "EdgeNetwork initializeZone Sample", - "origin": "API_DEFINITION", - "description": " InitializeZone will initialize resources for a zone in a project.", - "canonical": true, - "file": "edge_network.initialize_zone.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 53, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "InitializeZone", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.InitializeZone", - "async": true, - "parameters": [ - { - "name": "name", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.cloud.edgenetwork.v1.InitializeZoneResponse", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "InitializeZone", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.InitializeZone", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListZones_async", - "title": "EdgeNetwork listZones Sample", - "origin": "API_DEFINITION", - "description": " Lists Zones in a given project and location.", - "canonical": true, - "file": "edge_network.list_zones.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 72, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "ListZones", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListZones", - "async": true, - "parameters": [ - { - "name": "parent", - "type": "TYPE_STRING" - }, - { - "name": "page_size", - "type": "TYPE_INT32" - }, - { - "name": "page_token", - "type": "TYPE_STRING" - }, - { - "name": "filter", - "type": "TYPE_STRING" - }, - { - "name": "order_by", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.cloud.edgenetwork.v1.ListZonesResponse", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "ListZones", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListZones", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetZone_async", - "title": "EdgeNetwork getZone Sample", - "origin": "API_DEFINITION", - "description": " Gets details of a single Zone.", - "canonical": true, - "file": "edge_network.get_zone.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 53, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "GetZone", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetZone", - "async": true, - "parameters": [ - { - "name": "name", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.cloud.edgenetwork.v1.Zone", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "GetZone", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetZone", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListNetworks_async", - "title": "EdgeNetwork listNetworks Sample", - "origin": "API_DEFINITION", - "description": " Lists Networks in a given project and location.", - "canonical": true, - "file": "edge_network.list_networks.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 72, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "ListNetworks", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListNetworks", - "async": true, - "parameters": [ - { - "name": "parent", - "type": "TYPE_STRING" - }, - { - "name": "page_size", - "type": "TYPE_INT32" - }, - { - "name": "page_token", - "type": "TYPE_STRING" - }, - { - "name": "filter", - "type": "TYPE_STRING" - }, - { - "name": "order_by", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.cloud.edgenetwork.v1.ListNetworksResponse", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "ListNetworks", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListNetworks", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetNetwork_async", - "title": "EdgeNetwork getNetwork Sample", - "origin": "API_DEFINITION", - "description": " Gets details of a single Network.", - "canonical": true, - "file": "edge_network.get_network.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 53, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "GetNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetNetwork", - "async": true, - "parameters": [ - { - "name": "name", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.cloud.edgenetwork.v1.Network", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "GetNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetNetwork", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DiagnoseNetwork_async", - "title": "EdgeNetwork diagnoseNetwork Sample", - "origin": "API_DEFINITION", - "description": " Get the diagnostics of a single network resource.", - "canonical": true, - "file": "edge_network.diagnose_network.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 53, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "DiagnoseNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseNetwork", - "async": true, - "parameters": [ - { - "name": "name", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.cloud.edgenetwork.v1.DiagnoseNetworkResponse", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "DiagnoseNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseNetwork", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_CreateNetwork_async", - "title": "EdgeNetwork createNetwork Sample", - "origin": "API_DEFINITION", - "description": " Creates a new Network in a given project and location.", - "canonical": true, - "file": "edge_network.create_network.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 80, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "CreateNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateNetwork", - "async": true, - "parameters": [ - { - "name": "parent", - "type": "TYPE_STRING" - }, - { - "name": "network_id", - "type": "TYPE_STRING" - }, - { - "name": "network", - "type": ".google.cloud.edgenetwork.v1.Network" - }, - { - "name": "request_id", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.longrunning.Operation", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "CreateNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateNetwork", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DeleteNetwork_async", - "title": "EdgeNetwork deleteNetwork Sample", - "origin": "API_DEFINITION", - "description": " Deletes a single Network.", - "canonical": true, - "file": "edge_network.delete_network.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 68, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "DeleteNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteNetwork", - "async": true, - "parameters": [ - { - "name": "name", - "type": "TYPE_STRING" - }, - { - "name": "request_id", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.longrunning.Operation", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "DeleteNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteNetwork", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListSubnets_async", - "title": "EdgeNetwork listSubnets Sample", - "origin": "API_DEFINITION", - "description": " Lists Subnets in a given project and location.", - "canonical": true, - "file": "edge_network.list_subnets.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 72, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "ListSubnets", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListSubnets", - "async": true, - "parameters": [ - { - "name": "parent", - "type": "TYPE_STRING" - }, - { - "name": "page_size", - "type": "TYPE_INT32" - }, - { - "name": "page_token", - "type": "TYPE_STRING" - }, - { - "name": "filter", - "type": "TYPE_STRING" - }, - { - "name": "order_by", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.cloud.edgenetwork.v1.ListSubnetsResponse", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "ListSubnets", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListSubnets", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetSubnet_async", - "title": "EdgeNetwork getSubnet Sample", - "origin": "API_DEFINITION", - "description": " Gets details of a single Subnet.", - "canonical": true, - "file": "edge_network.get_subnet.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 53, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "GetSubnet", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetSubnet", - "async": true, - "parameters": [ - { - "name": "name", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.cloud.edgenetwork.v1.Subnet", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "GetSubnet", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetSubnet", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_CreateSubnet_async", - "title": "EdgeNetwork createSubnet Sample", - "origin": "API_DEFINITION", - "description": " Creates a new Subnet in a given project and location.", - "canonical": true, - "file": "edge_network.create_subnet.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 80, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "CreateSubnet", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateSubnet", - "async": true, - "parameters": [ - { - "name": "parent", - "type": "TYPE_STRING" - }, - { - "name": "subnet_id", - "type": "TYPE_STRING" - }, - { - "name": "subnet", - "type": ".google.cloud.edgenetwork.v1.Subnet" - }, - { - "name": "request_id", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.longrunning.Operation", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "CreateSubnet", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateSubnet", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_UpdateSubnet_async", - "title": "EdgeNetwork updateSubnet Sample", - "origin": "API_DEFINITION", - "description": " Updates the parameters of a single Subnet.", - "canonical": true, - "file": "edge_network.update_subnet.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 77, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "UpdateSubnet", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.UpdateSubnet", - "async": true, - "parameters": [ - { - "name": "update_mask", - "type": ".google.protobuf.FieldMask" - }, - { - "name": "subnet", - "type": ".google.cloud.edgenetwork.v1.Subnet" - }, - { - "name": "request_id", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.longrunning.Operation", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "UpdateSubnet", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.UpdateSubnet", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DeleteSubnet_async", - "title": "EdgeNetwork deleteSubnet Sample", - "origin": "API_DEFINITION", - "description": " Deletes a single Subnet.", - "canonical": true, - "file": "edge_network.delete_subnet.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 68, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "DeleteSubnet", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteSubnet", - "async": true, - "parameters": [ - { - "name": "name", - "type": "TYPE_STRING" - }, - { - "name": "request_id", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.longrunning.Operation", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "DeleteSubnet", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteSubnet", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListInterconnects_async", - "title": "EdgeNetwork listInterconnects Sample", - "origin": "API_DEFINITION", - "description": " Lists Interconnects in a given project and location.", - "canonical": true, - "file": "edge_network.list_interconnects.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 72, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "ListInterconnects", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListInterconnects", - "async": true, - "parameters": [ - { - "name": "parent", - "type": "TYPE_STRING" - }, - { - "name": "page_size", - "type": "TYPE_INT32" - }, - { - "name": "page_token", - "type": "TYPE_STRING" - }, - { - "name": "filter", - "type": "TYPE_STRING" - }, - { - "name": "order_by", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.cloud.edgenetwork.v1.ListInterconnectsResponse", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "ListInterconnects", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListInterconnects", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetInterconnect_async", - "title": "EdgeNetwork getInterconnect Sample", - "origin": "API_DEFINITION", - "description": " Gets details of a single Interconnect.", - "canonical": true, - "file": "edge_network.get_interconnect.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 53, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "GetInterconnect", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetInterconnect", - "async": true, - "parameters": [ - { - "name": "name", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.cloud.edgenetwork.v1.Interconnect", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "GetInterconnect", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetInterconnect", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DiagnoseInterconnect_async", - "title": "EdgeNetwork diagnoseInterconnect Sample", - "origin": "API_DEFINITION", - "description": " Get the diagnostics of a single interconnect resource.", - "canonical": true, - "file": "edge_network.diagnose_interconnect.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 53, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "DiagnoseInterconnect", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseInterconnect", - "async": true, - "parameters": [ - { - "name": "name", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "DiagnoseInterconnect", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseInterconnect", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListInterconnectAttachments_async", - "title": "EdgeNetwork listInterconnectAttachments Sample", - "origin": "API_DEFINITION", - "description": " Lists InterconnectAttachments in a given project and location.", - "canonical": true, - "file": "edge_network.list_interconnect_attachments.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 72, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "ListInterconnectAttachments", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListInterconnectAttachments", - "async": true, - "parameters": [ - { - "name": "parent", - "type": "TYPE_STRING" - }, - { - "name": "page_size", - "type": "TYPE_INT32" - }, - { - "name": "page_token", - "type": "TYPE_STRING" - }, - { - "name": "filter", - "type": "TYPE_STRING" - }, - { - "name": "order_by", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "ListInterconnectAttachments", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListInterconnectAttachments", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetInterconnectAttachment_async", - "title": "EdgeNetwork getInterconnectAttachment Sample", - "origin": "API_DEFINITION", - "description": " Gets details of a single InterconnectAttachment.", - "canonical": true, - "file": "edge_network.get_interconnect_attachment.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 53, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "GetInterconnectAttachment", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetInterconnectAttachment", - "async": true, - "parameters": [ - { - "name": "name", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.cloud.edgenetwork.v1.InterconnectAttachment", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "GetInterconnectAttachment", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetInterconnectAttachment", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_CreateInterconnectAttachment_async", - "title": "EdgeNetwork createInterconnectAttachment Sample", - "origin": "API_DEFINITION", - "description": " Creates a new InterconnectAttachment in a given project and location.", - "canonical": true, - "file": "edge_network.create_interconnect_attachment.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 80, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "CreateInterconnectAttachment", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateInterconnectAttachment", - "async": true, - "parameters": [ - { - "name": "parent", - "type": "TYPE_STRING" - }, - { - "name": "interconnect_attachment_id", - "type": "TYPE_STRING" - }, - { - "name": "interconnect_attachment", - "type": ".google.cloud.edgenetwork.v1.InterconnectAttachment" - }, - { - "name": "request_id", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.longrunning.Operation", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "CreateInterconnectAttachment", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateInterconnectAttachment", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DeleteInterconnectAttachment_async", - "title": "EdgeNetwork deleteInterconnectAttachment Sample", - "origin": "API_DEFINITION", - "description": " Deletes a single InterconnectAttachment.", - "canonical": true, - "file": "edge_network.delete_interconnect_attachment.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 68, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "DeleteInterconnectAttachment", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteInterconnectAttachment", - "async": true, - "parameters": [ - { - "name": "name", - "type": "TYPE_STRING" - }, - { - "name": "request_id", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.longrunning.Operation", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "DeleteInterconnectAttachment", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteInterconnectAttachment", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListRouters_async", - "title": "EdgeNetwork listRouters Sample", - "origin": "API_DEFINITION", - "description": " Lists Routers in a given project and location.", - "canonical": true, - "file": "edge_network.list_routers.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 72, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "ListRouters", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListRouters", - "async": true, - "parameters": [ - { - "name": "parent", - "type": "TYPE_STRING" - }, - { - "name": "page_size", - "type": "TYPE_INT32" - }, - { - "name": "page_token", - "type": "TYPE_STRING" - }, - { - "name": "filter", - "type": "TYPE_STRING" - }, - { - "name": "order_by", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.cloud.edgenetwork.v1.ListRoutersResponse", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "ListRouters", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListRouters", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetRouter_async", - "title": "EdgeNetwork getRouter Sample", - "origin": "API_DEFINITION", - "description": " Gets details of a single Router.", - "canonical": true, - "file": "edge_network.get_router.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 53, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "GetRouter", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetRouter", - "async": true, - "parameters": [ - { - "name": "name", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.cloud.edgenetwork.v1.Router", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "GetRouter", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetRouter", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DiagnoseRouter_async", - "title": "EdgeNetwork diagnoseRouter Sample", - "origin": "API_DEFINITION", - "description": " Get the diagnostics of a single router resource.", - "canonical": true, - "file": "edge_network.diagnose_router.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 53, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "DiagnoseRouter", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseRouter", - "async": true, - "parameters": [ - { - "name": "name", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.cloud.edgenetwork.v1.DiagnoseRouterResponse", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "DiagnoseRouter", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseRouter", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_CreateRouter_async", - "title": "EdgeNetwork createRouter Sample", - "origin": "API_DEFINITION", - "description": " Creates a new Router in a given project and location.", - "canonical": true, - "file": "edge_network.create_router.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 80, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "CreateRouter", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateRouter", - "async": true, - "parameters": [ - { - "name": "parent", - "type": "TYPE_STRING" - }, - { - "name": "router_id", - "type": "TYPE_STRING" - }, - { - "name": "router", - "type": ".google.cloud.edgenetwork.v1.Router" - }, - { - "name": "request_id", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.longrunning.Operation", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "CreateRouter", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateRouter", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_UpdateRouter_async", - "title": "EdgeNetwork updateRouter Sample", - "origin": "API_DEFINITION", - "description": " Updates the parameters of a single Router.", - "canonical": true, - "file": "edge_network.update_router.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 77, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "UpdateRouter", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.UpdateRouter", - "async": true, - "parameters": [ - { - "name": "update_mask", - "type": ".google.protobuf.FieldMask" - }, - { - "name": "router", - "type": ".google.cloud.edgenetwork.v1.Router" - }, - { - "name": "request_id", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.longrunning.Operation", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "UpdateRouter", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.UpdateRouter", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - }, - { - "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DeleteRouter_async", - "title": "EdgeNetwork deleteRouter Sample", - "origin": "API_DEFINITION", - "description": " Deletes a single Router.", - "canonical": true, - "file": "edge_network.delete_router.js", - "language": "JAVASCRIPT", - "segments": [ - { - "start": 25, - "end": 68, - "type": "FULL" - } - ], - "clientMethod": { - "shortName": "DeleteRouter", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteRouter", - "async": true, - "parameters": [ - { - "name": "name", - "type": "TYPE_STRING" - }, - { - "name": "request_id", - "type": "TYPE_STRING" - } - ], - "resultType": ".google.longrunning.Operation", - "client": { - "shortName": "EdgeNetworkClient", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" - }, - "method": { - "shortName": "DeleteRouter", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteRouter", - "service": { - "shortName": "EdgeNetwork", - "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" - } - } - } - } - ] -} diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_client.ts b/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_client.ts deleted file mode 100644 index 4ada68d316e5..000000000000 --- a/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_client.ts +++ /dev/null @@ -1,4016 +0,0 @@ -// Copyright 2023 Google LLC -// -// Licensed under the Apache License, Version 2.0 (the "License"); -// you may not use this file except in compliance with the License. -// You may obtain a copy of the License at -// -// https://www.apache.org/licenses/LICENSE-2.0 -// -// Unless required by applicable law or agreed to in writing, software -// distributed under the License is distributed on an "AS IS" BASIS, -// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -// See the License for the specific language governing permissions and -// limitations under the License. -// -// ** This file is automatically generated by gapic-generator-typescript. ** -// ** https://github.com/googleapis/gapic-generator-typescript ** -// ** All changes to this file may be overwritten. ** - -/* global window */ -import type * as gax from 'google-gax'; -import type {Callback, CallOptions, Descriptors, ClientOptions, GrpcClientOptions, LROperation, PaginationCallback, GaxCall, LocationsClient, LocationProtos} from 'google-gax'; -import {Transform} from 'stream'; -import * as protos from '../../protos/protos'; -import jsonProtos = require('../../protos/protos.json'); -/** - * Client JSON configuration object, loaded from - * `src/v1/edge_network_client_config.json`. - * This file defines retry strategy and timeouts for all API methods in this library. - */ -import * as gapicConfig from './edge_network_client_config.json'; -const version = require('../../../package.json').version; - -/** - * EdgeNetwork API provides managed, highly available cloud dynamic network - * configuration service to the GEC customer to enable edge application and - * network function solutions. This allows the customers to easily define and - * configure the network setup and property to meet the workload requirement. - * @class - * @memberof v1 - */ -export class EdgeNetworkClient { - private _terminated = false; - private _opts: ClientOptions; - private _providedCustomServicePath: boolean; - private _gaxModule: typeof gax | typeof gax.fallback; - private _gaxGrpc: gax.GrpcClient | gax.fallback.GrpcClient; - private _protos: {}; - private _defaults: {[method: string]: gax.CallSettings}; - auth: gax.GoogleAuth; - descriptors: Descriptors = { - page: {}, - stream: {}, - longrunning: {}, - batching: {}, - }; - warn: (code: string, message: string, warnType?: string) => void; - innerApiCalls: {[name: string]: Function}; - locationsClient: LocationsClient; - pathTemplates: {[name: string]: gax.PathTemplate}; - operationsClient: gax.OperationsClient; - edgeNetworkStub?: Promise<{[name: string]: Function}>; - - /** - * Construct an instance of EdgeNetworkClient. - * - * @param {object} [options] - The configuration object. - * The options accepted by the constructor are described in detail - * in [this document](https://github.com/googleapis/gax-nodejs/blob/main/client-libraries.md#creating-the-client-instance). - * The common options are: - * @param {object} [options.credentials] - Credentials object. - * @param {string} [options.credentials.client_email] - * @param {string} [options.credentials.private_key] - * @param {string} [options.email] - Account email address. Required when - * using a .pem or .p12 keyFilename. - * @param {string} [options.keyFilename] - Full path to the a .json, .pem, or - * .p12 key downloaded from the Google Developers Console. If you provide - * a path to a JSON file, the projectId option below is not necessary. - * NOTE: .pem and .p12 require you to specify options.email as well. - * @param {number} [options.port] - The port on which to connect to - * the remote host. - * @param {string} [options.projectId] - The project ID from the Google - * Developer's Console, e.g. 'grape-spaceship-123'. We will also check - * the environment variable GCLOUD_PROJECT for your project ID. If your - * app is running in an environment which supports - * {@link https://developers.google.com/identity/protocols/application-default-credentials Application Default Credentials}, - * your project ID will be detected automatically. - * @param {string} [options.apiEndpoint] - The domain name of the - * API remote host. - * @param {gax.ClientConfig} [options.clientConfig] - Client configuration override. - * Follows the structure of {@link gapicConfig}. - * @param {boolean} [options.fallback] - Use HTTP/1.1 REST mode. - * For more information, please check the - * {@link https://github.com/googleapis/gax-nodejs/blob/main/client-libraries.md#http11-rest-api-mode documentation}. - * @param {gax} [gaxInstance]: loaded instance of `google-gax`. Useful if you - * need to avoid loading the default gRPC version and want to use the fallback - * HTTP implementation. Load only fallback version and pass it to the constructor: - * ``` - * const gax = require('google-gax/build/src/fallback'); // avoids loading google-gax with gRPC - * const client = new EdgeNetworkClient({fallback: true}, gax); - * ``` - */ - constructor(opts?: ClientOptions, gaxInstance?: typeof gax | typeof gax.fallback) { - // Ensure that options include all the required fields. - const staticMembers = this.constructor as typeof EdgeNetworkClient; - const servicePath = opts?.servicePath || opts?.apiEndpoint || staticMembers.servicePath; - this._providedCustomServicePath = !!(opts?.servicePath || opts?.apiEndpoint); - const port = opts?.port || staticMembers.port; - const clientConfig = opts?.clientConfig ?? {}; - const fallback = opts?.fallback ?? (typeof window !== 'undefined' && typeof window?.fetch === 'function'); - opts = Object.assign({servicePath, port, clientConfig, fallback}, opts); - - // Request numeric enum values if REST transport is used. - opts.numericEnums = true; - - // If scopes are unset in options and we're connecting to a non-default endpoint, set scopes just in case. - if (servicePath !== staticMembers.servicePath && !('scopes' in opts)) { - opts['scopes'] = staticMembers.scopes; - } - - // Load google-gax module synchronously if needed - if (!gaxInstance) { - gaxInstance = require('google-gax') as typeof gax; - } - - // Choose either gRPC or proto-over-HTTP implementation of google-gax. - this._gaxModule = opts.fallback ? gaxInstance.fallback : gaxInstance; - - // Create a `gaxGrpc` object, with any grpc-specific options sent to the client. - this._gaxGrpc = new this._gaxModule.GrpcClient(opts); - - // Save options to use in initialize() method. - this._opts = opts; - - // Save the auth object to the client, for use by other methods. - this.auth = (this._gaxGrpc.auth as gax.GoogleAuth); - - // Set useJWTAccessWithScope on the auth object. - this.auth.useJWTAccessWithScope = true; - - // Set defaultServicePath on the auth object. - this.auth.defaultServicePath = staticMembers.servicePath; - - // Set the default scopes in auth client if needed. - if (servicePath === staticMembers.servicePath) { - this.auth.defaultScopes = staticMembers.scopes; - } - this.locationsClient = new this._gaxModule.LocationsClient( - this._gaxGrpc, - opts - ); - - - // Determine the client header string. - const clientHeader = [ - `gax/${this._gaxModule.version}`, - `gapic/${version}`, - ]; - if (typeof process !== 'undefined' && 'versions' in process) { - clientHeader.push(`gl-node/${process.versions.node}`); - } else { - clientHeader.push(`gl-web/${this._gaxModule.version}`); - } - if (!opts.fallback) { - clientHeader.push(`grpc/${this._gaxGrpc.grpcVersion}`); - } else { - clientHeader.push(`rest/${this._gaxGrpc.grpcVersion}`); - } - if (opts.libName && opts.libVersion) { - clientHeader.push(`${opts.libName}/${opts.libVersion}`); - } - // Load the applicable protos. - this._protos = this._gaxGrpc.loadProtoJSON(jsonProtos); - - // This API contains "path templates"; forward-slash-separated - // identifiers to uniquely identify resources within the API. - // Create useful helper objects for these. - this.pathTemplates = { - interconnectPathTemplate: new this._gaxModule.PathTemplate( - 'projects/{project}/locations/{location}/zones/{zone}/interconnects/{interconnect}' - ), - interconnectAttachmentPathTemplate: new this._gaxModule.PathTemplate( - 'projects/{project}/locations/{location}/zones/{zone}/interconnectAttachments/{interconnect_attachment}' - ), - locationPathTemplate: new this._gaxModule.PathTemplate( - 'projects/{project}/locations/{location}' - ), - networkPathTemplate: new this._gaxModule.PathTemplate( - 'projects/{project}/locations/{location}/zones/{zone}/networks/{network}' - ), - projectPathTemplate: new this._gaxModule.PathTemplate( - 'projects/{project}' - ), - routerPathTemplate: new this._gaxModule.PathTemplate( - 'projects/{project}/locations/{location}/zones/{zone}/routers/{router}' - ), - subnetPathTemplate: new this._gaxModule.PathTemplate( - 'projects/{project}/locations/{location}/zones/{zone}/subnets/{subnet}' - ), - zonePathTemplate: new this._gaxModule.PathTemplate( - 'projects/{project}/locations/{location}/zones/{zone}' - ), - }; - - // Some of the methods on this service return "paged" results, - // (e.g. 50 results at a time, with tokens to get subsequent - // pages). Denote the keys used for pagination and results. - this.descriptors.page = { - listZones: - new this._gaxModule.PageDescriptor('pageToken', 'nextPageToken', 'zones'), - listNetworks: - new this._gaxModule.PageDescriptor('pageToken', 'nextPageToken', 'networks'), - listSubnets: - new this._gaxModule.PageDescriptor('pageToken', 'nextPageToken', 'subnets'), - listInterconnects: - new this._gaxModule.PageDescriptor('pageToken', 'nextPageToken', 'interconnects'), - listInterconnectAttachments: - new this._gaxModule.PageDescriptor('pageToken', 'nextPageToken', 'interconnectAttachments'), - listRouters: - new this._gaxModule.PageDescriptor('pageToken', 'nextPageToken', 'routers') - }; - - const protoFilesRoot = this._gaxModule.protobuf.Root.fromJSON(jsonProtos); - // This API contains "long-running operations", which return a - // an Operation object that allows for tracking of the operation, - // rather than holding a request open. - const lroOptions: GrpcClientOptions = { - auth: this.auth, - grpc: 'grpc' in this._gaxGrpc ? this._gaxGrpc.grpc : undefined - }; - if (opts.fallback) { - lroOptions.protoJson = protoFilesRoot; - lroOptions.httpRules = [{selector: 'google.cloud.location.Locations.GetLocation',get: '/v1/{name=projects/*/locations/*}',},{selector: 'google.cloud.location.Locations.ListLocations',get: '/v1/{name=projects/*}/locations',},{selector: 'google.longrunning.Operations.CancelOperation',post: '/v1/{name=projects/*/locations/*/operations/*}:cancel',body: '*',},{selector: 'google.longrunning.Operations.DeleteOperation',delete: '/v1/{name=projects/*/locations/*/operations/*}',},{selector: 'google.longrunning.Operations.GetOperation',get: '/v1/{name=projects/*/locations/*/operations/*}',},{selector: 'google.longrunning.Operations.ListOperations',get: '/v1/{name=projects/*/locations/*}/operations',}]; - } - this.operationsClient = this._gaxModule.lro(lroOptions).operationsClient(opts); - const createNetworkResponse = protoFilesRoot.lookup( - '.google.cloud.edgenetwork.v1.Network') as gax.protobuf.Type; - const createNetworkMetadata = protoFilesRoot.lookup( - '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; - const deleteNetworkResponse = protoFilesRoot.lookup( - '.google.protobuf.Empty') as gax.protobuf.Type; - const deleteNetworkMetadata = protoFilesRoot.lookup( - '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; - const createSubnetResponse = protoFilesRoot.lookup( - '.google.cloud.edgenetwork.v1.Subnet') as gax.protobuf.Type; - const createSubnetMetadata = protoFilesRoot.lookup( - '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; - const updateSubnetResponse = protoFilesRoot.lookup( - '.google.cloud.edgenetwork.v1.Subnet') as gax.protobuf.Type; - const updateSubnetMetadata = protoFilesRoot.lookup( - '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; - const deleteSubnetResponse = protoFilesRoot.lookup( - '.google.protobuf.Empty') as gax.protobuf.Type; - const deleteSubnetMetadata = protoFilesRoot.lookup( - '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; - const createInterconnectAttachmentResponse = protoFilesRoot.lookup( - '.google.cloud.edgenetwork.v1.InterconnectAttachment') as gax.protobuf.Type; - const createInterconnectAttachmentMetadata = protoFilesRoot.lookup( - '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; - const deleteInterconnectAttachmentResponse = protoFilesRoot.lookup( - '.google.protobuf.Empty') as gax.protobuf.Type; - const deleteInterconnectAttachmentMetadata = protoFilesRoot.lookup( - '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; - const createRouterResponse = protoFilesRoot.lookup( - '.google.cloud.edgenetwork.v1.Router') as gax.protobuf.Type; - const createRouterMetadata = protoFilesRoot.lookup( - '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; - const updateRouterResponse = protoFilesRoot.lookup( - '.google.cloud.edgenetwork.v1.Router') as gax.protobuf.Type; - const updateRouterMetadata = protoFilesRoot.lookup( - '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; - const deleteRouterResponse = protoFilesRoot.lookup( - '.google.protobuf.Empty') as gax.protobuf.Type; - const deleteRouterMetadata = protoFilesRoot.lookup( - '.google.cloud.edgenetwork.v1.OperationMetadata') as gax.protobuf.Type; - - this.descriptors.longrunning = { - createNetwork: new this._gaxModule.LongrunningDescriptor( - this.operationsClient, - createNetworkResponse.decode.bind(createNetworkResponse), - createNetworkMetadata.decode.bind(createNetworkMetadata)), - deleteNetwork: new this._gaxModule.LongrunningDescriptor( - this.operationsClient, - deleteNetworkResponse.decode.bind(deleteNetworkResponse), - deleteNetworkMetadata.decode.bind(deleteNetworkMetadata)), - createSubnet: new this._gaxModule.LongrunningDescriptor( - this.operationsClient, - createSubnetResponse.decode.bind(createSubnetResponse), - createSubnetMetadata.decode.bind(createSubnetMetadata)), - updateSubnet: new this._gaxModule.LongrunningDescriptor( - this.operationsClient, - updateSubnetResponse.decode.bind(updateSubnetResponse), - updateSubnetMetadata.decode.bind(updateSubnetMetadata)), - deleteSubnet: new this._gaxModule.LongrunningDescriptor( - this.operationsClient, - deleteSubnetResponse.decode.bind(deleteSubnetResponse), - deleteSubnetMetadata.decode.bind(deleteSubnetMetadata)), - createInterconnectAttachment: new this._gaxModule.LongrunningDescriptor( - this.operationsClient, - createInterconnectAttachmentResponse.decode.bind(createInterconnectAttachmentResponse), - createInterconnectAttachmentMetadata.decode.bind(createInterconnectAttachmentMetadata)), - deleteInterconnectAttachment: new this._gaxModule.LongrunningDescriptor( - this.operationsClient, - deleteInterconnectAttachmentResponse.decode.bind(deleteInterconnectAttachmentResponse), - deleteInterconnectAttachmentMetadata.decode.bind(deleteInterconnectAttachmentMetadata)), - createRouter: new this._gaxModule.LongrunningDescriptor( - this.operationsClient, - createRouterResponse.decode.bind(createRouterResponse), - createRouterMetadata.decode.bind(createRouterMetadata)), - updateRouter: new this._gaxModule.LongrunningDescriptor( - this.operationsClient, - updateRouterResponse.decode.bind(updateRouterResponse), - updateRouterMetadata.decode.bind(updateRouterMetadata)), - deleteRouter: new this._gaxModule.LongrunningDescriptor( - this.operationsClient, - deleteRouterResponse.decode.bind(deleteRouterResponse), - deleteRouterMetadata.decode.bind(deleteRouterMetadata)) - }; - - // Put together the default options sent with requests. - this._defaults = this._gaxGrpc.constructSettings( - 'google.cloud.edgenetwork.v1.EdgeNetwork', gapicConfig as gax.ClientConfig, - opts.clientConfig || {}, {'x-goog-api-client': clientHeader.join(' ')}); - - // Set up a dictionary of "inner API calls"; the core implementation - // of calling the API is handled in `google-gax`, with this code - // merely providing the destination and request information. - this.innerApiCalls = {}; - - // Add a warn function to the client constructor so it can be easily tested. - this.warn = this._gaxModule.warn; - } - - /** - * Initialize the client. - * Performs asynchronous operations (such as authentication) and prepares the client. - * This function will be called automatically when any class method is called for the - * first time, but if you need to initialize it before calling an actual method, - * feel free to call initialize() directly. - * - * You can await on this method if you want to make sure the client is initialized. - * - * @returns {Promise} A promise that resolves to an authenticated service stub. - */ - initialize() { - // If the client stub promise is already initialized, return immediately. - if (this.edgeNetworkStub) { - return this.edgeNetworkStub; - } - - // Put together the "service stub" for - // google.cloud.edgenetwork.v1.EdgeNetwork. - this.edgeNetworkStub = this._gaxGrpc.createStub( - this._opts.fallback ? - (this._protos as protobuf.Root).lookupService('google.cloud.edgenetwork.v1.EdgeNetwork') : - // eslint-disable-next-line @typescript-eslint/no-explicit-any - (this._protos as any).google.cloud.edgenetwork.v1.EdgeNetwork, - this._opts, this._providedCustomServicePath) as Promise<{[method: string]: Function}>; - - // Iterate over each of the methods that the service provides - // and create an API call method for each. - const edgeNetworkStubMethods = - ['initializeZone', 'listZones', 'getZone', 'listNetworks', 'getNetwork', 'diagnoseNetwork', 'createNetwork', 'deleteNetwork', 'listSubnets', 'getSubnet', 'createSubnet', 'updateSubnet', 'deleteSubnet', 'listInterconnects', 'getInterconnect', 'diagnoseInterconnect', 'listInterconnectAttachments', 'getInterconnectAttachment', 'createInterconnectAttachment', 'deleteInterconnectAttachment', 'listRouters', 'getRouter', 'diagnoseRouter', 'createRouter', 'updateRouter', 'deleteRouter']; - for (const methodName of edgeNetworkStubMethods) { - const callPromise = this.edgeNetworkStub.then( - stub => (...args: Array<{}>) => { - if (this._terminated) { - return Promise.reject('The client has already been closed.'); - } - const func = stub[methodName]; - return func.apply(stub, args); - }, - (err: Error|null|undefined) => () => { - throw err; - }); - - const descriptor = - this.descriptors.page[methodName] || - this.descriptors.longrunning[methodName] || - undefined; - const apiCall = this._gaxModule.createApiCall( - callPromise, - this._defaults[methodName], - descriptor, - this._opts.fallback - ); - - this.innerApiCalls[methodName] = apiCall; - } - - return this.edgeNetworkStub; - } - - /** - * The DNS address for this API service. - * @returns {string} The DNS address for this service. - */ - static get servicePath() { - return 'edgenetwork.googleapis.com'; - } - - /** - * The DNS address for this API service - same as servicePath(), - * exists for compatibility reasons. - * @returns {string} The DNS address for this service. - */ - static get apiEndpoint() { - return 'edgenetwork.googleapis.com'; - } - - /** - * The port for this API service. - * @returns {number} The default port for this service. - */ - static get port() { - return 443; - } - - /** - * The scopes needed to make gRPC calls for every method defined - * in this service. - * @returns {string[]} List of default scopes. - */ - static get scopes() { - return [ - 'https://www.googleapis.com/auth/cloud-platform' - ]; - } - - getProjectId(): Promise; - getProjectId(callback: Callback): void; - /** - * Return the project ID used by this class. - * @returns {Promise} A promise that resolves to string containing the project ID. - */ - getProjectId(callback?: Callback): - Promise|void { - if (callback) { - this.auth.getProjectId(callback); - return; - } - return this.auth.getProjectId(); - } - - // ------------------- - // -- Service calls -- - // ------------------- -/** - * InitializeZone will initialize resources for a zone in a project. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.name - * Required. The name of the zone resource. - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.InitializeZoneResponse|InitializeZoneResponse}. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.initialize_zone.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_InitializeZone_async - */ - initializeZone( - request?: protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest, - options?: CallOptions): - Promise<[ - protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, - protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest|undefined, {}|undefined - ]>; - initializeZone( - request: protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest, - options: CallOptions, - callback: Callback< - protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, - protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest|null|undefined, - {}|null|undefined>): void; - initializeZone( - request: protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest, - callback: Callback< - protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, - protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest|null|undefined, - {}|null|undefined>): void; - initializeZone( - request?: protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest, - optionsOrCallback?: CallOptions|Callback< - protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, - protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest|null|undefined, - {}|null|undefined>, - callback?: Callback< - protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, - protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest|null|undefined, - {}|null|undefined>): - Promise<[ - protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, - protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'name': request.name ?? '', - }); - this.initialize(); - return this.innerApiCalls.initializeZone(request, options, callback); - } -/** - * Gets details of a single Zone. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.name - * Required. Name of the resource - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.Zone|Zone}. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.get_zone.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetZone_async - */ - getZone( - request?: protos.google.cloud.edgenetwork.v1.IGetZoneRequest, - options?: CallOptions): - Promise<[ - protos.google.cloud.edgenetwork.v1.IZone, - protos.google.cloud.edgenetwork.v1.IGetZoneRequest|undefined, {}|undefined - ]>; - getZone( - request: protos.google.cloud.edgenetwork.v1.IGetZoneRequest, - options: CallOptions, - callback: Callback< - protos.google.cloud.edgenetwork.v1.IZone, - protos.google.cloud.edgenetwork.v1.IGetZoneRequest|null|undefined, - {}|null|undefined>): void; - getZone( - request: protos.google.cloud.edgenetwork.v1.IGetZoneRequest, - callback: Callback< - protos.google.cloud.edgenetwork.v1.IZone, - protos.google.cloud.edgenetwork.v1.IGetZoneRequest|null|undefined, - {}|null|undefined>): void; - getZone( - request?: protos.google.cloud.edgenetwork.v1.IGetZoneRequest, - optionsOrCallback?: CallOptions|Callback< - protos.google.cloud.edgenetwork.v1.IZone, - protos.google.cloud.edgenetwork.v1.IGetZoneRequest|null|undefined, - {}|null|undefined>, - callback?: Callback< - protos.google.cloud.edgenetwork.v1.IZone, - protos.google.cloud.edgenetwork.v1.IGetZoneRequest|null|undefined, - {}|null|undefined>): - Promise<[ - protos.google.cloud.edgenetwork.v1.IZone, - protos.google.cloud.edgenetwork.v1.IGetZoneRequest|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'name': request.name ?? '', - }); - this.initialize(); - return this.innerApiCalls.getZone(request, options, callback); - } -/** - * Gets details of a single Network. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.name - * Required. Name of the resource - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.Network|Network}. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.get_network.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetNetwork_async - */ - getNetwork( - request?: protos.google.cloud.edgenetwork.v1.IGetNetworkRequest, - options?: CallOptions): - Promise<[ - protos.google.cloud.edgenetwork.v1.INetwork, - protos.google.cloud.edgenetwork.v1.IGetNetworkRequest|undefined, {}|undefined - ]>; - getNetwork( - request: protos.google.cloud.edgenetwork.v1.IGetNetworkRequest, - options: CallOptions, - callback: Callback< - protos.google.cloud.edgenetwork.v1.INetwork, - protos.google.cloud.edgenetwork.v1.IGetNetworkRequest|null|undefined, - {}|null|undefined>): void; - getNetwork( - request: protos.google.cloud.edgenetwork.v1.IGetNetworkRequest, - callback: Callback< - protos.google.cloud.edgenetwork.v1.INetwork, - protos.google.cloud.edgenetwork.v1.IGetNetworkRequest|null|undefined, - {}|null|undefined>): void; - getNetwork( - request?: protos.google.cloud.edgenetwork.v1.IGetNetworkRequest, - optionsOrCallback?: CallOptions|Callback< - protos.google.cloud.edgenetwork.v1.INetwork, - protos.google.cloud.edgenetwork.v1.IGetNetworkRequest|null|undefined, - {}|null|undefined>, - callback?: Callback< - protos.google.cloud.edgenetwork.v1.INetwork, - protos.google.cloud.edgenetwork.v1.IGetNetworkRequest|null|undefined, - {}|null|undefined>): - Promise<[ - protos.google.cloud.edgenetwork.v1.INetwork, - protos.google.cloud.edgenetwork.v1.IGetNetworkRequest|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'name': request.name ?? '', - }); - this.initialize(); - return this.innerApiCalls.getNetwork(request, options, callback); - } -/** - * Get the diagnostics of a single network resource. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.name - * Required. The name of the network resource. - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse|DiagnoseNetworkResponse}. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.diagnose_network.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_DiagnoseNetwork_async - */ - diagnoseNetwork( - request?: protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest, - options?: CallOptions): - Promise<[ - protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest|undefined, {}|undefined - ]>; - diagnoseNetwork( - request: protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest, - options: CallOptions, - callback: Callback< - protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest|null|undefined, - {}|null|undefined>): void; - diagnoseNetwork( - request: protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest, - callback: Callback< - protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest|null|undefined, - {}|null|undefined>): void; - diagnoseNetwork( - request?: protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest, - optionsOrCallback?: CallOptions|Callback< - protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest|null|undefined, - {}|null|undefined>, - callback?: Callback< - protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest|null|undefined, - {}|null|undefined>): - Promise<[ - protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'name': request.name ?? '', - }); - this.initialize(); - return this.innerApiCalls.diagnoseNetwork(request, options, callback); - } -/** - * Gets details of a single Subnet. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.name - * Required. Name of the resource - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.Subnet|Subnet}. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.get_subnet.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetSubnet_async - */ - getSubnet( - request?: protos.google.cloud.edgenetwork.v1.IGetSubnetRequest, - options?: CallOptions): - Promise<[ - protos.google.cloud.edgenetwork.v1.ISubnet, - protos.google.cloud.edgenetwork.v1.IGetSubnetRequest|undefined, {}|undefined - ]>; - getSubnet( - request: protos.google.cloud.edgenetwork.v1.IGetSubnetRequest, - options: CallOptions, - callback: Callback< - protos.google.cloud.edgenetwork.v1.ISubnet, - protos.google.cloud.edgenetwork.v1.IGetSubnetRequest|null|undefined, - {}|null|undefined>): void; - getSubnet( - request: protos.google.cloud.edgenetwork.v1.IGetSubnetRequest, - callback: Callback< - protos.google.cloud.edgenetwork.v1.ISubnet, - protos.google.cloud.edgenetwork.v1.IGetSubnetRequest|null|undefined, - {}|null|undefined>): void; - getSubnet( - request?: protos.google.cloud.edgenetwork.v1.IGetSubnetRequest, - optionsOrCallback?: CallOptions|Callback< - protos.google.cloud.edgenetwork.v1.ISubnet, - protos.google.cloud.edgenetwork.v1.IGetSubnetRequest|null|undefined, - {}|null|undefined>, - callback?: Callback< - protos.google.cloud.edgenetwork.v1.ISubnet, - protos.google.cloud.edgenetwork.v1.IGetSubnetRequest|null|undefined, - {}|null|undefined>): - Promise<[ - protos.google.cloud.edgenetwork.v1.ISubnet, - protos.google.cloud.edgenetwork.v1.IGetSubnetRequest|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'name': request.name ?? '', - }); - this.initialize(); - return this.innerApiCalls.getSubnet(request, options, callback); - } -/** - * Gets details of a single Interconnect. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.name - * Required. Name of the resource - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.Interconnect|Interconnect}. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.get_interconnect.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetInterconnect_async - */ - getInterconnect( - request?: protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest, - options?: CallOptions): - Promise<[ - protos.google.cloud.edgenetwork.v1.IInterconnect, - protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest|undefined, {}|undefined - ]>; - getInterconnect( - request: protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest, - options: CallOptions, - callback: Callback< - protos.google.cloud.edgenetwork.v1.IInterconnect, - protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest|null|undefined, - {}|null|undefined>): void; - getInterconnect( - request: protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest, - callback: Callback< - protos.google.cloud.edgenetwork.v1.IInterconnect, - protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest|null|undefined, - {}|null|undefined>): void; - getInterconnect( - request?: protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest, - optionsOrCallback?: CallOptions|Callback< - protos.google.cloud.edgenetwork.v1.IInterconnect, - protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest|null|undefined, - {}|null|undefined>, - callback?: Callback< - protos.google.cloud.edgenetwork.v1.IInterconnect, - protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest|null|undefined, - {}|null|undefined>): - Promise<[ - protos.google.cloud.edgenetwork.v1.IInterconnect, - protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'name': request.name ?? '', - }); - this.initialize(); - return this.innerApiCalls.getInterconnect(request, options, callback); - } -/** - * Get the diagnostics of a single interconnect resource. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.name - * Required. The name of the interconnect resource. - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse|DiagnoseInterconnectResponse}. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.diagnose_interconnect.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_DiagnoseInterconnect_async - */ - diagnoseInterconnect( - request?: protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest, - options?: CallOptions): - Promise<[ - protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest|undefined, {}|undefined - ]>; - diagnoseInterconnect( - request: protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest, - options: CallOptions, - callback: Callback< - protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest|null|undefined, - {}|null|undefined>): void; - diagnoseInterconnect( - request: protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest, - callback: Callback< - protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest|null|undefined, - {}|null|undefined>): void; - diagnoseInterconnect( - request?: protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest, - optionsOrCallback?: CallOptions|Callback< - protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest|null|undefined, - {}|null|undefined>, - callback?: Callback< - protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest|null|undefined, - {}|null|undefined>): - Promise<[ - protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'name': request.name ?? '', - }); - this.initialize(); - return this.innerApiCalls.diagnoseInterconnect(request, options, callback); - } -/** - * Gets details of a single InterconnectAttachment. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.name - * Required. Name of the resource - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.InterconnectAttachment|InterconnectAttachment}. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.get_interconnect_attachment.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetInterconnectAttachment_async - */ - getInterconnectAttachment( - request?: protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest, - options?: CallOptions): - Promise<[ - protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, - protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest|undefined, {}|undefined - ]>; - getInterconnectAttachment( - request: protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest, - options: CallOptions, - callback: Callback< - protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, - protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest|null|undefined, - {}|null|undefined>): void; - getInterconnectAttachment( - request: protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest, - callback: Callback< - protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, - protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest|null|undefined, - {}|null|undefined>): void; - getInterconnectAttachment( - request?: protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest, - optionsOrCallback?: CallOptions|Callback< - protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, - protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest|null|undefined, - {}|null|undefined>, - callback?: Callback< - protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, - protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest|null|undefined, - {}|null|undefined>): - Promise<[ - protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, - protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'name': request.name ?? '', - }); - this.initialize(); - return this.innerApiCalls.getInterconnectAttachment(request, options, callback); - } -/** - * Gets details of a single Router. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.name - * Required. Name of the resource - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.Router|Router}. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.get_router.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetRouter_async - */ - getRouter( - request?: protos.google.cloud.edgenetwork.v1.IGetRouterRequest, - options?: CallOptions): - Promise<[ - protos.google.cloud.edgenetwork.v1.IRouter, - protos.google.cloud.edgenetwork.v1.IGetRouterRequest|undefined, {}|undefined - ]>; - getRouter( - request: protos.google.cloud.edgenetwork.v1.IGetRouterRequest, - options: CallOptions, - callback: Callback< - protos.google.cloud.edgenetwork.v1.IRouter, - protos.google.cloud.edgenetwork.v1.IGetRouterRequest|null|undefined, - {}|null|undefined>): void; - getRouter( - request: protos.google.cloud.edgenetwork.v1.IGetRouterRequest, - callback: Callback< - protos.google.cloud.edgenetwork.v1.IRouter, - protos.google.cloud.edgenetwork.v1.IGetRouterRequest|null|undefined, - {}|null|undefined>): void; - getRouter( - request?: protos.google.cloud.edgenetwork.v1.IGetRouterRequest, - optionsOrCallback?: CallOptions|Callback< - protos.google.cloud.edgenetwork.v1.IRouter, - protos.google.cloud.edgenetwork.v1.IGetRouterRequest|null|undefined, - {}|null|undefined>, - callback?: Callback< - protos.google.cloud.edgenetwork.v1.IRouter, - protos.google.cloud.edgenetwork.v1.IGetRouterRequest|null|undefined, - {}|null|undefined>): - Promise<[ - protos.google.cloud.edgenetwork.v1.IRouter, - protos.google.cloud.edgenetwork.v1.IGetRouterRequest|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'name': request.name ?? '', - }); - this.initialize(); - return this.innerApiCalls.getRouter(request, options, callback); - } -/** - * Get the diagnostics of a single router resource. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.name - * Required. The name of the router resource. - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.DiagnoseRouterResponse|DiagnoseRouterResponse}. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.diagnose_router.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_DiagnoseRouter_async - */ - diagnoseRouter( - request?: protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest, - options?: CallOptions): - Promise<[ - protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest|undefined, {}|undefined - ]>; - diagnoseRouter( - request: protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest, - options: CallOptions, - callback: Callback< - protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest|null|undefined, - {}|null|undefined>): void; - diagnoseRouter( - request: protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest, - callback: Callback< - protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest|null|undefined, - {}|null|undefined>): void; - diagnoseRouter( - request?: protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest, - optionsOrCallback?: CallOptions|Callback< - protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest|null|undefined, - {}|null|undefined>, - callback?: Callback< - protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest|null|undefined, - {}|null|undefined>): - Promise<[ - protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, - protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'name': request.name ?? '', - }); - this.initialize(); - return this.innerApiCalls.diagnoseRouter(request, options, callback); - } - -/** - * Creates a new Network in a given project and location. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Value for parent. - * @param {string} request.networkId - * Required. Id of the requesting object - * If auto-generating Id server-side, remove this field and - * network_id from the method_signature of Create RPC - * @param {google.cloud.edgenetwork.v1.Network} request.network - * Required. The resource being created - * @param {string} [request.requestId] - * Optional. An optional request ID to identify requests. Specify a unique - * request ID so that if you must retry your request, the server will know to - * ignore the request if it has already been completed. The server will - * guarantee that for at least 60 minutes since the first request. - * - * For example, consider a situation where you make an initial request and - * the request times out. If you make the request again with the same request - * ID, the server can check if original operation with the same request ID - * was received, and if so, will ignore the second request. This prevents - * clients from accidentally creating duplicate commitments. - * - * The request ID must be a valid UUID with the exception that zero UUID is - * not supported (00000000-0000-0000-0000-000000000000). - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing - * a long running operation. Its `promise()` method returns a promise - * you can `await` for. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.create_network.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateNetwork_async - */ - createNetwork( - request?: protos.google.cloud.edgenetwork.v1.ICreateNetworkRequest, - options?: CallOptions): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>; - createNetwork( - request: protos.google.cloud.edgenetwork.v1.ICreateNetworkRequest, - options: CallOptions, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - createNetwork( - request: protos.google.cloud.edgenetwork.v1.ICreateNetworkRequest, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - createNetwork( - request?: protos.google.cloud.edgenetwork.v1.ICreateNetworkRequest, - optionsOrCallback?: CallOptions|Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>, - callback?: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - this.initialize(); - return this.innerApiCalls.createNetwork(request, options, callback); - } -/** - * Check the status of the long running operation returned by `createNetwork()`. - * @param {String} name - * The operation name that will be passed. - * @returns {Promise} - The promise which resolves to an object. - * The decoded operation object has result and metadata field to get information from. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.create_network.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateNetwork_async - */ - async checkCreateNetworkProgress(name: string): Promise>{ - const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); - const [operation] = await this.operationsClient.getOperation(request); - const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.createNetwork, this._gaxModule.createDefaultBackoffSettings()); - return decodeOperation as LROperation; - } -/** - * Deletes a single Network. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.name - * Required. Name of the resource - * @param {string} [request.requestId] - * Optional. An optional request ID to identify requests. Specify a unique - * request ID so that if you must retry your request, the server will know to - * ignore the request if it has already been completed. The server will - * guarantee that for at least 60 minutes after the first request. - * - * For example, consider a situation where you make an initial request and - * the request times out. If you make the request again with the same request - * ID, the server can check if original operation with the same request ID - * was received, and if so, will ignore the second request. This prevents - * clients from accidentally creating duplicate commitments. - * - * The request ID must be a valid UUID with the exception that zero UUID is - * not supported (00000000-0000-0000-0000-000000000000). - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing - * a long running operation. Its `promise()` method returns a promise - * you can `await` for. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.delete_network.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteNetwork_async - */ - deleteNetwork( - request?: protos.google.cloud.edgenetwork.v1.IDeleteNetworkRequest, - options?: CallOptions): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>; - deleteNetwork( - request: protos.google.cloud.edgenetwork.v1.IDeleteNetworkRequest, - options: CallOptions, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - deleteNetwork( - request: protos.google.cloud.edgenetwork.v1.IDeleteNetworkRequest, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - deleteNetwork( - request?: protos.google.cloud.edgenetwork.v1.IDeleteNetworkRequest, - optionsOrCallback?: CallOptions|Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>, - callback?: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'name': request.name ?? '', - }); - this.initialize(); - return this.innerApiCalls.deleteNetwork(request, options, callback); - } -/** - * Check the status of the long running operation returned by `deleteNetwork()`. - * @param {String} name - * The operation name that will be passed. - * @returns {Promise} - The promise which resolves to an object. - * The decoded operation object has result and metadata field to get information from. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.delete_network.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteNetwork_async - */ - async checkDeleteNetworkProgress(name: string): Promise>{ - const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); - const [operation] = await this.operationsClient.getOperation(request); - const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.deleteNetwork, this._gaxModule.createDefaultBackoffSettings()); - return decodeOperation as LROperation; - } -/** - * Creates a new Subnet in a given project and location. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Value for parent. - * @param {string} request.subnetId - * Required. Id of the requesting object - * If auto-generating Id server-side, remove this field and - * subnet_id from the method_signature of Create RPC - * @param {google.cloud.edgenetwork.v1.Subnet} request.subnet - * Required. The resource being created - * @param {string} [request.requestId] - * Optional. An optional request ID to identify requests. Specify a unique - * request ID so that if you must retry your request, the server will know to - * ignore the request if it has already been completed. The server will - * guarantee that for at least 60 minutes since the first request. - * - * For example, consider a situation where you make an initial request and - * the request times out. If you make the request again with the same request - * ID, the server can check if original operation with the same request ID - * was received, and if so, will ignore the second request. This prevents - * clients from accidentally creating duplicate commitments. - * - * The request ID must be a valid UUID with the exception that zero UUID is - * not supported (00000000-0000-0000-0000-000000000000). - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing - * a long running operation. Its `promise()` method returns a promise - * you can `await` for. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.create_subnet.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateSubnet_async - */ - createSubnet( - request?: protos.google.cloud.edgenetwork.v1.ICreateSubnetRequest, - options?: CallOptions): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>; - createSubnet( - request: protos.google.cloud.edgenetwork.v1.ICreateSubnetRequest, - options: CallOptions, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - createSubnet( - request: protos.google.cloud.edgenetwork.v1.ICreateSubnetRequest, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - createSubnet( - request?: protos.google.cloud.edgenetwork.v1.ICreateSubnetRequest, - optionsOrCallback?: CallOptions|Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>, - callback?: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - this.initialize(); - return this.innerApiCalls.createSubnet(request, options, callback); - } -/** - * Check the status of the long running operation returned by `createSubnet()`. - * @param {String} name - * The operation name that will be passed. - * @returns {Promise} - The promise which resolves to an object. - * The decoded operation object has result and metadata field to get information from. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.create_subnet.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateSubnet_async - */ - async checkCreateSubnetProgress(name: string): Promise>{ - const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); - const [operation] = await this.operationsClient.getOperation(request); - const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.createSubnet, this._gaxModule.createDefaultBackoffSettings()); - return decodeOperation as LROperation; - } -/** - * Updates the parameters of a single Subnet. - * - * @param {Object} request - * The request object that will be sent. - * @param {google.protobuf.FieldMask} request.updateMask - * Required. Field mask is used to specify the fields to be overwritten in the - * Subnet resource by the update. - * The fields specified in the update_mask are relative to the resource, not - * the full request. A field will be overwritten if it is in the mask. If the - * user does not provide a mask then all fields will be overwritten. - * @param {google.cloud.edgenetwork.v1.Subnet} request.subnet - * Required. The resource being updated - * @param {string} [request.requestId] - * Optional. An optional request ID to identify requests. Specify a unique - * request ID so that if you must retry your request, the server will know to - * ignore the request if it has already been completed. The server will - * guarantee that for at least 60 minutes since the first request. - * - * For example, consider a situation where you make an initial request and - * the request times out. If you make the request again with the same request - * ID, the server can check if original operation with the same request ID - * was received, and if so, will ignore the second request. This prevents - * clients from accidentally creating duplicate commitments. - * - * The request ID must be a valid UUID with the exception that zero UUID is - * not supported (00000000-0000-0000-0000-000000000000). - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing - * a long running operation. Its `promise()` method returns a promise - * you can `await` for. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.update_subnet.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_UpdateSubnet_async - */ - updateSubnet( - request?: protos.google.cloud.edgenetwork.v1.IUpdateSubnetRequest, - options?: CallOptions): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>; - updateSubnet( - request: protos.google.cloud.edgenetwork.v1.IUpdateSubnetRequest, - options: CallOptions, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - updateSubnet( - request: protos.google.cloud.edgenetwork.v1.IUpdateSubnetRequest, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - updateSubnet( - request?: protos.google.cloud.edgenetwork.v1.IUpdateSubnetRequest, - optionsOrCallback?: CallOptions|Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>, - callback?: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'subnet.name': request.subnet!.name ?? '', - }); - this.initialize(); - return this.innerApiCalls.updateSubnet(request, options, callback); - } -/** - * Check the status of the long running operation returned by `updateSubnet()`. - * @param {String} name - * The operation name that will be passed. - * @returns {Promise} - The promise which resolves to an object. - * The decoded operation object has result and metadata field to get information from. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.update_subnet.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_UpdateSubnet_async - */ - async checkUpdateSubnetProgress(name: string): Promise>{ - const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); - const [operation] = await this.operationsClient.getOperation(request); - const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.updateSubnet, this._gaxModule.createDefaultBackoffSettings()); - return decodeOperation as LROperation; - } -/** - * Deletes a single Subnet. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.name - * Required. Name of the resource - * @param {string} [request.requestId] - * Optional. An optional request ID to identify requests. Specify a unique - * request ID so that if you must retry your request, the server will know to - * ignore the request if it has already been completed. The server will - * guarantee that for at least 60 minutes after the first request. - * - * For example, consider a situation where you make an initial request and - * the request times out. If you make the request again with the same request - * ID, the server can check if original operation with the same request ID - * was received, and if so, will ignore the second request. This prevents - * clients from accidentally creating duplicate commitments. - * - * The request ID must be a valid UUID with the exception that zero UUID is - * not supported (00000000-0000-0000-0000-000000000000). - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing - * a long running operation. Its `promise()` method returns a promise - * you can `await` for. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.delete_subnet.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteSubnet_async - */ - deleteSubnet( - request?: protos.google.cloud.edgenetwork.v1.IDeleteSubnetRequest, - options?: CallOptions): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>; - deleteSubnet( - request: protos.google.cloud.edgenetwork.v1.IDeleteSubnetRequest, - options: CallOptions, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - deleteSubnet( - request: protos.google.cloud.edgenetwork.v1.IDeleteSubnetRequest, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - deleteSubnet( - request?: protos.google.cloud.edgenetwork.v1.IDeleteSubnetRequest, - optionsOrCallback?: CallOptions|Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>, - callback?: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'name': request.name ?? '', - }); - this.initialize(); - return this.innerApiCalls.deleteSubnet(request, options, callback); - } -/** - * Check the status of the long running operation returned by `deleteSubnet()`. - * @param {String} name - * The operation name that will be passed. - * @returns {Promise} - The promise which resolves to an object. - * The decoded operation object has result and metadata field to get information from. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.delete_subnet.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteSubnet_async - */ - async checkDeleteSubnetProgress(name: string): Promise>{ - const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); - const [operation] = await this.operationsClient.getOperation(request); - const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.deleteSubnet, this._gaxModule.createDefaultBackoffSettings()); - return decodeOperation as LROperation; - } -/** - * Creates a new InterconnectAttachment in a given project and location. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Value for parent. - * @param {string} request.interconnectAttachmentId - * Required. Id of the requesting object - * If auto-generating Id server-side, remove this field and - * interconnect_attachment_id from the method_signature of Create RPC - * @param {google.cloud.edgenetwork.v1.InterconnectAttachment} request.interconnectAttachment - * Required. The resource being created - * @param {string} [request.requestId] - * Optional. An optional request ID to identify requests. Specify a unique - * request ID so that if you must retry your request, the server will know to - * ignore the request if it has already been completed. The server will - * guarantee that for at least 60 minutes since the first request. - * - * For example, consider a situation where you make an initial request and - * the request times out. If you make the request again with the same request - * ID, the server can check if original operation with the same request ID - * was received, and if so, will ignore the second request. This prevents - * clients from accidentally creating duplicate commitments. - * - * The request ID must be a valid UUID with the exception that zero UUID is - * not supported (00000000-0000-0000-0000-000000000000). - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing - * a long running operation. Its `promise()` method returns a promise - * you can `await` for. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.create_interconnect_attachment.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateInterconnectAttachment_async - */ - createInterconnectAttachment( - request?: protos.google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest, - options?: CallOptions): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>; - createInterconnectAttachment( - request: protos.google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest, - options: CallOptions, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - createInterconnectAttachment( - request: protos.google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - createInterconnectAttachment( - request?: protos.google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest, - optionsOrCallback?: CallOptions|Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>, - callback?: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - this.initialize(); - return this.innerApiCalls.createInterconnectAttachment(request, options, callback); - } -/** - * Check the status of the long running operation returned by `createInterconnectAttachment()`. - * @param {String} name - * The operation name that will be passed. - * @returns {Promise} - The promise which resolves to an object. - * The decoded operation object has result and metadata field to get information from. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.create_interconnect_attachment.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateInterconnectAttachment_async - */ - async checkCreateInterconnectAttachmentProgress(name: string): Promise>{ - const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); - const [operation] = await this.operationsClient.getOperation(request); - const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.createInterconnectAttachment, this._gaxModule.createDefaultBackoffSettings()); - return decodeOperation as LROperation; - } -/** - * Deletes a single InterconnectAttachment. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.name - * Required. Name of the resource - * @param {string} [request.requestId] - * Optional. An optional request ID to identify requests. Specify a unique - * request ID so that if you must retry your request, the server will know to - * ignore the request if it has already been completed. The server will - * guarantee that for at least 60 minutes after the first request. - * - * For example, consider a situation where you make an initial request and - * the request times out. If you make the request again with the same request - * ID, the server can check if original operation with the same request ID - * was received, and if so, will ignore the second request. This prevents - * clients from accidentally creating duplicate commitments. - * - * The request ID must be a valid UUID with the exception that zero UUID is - * not supported (00000000-0000-0000-0000-000000000000). - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing - * a long running operation. Its `promise()` method returns a promise - * you can `await` for. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.delete_interconnect_attachment.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteInterconnectAttachment_async - */ - deleteInterconnectAttachment( - request?: protos.google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest, - options?: CallOptions): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>; - deleteInterconnectAttachment( - request: protos.google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest, - options: CallOptions, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - deleteInterconnectAttachment( - request: protos.google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - deleteInterconnectAttachment( - request?: protos.google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest, - optionsOrCallback?: CallOptions|Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>, - callback?: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'name': request.name ?? '', - }); - this.initialize(); - return this.innerApiCalls.deleteInterconnectAttachment(request, options, callback); - } -/** - * Check the status of the long running operation returned by `deleteInterconnectAttachment()`. - * @param {String} name - * The operation name that will be passed. - * @returns {Promise} - The promise which resolves to an object. - * The decoded operation object has result and metadata field to get information from. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.delete_interconnect_attachment.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteInterconnectAttachment_async - */ - async checkDeleteInterconnectAttachmentProgress(name: string): Promise>{ - const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); - const [operation] = await this.operationsClient.getOperation(request); - const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.deleteInterconnectAttachment, this._gaxModule.createDefaultBackoffSettings()); - return decodeOperation as LROperation; - } -/** - * Creates a new Router in a given project and location. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Value for parent. - * @param {string} request.routerId - * Required. Id of the requesting object - * If auto-generating Id server-side, remove this field and - * router_id from the method_signature of Create RPC - * @param {google.cloud.edgenetwork.v1.Router} request.router - * Required. The resource being created - * @param {string} [request.requestId] - * Optional. An optional request ID to identify requests. Specify a unique - * request ID so that if you must retry your request, the server will know to - * ignore the request if it has already been completed. The server will - * guarantee that for at least 60 minutes since the first request. - * - * For example, consider a situation where you make an initial request and - * the request times out. If you make the request again with the same request - * ID, the server can check if original operation with the same request ID - * was received, and if so, will ignore the second request. This prevents - * clients from accidentally creating duplicate commitments. - * - * The request ID must be a valid UUID with the exception that zero UUID is - * not supported (00000000-0000-0000-0000-000000000000). - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing - * a long running operation. Its `promise()` method returns a promise - * you can `await` for. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.create_router.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateRouter_async - */ - createRouter( - request?: protos.google.cloud.edgenetwork.v1.ICreateRouterRequest, - options?: CallOptions): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>; - createRouter( - request: protos.google.cloud.edgenetwork.v1.ICreateRouterRequest, - options: CallOptions, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - createRouter( - request: protos.google.cloud.edgenetwork.v1.ICreateRouterRequest, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - createRouter( - request?: protos.google.cloud.edgenetwork.v1.ICreateRouterRequest, - optionsOrCallback?: CallOptions|Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>, - callback?: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - this.initialize(); - return this.innerApiCalls.createRouter(request, options, callback); - } -/** - * Check the status of the long running operation returned by `createRouter()`. - * @param {String} name - * The operation name that will be passed. - * @returns {Promise} - The promise which resolves to an object. - * The decoded operation object has result and metadata field to get information from. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.create_router.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateRouter_async - */ - async checkCreateRouterProgress(name: string): Promise>{ - const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); - const [operation] = await this.operationsClient.getOperation(request); - const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.createRouter, this._gaxModule.createDefaultBackoffSettings()); - return decodeOperation as LROperation; - } -/** - * Updates the parameters of a single Router. - * - * @param {Object} request - * The request object that will be sent. - * @param {google.protobuf.FieldMask} request.updateMask - * Required. Field mask is used to specify the fields to be overwritten in the - * Router resource by the update. - * The fields specified in the update_mask are relative to the resource, not - * the full request. A field will be overwritten if it is in the mask. If the - * user does not provide a mask then all fields will be overwritten. - * @param {google.cloud.edgenetwork.v1.Router} request.router - * Required. The resource being updated - * @param {string} [request.requestId] - * Optional. An optional request ID to identify requests. Specify a unique - * request ID so that if you must retry your request, the server will know to - * ignore the request if it has already been completed. The server will - * guarantee that for at least 60 minutes since the first request. - * - * For example, consider a situation where you make an initial request and - * the request times out. If you make the request again with the same request - * ID, the server can check if original operation with the same request ID - * was received, and if so, will ignore the second request. This prevents - * clients from accidentally creating duplicate commitments. - * - * The request ID must be a valid UUID with the exception that zero UUID is - * not supported (00000000-0000-0000-0000-000000000000). - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing - * a long running operation. Its `promise()` method returns a promise - * you can `await` for. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.update_router.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_UpdateRouter_async - */ - updateRouter( - request?: protos.google.cloud.edgenetwork.v1.IUpdateRouterRequest, - options?: CallOptions): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>; - updateRouter( - request: protos.google.cloud.edgenetwork.v1.IUpdateRouterRequest, - options: CallOptions, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - updateRouter( - request: protos.google.cloud.edgenetwork.v1.IUpdateRouterRequest, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - updateRouter( - request?: protos.google.cloud.edgenetwork.v1.IUpdateRouterRequest, - optionsOrCallback?: CallOptions|Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>, - callback?: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'router.name': request.router!.name ?? '', - }); - this.initialize(); - return this.innerApiCalls.updateRouter(request, options, callback); - } -/** - * Check the status of the long running operation returned by `updateRouter()`. - * @param {String} name - * The operation name that will be passed. - * @returns {Promise} - The promise which resolves to an object. - * The decoded operation object has result and metadata field to get information from. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.update_router.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_UpdateRouter_async - */ - async checkUpdateRouterProgress(name: string): Promise>{ - const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); - const [operation] = await this.operationsClient.getOperation(request); - const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.updateRouter, this._gaxModule.createDefaultBackoffSettings()); - return decodeOperation as LROperation; - } -/** - * Deletes a single Router. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.name - * Required. Name of the resource - * @param {string} [request.requestId] - * Optional. An optional request ID to identify requests. Specify a unique - * request ID so that if you must retry your request, the server will know to - * ignore the request if it has already been completed. The server will - * guarantee that for at least 60 minutes after the first request. - * - * For example, consider a situation where you make an initial request and - * the request times out. If you make the request again with the same request - * ID, the server can check if original operation with the same request ID - * was received, and if so, will ignore the second request. This prevents - * clients from accidentally creating duplicate commitments. - * - * The request ID must be a valid UUID with the exception that zero UUID is - * not supported (00000000-0000-0000-0000-000000000000). - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing - * a long running operation. Its `promise()` method returns a promise - * you can `await` for. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.delete_router.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteRouter_async - */ - deleteRouter( - request?: protos.google.cloud.edgenetwork.v1.IDeleteRouterRequest, - options?: CallOptions): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>; - deleteRouter( - request: protos.google.cloud.edgenetwork.v1.IDeleteRouterRequest, - options: CallOptions, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - deleteRouter( - request: protos.google.cloud.edgenetwork.v1.IDeleteRouterRequest, - callback: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): void; - deleteRouter( - request?: protos.google.cloud.edgenetwork.v1.IDeleteRouterRequest, - optionsOrCallback?: CallOptions|Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>, - callback?: Callback< - LROperation, - protos.google.longrunning.IOperation|null|undefined, - {}|null|undefined>): - Promise<[ - LROperation, - protos.google.longrunning.IOperation|undefined, {}|undefined - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'name': request.name ?? '', - }); - this.initialize(); - return this.innerApiCalls.deleteRouter(request, options, callback); - } -/** - * Check the status of the long running operation returned by `deleteRouter()`. - * @param {String} name - * The operation name that will be passed. - * @returns {Promise} - The promise which resolves to an object. - * The decoded operation object has result and metadata field to get information from. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.delete_router.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteRouter_async - */ - async checkDeleteRouterProgress(name: string): Promise>{ - const request = new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest({name}); - const [operation] = await this.operationsClient.getOperation(request); - const decodeOperation = new this._gaxModule.Operation(operation, this.descriptors.longrunning.deleteRouter, this._gaxModule.createDefaultBackoffSettings()); - return decodeOperation as LROperation; - } - /** - * Lists Zones in a given project and location. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListZonesRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.Zone|Zone}. - * The client library will perform auto-pagination by default: it will call the API as many - * times as needed and will merge results from all the pages into this array. - * Note that it can affect your quota. - * We recommend using `listZonesAsync()` - * method described below for async iteration which you can stop as needed. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - */ - listZones( - request?: protos.google.cloud.edgenetwork.v1.IListZonesRequest, - options?: CallOptions): - Promise<[ - protos.google.cloud.edgenetwork.v1.IZone[], - protos.google.cloud.edgenetwork.v1.IListZonesRequest|null, - protos.google.cloud.edgenetwork.v1.IListZonesResponse - ]>; - listZones( - request: protos.google.cloud.edgenetwork.v1.IListZonesRequest, - options: CallOptions, - callback: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListZonesRequest, - protos.google.cloud.edgenetwork.v1.IListZonesResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.IZone>): void; - listZones( - request: protos.google.cloud.edgenetwork.v1.IListZonesRequest, - callback: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListZonesRequest, - protos.google.cloud.edgenetwork.v1.IListZonesResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.IZone>): void; - listZones( - request?: protos.google.cloud.edgenetwork.v1.IListZonesRequest, - optionsOrCallback?: CallOptions|PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListZonesRequest, - protos.google.cloud.edgenetwork.v1.IListZonesResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.IZone>, - callback?: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListZonesRequest, - protos.google.cloud.edgenetwork.v1.IListZonesResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.IZone>): - Promise<[ - protos.google.cloud.edgenetwork.v1.IZone[], - protos.google.cloud.edgenetwork.v1.IListZonesRequest|null, - protos.google.cloud.edgenetwork.v1.IListZonesResponse - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - this.initialize(); - return this.innerApiCalls.listZones(request, options, callback); - } - -/** - * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListZonesRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Stream} - * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.Zone|Zone} on 'data' event. - * The client library will perform auto-pagination by default: it will call the API as many - * times as needed. Note that it can affect your quota. - * We recommend using `listZonesAsync()` - * method described below for async iteration which you can stop as needed. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - */ - listZonesStream( - request?: protos.google.cloud.edgenetwork.v1.IListZonesRequest, - options?: CallOptions): - Transform{ - request = request || {}; - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - const defaultCallSettings = this._defaults['listZones']; - const callSettings = defaultCallSettings.merge(options); - this.initialize(); - return this.descriptors.page.listZones.createStream( - this.innerApiCalls.listZones as GaxCall, - request, - callSettings - ); - } - -/** - * Equivalent to `listZones`, but returns an iterable object. - * - * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListZonesRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Object} - * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. - * When you iterate the returned iterable, each element will be an object representing - * {@link protos.google.cloud.edgenetwork.v1.Zone|Zone}. The API will be called under the hood as needed, once per the page, - * so you can stop the iteration when you don't need more results. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.list_zones.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListZones_async - */ - listZonesAsync( - request?: protos.google.cloud.edgenetwork.v1.IListZonesRequest, - options?: CallOptions): - AsyncIterable{ - request = request || {}; - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - const defaultCallSettings = this._defaults['listZones']; - const callSettings = defaultCallSettings.merge(options); - this.initialize(); - return this.descriptors.page.listZones.asyncIterate( - this.innerApiCalls['listZones'] as GaxCall, - request as {}, - callSettings - ) as AsyncIterable; - } - /** - * Lists Networks in a given project and location. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListNetworksRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.Network|Network}. - * The client library will perform auto-pagination by default: it will call the API as many - * times as needed and will merge results from all the pages into this array. - * Note that it can affect your quota. - * We recommend using `listNetworksAsync()` - * method described below for async iteration which you can stop as needed. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - */ - listNetworks( - request?: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, - options?: CallOptions): - Promise<[ - protos.google.cloud.edgenetwork.v1.INetwork[], - protos.google.cloud.edgenetwork.v1.IListNetworksRequest|null, - protos.google.cloud.edgenetwork.v1.IListNetworksResponse - ]>; - listNetworks( - request: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, - options: CallOptions, - callback: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListNetworksRequest, - protos.google.cloud.edgenetwork.v1.IListNetworksResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.INetwork>): void; - listNetworks( - request: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, - callback: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListNetworksRequest, - protos.google.cloud.edgenetwork.v1.IListNetworksResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.INetwork>): void; - listNetworks( - request?: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, - optionsOrCallback?: CallOptions|PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListNetworksRequest, - protos.google.cloud.edgenetwork.v1.IListNetworksResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.INetwork>, - callback?: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListNetworksRequest, - protos.google.cloud.edgenetwork.v1.IListNetworksResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.INetwork>): - Promise<[ - protos.google.cloud.edgenetwork.v1.INetwork[], - protos.google.cloud.edgenetwork.v1.IListNetworksRequest|null, - protos.google.cloud.edgenetwork.v1.IListNetworksResponse - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - this.initialize(); - return this.innerApiCalls.listNetworks(request, options, callback); - } - -/** - * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListNetworksRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Stream} - * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.Network|Network} on 'data' event. - * The client library will perform auto-pagination by default: it will call the API as many - * times as needed. Note that it can affect your quota. - * We recommend using `listNetworksAsync()` - * method described below for async iteration which you can stop as needed. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - */ - listNetworksStream( - request?: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, - options?: CallOptions): - Transform{ - request = request || {}; - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - const defaultCallSettings = this._defaults['listNetworks']; - const callSettings = defaultCallSettings.merge(options); - this.initialize(); - return this.descriptors.page.listNetworks.createStream( - this.innerApiCalls.listNetworks as GaxCall, - request, - callSettings - ); - } - -/** - * Equivalent to `listNetworks`, but returns an iterable object. - * - * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListNetworksRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Object} - * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. - * When you iterate the returned iterable, each element will be an object representing - * {@link protos.google.cloud.edgenetwork.v1.Network|Network}. The API will be called under the hood as needed, once per the page, - * so you can stop the iteration when you don't need more results. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.list_networks.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListNetworks_async - */ - listNetworksAsync( - request?: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, - options?: CallOptions): - AsyncIterable{ - request = request || {}; - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - const defaultCallSettings = this._defaults['listNetworks']; - const callSettings = defaultCallSettings.merge(options); - this.initialize(); - return this.descriptors.page.listNetworks.asyncIterate( - this.innerApiCalls['listNetworks'] as GaxCall, - request as {}, - callSettings - ) as AsyncIterable; - } - /** - * Lists Subnets in a given project and location. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListSubnetsRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.Subnet|Subnet}. - * The client library will perform auto-pagination by default: it will call the API as many - * times as needed and will merge results from all the pages into this array. - * Note that it can affect your quota. - * We recommend using `listSubnetsAsync()` - * method described below for async iteration which you can stop as needed. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - */ - listSubnets( - request?: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, - options?: CallOptions): - Promise<[ - protos.google.cloud.edgenetwork.v1.ISubnet[], - protos.google.cloud.edgenetwork.v1.IListSubnetsRequest|null, - protos.google.cloud.edgenetwork.v1.IListSubnetsResponse - ]>; - listSubnets( - request: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, - options: CallOptions, - callback: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, - protos.google.cloud.edgenetwork.v1.IListSubnetsResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.ISubnet>): void; - listSubnets( - request: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, - callback: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, - protos.google.cloud.edgenetwork.v1.IListSubnetsResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.ISubnet>): void; - listSubnets( - request?: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, - optionsOrCallback?: CallOptions|PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, - protos.google.cloud.edgenetwork.v1.IListSubnetsResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.ISubnet>, - callback?: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, - protos.google.cloud.edgenetwork.v1.IListSubnetsResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.ISubnet>): - Promise<[ - protos.google.cloud.edgenetwork.v1.ISubnet[], - protos.google.cloud.edgenetwork.v1.IListSubnetsRequest|null, - protos.google.cloud.edgenetwork.v1.IListSubnetsResponse - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - this.initialize(); - return this.innerApiCalls.listSubnets(request, options, callback); - } - -/** - * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListSubnetsRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Stream} - * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.Subnet|Subnet} on 'data' event. - * The client library will perform auto-pagination by default: it will call the API as many - * times as needed. Note that it can affect your quota. - * We recommend using `listSubnetsAsync()` - * method described below for async iteration which you can stop as needed. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - */ - listSubnetsStream( - request?: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, - options?: CallOptions): - Transform{ - request = request || {}; - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - const defaultCallSettings = this._defaults['listSubnets']; - const callSettings = defaultCallSettings.merge(options); - this.initialize(); - return this.descriptors.page.listSubnets.createStream( - this.innerApiCalls.listSubnets as GaxCall, - request, - callSettings - ); - } - -/** - * Equivalent to `listSubnets`, but returns an iterable object. - * - * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListSubnetsRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Object} - * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. - * When you iterate the returned iterable, each element will be an object representing - * {@link protos.google.cloud.edgenetwork.v1.Subnet|Subnet}. The API will be called under the hood as needed, once per the page, - * so you can stop the iteration when you don't need more results. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.list_subnets.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListSubnets_async - */ - listSubnetsAsync( - request?: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, - options?: CallOptions): - AsyncIterable{ - request = request || {}; - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - const defaultCallSettings = this._defaults['listSubnets']; - const callSettings = defaultCallSettings.merge(options); - this.initialize(); - return this.descriptors.page.listSubnets.asyncIterate( - this.innerApiCalls['listSubnets'] as GaxCall, - request as {}, - callSettings - ) as AsyncIterable; - } - /** - * Lists Interconnects in a given project and location. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListInterconnectsRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.Interconnect|Interconnect}. - * The client library will perform auto-pagination by default: it will call the API as many - * times as needed and will merge results from all the pages into this array. - * Note that it can affect your quota. - * We recommend using `listInterconnectsAsync()` - * method described below for async iteration which you can stop as needed. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - */ - listInterconnects( - request?: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, - options?: CallOptions): - Promise<[ - protos.google.cloud.edgenetwork.v1.IInterconnect[], - protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest|null, - protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse - ]>; - listInterconnects( - request: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, - options: CallOptions, - callback: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, - protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.IInterconnect>): void; - listInterconnects( - request: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, - callback: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, - protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.IInterconnect>): void; - listInterconnects( - request?: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, - optionsOrCallback?: CallOptions|PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, - protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.IInterconnect>, - callback?: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, - protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.IInterconnect>): - Promise<[ - protos.google.cloud.edgenetwork.v1.IInterconnect[], - protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest|null, - protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - this.initialize(); - return this.innerApiCalls.listInterconnects(request, options, callback); - } - -/** - * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListInterconnectsRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Stream} - * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.Interconnect|Interconnect} on 'data' event. - * The client library will perform auto-pagination by default: it will call the API as many - * times as needed. Note that it can affect your quota. - * We recommend using `listInterconnectsAsync()` - * method described below for async iteration which you can stop as needed. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - */ - listInterconnectsStream( - request?: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, - options?: CallOptions): - Transform{ - request = request || {}; - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - const defaultCallSettings = this._defaults['listInterconnects']; - const callSettings = defaultCallSettings.merge(options); - this.initialize(); - return this.descriptors.page.listInterconnects.createStream( - this.innerApiCalls.listInterconnects as GaxCall, - request, - callSettings - ); - } - -/** - * Equivalent to `listInterconnects`, but returns an iterable object. - * - * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListInterconnectsRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Object} - * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. - * When you iterate the returned iterable, each element will be an object representing - * {@link protos.google.cloud.edgenetwork.v1.Interconnect|Interconnect}. The API will be called under the hood as needed, once per the page, - * so you can stop the iteration when you don't need more results. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.list_interconnects.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListInterconnects_async - */ - listInterconnectsAsync( - request?: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, - options?: CallOptions): - AsyncIterable{ - request = request || {}; - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - const defaultCallSettings = this._defaults['listInterconnects']; - const callSettings = defaultCallSettings.merge(options); - this.initialize(); - return this.descriptors.page.listInterconnects.asyncIterate( - this.innerApiCalls['listInterconnects'] as GaxCall, - request as {}, - callSettings - ) as AsyncIterable; - } - /** - * Lists InterconnectAttachments in a given project and location. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListInterconnectAttachmentsRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.InterconnectAttachment|InterconnectAttachment}. - * The client library will perform auto-pagination by default: it will call the API as many - * times as needed and will merge results from all the pages into this array. - * Note that it can affect your quota. - * We recommend using `listInterconnectAttachmentsAsync()` - * method described below for async iteration which you can stop as needed. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - */ - listInterconnectAttachments( - request?: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, - options?: CallOptions): - Promise<[ - protos.google.cloud.edgenetwork.v1.IInterconnectAttachment[], - protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest|null, - protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse - ]>; - listInterconnectAttachments( - request: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, - options: CallOptions, - callback: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, - protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.IInterconnectAttachment>): void; - listInterconnectAttachments( - request: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, - callback: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, - protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.IInterconnectAttachment>): void; - listInterconnectAttachments( - request?: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, - optionsOrCallback?: CallOptions|PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, - protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.IInterconnectAttachment>, - callback?: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, - protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.IInterconnectAttachment>): - Promise<[ - protos.google.cloud.edgenetwork.v1.IInterconnectAttachment[], - protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest|null, - protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - this.initialize(); - return this.innerApiCalls.listInterconnectAttachments(request, options, callback); - } - -/** - * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListInterconnectAttachmentsRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Stream} - * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.InterconnectAttachment|InterconnectAttachment} on 'data' event. - * The client library will perform auto-pagination by default: it will call the API as many - * times as needed. Note that it can affect your quota. - * We recommend using `listInterconnectAttachmentsAsync()` - * method described below for async iteration which you can stop as needed. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - */ - listInterconnectAttachmentsStream( - request?: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, - options?: CallOptions): - Transform{ - request = request || {}; - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - const defaultCallSettings = this._defaults['listInterconnectAttachments']; - const callSettings = defaultCallSettings.merge(options); - this.initialize(); - return this.descriptors.page.listInterconnectAttachments.createStream( - this.innerApiCalls.listInterconnectAttachments as GaxCall, - request, - callSettings - ); - } - -/** - * Equivalent to `listInterconnectAttachments`, but returns an iterable object. - * - * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListInterconnectAttachmentsRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Object} - * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. - * When you iterate the returned iterable, each element will be an object representing - * {@link protos.google.cloud.edgenetwork.v1.InterconnectAttachment|InterconnectAttachment}. The API will be called under the hood as needed, once per the page, - * so you can stop the iteration when you don't need more results. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.list_interconnect_attachments.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListInterconnectAttachments_async - */ - listInterconnectAttachmentsAsync( - request?: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, - options?: CallOptions): - AsyncIterable{ - request = request || {}; - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - const defaultCallSettings = this._defaults['listInterconnectAttachments']; - const callSettings = defaultCallSettings.merge(options); - this.initialize(); - return this.descriptors.page.listInterconnectAttachments.asyncIterate( - this.innerApiCalls['listInterconnectAttachments'] as GaxCall, - request as {}, - callSettings - ) as AsyncIterable; - } - /** - * Lists Routers in a given project and location. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListRoutersRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.Router|Router}. - * The client library will perform auto-pagination by default: it will call the API as many - * times as needed and will merge results from all the pages into this array. - * Note that it can affect your quota. - * We recommend using `listRoutersAsync()` - * method described below for async iteration which you can stop as needed. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - */ - listRouters( - request?: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, - options?: CallOptions): - Promise<[ - protos.google.cloud.edgenetwork.v1.IRouter[], - protos.google.cloud.edgenetwork.v1.IListRoutersRequest|null, - protos.google.cloud.edgenetwork.v1.IListRoutersResponse - ]>; - listRouters( - request: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, - options: CallOptions, - callback: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListRoutersRequest, - protos.google.cloud.edgenetwork.v1.IListRoutersResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.IRouter>): void; - listRouters( - request: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, - callback: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListRoutersRequest, - protos.google.cloud.edgenetwork.v1.IListRoutersResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.IRouter>): void; - listRouters( - request?: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, - optionsOrCallback?: CallOptions|PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListRoutersRequest, - protos.google.cloud.edgenetwork.v1.IListRoutersResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.IRouter>, - callback?: PaginationCallback< - protos.google.cloud.edgenetwork.v1.IListRoutersRequest, - protos.google.cloud.edgenetwork.v1.IListRoutersResponse|null|undefined, - protos.google.cloud.edgenetwork.v1.IRouter>): - Promise<[ - protos.google.cloud.edgenetwork.v1.IRouter[], - protos.google.cloud.edgenetwork.v1.IListRoutersRequest|null, - protos.google.cloud.edgenetwork.v1.IListRoutersResponse - ]>|void { - request = request || {}; - let options: CallOptions; - if (typeof optionsOrCallback === 'function' && callback === undefined) { - callback = optionsOrCallback; - options = {}; - } - else { - options = optionsOrCallback as CallOptions; - } - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - this.initialize(); - return this.innerApiCalls.listRouters(request, options, callback); - } - -/** - * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListRoutersRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Stream} - * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.Router|Router} on 'data' event. - * The client library will perform auto-pagination by default: it will call the API as many - * times as needed. Note that it can affect your quota. - * We recommend using `listRoutersAsync()` - * method described below for async iteration which you can stop as needed. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - */ - listRoutersStream( - request?: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, - options?: CallOptions): - Transform{ - request = request || {}; - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - const defaultCallSettings = this._defaults['listRouters']; - const callSettings = defaultCallSettings.merge(options); - this.initialize(); - return this.descriptors.page.listRouters.createStream( - this.innerApiCalls.listRouters as GaxCall, - request, - callSettings - ); - } - -/** - * Equivalent to `listRouters`, but returns an iterable object. - * - * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. - * @param {Object} request - * The request object that will be sent. - * @param {string} request.parent - * Required. Parent value for ListRoutersRequest - * @param {number} request.pageSize - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - * @param {string} request.pageToken - * A token identifying a page of results the server should return. - * @param {string} request.filter - * Filtering results - * @param {string} request.orderBy - * Hint for how to order the results - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Object} - * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. - * When you iterate the returned iterable, each element will be an object representing - * {@link protos.google.cloud.edgenetwork.v1.Router|Router}. The API will be called under the hood as needed, once per the page, - * so you can stop the iteration when you don't need more results. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - * @example include:samples/generated/v1/edge_network.list_routers.js - * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListRouters_async - */ - listRoutersAsync( - request?: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, - options?: CallOptions): - AsyncIterable{ - request = request || {}; - options = options || {}; - options.otherArgs = options.otherArgs || {}; - options.otherArgs.headers = options.otherArgs.headers || {}; - options.otherArgs.headers[ - 'x-goog-request-params' - ] = this._gaxModule.routingHeader.fromParams({ - 'parent': request.parent ?? '', - }); - const defaultCallSettings = this._defaults['listRouters']; - const callSettings = defaultCallSettings.merge(options); - this.initialize(); - return this.descriptors.page.listRouters.asyncIterate( - this.innerApiCalls['listRouters'] as GaxCall, - request as {}, - callSettings - ) as AsyncIterable; - } -/** - * Gets information about a location. - * - * @param {Object} request - * The request object that will be sent. - * @param {string} request.name - * Resource name for the location. - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html | CallOptions} for more details. - * @returns {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing {@link google.cloud.location.Location | Location}. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } - * for more details and examples. - * @example - * ``` - * const [response] = await client.getLocation(request); - * ``` - */ - getLocation( - request: LocationProtos.google.cloud.location.IGetLocationRequest, - options?: - | gax.CallOptions - | Callback< - LocationProtos.google.cloud.location.ILocation, - | LocationProtos.google.cloud.location.IGetLocationRequest - | null - | undefined, - {} | null | undefined - >, - callback?: Callback< - LocationProtos.google.cloud.location.ILocation, - | LocationProtos.google.cloud.location.IGetLocationRequest - | null - | undefined, - {} | null | undefined - > - ): Promise { - return this.locationsClient.getLocation(request, options, callback); - } - -/** - * Lists information about the supported locations for this service. Returns an iterable object. - * - * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. - * @param {Object} request - * The request object that will be sent. - * @param {string} request.name - * The resource that owns the locations collection, if applicable. - * @param {string} request.filter - * The standard list filter. - * @param {number} request.pageSize - * The standard list page size. - * @param {string} request.pageToken - * The standard list page token. - * @param {object} [options] - * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. - * @returns {Object} - * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. - * When you iterate the returned iterable, each element will be an object representing - * {@link google.cloud.location.Location | Location}. The API will be called under the hood as needed, once per the page, - * so you can stop the iteration when you don't need more results. - * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } - * for more details and examples. - * @example - * ``` - * const iterable = client.listLocationsAsync(request); - * for await (const response of iterable) { - * // process response - * } - * ``` - */ - listLocationsAsync( - request: LocationProtos.google.cloud.location.IListLocationsRequest, - options?: CallOptions - ): AsyncIterable { - return this.locationsClient.listLocationsAsync(request, options); - } - -/** - * Gets the latest state of a long-running operation. Clients can use this - * method to poll the operation result at intervals as recommended by the API - * service. - * - * @param {Object} request - The request object that will be sent. - * @param {string} request.name - The name of the operation resource. - * @param {Object=} options - * Optional parameters. You can override the default settings for this call, - * e.g, timeout, retries, paginations, etc. See {@link - * https://googleapis.github.io/gax-nodejs/global.html#CallOptions | gax.CallOptions} - * for the details. - * @param {function(?Error, ?Object)=} callback - * The function which will be called with the result of the API call. - * - * The second parameter to the callback is an object representing - * {@link google.longrunning.Operation | google.longrunning.Operation}. - * @return {Promise} - The promise which resolves to an array. - * The first element of the array is an object representing - * {@link google.longrunning.Operation | google.longrunning.Operation}. - * The promise has a method named "cancel" which cancels the ongoing API call. - * - * @example - * ``` - * const client = longrunning.operationsClient(); - * const name = ''; - * const [response] = await client.getOperation({name}); - * // doThingsWith(response) - * ``` - */ - getOperation( - request: protos.google.longrunning.GetOperationRequest, - options?: - | gax.CallOptions - | Callback< - protos.google.longrunning.Operation, - protos.google.longrunning.GetOperationRequest, - {} | null | undefined - >, - callback?: Callback< - protos.google.longrunning.Operation, - protos.google.longrunning.GetOperationRequest, - {} | null | undefined - > - ): Promise<[protos.google.longrunning.Operation]> { - return this.operationsClient.getOperation(request, options, callback); - } - /** - * Lists operations that match the specified filter in the request. If the - * server doesn't support this method, it returns `UNIMPLEMENTED`. Returns an iterable object. - * - * For-await-of syntax is used with the iterable to recursively get response element on-demand. - * - * @param {Object} request - The request object that will be sent. - * @param {string} request.name - The name of the operation collection. - * @param {string} request.filter - The standard list filter. - * @param {number=} request.pageSize - - * The maximum number of resources contained in the underlying API - * response. If page streaming is performed per-resource, this - * parameter does not affect the return value. If page streaming is - * performed per-page, this determines the maximum number of - * resources in a page. - * @param {Object=} options - * Optional parameters. You can override the default settings for this call, - * e.g, timeout, retries, paginations, etc. See {@link - * https://googleapis.github.io/gax-nodejs/global.html#CallOptions | gax.CallOptions} for the - * details. - * @returns {Object} - * An iterable Object that conforms to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | iteration protocols}. - * - * @example - * ``` - * const client = longrunning.operationsClient(); - * for await (const response of client.listOperationsAsync(request)); - * // doThingsWith(response) - * ``` - */ - listOperationsAsync( - request: protos.google.longrunning.ListOperationsRequest, - options?: gax.CallOptions - ): AsyncIterable { - return this.operationsClient.listOperationsAsync(request, options); - } - /** - * Starts asynchronous cancellation on a long-running operation. The server - * makes a best effort to cancel the operation, but success is not - * guaranteed. If the server doesn't support this method, it returns - * `google.rpc.Code.UNIMPLEMENTED`. Clients can use - * {@link Operations.GetOperation} or - * other methods to check whether the cancellation succeeded or whether the - * operation completed despite cancellation. On successful cancellation, - * the operation is not deleted; instead, it becomes an operation with - * an {@link Operation.error} value with a {@link google.rpc.Status.code} of - * 1, corresponding to `Code.CANCELLED`. - * - * @param {Object} request - The request object that will be sent. - * @param {string} request.name - The name of the operation resource to be cancelled. - * @param {Object=} options - * Optional parameters. You can override the default settings for this call, - * e.g, timeout, retries, paginations, etc. See {@link - * https://googleapis.github.io/gax-nodejs/global.html#CallOptions | gax.CallOptions} for the - * details. - * @param {function(?Error)=} callback - * The function which will be called with the result of the API call. - * @return {Promise} - The promise which resolves when API call finishes. - * The promise has a method named "cancel" which cancels the ongoing API - * call. - * - * @example - * ``` - * const client = longrunning.operationsClient(); - * await client.cancelOperation({name: ''}); - * ``` - */ - cancelOperation( - request: protos.google.longrunning.CancelOperationRequest, - options?: - | gax.CallOptions - | Callback< - protos.google.protobuf.Empty, - protos.google.longrunning.CancelOperationRequest, - {} | undefined | null - >, - callback?: Callback< - protos.google.longrunning.CancelOperationRequest, - protos.google.protobuf.Empty, - {} | undefined | null - > - ): Promise { - return this.operationsClient.cancelOperation(request, options, callback); - } - - /** - * Deletes a long-running operation. This method indicates that the client is - * no longer interested in the operation result. It does not cancel the - * operation. If the server doesn't support this method, it returns - * `google.rpc.Code.UNIMPLEMENTED`. - * - * @param {Object} request - The request object that will be sent. - * @param {string} request.name - The name of the operation resource to be deleted. - * @param {Object=} options - * Optional parameters. You can override the default settings for this call, - * e.g, timeout, retries, paginations, etc. See {@link - * https://googleapis.github.io/gax-nodejs/global.html#CallOptions | gax.CallOptions} - * for the details. - * @param {function(?Error)=} callback - * The function which will be called with the result of the API call. - * @return {Promise} - The promise which resolves when API call finishes. - * The promise has a method named "cancel" which cancels the ongoing API - * call. - * - * @example - * ``` - * const client = longrunning.operationsClient(); - * await client.deleteOperation({name: ''}); - * ``` - */ - deleteOperation( - request: protos.google.longrunning.DeleteOperationRequest, - options?: - | gax.CallOptions - | Callback< - protos.google.protobuf.Empty, - protos.google.longrunning.DeleteOperationRequest, - {} | null | undefined - >, - callback?: Callback< - protos.google.protobuf.Empty, - protos.google.longrunning.DeleteOperationRequest, - {} | null | undefined - > - ): Promise { - return this.operationsClient.deleteOperation(request, options, callback); - } - - // -------------------- - // -- Path templates -- - // -------------------- - - /** - * Return a fully-qualified interconnect resource name string. - * - * @param {string} project - * @param {string} location - * @param {string} zone - * @param {string} interconnect - * @returns {string} Resource name string. - */ - interconnectPath(project:string,location:string,zone:string,interconnect:string) { - return this.pathTemplates.interconnectPathTemplate.render({ - project: project, - location: location, - zone: zone, - interconnect: interconnect, - }); - } - - /** - * Parse the project from Interconnect resource. - * - * @param {string} interconnectName - * A fully-qualified path representing Interconnect resource. - * @returns {string} A string representing the project. - */ - matchProjectFromInterconnectName(interconnectName: string) { - return this.pathTemplates.interconnectPathTemplate.match(interconnectName).project; - } - - /** - * Parse the location from Interconnect resource. - * - * @param {string} interconnectName - * A fully-qualified path representing Interconnect resource. - * @returns {string} A string representing the location. - */ - matchLocationFromInterconnectName(interconnectName: string) { - return this.pathTemplates.interconnectPathTemplate.match(interconnectName).location; - } - - /** - * Parse the zone from Interconnect resource. - * - * @param {string} interconnectName - * A fully-qualified path representing Interconnect resource. - * @returns {string} A string representing the zone. - */ - matchZoneFromInterconnectName(interconnectName: string) { - return this.pathTemplates.interconnectPathTemplate.match(interconnectName).zone; - } - - /** - * Parse the interconnect from Interconnect resource. - * - * @param {string} interconnectName - * A fully-qualified path representing Interconnect resource. - * @returns {string} A string representing the interconnect. - */ - matchInterconnectFromInterconnectName(interconnectName: string) { - return this.pathTemplates.interconnectPathTemplate.match(interconnectName).interconnect; - } - - /** - * Return a fully-qualified interconnectAttachment resource name string. - * - * @param {string} project - * @param {string} location - * @param {string} zone - * @param {string} interconnect_attachment - * @returns {string} Resource name string. - */ - interconnectAttachmentPath(project:string,location:string,zone:string,interconnectAttachment:string) { - return this.pathTemplates.interconnectAttachmentPathTemplate.render({ - project: project, - location: location, - zone: zone, - interconnect_attachment: interconnectAttachment, - }); - } - - /** - * Parse the project from InterconnectAttachment resource. - * - * @param {string} interconnectAttachmentName - * A fully-qualified path representing InterconnectAttachment resource. - * @returns {string} A string representing the project. - */ - matchProjectFromInterconnectAttachmentName(interconnectAttachmentName: string) { - return this.pathTemplates.interconnectAttachmentPathTemplate.match(interconnectAttachmentName).project; - } - - /** - * Parse the location from InterconnectAttachment resource. - * - * @param {string} interconnectAttachmentName - * A fully-qualified path representing InterconnectAttachment resource. - * @returns {string} A string representing the location. - */ - matchLocationFromInterconnectAttachmentName(interconnectAttachmentName: string) { - return this.pathTemplates.interconnectAttachmentPathTemplate.match(interconnectAttachmentName).location; - } - - /** - * Parse the zone from InterconnectAttachment resource. - * - * @param {string} interconnectAttachmentName - * A fully-qualified path representing InterconnectAttachment resource. - * @returns {string} A string representing the zone. - */ - matchZoneFromInterconnectAttachmentName(interconnectAttachmentName: string) { - return this.pathTemplates.interconnectAttachmentPathTemplate.match(interconnectAttachmentName).zone; - } - - /** - * Parse the interconnect_attachment from InterconnectAttachment resource. - * - * @param {string} interconnectAttachmentName - * A fully-qualified path representing InterconnectAttachment resource. - * @returns {string} A string representing the interconnect_attachment. - */ - matchInterconnectAttachmentFromInterconnectAttachmentName(interconnectAttachmentName: string) { - return this.pathTemplates.interconnectAttachmentPathTemplate.match(interconnectAttachmentName).interconnect_attachment; - } - - /** - * Return a fully-qualified location resource name string. - * - * @param {string} project - * @param {string} location - * @returns {string} Resource name string. - */ - locationPath(project:string,location:string) { - return this.pathTemplates.locationPathTemplate.render({ - project: project, - location: location, - }); - } - - /** - * Parse the project from Location resource. - * - * @param {string} locationName - * A fully-qualified path representing Location resource. - * @returns {string} A string representing the project. - */ - matchProjectFromLocationName(locationName: string) { - return this.pathTemplates.locationPathTemplate.match(locationName).project; - } - - /** - * Parse the location from Location resource. - * - * @param {string} locationName - * A fully-qualified path representing Location resource. - * @returns {string} A string representing the location. - */ - matchLocationFromLocationName(locationName: string) { - return this.pathTemplates.locationPathTemplate.match(locationName).location; - } - - /** - * Return a fully-qualified network resource name string. - * - * @param {string} project - * @param {string} location - * @param {string} zone - * @param {string} network - * @returns {string} Resource name string. - */ - networkPath(project:string,location:string,zone:string,network:string) { - return this.pathTemplates.networkPathTemplate.render({ - project: project, - location: location, - zone: zone, - network: network, - }); - } - - /** - * Parse the project from Network resource. - * - * @param {string} networkName - * A fully-qualified path representing Network resource. - * @returns {string} A string representing the project. - */ - matchProjectFromNetworkName(networkName: string) { - return this.pathTemplates.networkPathTemplate.match(networkName).project; - } - - /** - * Parse the location from Network resource. - * - * @param {string} networkName - * A fully-qualified path representing Network resource. - * @returns {string} A string representing the location. - */ - matchLocationFromNetworkName(networkName: string) { - return this.pathTemplates.networkPathTemplate.match(networkName).location; - } - - /** - * Parse the zone from Network resource. - * - * @param {string} networkName - * A fully-qualified path representing Network resource. - * @returns {string} A string representing the zone. - */ - matchZoneFromNetworkName(networkName: string) { - return this.pathTemplates.networkPathTemplate.match(networkName).zone; - } - - /** - * Parse the network from Network resource. - * - * @param {string} networkName - * A fully-qualified path representing Network resource. - * @returns {string} A string representing the network. - */ - matchNetworkFromNetworkName(networkName: string) { - return this.pathTemplates.networkPathTemplate.match(networkName).network; - } - - /** - * Return a fully-qualified project resource name string. - * - * @param {string} project - * @returns {string} Resource name string. - */ - projectPath(project:string) { - return this.pathTemplates.projectPathTemplate.render({ - project: project, - }); - } - - /** - * Parse the project from Project resource. - * - * @param {string} projectName - * A fully-qualified path representing Project resource. - * @returns {string} A string representing the project. - */ - matchProjectFromProjectName(projectName: string) { - return this.pathTemplates.projectPathTemplate.match(projectName).project; - } - - /** - * Return a fully-qualified router resource name string. - * - * @param {string} project - * @param {string} location - * @param {string} zone - * @param {string} router - * @returns {string} Resource name string. - */ - routerPath(project:string,location:string,zone:string,router:string) { - return this.pathTemplates.routerPathTemplate.render({ - project: project, - location: location, - zone: zone, - router: router, - }); - } - - /** - * Parse the project from Router resource. - * - * @param {string} routerName - * A fully-qualified path representing Router resource. - * @returns {string} A string representing the project. - */ - matchProjectFromRouterName(routerName: string) { - return this.pathTemplates.routerPathTemplate.match(routerName).project; - } - - /** - * Parse the location from Router resource. - * - * @param {string} routerName - * A fully-qualified path representing Router resource. - * @returns {string} A string representing the location. - */ - matchLocationFromRouterName(routerName: string) { - return this.pathTemplates.routerPathTemplate.match(routerName).location; - } - - /** - * Parse the zone from Router resource. - * - * @param {string} routerName - * A fully-qualified path representing Router resource. - * @returns {string} A string representing the zone. - */ - matchZoneFromRouterName(routerName: string) { - return this.pathTemplates.routerPathTemplate.match(routerName).zone; - } - - /** - * Parse the router from Router resource. - * - * @param {string} routerName - * A fully-qualified path representing Router resource. - * @returns {string} A string representing the router. - */ - matchRouterFromRouterName(routerName: string) { - return this.pathTemplates.routerPathTemplate.match(routerName).router; - } - - /** - * Return a fully-qualified subnet resource name string. - * - * @param {string} project - * @param {string} location - * @param {string} zone - * @param {string} subnet - * @returns {string} Resource name string. - */ - subnetPath(project:string,location:string,zone:string,subnet:string) { - return this.pathTemplates.subnetPathTemplate.render({ - project: project, - location: location, - zone: zone, - subnet: subnet, - }); - } - - /** - * Parse the project from Subnet resource. - * - * @param {string} subnetName - * A fully-qualified path representing Subnet resource. - * @returns {string} A string representing the project. - */ - matchProjectFromSubnetName(subnetName: string) { - return this.pathTemplates.subnetPathTemplate.match(subnetName).project; - } - - /** - * Parse the location from Subnet resource. - * - * @param {string} subnetName - * A fully-qualified path representing Subnet resource. - * @returns {string} A string representing the location. - */ - matchLocationFromSubnetName(subnetName: string) { - return this.pathTemplates.subnetPathTemplate.match(subnetName).location; - } - - /** - * Parse the zone from Subnet resource. - * - * @param {string} subnetName - * A fully-qualified path representing Subnet resource. - * @returns {string} A string representing the zone. - */ - matchZoneFromSubnetName(subnetName: string) { - return this.pathTemplates.subnetPathTemplate.match(subnetName).zone; - } - - /** - * Parse the subnet from Subnet resource. - * - * @param {string} subnetName - * A fully-qualified path representing Subnet resource. - * @returns {string} A string representing the subnet. - */ - matchSubnetFromSubnetName(subnetName: string) { - return this.pathTemplates.subnetPathTemplate.match(subnetName).subnet; - } - - /** - * Return a fully-qualified zone resource name string. - * - * @param {string} project - * @param {string} location - * @param {string} zone - * @returns {string} Resource name string. - */ - zonePath(project:string,location:string,zone:string) { - return this.pathTemplates.zonePathTemplate.render({ - project: project, - location: location, - zone: zone, - }); - } - - /** - * Parse the project from Zone resource. - * - * @param {string} zoneName - * A fully-qualified path representing Zone resource. - * @returns {string} A string representing the project. - */ - matchProjectFromZoneName(zoneName: string) { - return this.pathTemplates.zonePathTemplate.match(zoneName).project; - } - - /** - * Parse the location from Zone resource. - * - * @param {string} zoneName - * A fully-qualified path representing Zone resource. - * @returns {string} A string representing the location. - */ - matchLocationFromZoneName(zoneName: string) { - return this.pathTemplates.zonePathTemplate.match(zoneName).location; - } - - /** - * Parse the zone from Zone resource. - * - * @param {string} zoneName - * A fully-qualified path representing Zone resource. - * @returns {string} A string representing the zone. - */ - matchZoneFromZoneName(zoneName: string) { - return this.pathTemplates.zonePathTemplate.match(zoneName).zone; - } - - /** - * Terminate the gRPC channel and close the client. - * - * The client will no longer be usable and all future behavior is undefined. - * @returns {Promise} A promise that resolves when the client is closed. - */ - close(): Promise { - if (this.edgeNetworkStub && !this._terminated) { - return this.edgeNetworkStub.then(stub => { - this._terminated = true; - stub.close(); - this.locationsClient.close(); - this.operationsClient.close(); - }); - } - return Promise.resolve(); - } -} diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/test/gapic_edge_network_v1.ts b/owl-bot-staging/google-cloud-edgenetwork/v1/test/gapic_edge_network_v1.ts deleted file mode 100644 index b1880de9d1a2..000000000000 --- a/owl-bot-staging/google-cloud-edgenetwork/v1/test/gapic_edge_network_v1.ts +++ /dev/null @@ -1,5119 +0,0 @@ -// Copyright 2023 Google LLC -// -// Licensed under the Apache License, Version 2.0 (the "License"); -// you may not use this file except in compliance with the License. -// You may obtain a copy of the License at -// -// https://www.apache.org/licenses/LICENSE-2.0 -// -// Unless required by applicable law or agreed to in writing, software -// distributed under the License is distributed on an "AS IS" BASIS, -// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -// See the License for the specific language governing permissions and -// limitations under the License. -// -// ** This file is automatically generated by gapic-generator-typescript. ** -// ** https://github.com/googleapis/gapic-generator-typescript ** -// ** All changes to this file may be overwritten. ** - -import * as protos from '../protos/protos'; -import * as assert from 'assert'; -import * as sinon from 'sinon'; -import {SinonStub} from 'sinon'; -import {describe, it} from 'mocha'; -import * as edgenetworkModule from '../src'; - -import {PassThrough} from 'stream'; - -import {protobuf, LROperation, operationsProtos, LocationProtos} from 'google-gax'; - -// Dynamically loaded proto JSON is needed to get the type information -// to fill in default values for request objects -const root = protobuf.Root.fromJSON(require('../protos/protos.json')).resolveAll(); - -// eslint-disable-next-line @typescript-eslint/no-unused-vars -function getTypeDefaultValue(typeName: string, fields: string[]) { - let type = root.lookupType(typeName) as protobuf.Type; - for (const field of fields.slice(0, -1)) { - type = type.fields[field]?.resolvedType as protobuf.Type; - } - return type.fields[fields[fields.length - 1]]?.defaultValue; -} - -function generateSampleMessage(instance: T) { - const filledObject = (instance.constructor as typeof protobuf.Message) - .toObject(instance as protobuf.Message, {defaults: true}); - return (instance.constructor as typeof protobuf.Message).fromObject(filledObject) as T; -} - -function stubSimpleCall(response?: ResponseType, error?: Error) { - return error ? sinon.stub().rejects(error) : sinon.stub().resolves([response]); -} - -function stubSimpleCallWithCallback(response?: ResponseType, error?: Error) { - return error ? sinon.stub().callsArgWith(2, error) : sinon.stub().callsArgWith(2, null, response); -} - -function stubLongRunningCall(response?: ResponseType, callError?: Error, lroError?: Error) { - const innerStub = lroError ? sinon.stub().rejects(lroError) : sinon.stub().resolves([response]); - const mockOperation = { - promise: innerStub, - }; - return callError ? sinon.stub().rejects(callError) : sinon.stub().resolves([mockOperation]); -} - -function stubLongRunningCallWithCallback(response?: ResponseType, callError?: Error, lroError?: Error) { - const innerStub = lroError ? sinon.stub().rejects(lroError) : sinon.stub().resolves([response]); - const mockOperation = { - promise: innerStub, - }; - return callError ? sinon.stub().callsArgWith(2, callError) : sinon.stub().callsArgWith(2, null, mockOperation); -} - -function stubPageStreamingCall(responses?: ResponseType[], error?: Error) { - const pagingStub = sinon.stub(); - if (responses) { - for (let i = 0; i < responses.length; ++i) { - pagingStub.onCall(i).callsArgWith(2, null, responses[i]); - } - } - const transformStub = error ? sinon.stub().callsArgWith(2, error) : pagingStub; - const mockStream = new PassThrough({ - objectMode: true, - transform: transformStub, - }); - // trigger as many responses as needed - if (responses) { - for (let i = 0; i < responses.length; ++i) { - setImmediate(() => { mockStream.write({}); }); - } - setImmediate(() => { mockStream.end(); }); - } else { - setImmediate(() => { mockStream.write({}); }); - setImmediate(() => { mockStream.end(); }); - } - return sinon.stub().returns(mockStream); -} - -function stubAsyncIterationCall(responses?: ResponseType[], error?: Error) { - let counter = 0; - const asyncIterable = { - [Symbol.asyncIterator]() { - return { - async next() { - if (error) { - return Promise.reject(error); - } - if (counter >= responses!.length) { - return Promise.resolve({done: true, value: undefined}); - } - return Promise.resolve({done: false, value: responses![counter++]}); - } - }; - } - }; - return sinon.stub().returns(asyncIterable); -} - -describe('v1.EdgeNetworkClient', () => { - describe('Common methods', () => { - it('has servicePath', () => { - const servicePath = edgenetworkModule.v1.EdgeNetworkClient.servicePath; - assert(servicePath); - }); - - it('has apiEndpoint', () => { - const apiEndpoint = edgenetworkModule.v1.EdgeNetworkClient.apiEndpoint; - assert(apiEndpoint); - }); - - it('has port', () => { - const port = edgenetworkModule.v1.EdgeNetworkClient.port; - assert(port); - assert(typeof port === 'number'); - }); - - it('should create a client with no option', () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient(); - assert(client); - }); - - it('should create a client with gRPC fallback', () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - fallback: true, - }); - assert(client); - }); - - it('has initialize method and supports deferred initialization', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - assert.strictEqual(client.edgeNetworkStub, undefined); - await client.initialize(); - assert(client.edgeNetworkStub); - }); - - it('has close method for the initialized client', done => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - assert(client.edgeNetworkStub); - client.close().then(() => { - done(); - }); - }); - - it('has close method for the non-initialized client', done => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - assert.strictEqual(client.edgeNetworkStub, undefined); - client.close().then(() => { - done(); - }); - }); - - it('has getProjectId method', async () => { - const fakeProjectId = 'fake-project-id'; - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.auth.getProjectId = sinon.stub().resolves(fakeProjectId); - const result = await client.getProjectId(); - assert.strictEqual(result, fakeProjectId); - assert((client.auth.getProjectId as SinonStub).calledWithExactly()); - }); - - it('has getProjectId method with callback', async () => { - const fakeProjectId = 'fake-project-id'; - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.auth.getProjectId = sinon.stub().callsArgWith(0, null, fakeProjectId); - const promise = new Promise((resolve, reject) => { - client.getProjectId((err?: Error|null, projectId?: string|null) => { - if (err) { - reject(err); - } else { - resolve(projectId); - } - }); - }); - const result = await promise; - assert.strictEqual(result, fakeProjectId); - }); - }); - - describe('initializeZone', () => { - it('invokes initializeZone without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.InitializeZoneRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.InitializeZoneRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.InitializeZoneResponse() - ); - client.innerApiCalls.initializeZone = stubSimpleCall(expectedResponse); - const [response] = await client.initializeZone(request); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.initializeZone as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.initializeZone as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes initializeZone without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.InitializeZoneRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.InitializeZoneRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.InitializeZoneResponse() - ); - client.innerApiCalls.initializeZone = stubSimpleCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.initializeZone( - request, - (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse|null) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.initializeZone as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.initializeZone as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes initializeZone with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.InitializeZoneRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.InitializeZoneRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.initializeZone = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.initializeZone(request), expectedError); - const actualRequest = (client.innerApiCalls.initializeZone as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.initializeZone as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes initializeZone with closed client', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.InitializeZoneRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.InitializeZoneRequest', ['name']); - request.name = defaultValue1; - const expectedError = new Error('The client has already been closed.'); - client.close(); - await assert.rejects(client.initializeZone(request), expectedError); - }); - }); - - describe('getZone', () => { - it('invokes getZone without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetZoneRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetZoneRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.Zone() - ); - client.innerApiCalls.getZone = stubSimpleCall(expectedResponse); - const [response] = await client.getZone(request); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.getZone as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getZone as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getZone without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetZoneRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetZoneRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.Zone() - ); - client.innerApiCalls.getZone = stubSimpleCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.getZone( - request, - (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IZone|null) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.getZone as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getZone as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getZone with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetZoneRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetZoneRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.getZone = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.getZone(request), expectedError); - const actualRequest = (client.innerApiCalls.getZone as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getZone as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getZone with closed client', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetZoneRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetZoneRequest', ['name']); - request.name = defaultValue1; - const expectedError = new Error('The client has already been closed.'); - client.close(); - await assert.rejects(client.getZone(request), expectedError); - }); - }); - - describe('getNetwork', () => { - it('invokes getNetwork without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetNetworkRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetNetworkRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.Network() - ); - client.innerApiCalls.getNetwork = stubSimpleCall(expectedResponse); - const [response] = await client.getNetwork(request); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.getNetwork as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getNetwork as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getNetwork without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetNetworkRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetNetworkRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.Network() - ); - client.innerApiCalls.getNetwork = stubSimpleCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.getNetwork( - request, - (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.INetwork|null) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.getNetwork as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getNetwork as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getNetwork with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetNetworkRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetNetworkRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.getNetwork = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.getNetwork(request), expectedError); - const actualRequest = (client.innerApiCalls.getNetwork as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getNetwork as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getNetwork with closed client', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetNetworkRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetNetworkRequest', ['name']); - request.name = defaultValue1; - const expectedError = new Error('The client has already been closed.'); - client.close(); - await assert.rejects(client.getNetwork(request), expectedError); - }); - }); - - describe('diagnoseNetwork', () => { - it('invokes diagnoseNetwork without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse() - ); - client.innerApiCalls.diagnoseNetwork = stubSimpleCall(expectedResponse); - const [response] = await client.diagnoseNetwork(request); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.diagnoseNetwork as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.diagnoseNetwork as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes diagnoseNetwork without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse() - ); - client.innerApiCalls.diagnoseNetwork = stubSimpleCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.diagnoseNetwork( - request, - (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse|null) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.diagnoseNetwork as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.diagnoseNetwork as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes diagnoseNetwork with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.diagnoseNetwork = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.diagnoseNetwork(request), expectedError); - const actualRequest = (client.innerApiCalls.diagnoseNetwork as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.diagnoseNetwork as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes diagnoseNetwork with closed client', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest', ['name']); - request.name = defaultValue1; - const expectedError = new Error('The client has already been closed.'); - client.close(); - await assert.rejects(client.diagnoseNetwork(request), expectedError); - }); - }); - - describe('getSubnet', () => { - it('invokes getSubnet without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetSubnetRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetSubnetRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.Subnet() - ); - client.innerApiCalls.getSubnet = stubSimpleCall(expectedResponse); - const [response] = await client.getSubnet(request); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.getSubnet as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getSubnet as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getSubnet without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetSubnetRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetSubnetRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.Subnet() - ); - client.innerApiCalls.getSubnet = stubSimpleCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.getSubnet( - request, - (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.ISubnet|null) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.getSubnet as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getSubnet as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getSubnet with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetSubnetRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetSubnetRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.getSubnet = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.getSubnet(request), expectedError); - const actualRequest = (client.innerApiCalls.getSubnet as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getSubnet as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getSubnet with closed client', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetSubnetRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetSubnetRequest', ['name']); - request.name = defaultValue1; - const expectedError = new Error('The client has already been closed.'); - client.close(); - await assert.rejects(client.getSubnet(request), expectedError); - }); - }); - - describe('getInterconnect', () => { - it('invokes getInterconnect without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetInterconnectRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetInterconnectRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.Interconnect() - ); - client.innerApiCalls.getInterconnect = stubSimpleCall(expectedResponse); - const [response] = await client.getInterconnect(request); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.getInterconnect as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getInterconnect as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getInterconnect without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetInterconnectRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetInterconnectRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.Interconnect() - ); - client.innerApiCalls.getInterconnect = stubSimpleCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.getInterconnect( - request, - (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IInterconnect|null) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.getInterconnect as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getInterconnect as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getInterconnect with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetInterconnectRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetInterconnectRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.getInterconnect = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.getInterconnect(request), expectedError); - const actualRequest = (client.innerApiCalls.getInterconnect as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getInterconnect as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getInterconnect with closed client', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetInterconnectRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetInterconnectRequest', ['name']); - request.name = defaultValue1; - const expectedError = new Error('The client has already been closed.'); - client.close(); - await assert.rejects(client.getInterconnect(request), expectedError); - }); - }); - - describe('diagnoseInterconnect', () => { - it('invokes diagnoseInterconnect without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse() - ); - client.innerApiCalls.diagnoseInterconnect = stubSimpleCall(expectedResponse); - const [response] = await client.diagnoseInterconnect(request); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.diagnoseInterconnect as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.diagnoseInterconnect as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes diagnoseInterconnect without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse() - ); - client.innerApiCalls.diagnoseInterconnect = stubSimpleCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.diagnoseInterconnect( - request, - (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse|null) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.diagnoseInterconnect as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.diagnoseInterconnect as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes diagnoseInterconnect with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.diagnoseInterconnect = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.diagnoseInterconnect(request), expectedError); - const actualRequest = (client.innerApiCalls.diagnoseInterconnect as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.diagnoseInterconnect as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes diagnoseInterconnect with closed client', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest', ['name']); - request.name = defaultValue1; - const expectedError = new Error('The client has already been closed.'); - client.close(); - await assert.rejects(client.diagnoseInterconnect(request), expectedError); - }); - }); - - describe('getInterconnectAttachment', () => { - it('invokes getInterconnectAttachment without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() - ); - client.innerApiCalls.getInterconnectAttachment = stubSimpleCall(expectedResponse); - const [response] = await client.getInterconnectAttachment(request); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.getInterconnectAttachment as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getInterconnectAttachment as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getInterconnectAttachment without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() - ); - client.innerApiCalls.getInterconnectAttachment = stubSimpleCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.getInterconnectAttachment( - request, - (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IInterconnectAttachment|null) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.getInterconnectAttachment as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getInterconnectAttachment as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getInterconnectAttachment with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.getInterconnectAttachment = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.getInterconnectAttachment(request), expectedError); - const actualRequest = (client.innerApiCalls.getInterconnectAttachment as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getInterconnectAttachment as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getInterconnectAttachment with closed client', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest', ['name']); - request.name = defaultValue1; - const expectedError = new Error('The client has already been closed.'); - client.close(); - await assert.rejects(client.getInterconnectAttachment(request), expectedError); - }); - }); - - describe('getRouter', () => { - it('invokes getRouter without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetRouterRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetRouterRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.Router() - ); - client.innerApiCalls.getRouter = stubSimpleCall(expectedResponse); - const [response] = await client.getRouter(request); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.getRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getRouter without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetRouterRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetRouterRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.Router() - ); - client.innerApiCalls.getRouter = stubSimpleCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.getRouter( - request, - (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IRouter|null) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.getRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getRouter with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetRouterRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetRouterRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.getRouter = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.getRouter(request), expectedError); - const actualRequest = (client.innerApiCalls.getRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.getRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes getRouter with closed client', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.GetRouterRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.GetRouterRequest', ['name']); - request.name = defaultValue1; - const expectedError = new Error('The client has already been closed.'); - client.close(); - await assert.rejects(client.getRouter(request), expectedError); - }); - }); - - describe('diagnoseRouter', () => { - it('invokes diagnoseRouter without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseRouterRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseRouterRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseRouterResponse() - ); - client.innerApiCalls.diagnoseRouter = stubSimpleCall(expectedResponse); - const [response] = await client.diagnoseRouter(request); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.diagnoseRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.diagnoseRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes diagnoseRouter without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseRouterRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseRouterRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseRouterResponse() - ); - client.innerApiCalls.diagnoseRouter = stubSimpleCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.diagnoseRouter( - request, - (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse|null) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.diagnoseRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.diagnoseRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes diagnoseRouter with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseRouterRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseRouterRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.diagnoseRouter = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.diagnoseRouter(request), expectedError); - const actualRequest = (client.innerApiCalls.diagnoseRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.diagnoseRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes diagnoseRouter with closed client', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DiagnoseRouterRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DiagnoseRouterRequest', ['name']); - request.name = defaultValue1; - const expectedError = new Error('The client has already been closed.'); - client.close(); - await assert.rejects(client.diagnoseRouter(request), expectedError); - }); - }); - - describe('createNetwork', () => { - it('invokes createNetwork without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.CreateNetworkRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateNetworkRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.createNetwork = stubLongRunningCall(expectedResponse); - const [operation] = await client.createNetwork(request); - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.createNetwork as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.createNetwork as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes createNetwork without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.CreateNetworkRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateNetworkRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.createNetwork = stubLongRunningCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.createNetwork( - request, - (err?: Error|null, - result?: LROperation|null - ) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const operation = await promise as LROperation; - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.createNetwork as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.createNetwork as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes createNetwork with call error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.CreateNetworkRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateNetworkRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.createNetwork = stubLongRunningCall(undefined, expectedError); - await assert.rejects(client.createNetwork(request), expectedError); - const actualRequest = (client.innerApiCalls.createNetwork as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.createNetwork as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes createNetwork with LRO error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.CreateNetworkRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateNetworkRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.createNetwork = stubLongRunningCall(undefined, undefined, expectedError); - const [operation] = await client.createNetwork(request); - await assert.rejects(operation.promise(), expectedError); - const actualRequest = (client.innerApiCalls.createNetwork as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.createNetwork as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes checkCreateNetworkProgress without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedResponse = generateSampleMessage( - new operationsProtos.google.longrunning.Operation() - ); - expectedResponse.name = 'test'; - expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; - expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} - - client.operationsClient.getOperation = stubSimpleCall(expectedResponse); - const decodedOperation = await client.checkCreateNetworkProgress(expectedResponse.name); - assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); - assert(decodedOperation.metadata); - assert((client.operationsClient.getOperation as SinonStub).getCall(0)); - }); - - it('invokes checkCreateNetworkProgress with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedError = new Error('expected'); - - client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.checkCreateNetworkProgress(''), expectedError); - assert((client.operationsClient.getOperation as SinonStub) - .getCall(0)); - }); - }); - - describe('deleteNetwork', () => { - it('invokes deleteNetwork without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DeleteNetworkRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteNetworkRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.deleteNetwork = stubLongRunningCall(expectedResponse); - const [operation] = await client.deleteNetwork(request); - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.deleteNetwork as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.deleteNetwork as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes deleteNetwork without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DeleteNetworkRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteNetworkRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.deleteNetwork = stubLongRunningCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.deleteNetwork( - request, - (err?: Error|null, - result?: LROperation|null - ) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const operation = await promise as LROperation; - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.deleteNetwork as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.deleteNetwork as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes deleteNetwork with call error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DeleteNetworkRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteNetworkRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.deleteNetwork = stubLongRunningCall(undefined, expectedError); - await assert.rejects(client.deleteNetwork(request), expectedError); - const actualRequest = (client.innerApiCalls.deleteNetwork as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.deleteNetwork as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes deleteNetwork with LRO error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DeleteNetworkRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteNetworkRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.deleteNetwork = stubLongRunningCall(undefined, undefined, expectedError); - const [operation] = await client.deleteNetwork(request); - await assert.rejects(operation.promise(), expectedError); - const actualRequest = (client.innerApiCalls.deleteNetwork as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.deleteNetwork as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes checkDeleteNetworkProgress without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedResponse = generateSampleMessage( - new operationsProtos.google.longrunning.Operation() - ); - expectedResponse.name = 'test'; - expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; - expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} - - client.operationsClient.getOperation = stubSimpleCall(expectedResponse); - const decodedOperation = await client.checkDeleteNetworkProgress(expectedResponse.name); - assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); - assert(decodedOperation.metadata); - assert((client.operationsClient.getOperation as SinonStub).getCall(0)); - }); - - it('invokes checkDeleteNetworkProgress with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedError = new Error('expected'); - - client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.checkDeleteNetworkProgress(''), expectedError); - assert((client.operationsClient.getOperation as SinonStub) - .getCall(0)); - }); - }); - - describe('createSubnet', () => { - it('invokes createSubnet without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.CreateSubnetRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateSubnetRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.createSubnet = stubLongRunningCall(expectedResponse); - const [operation] = await client.createSubnet(request); - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.createSubnet as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.createSubnet as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes createSubnet without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.CreateSubnetRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateSubnetRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.createSubnet = stubLongRunningCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.createSubnet( - request, - (err?: Error|null, - result?: LROperation|null - ) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const operation = await promise as LROperation; - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.createSubnet as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.createSubnet as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes createSubnet with call error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.CreateSubnetRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateSubnetRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.createSubnet = stubLongRunningCall(undefined, expectedError); - await assert.rejects(client.createSubnet(request), expectedError); - const actualRequest = (client.innerApiCalls.createSubnet as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.createSubnet as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes createSubnet with LRO error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.CreateSubnetRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateSubnetRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.createSubnet = stubLongRunningCall(undefined, undefined, expectedError); - const [operation] = await client.createSubnet(request); - await assert.rejects(operation.promise(), expectedError); - const actualRequest = (client.innerApiCalls.createSubnet as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.createSubnet as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes checkCreateSubnetProgress without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedResponse = generateSampleMessage( - new operationsProtos.google.longrunning.Operation() - ); - expectedResponse.name = 'test'; - expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; - expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} - - client.operationsClient.getOperation = stubSimpleCall(expectedResponse); - const decodedOperation = await client.checkCreateSubnetProgress(expectedResponse.name); - assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); - assert(decodedOperation.metadata); - assert((client.operationsClient.getOperation as SinonStub).getCall(0)); - }); - - it('invokes checkCreateSubnetProgress with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedError = new Error('expected'); - - client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.checkCreateSubnetProgress(''), expectedError); - assert((client.operationsClient.getOperation as SinonStub) - .getCall(0)); - }); - }); - - describe('updateSubnet', () => { - it('invokes updateSubnet without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.UpdateSubnetRequest() - ); - request.subnet ??= {}; - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.UpdateSubnetRequest', ['subnet', 'name']); - request.subnet.name = defaultValue1; - const expectedHeaderRequestParams = `subnet.name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.updateSubnet = stubLongRunningCall(expectedResponse); - const [operation] = await client.updateSubnet(request); - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.updateSubnet as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.updateSubnet as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes updateSubnet without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.UpdateSubnetRequest() - ); - request.subnet ??= {}; - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.UpdateSubnetRequest', ['subnet', 'name']); - request.subnet.name = defaultValue1; - const expectedHeaderRequestParams = `subnet.name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.updateSubnet = stubLongRunningCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.updateSubnet( - request, - (err?: Error|null, - result?: LROperation|null - ) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const operation = await promise as LROperation; - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.updateSubnet as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.updateSubnet as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes updateSubnet with call error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.UpdateSubnetRequest() - ); - request.subnet ??= {}; - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.UpdateSubnetRequest', ['subnet', 'name']); - request.subnet.name = defaultValue1; - const expectedHeaderRequestParams = `subnet.name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.updateSubnet = stubLongRunningCall(undefined, expectedError); - await assert.rejects(client.updateSubnet(request), expectedError); - const actualRequest = (client.innerApiCalls.updateSubnet as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.updateSubnet as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes updateSubnet with LRO error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.UpdateSubnetRequest() - ); - request.subnet ??= {}; - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.UpdateSubnetRequest', ['subnet', 'name']); - request.subnet.name = defaultValue1; - const expectedHeaderRequestParams = `subnet.name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.updateSubnet = stubLongRunningCall(undefined, undefined, expectedError); - const [operation] = await client.updateSubnet(request); - await assert.rejects(operation.promise(), expectedError); - const actualRequest = (client.innerApiCalls.updateSubnet as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.updateSubnet as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes checkUpdateSubnetProgress without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedResponse = generateSampleMessage( - new operationsProtos.google.longrunning.Operation() - ); - expectedResponse.name = 'test'; - expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; - expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} - - client.operationsClient.getOperation = stubSimpleCall(expectedResponse); - const decodedOperation = await client.checkUpdateSubnetProgress(expectedResponse.name); - assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); - assert(decodedOperation.metadata); - assert((client.operationsClient.getOperation as SinonStub).getCall(0)); - }); - - it('invokes checkUpdateSubnetProgress with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedError = new Error('expected'); - - client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.checkUpdateSubnetProgress(''), expectedError); - assert((client.operationsClient.getOperation as SinonStub) - .getCall(0)); - }); - }); - - describe('deleteSubnet', () => { - it('invokes deleteSubnet without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DeleteSubnetRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteSubnetRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.deleteSubnet = stubLongRunningCall(expectedResponse); - const [operation] = await client.deleteSubnet(request); - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.deleteSubnet as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.deleteSubnet as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes deleteSubnet without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DeleteSubnetRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteSubnetRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.deleteSubnet = stubLongRunningCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.deleteSubnet( - request, - (err?: Error|null, - result?: LROperation|null - ) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const operation = await promise as LROperation; - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.deleteSubnet as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.deleteSubnet as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes deleteSubnet with call error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DeleteSubnetRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteSubnetRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.deleteSubnet = stubLongRunningCall(undefined, expectedError); - await assert.rejects(client.deleteSubnet(request), expectedError); - const actualRequest = (client.innerApiCalls.deleteSubnet as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.deleteSubnet as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes deleteSubnet with LRO error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DeleteSubnetRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteSubnetRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.deleteSubnet = stubLongRunningCall(undefined, undefined, expectedError); - const [operation] = await client.deleteSubnet(request); - await assert.rejects(operation.promise(), expectedError); - const actualRequest = (client.innerApiCalls.deleteSubnet as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.deleteSubnet as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes checkDeleteSubnetProgress without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedResponse = generateSampleMessage( - new operationsProtos.google.longrunning.Operation() - ); - expectedResponse.name = 'test'; - expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; - expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} - - client.operationsClient.getOperation = stubSimpleCall(expectedResponse); - const decodedOperation = await client.checkDeleteSubnetProgress(expectedResponse.name); - assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); - assert(decodedOperation.metadata); - assert((client.operationsClient.getOperation as SinonStub).getCall(0)); - }); - - it('invokes checkDeleteSubnetProgress with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedError = new Error('expected'); - - client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.checkDeleteSubnetProgress(''), expectedError); - assert((client.operationsClient.getOperation as SinonStub) - .getCall(0)); - }); - }); - - describe('createInterconnectAttachment', () => { - it('invokes createInterconnectAttachment without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.createInterconnectAttachment = stubLongRunningCall(expectedResponse); - const [operation] = await client.createInterconnectAttachment(request); - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.createInterconnectAttachment as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.createInterconnectAttachment as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes createInterconnectAttachment without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.createInterconnectAttachment = stubLongRunningCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.createInterconnectAttachment( - request, - (err?: Error|null, - result?: LROperation|null - ) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const operation = await promise as LROperation; - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.createInterconnectAttachment as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.createInterconnectAttachment as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes createInterconnectAttachment with call error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.createInterconnectAttachment = stubLongRunningCall(undefined, expectedError); - await assert.rejects(client.createInterconnectAttachment(request), expectedError); - const actualRequest = (client.innerApiCalls.createInterconnectAttachment as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.createInterconnectAttachment as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes createInterconnectAttachment with LRO error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.createInterconnectAttachment = stubLongRunningCall(undefined, undefined, expectedError); - const [operation] = await client.createInterconnectAttachment(request); - await assert.rejects(operation.promise(), expectedError); - const actualRequest = (client.innerApiCalls.createInterconnectAttachment as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.createInterconnectAttachment as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes checkCreateInterconnectAttachmentProgress without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedResponse = generateSampleMessage( - new operationsProtos.google.longrunning.Operation() - ); - expectedResponse.name = 'test'; - expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; - expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} - - client.operationsClient.getOperation = stubSimpleCall(expectedResponse); - const decodedOperation = await client.checkCreateInterconnectAttachmentProgress(expectedResponse.name); - assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); - assert(decodedOperation.metadata); - assert((client.operationsClient.getOperation as SinonStub).getCall(0)); - }); - - it('invokes checkCreateInterconnectAttachmentProgress with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedError = new Error('expected'); - - client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.checkCreateInterconnectAttachmentProgress(''), expectedError); - assert((client.operationsClient.getOperation as SinonStub) - .getCall(0)); - }); - }); - - describe('deleteInterconnectAttachment', () => { - it('invokes deleteInterconnectAttachment without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.deleteInterconnectAttachment = stubLongRunningCall(expectedResponse); - const [operation] = await client.deleteInterconnectAttachment(request); - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.deleteInterconnectAttachment as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.deleteInterconnectAttachment as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes deleteInterconnectAttachment without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.deleteInterconnectAttachment = stubLongRunningCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.deleteInterconnectAttachment( - request, - (err?: Error|null, - result?: LROperation|null - ) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const operation = await promise as LROperation; - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.deleteInterconnectAttachment as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.deleteInterconnectAttachment as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes deleteInterconnectAttachment with call error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.deleteInterconnectAttachment = stubLongRunningCall(undefined, expectedError); - await assert.rejects(client.deleteInterconnectAttachment(request), expectedError); - const actualRequest = (client.innerApiCalls.deleteInterconnectAttachment as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.deleteInterconnectAttachment as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes deleteInterconnectAttachment with LRO error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.deleteInterconnectAttachment = stubLongRunningCall(undefined, undefined, expectedError); - const [operation] = await client.deleteInterconnectAttachment(request); - await assert.rejects(operation.promise(), expectedError); - const actualRequest = (client.innerApiCalls.deleteInterconnectAttachment as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.deleteInterconnectAttachment as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes checkDeleteInterconnectAttachmentProgress without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedResponse = generateSampleMessage( - new operationsProtos.google.longrunning.Operation() - ); - expectedResponse.name = 'test'; - expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; - expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} - - client.operationsClient.getOperation = stubSimpleCall(expectedResponse); - const decodedOperation = await client.checkDeleteInterconnectAttachmentProgress(expectedResponse.name); - assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); - assert(decodedOperation.metadata); - assert((client.operationsClient.getOperation as SinonStub).getCall(0)); - }); - - it('invokes checkDeleteInterconnectAttachmentProgress with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedError = new Error('expected'); - - client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.checkDeleteInterconnectAttachmentProgress(''), expectedError); - assert((client.operationsClient.getOperation as SinonStub) - .getCall(0)); - }); - }); - - describe('createRouter', () => { - it('invokes createRouter without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.CreateRouterRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateRouterRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.createRouter = stubLongRunningCall(expectedResponse); - const [operation] = await client.createRouter(request); - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.createRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.createRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes createRouter without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.CreateRouterRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateRouterRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.createRouter = stubLongRunningCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.createRouter( - request, - (err?: Error|null, - result?: LROperation|null - ) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const operation = await promise as LROperation; - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.createRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.createRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes createRouter with call error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.CreateRouterRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateRouterRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.createRouter = stubLongRunningCall(undefined, expectedError); - await assert.rejects(client.createRouter(request), expectedError); - const actualRequest = (client.innerApiCalls.createRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.createRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes createRouter with LRO error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.CreateRouterRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.CreateRouterRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.createRouter = stubLongRunningCall(undefined, undefined, expectedError); - const [operation] = await client.createRouter(request); - await assert.rejects(operation.promise(), expectedError); - const actualRequest = (client.innerApiCalls.createRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.createRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes checkCreateRouterProgress without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedResponse = generateSampleMessage( - new operationsProtos.google.longrunning.Operation() - ); - expectedResponse.name = 'test'; - expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; - expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} - - client.operationsClient.getOperation = stubSimpleCall(expectedResponse); - const decodedOperation = await client.checkCreateRouterProgress(expectedResponse.name); - assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); - assert(decodedOperation.metadata); - assert((client.operationsClient.getOperation as SinonStub).getCall(0)); - }); - - it('invokes checkCreateRouterProgress with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedError = new Error('expected'); - - client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.checkCreateRouterProgress(''), expectedError); - assert((client.operationsClient.getOperation as SinonStub) - .getCall(0)); - }); - }); - - describe('updateRouter', () => { - it('invokes updateRouter without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.UpdateRouterRequest() - ); - request.router ??= {}; - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.UpdateRouterRequest', ['router', 'name']); - request.router.name = defaultValue1; - const expectedHeaderRequestParams = `router.name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.updateRouter = stubLongRunningCall(expectedResponse); - const [operation] = await client.updateRouter(request); - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.updateRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.updateRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes updateRouter without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.UpdateRouterRequest() - ); - request.router ??= {}; - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.UpdateRouterRequest', ['router', 'name']); - request.router.name = defaultValue1; - const expectedHeaderRequestParams = `router.name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.updateRouter = stubLongRunningCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.updateRouter( - request, - (err?: Error|null, - result?: LROperation|null - ) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const operation = await promise as LROperation; - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.updateRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.updateRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes updateRouter with call error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.UpdateRouterRequest() - ); - request.router ??= {}; - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.UpdateRouterRequest', ['router', 'name']); - request.router.name = defaultValue1; - const expectedHeaderRequestParams = `router.name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.updateRouter = stubLongRunningCall(undefined, expectedError); - await assert.rejects(client.updateRouter(request), expectedError); - const actualRequest = (client.innerApiCalls.updateRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.updateRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes updateRouter with LRO error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.UpdateRouterRequest() - ); - request.router ??= {}; - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.UpdateRouterRequest', ['router', 'name']); - request.router.name = defaultValue1; - const expectedHeaderRequestParams = `router.name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.updateRouter = stubLongRunningCall(undefined, undefined, expectedError); - const [operation] = await client.updateRouter(request); - await assert.rejects(operation.promise(), expectedError); - const actualRequest = (client.innerApiCalls.updateRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.updateRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes checkUpdateRouterProgress without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedResponse = generateSampleMessage( - new operationsProtos.google.longrunning.Operation() - ); - expectedResponse.name = 'test'; - expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; - expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} - - client.operationsClient.getOperation = stubSimpleCall(expectedResponse); - const decodedOperation = await client.checkUpdateRouterProgress(expectedResponse.name); - assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); - assert(decodedOperation.metadata); - assert((client.operationsClient.getOperation as SinonStub).getCall(0)); - }); - - it('invokes checkUpdateRouterProgress with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedError = new Error('expected'); - - client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.checkUpdateRouterProgress(''), expectedError); - assert((client.operationsClient.getOperation as SinonStub) - .getCall(0)); - }); - }); - - describe('deleteRouter', () => { - it('invokes deleteRouter without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DeleteRouterRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteRouterRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.deleteRouter = stubLongRunningCall(expectedResponse); - const [operation] = await client.deleteRouter(request); - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.deleteRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.deleteRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes deleteRouter without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DeleteRouterRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteRouterRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedResponse = generateSampleMessage( - new protos.google.longrunning.Operation() - ); - client.innerApiCalls.deleteRouter = stubLongRunningCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.deleteRouter( - request, - (err?: Error|null, - result?: LROperation|null - ) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const operation = await promise as LROperation; - const [response] = await operation.promise(); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.deleteRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.deleteRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes deleteRouter with call error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DeleteRouterRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteRouterRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.deleteRouter = stubLongRunningCall(undefined, expectedError); - await assert.rejects(client.deleteRouter(request), expectedError); - const actualRequest = (client.innerApiCalls.deleteRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.deleteRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes deleteRouter with LRO error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.DeleteRouterRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.DeleteRouterRequest', ['name']); - request.name = defaultValue1; - const expectedHeaderRequestParams = `name=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.deleteRouter = stubLongRunningCall(undefined, undefined, expectedError); - const [operation] = await client.deleteRouter(request); - await assert.rejects(operation.promise(), expectedError); - const actualRequest = (client.innerApiCalls.deleteRouter as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.deleteRouter as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes checkDeleteRouterProgress without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedResponse = generateSampleMessage( - new operationsProtos.google.longrunning.Operation() - ); - expectedResponse.name = 'test'; - expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; - expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')} - - client.operationsClient.getOperation = stubSimpleCall(expectedResponse); - const decodedOperation = await client.checkDeleteRouterProgress(expectedResponse.name); - assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); - assert(decodedOperation.metadata); - assert((client.operationsClient.getOperation as SinonStub).getCall(0)); - }); - - it('invokes checkDeleteRouterProgress with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const expectedError = new Error('expected'); - - client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.checkDeleteRouterProgress(''), expectedError); - assert((client.operationsClient.getOperation as SinonStub) - .getCall(0)); - }); - }); - - describe('listZones', () => { - it('invokes listZones without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListZonesRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListZonesRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), - ]; - client.innerApiCalls.listZones = stubSimpleCall(expectedResponse); - const [response] = await client.listZones(request); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.listZones as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listZones as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listZones without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListZonesRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListZonesRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), - ]; - client.innerApiCalls.listZones = stubSimpleCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.listZones( - request, - (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IZone[]|null) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.listZones as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listZones as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listZones with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListZonesRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListZonesRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.listZones = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.listZones(request), expectedError); - const actualRequest = (client.innerApiCalls.listZones as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listZones as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listZonesStream without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListZonesRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListZonesRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), - ]; - client.descriptors.page.listZones.createStream = stubPageStreamingCall(expectedResponse); - const stream = client.listZonesStream(request); - const promise = new Promise((resolve, reject) => { - const responses: protos.google.cloud.edgenetwork.v1.Zone[] = []; - stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Zone) => { - responses.push(response); - }); - stream.on('end', () => { - resolve(responses); - }); - stream.on('error', (err: Error) => { - reject(err); - }); - }); - const responses = await promise; - assert.deepStrictEqual(responses, expectedResponse); - assert((client.descriptors.page.listZones.createStream as SinonStub) - .getCall(0).calledWith(client.innerApiCalls.listZones, request)); - assert( - (client.descriptors.page.listZones.createStream as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('invokes listZonesStream with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListZonesRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListZonesRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.descriptors.page.listZones.createStream = stubPageStreamingCall(undefined, expectedError); - const stream = client.listZonesStream(request); - const promise = new Promise((resolve, reject) => { - const responses: protos.google.cloud.edgenetwork.v1.Zone[] = []; - stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Zone) => { - responses.push(response); - }); - stream.on('end', () => { - resolve(responses); - }); - stream.on('error', (err: Error) => { - reject(err); - }); - }); - await assert.rejects(promise, expectedError); - assert((client.descriptors.page.listZones.createStream as SinonStub) - .getCall(0).calledWith(client.innerApiCalls.listZones, request)); - assert( - (client.descriptors.page.listZones.createStream as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('uses async iteration with listZones without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListZonesRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListZonesRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), - ]; - client.descriptors.page.listZones.asyncIterate = stubAsyncIterationCall(expectedResponse); - const responses: protos.google.cloud.edgenetwork.v1.IZone[] = []; - const iterable = client.listZonesAsync(request); - for await (const resource of iterable) { - responses.push(resource!); - } - assert.deepStrictEqual(responses, expectedResponse); - assert.deepStrictEqual( - (client.descriptors.page.listZones.asyncIterate as SinonStub) - .getCall(0).args[1], request); - assert( - (client.descriptors.page.listZones.asyncIterate as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('uses async iteration with listZones with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListZonesRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListZonesRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.descriptors.page.listZones.asyncIterate = stubAsyncIterationCall(undefined, expectedError); - const iterable = client.listZonesAsync(request); - await assert.rejects(async () => { - const responses: protos.google.cloud.edgenetwork.v1.IZone[] = []; - for await (const resource of iterable) { - responses.push(resource!); - } - }); - assert.deepStrictEqual( - (client.descriptors.page.listZones.asyncIterate as SinonStub) - .getCall(0).args[1], request); - assert( - (client.descriptors.page.listZones.asyncIterate as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - }); - - describe('listNetworks', () => { - it('invokes listNetworks without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListNetworksRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), - ]; - client.innerApiCalls.listNetworks = stubSimpleCall(expectedResponse); - const [response] = await client.listNetworks(request); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.listNetworks as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listNetworks as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listNetworks without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListNetworksRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), - ]; - client.innerApiCalls.listNetworks = stubSimpleCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.listNetworks( - request, - (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.INetwork[]|null) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.listNetworks as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listNetworks as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listNetworks with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListNetworksRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.listNetworks = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.listNetworks(request), expectedError); - const actualRequest = (client.innerApiCalls.listNetworks as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listNetworks as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listNetworksStream without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListNetworksRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), - ]; - client.descriptors.page.listNetworks.createStream = stubPageStreamingCall(expectedResponse); - const stream = client.listNetworksStream(request); - const promise = new Promise((resolve, reject) => { - const responses: protos.google.cloud.edgenetwork.v1.Network[] = []; - stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Network) => { - responses.push(response); - }); - stream.on('end', () => { - resolve(responses); - }); - stream.on('error', (err: Error) => { - reject(err); - }); - }); - const responses = await promise; - assert.deepStrictEqual(responses, expectedResponse); - assert((client.descriptors.page.listNetworks.createStream as SinonStub) - .getCall(0).calledWith(client.innerApiCalls.listNetworks, request)); - assert( - (client.descriptors.page.listNetworks.createStream as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('invokes listNetworksStream with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListNetworksRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.descriptors.page.listNetworks.createStream = stubPageStreamingCall(undefined, expectedError); - const stream = client.listNetworksStream(request); - const promise = new Promise((resolve, reject) => { - const responses: protos.google.cloud.edgenetwork.v1.Network[] = []; - stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Network) => { - responses.push(response); - }); - stream.on('end', () => { - resolve(responses); - }); - stream.on('error', (err: Error) => { - reject(err); - }); - }); - await assert.rejects(promise, expectedError); - assert((client.descriptors.page.listNetworks.createStream as SinonStub) - .getCall(0).calledWith(client.innerApiCalls.listNetworks, request)); - assert( - (client.descriptors.page.listNetworks.createStream as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('uses async iteration with listNetworks without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListNetworksRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), - ]; - client.descriptors.page.listNetworks.asyncIterate = stubAsyncIterationCall(expectedResponse); - const responses: protos.google.cloud.edgenetwork.v1.INetwork[] = []; - const iterable = client.listNetworksAsync(request); - for await (const resource of iterable) { - responses.push(resource!); - } - assert.deepStrictEqual(responses, expectedResponse); - assert.deepStrictEqual( - (client.descriptors.page.listNetworks.asyncIterate as SinonStub) - .getCall(0).args[1], request); - assert( - (client.descriptors.page.listNetworks.asyncIterate as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('uses async iteration with listNetworks with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListNetworksRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.descriptors.page.listNetworks.asyncIterate = stubAsyncIterationCall(undefined, expectedError); - const iterable = client.listNetworksAsync(request); - await assert.rejects(async () => { - const responses: protos.google.cloud.edgenetwork.v1.INetwork[] = []; - for await (const resource of iterable) { - responses.push(resource!); - } - }); - assert.deepStrictEqual( - (client.descriptors.page.listNetworks.asyncIterate as SinonStub) - .getCall(0).args[1], request); - assert( - (client.descriptors.page.listNetworks.asyncIterate as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - }); - - describe('listSubnets', () => { - it('invokes listSubnets without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListSubnetsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), - ]; - client.innerApiCalls.listSubnets = stubSimpleCall(expectedResponse); - const [response] = await client.listSubnets(request); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.listSubnets as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listSubnets as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listSubnets without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListSubnetsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), - ]; - client.innerApiCalls.listSubnets = stubSimpleCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.listSubnets( - request, - (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.ISubnet[]|null) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.listSubnets as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listSubnets as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listSubnets with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListSubnetsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.listSubnets = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.listSubnets(request), expectedError); - const actualRequest = (client.innerApiCalls.listSubnets as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listSubnets as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listSubnetsStream without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListSubnetsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), - ]; - client.descriptors.page.listSubnets.createStream = stubPageStreamingCall(expectedResponse); - const stream = client.listSubnetsStream(request); - const promise = new Promise((resolve, reject) => { - const responses: protos.google.cloud.edgenetwork.v1.Subnet[] = []; - stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Subnet) => { - responses.push(response); - }); - stream.on('end', () => { - resolve(responses); - }); - stream.on('error', (err: Error) => { - reject(err); - }); - }); - const responses = await promise; - assert.deepStrictEqual(responses, expectedResponse); - assert((client.descriptors.page.listSubnets.createStream as SinonStub) - .getCall(0).calledWith(client.innerApiCalls.listSubnets, request)); - assert( - (client.descriptors.page.listSubnets.createStream as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('invokes listSubnetsStream with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListSubnetsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.descriptors.page.listSubnets.createStream = stubPageStreamingCall(undefined, expectedError); - const stream = client.listSubnetsStream(request); - const promise = new Promise((resolve, reject) => { - const responses: protos.google.cloud.edgenetwork.v1.Subnet[] = []; - stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Subnet) => { - responses.push(response); - }); - stream.on('end', () => { - resolve(responses); - }); - stream.on('error', (err: Error) => { - reject(err); - }); - }); - await assert.rejects(promise, expectedError); - assert((client.descriptors.page.listSubnets.createStream as SinonStub) - .getCall(0).calledWith(client.innerApiCalls.listSubnets, request)); - assert( - (client.descriptors.page.listSubnets.createStream as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('uses async iteration with listSubnets without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListSubnetsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), - ]; - client.descriptors.page.listSubnets.asyncIterate = stubAsyncIterationCall(expectedResponse); - const responses: protos.google.cloud.edgenetwork.v1.ISubnet[] = []; - const iterable = client.listSubnetsAsync(request); - for await (const resource of iterable) { - responses.push(resource!); - } - assert.deepStrictEqual(responses, expectedResponse); - assert.deepStrictEqual( - (client.descriptors.page.listSubnets.asyncIterate as SinonStub) - .getCall(0).args[1], request); - assert( - (client.descriptors.page.listSubnets.asyncIterate as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('uses async iteration with listSubnets with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListSubnetsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.descriptors.page.listSubnets.asyncIterate = stubAsyncIterationCall(undefined, expectedError); - const iterable = client.listSubnetsAsync(request); - await assert.rejects(async () => { - const responses: protos.google.cloud.edgenetwork.v1.ISubnet[] = []; - for await (const resource of iterable) { - responses.push(resource!); - } - }); - assert.deepStrictEqual( - (client.descriptors.page.listSubnets.asyncIterate as SinonStub) - .getCall(0).args[1], request); - assert( - (client.descriptors.page.listSubnets.asyncIterate as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - }); - - describe('listInterconnects', () => { - it('invokes listInterconnects without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), - ]; - client.innerApiCalls.listInterconnects = stubSimpleCall(expectedResponse); - const [response] = await client.listInterconnects(request); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.listInterconnects as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listInterconnects as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listInterconnects without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), - ]; - client.innerApiCalls.listInterconnects = stubSimpleCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.listInterconnects( - request, - (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IInterconnect[]|null) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.listInterconnects as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listInterconnects as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listInterconnects with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.listInterconnects = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.listInterconnects(request), expectedError); - const actualRequest = (client.innerApiCalls.listInterconnects as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listInterconnects as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listInterconnectsStream without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), - ]; - client.descriptors.page.listInterconnects.createStream = stubPageStreamingCall(expectedResponse); - const stream = client.listInterconnectsStream(request); - const promise = new Promise((resolve, reject) => { - const responses: protos.google.cloud.edgenetwork.v1.Interconnect[] = []; - stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Interconnect) => { - responses.push(response); - }); - stream.on('end', () => { - resolve(responses); - }); - stream.on('error', (err: Error) => { - reject(err); - }); - }); - const responses = await promise; - assert.deepStrictEqual(responses, expectedResponse); - assert((client.descriptors.page.listInterconnects.createStream as SinonStub) - .getCall(0).calledWith(client.innerApiCalls.listInterconnects, request)); - assert( - (client.descriptors.page.listInterconnects.createStream as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('invokes listInterconnectsStream with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.descriptors.page.listInterconnects.createStream = stubPageStreamingCall(undefined, expectedError); - const stream = client.listInterconnectsStream(request); - const promise = new Promise((resolve, reject) => { - const responses: protos.google.cloud.edgenetwork.v1.Interconnect[] = []; - stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Interconnect) => { - responses.push(response); - }); - stream.on('end', () => { - resolve(responses); - }); - stream.on('error', (err: Error) => { - reject(err); - }); - }); - await assert.rejects(promise, expectedError); - assert((client.descriptors.page.listInterconnects.createStream as SinonStub) - .getCall(0).calledWith(client.innerApiCalls.listInterconnects, request)); - assert( - (client.descriptors.page.listInterconnects.createStream as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('uses async iteration with listInterconnects without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Interconnect()), - ]; - client.descriptors.page.listInterconnects.asyncIterate = stubAsyncIterationCall(expectedResponse); - const responses: protos.google.cloud.edgenetwork.v1.IInterconnect[] = []; - const iterable = client.listInterconnectsAsync(request); - for await (const resource of iterable) { - responses.push(resource!); - } - assert.deepStrictEqual(responses, expectedResponse); - assert.deepStrictEqual( - (client.descriptors.page.listInterconnects.asyncIterate as SinonStub) - .getCall(0).args[1], request); - assert( - (client.descriptors.page.listInterconnects.asyncIterate as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('uses async iteration with listInterconnects with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.descriptors.page.listInterconnects.asyncIterate = stubAsyncIterationCall(undefined, expectedError); - const iterable = client.listInterconnectsAsync(request); - await assert.rejects(async () => { - const responses: protos.google.cloud.edgenetwork.v1.IInterconnect[] = []; - for await (const resource of iterable) { - responses.push(resource!); - } - }); - assert.deepStrictEqual( - (client.descriptors.page.listInterconnects.asyncIterate as SinonStub) - .getCall(0).args[1], request); - assert( - (client.descriptors.page.listInterconnects.asyncIterate as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - }); - - describe('listInterconnectAttachments', () => { - it('invokes listInterconnectAttachments without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), - ]; - client.innerApiCalls.listInterconnectAttachments = stubSimpleCall(expectedResponse); - const [response] = await client.listInterconnectAttachments(request); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.listInterconnectAttachments as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listInterconnectAttachments as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listInterconnectAttachments without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), - ]; - client.innerApiCalls.listInterconnectAttachments = stubSimpleCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.listInterconnectAttachments( - request, - (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IInterconnectAttachment[]|null) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.listInterconnectAttachments as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listInterconnectAttachments as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listInterconnectAttachments with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.listInterconnectAttachments = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.listInterconnectAttachments(request), expectedError); - const actualRequest = (client.innerApiCalls.listInterconnectAttachments as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listInterconnectAttachments as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listInterconnectAttachmentsStream without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), - ]; - client.descriptors.page.listInterconnectAttachments.createStream = stubPageStreamingCall(expectedResponse); - const stream = client.listInterconnectAttachmentsStream(request); - const promise = new Promise((resolve, reject) => { - const responses: protos.google.cloud.edgenetwork.v1.InterconnectAttachment[] = []; - stream.on('data', (response: protos.google.cloud.edgenetwork.v1.InterconnectAttachment) => { - responses.push(response); - }); - stream.on('end', () => { - resolve(responses); - }); - stream.on('error', (err: Error) => { - reject(err); - }); - }); - const responses = await promise; - assert.deepStrictEqual(responses, expectedResponse); - assert((client.descriptors.page.listInterconnectAttachments.createStream as SinonStub) - .getCall(0).calledWith(client.innerApiCalls.listInterconnectAttachments, request)); - assert( - (client.descriptors.page.listInterconnectAttachments.createStream as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('invokes listInterconnectAttachmentsStream with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.descriptors.page.listInterconnectAttachments.createStream = stubPageStreamingCall(undefined, expectedError); - const stream = client.listInterconnectAttachmentsStream(request); - const promise = new Promise((resolve, reject) => { - const responses: protos.google.cloud.edgenetwork.v1.InterconnectAttachment[] = []; - stream.on('data', (response: protos.google.cloud.edgenetwork.v1.InterconnectAttachment) => { - responses.push(response); - }); - stream.on('end', () => { - resolve(responses); - }); - stream.on('error', (err: Error) => { - reject(err); - }); - }); - await assert.rejects(promise, expectedError); - assert((client.descriptors.page.listInterconnectAttachments.createStream as SinonStub) - .getCall(0).calledWith(client.innerApiCalls.listInterconnectAttachments, request)); - assert( - (client.descriptors.page.listInterconnectAttachments.createStream as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('uses async iteration with listInterconnectAttachments without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.InterconnectAttachment()), - ]; - client.descriptors.page.listInterconnectAttachments.asyncIterate = stubAsyncIterationCall(expectedResponse); - const responses: protos.google.cloud.edgenetwork.v1.IInterconnectAttachment[] = []; - const iterable = client.listInterconnectAttachmentsAsync(request); - for await (const resource of iterable) { - responses.push(resource!); - } - assert.deepStrictEqual(responses, expectedResponse); - assert.deepStrictEqual( - (client.descriptors.page.listInterconnectAttachments.asyncIterate as SinonStub) - .getCall(0).args[1], request); - assert( - (client.descriptors.page.listInterconnectAttachments.asyncIterate as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('uses async iteration with listInterconnectAttachments with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.descriptors.page.listInterconnectAttachments.asyncIterate = stubAsyncIterationCall(undefined, expectedError); - const iterable = client.listInterconnectAttachmentsAsync(request); - await assert.rejects(async () => { - const responses: protos.google.cloud.edgenetwork.v1.IInterconnectAttachment[] = []; - for await (const resource of iterable) { - responses.push(resource!); - } - }); - assert.deepStrictEqual( - (client.descriptors.page.listInterconnectAttachments.asyncIterate as SinonStub) - .getCall(0).args[1], request); - assert( - (client.descriptors.page.listInterconnectAttachments.asyncIterate as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - }); - - describe('listRouters', () => { - it('invokes listRouters without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListRoutersRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), - ]; - client.innerApiCalls.listRouters = stubSimpleCall(expectedResponse); - const [response] = await client.listRouters(request); - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.listRouters as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listRouters as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listRouters without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListRoutersRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`;const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), - ]; - client.innerApiCalls.listRouters = stubSimpleCallWithCallback(expectedResponse); - const promise = new Promise((resolve, reject) => { - client.listRouters( - request, - (err?: Error|null, result?: protos.google.cloud.edgenetwork.v1.IRouter[]|null) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - const actualRequest = (client.innerApiCalls.listRouters as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listRouters as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listRouters with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListRoutersRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.innerApiCalls.listRouters = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.listRouters(request), expectedError); - const actualRequest = (client.innerApiCalls.listRouters as SinonStub) - .getCall(0).args[0]; - assert.deepStrictEqual(actualRequest, request); - const actualHeaderRequestParams = (client.innerApiCalls.listRouters as SinonStub) - .getCall(0).args[1].otherArgs.headers['x-goog-request-params']; - assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); - }); - - it('invokes listRoutersStream without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListRoutersRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), - ]; - client.descriptors.page.listRouters.createStream = stubPageStreamingCall(expectedResponse); - const stream = client.listRoutersStream(request); - const promise = new Promise((resolve, reject) => { - const responses: protos.google.cloud.edgenetwork.v1.Router[] = []; - stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Router) => { - responses.push(response); - }); - stream.on('end', () => { - resolve(responses); - }); - stream.on('error', (err: Error) => { - reject(err); - }); - }); - const responses = await promise; - assert.deepStrictEqual(responses, expectedResponse); - assert((client.descriptors.page.listRouters.createStream as SinonStub) - .getCall(0).calledWith(client.innerApiCalls.listRouters, request)); - assert( - (client.descriptors.page.listRouters.createStream as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('invokes listRoutersStream with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListRoutersRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.descriptors.page.listRouters.createStream = stubPageStreamingCall(undefined, expectedError); - const stream = client.listRoutersStream(request); - const promise = new Promise((resolve, reject) => { - const responses: protos.google.cloud.edgenetwork.v1.Router[] = []; - stream.on('data', (response: protos.google.cloud.edgenetwork.v1.Router) => { - responses.push(response); - }); - stream.on('end', () => { - resolve(responses); - }); - stream.on('error', (err: Error) => { - reject(err); - }); - }); - await assert.rejects(promise, expectedError); - assert((client.descriptors.page.listRouters.createStream as SinonStub) - .getCall(0).calledWith(client.innerApiCalls.listRouters, request)); - assert( - (client.descriptors.page.listRouters.createStream as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('uses async iteration with listRouters without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListRoutersRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedResponse = [ - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), - generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), - ]; - client.descriptors.page.listRouters.asyncIterate = stubAsyncIterationCall(expectedResponse); - const responses: protos.google.cloud.edgenetwork.v1.IRouter[] = []; - const iterable = client.listRoutersAsync(request); - for await (const resource of iterable) { - responses.push(resource!); - } - assert.deepStrictEqual(responses, expectedResponse); - assert.deepStrictEqual( - (client.descriptors.page.listRouters.asyncIterate as SinonStub) - .getCall(0).args[1], request); - assert( - (client.descriptors.page.listRouters.asyncIterate as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - - it('uses async iteration with listRouters with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() - ); - const defaultValue1 = - getTypeDefaultValue('.google.cloud.edgenetwork.v1.ListRoutersRequest', ['parent']); - request.parent = defaultValue1; - const expectedHeaderRequestParams = `parent=${defaultValue1}`; - const expectedError = new Error('expected'); - client.descriptors.page.listRouters.asyncIterate = stubAsyncIterationCall(undefined, expectedError); - const iterable = client.listRoutersAsync(request); - await assert.rejects(async () => { - const responses: protos.google.cloud.edgenetwork.v1.IRouter[] = []; - for await (const resource of iterable) { - responses.push(resource!); - } - }); - assert.deepStrictEqual( - (client.descriptors.page.listRouters.asyncIterate as SinonStub) - .getCall(0).args[1], request); - assert( - (client.descriptors.page.listRouters.asyncIterate as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - }); - describe('getLocation', () => { - it('invokes getLocation without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new LocationProtos.google.cloud.location.GetLocationRequest() - ); - request.name = ''; - const expectedHeaderRequestParams = 'name='; - const expectedOptions = { - otherArgs: { - headers: { - 'x-goog-request-params': expectedHeaderRequestParams, - }, - }, - }; - const expectedResponse = generateSampleMessage( - new LocationProtos.google.cloud.location.Location() - ); - client.locationsClient.getLocation = stubSimpleCall(expectedResponse); - const response = await client.getLocation(request, expectedOptions); - assert.deepStrictEqual(response, [expectedResponse]); - assert((client.locationsClient.getLocation as SinonStub) - .getCall(0).calledWith(request, expectedOptions, undefined)); - }); - it('invokes getLocation without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new LocationProtos.google.cloud.location.GetLocationRequest() - ); - request.name = ''; - const expectedHeaderRequestParams = 'name='; - const expectedOptions = { - otherArgs: { - headers: { - 'x-goog-request-params': expectedHeaderRequestParams, - }, - }, - }; - const expectedResponse = generateSampleMessage( - new LocationProtos.google.cloud.location.Location() - ); - client.locationsClient.getLocation = sinon.stub().callsArgWith(2, null, expectedResponse); - const promise = new Promise((resolve, reject) => { - client.getLocation( - request, - expectedOptions, - ( - err?: Error | null, - result?: LocationProtos.google.cloud.location.ILocation | null - ) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - assert((client.locationsClient.getLocation as SinonStub) - .getCall(0)); - }); - it('invokes getLocation with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new LocationProtos.google.cloud.location.GetLocationRequest() - ); - request.name = ''; - const expectedHeaderRequestParams = 'name='; - const expectedOptions = { - otherArgs: { - headers: { - 'x-goog-request-params': expectedHeaderRequestParams, - }, - }, - }; - const expectedError = new Error('expected'); - client.locationsClient.getLocation = stubSimpleCall(undefined, expectedError); - await assert.rejects(client.getLocation(request, expectedOptions), expectedError); - assert((client.locationsClient.getLocation as SinonStub) - .getCall(0).calledWith(request, expectedOptions, undefined)); - }); - }); - describe('listLocationsAsync', () => { - it('uses async iteration with listLocations without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new LocationProtos.google.cloud.location.ListLocationsRequest() - ); - request.name = ''; - const expectedHeaderRequestParams = 'name='; - const expectedResponse = [ - generateSampleMessage( - new LocationProtos.google.cloud.location.Location() - ), - generateSampleMessage( - new LocationProtos.google.cloud.location.Location() - ), - generateSampleMessage( - new LocationProtos.google.cloud.location.Location() - ), - ]; - client.locationsClient.descriptors.page.listLocations.asyncIterate = stubAsyncIterationCall(expectedResponse); - const responses: LocationProtos.google.cloud.location.ILocation[] = []; - const iterable = client.listLocationsAsync(request); - for await (const resource of iterable) { - responses.push(resource!); - } - assert.deepStrictEqual(responses, expectedResponse); - assert.deepStrictEqual( - (client.locationsClient.descriptors.page.listLocations.asyncIterate as SinonStub) - .getCall(0).args[1], request); - assert( - (client.locationsClient.descriptors.page.listLocations.asyncIterate as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - it('uses async iteration with listLocations with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new LocationProtos.google.cloud.location.ListLocationsRequest() - ); - request.name = ''; - const expectedHeaderRequestParams = 'name='; - const expectedError = new Error('expected'); - client.locationsClient.descriptors.page.listLocations.asyncIterate = stubAsyncIterationCall(undefined, expectedError); - const iterable = client.listLocationsAsync(request); - await assert.rejects(async () => { - const responses: LocationProtos.google.cloud.location.ILocation[] = []; - for await (const resource of iterable) { - responses.push(resource!); - } - }); - assert.deepStrictEqual( - (client.locationsClient.descriptors.page.listLocations.asyncIterate as SinonStub) - .getCall(0).args[1], request); - assert( - (client.locationsClient.descriptors.page.listLocations.asyncIterate as SinonStub) - .getCall(0).args[2].otherArgs.headers['x-goog-request-params'].includes( - expectedHeaderRequestParams - ) - ); - }); - }); - describe('getOperation', () => { - it('invokes getOperation without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new operationsProtos.google.longrunning.GetOperationRequest() - ); - const expectedResponse = generateSampleMessage( - new operationsProtos.google.longrunning.Operation() - ); - client.operationsClient.getOperation = stubSimpleCall(expectedResponse); - const response = await client.getOperation(request); - assert.deepStrictEqual(response, [expectedResponse]); - assert((client.operationsClient.getOperation as SinonStub) - .getCall(0).calledWith(request) - ); - }); - it('invokes getOperation without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - const request = generateSampleMessage( - new operationsProtos.google.longrunning.GetOperationRequest() - ); - const expectedResponse = generateSampleMessage( - new operationsProtos.google.longrunning.Operation() - ); - client.operationsClient.getOperation = sinon.stub().callsArgWith(2, null, expectedResponse); - const promise = new Promise((resolve, reject) => { - client.operationsClient.getOperation( - request, - undefined, - ( - err?: Error | null, - result?: operationsProtos.google.longrunning.Operation | null - ) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - assert((client.operationsClient.getOperation as SinonStub) - .getCall(0)); - }); - it('invokes getOperation with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - const request = generateSampleMessage( - new operationsProtos.google.longrunning.GetOperationRequest() - ); - const expectedError = new Error('expected'); - client.operationsClient.getOperation = stubSimpleCall(undefined, expectedError); - await assert.rejects(async () => {await client.getOperation(request)}, expectedError); - assert((client.operationsClient.getOperation as SinonStub) - .getCall(0).calledWith(request)); - }); - }); - describe('cancelOperation', () => { - it('invokes cancelOperation without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new operationsProtos.google.longrunning.CancelOperationRequest() - ); - const expectedResponse = generateSampleMessage( - new protos.google.protobuf.Empty() - ); - client.operationsClient.cancelOperation = stubSimpleCall(expectedResponse); - const response = await client.cancelOperation(request); - assert.deepStrictEqual(response, [expectedResponse]); - assert((client.operationsClient.cancelOperation as SinonStub) - .getCall(0).calledWith(request) - ); - }); - it('invokes cancelOperation without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - const request = generateSampleMessage( - new operationsProtos.google.longrunning.CancelOperationRequest() - ); - const expectedResponse = generateSampleMessage( - new protos.google.protobuf.Empty() - ); - client.operationsClient.cancelOperation = sinon.stub().callsArgWith(2, null, expectedResponse); - const promise = new Promise((resolve, reject) => { - client.operationsClient.cancelOperation( - request, - undefined, - ( - err?: Error | null, - result?: protos.google.protobuf.Empty | null - ) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - assert((client.operationsClient.cancelOperation as SinonStub) - .getCall(0)); - }); - it('invokes cancelOperation with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - const request = generateSampleMessage( - new operationsProtos.google.longrunning.CancelOperationRequest() - ); - const expectedError = new Error('expected'); - client.operationsClient.cancelOperation = stubSimpleCall(undefined, expectedError); - await assert.rejects(async () => {await client.cancelOperation(request)}, expectedError); - assert((client.operationsClient.cancelOperation as SinonStub) - .getCall(0).calledWith(request)); - }); - }); - describe('deleteOperation', () => { - it('invokes deleteOperation without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new operationsProtos.google.longrunning.DeleteOperationRequest() - ); - const expectedResponse = generateSampleMessage( - new protos.google.protobuf.Empty() - ); - client.operationsClient.deleteOperation = stubSimpleCall(expectedResponse); - const response = await client.deleteOperation(request); - assert.deepStrictEqual(response, [expectedResponse]); - assert((client.operationsClient.deleteOperation as SinonStub) - .getCall(0).calledWith(request) - ); - }); - it('invokes deleteOperation without error using callback', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - const request = generateSampleMessage( - new operationsProtos.google.longrunning.DeleteOperationRequest() - ); - const expectedResponse = generateSampleMessage( - new protos.google.protobuf.Empty() - ); - client.operationsClient.deleteOperation = sinon.stub().callsArgWith(2, null, expectedResponse); - const promise = new Promise((resolve, reject) => { - client.operationsClient.deleteOperation( - request, - undefined, - ( - err?: Error | null, - result?: protos.google.protobuf.Empty | null - ) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }); - }); - const response = await promise; - assert.deepStrictEqual(response, expectedResponse); - assert((client.operationsClient.deleteOperation as SinonStub) - .getCall(0)); - }); - it('invokes deleteOperation with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - const request = generateSampleMessage( - new operationsProtos.google.longrunning.DeleteOperationRequest() - ); - const expectedError = new Error('expected'); - client.operationsClient.deleteOperation = stubSimpleCall(undefined, expectedError); - await assert.rejects(async () => {await client.deleteOperation(request)}, expectedError); - assert((client.operationsClient.deleteOperation as SinonStub) - .getCall(0).calledWith(request)); - }); - }); - describe('listOperationsAsync', () => { - it('uses async iteration with listOperations without error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - const request = generateSampleMessage( - new operationsProtos.google.longrunning.ListOperationsRequest() - ); - const expectedResponse = [ - generateSampleMessage( - new operationsProtos.google.longrunning.ListOperationsResponse() - ), - generateSampleMessage( - new operationsProtos.google.longrunning.ListOperationsResponse() - ), - generateSampleMessage( - new operationsProtos.google.longrunning.ListOperationsResponse() - ), - ]; - client.operationsClient.descriptor.listOperations.asyncIterate = stubAsyncIterationCall(expectedResponse); - const responses: operationsProtos.google.longrunning.ListOperationsResponse[] = []; - const iterable = client.operationsClient.listOperationsAsync(request); - for await (const resource of iterable) { - responses.push(resource!); - } - assert.deepStrictEqual(responses, expectedResponse); - assert.deepStrictEqual( - (client.operationsClient.descriptor.listOperations.asyncIterate as SinonStub) - .getCall(0).args[1], request); - }); - it('uses async iteration with listOperations with error', async () => { - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - const request = generateSampleMessage( - new operationsProtos.google.longrunning.ListOperationsRequest() - ); - const expectedError = new Error('expected'); - client.operationsClient.descriptor.listOperations.asyncIterate = stubAsyncIterationCall(undefined, expectedError); - const iterable = client.operationsClient.listOperationsAsync(request); - await assert.rejects(async () => { - const responses: operationsProtos.google.longrunning.ListOperationsResponse[] = []; - for await (const resource of iterable) { - responses.push(resource!); - } - }); - assert.deepStrictEqual( - (client.operationsClient.descriptor.listOperations.asyncIterate as SinonStub) - .getCall(0).args[1], request); - }); - }); - - describe('Path templates', () => { - - describe('interconnect', () => { - const fakePath = "/rendered/path/interconnect"; - const expectedParameters = { - project: "projectValue", - location: "locationValue", - zone: "zoneValue", - interconnect: "interconnectValue", - }; - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - client.pathTemplates.interconnectPathTemplate.render = - sinon.stub().returns(fakePath); - client.pathTemplates.interconnectPathTemplate.match = - sinon.stub().returns(expectedParameters); - - it('interconnectPath', () => { - const result = client.interconnectPath("projectValue", "locationValue", "zoneValue", "interconnectValue"); - assert.strictEqual(result, fakePath); - assert((client.pathTemplates.interconnectPathTemplate.render as SinonStub) - .getCall(-1).calledWith(expectedParameters)); - }); - - it('matchProjectFromInterconnectName', () => { - const result = client.matchProjectFromInterconnectName(fakePath); - assert.strictEqual(result, "projectValue"); - assert((client.pathTemplates.interconnectPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchLocationFromInterconnectName', () => { - const result = client.matchLocationFromInterconnectName(fakePath); - assert.strictEqual(result, "locationValue"); - assert((client.pathTemplates.interconnectPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchZoneFromInterconnectName', () => { - const result = client.matchZoneFromInterconnectName(fakePath); - assert.strictEqual(result, "zoneValue"); - assert((client.pathTemplates.interconnectPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchInterconnectFromInterconnectName', () => { - const result = client.matchInterconnectFromInterconnectName(fakePath); - assert.strictEqual(result, "interconnectValue"); - assert((client.pathTemplates.interconnectPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - }); - - describe('interconnectAttachment', () => { - const fakePath = "/rendered/path/interconnectAttachment"; - const expectedParameters = { - project: "projectValue", - location: "locationValue", - zone: "zoneValue", - interconnect_attachment: "interconnectAttachmentValue", - }; - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - client.pathTemplates.interconnectAttachmentPathTemplate.render = - sinon.stub().returns(fakePath); - client.pathTemplates.interconnectAttachmentPathTemplate.match = - sinon.stub().returns(expectedParameters); - - it('interconnectAttachmentPath', () => { - const result = client.interconnectAttachmentPath("projectValue", "locationValue", "zoneValue", "interconnectAttachmentValue"); - assert.strictEqual(result, fakePath); - assert((client.pathTemplates.interconnectAttachmentPathTemplate.render as SinonStub) - .getCall(-1).calledWith(expectedParameters)); - }); - - it('matchProjectFromInterconnectAttachmentName', () => { - const result = client.matchProjectFromInterconnectAttachmentName(fakePath); - assert.strictEqual(result, "projectValue"); - assert((client.pathTemplates.interconnectAttachmentPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchLocationFromInterconnectAttachmentName', () => { - const result = client.matchLocationFromInterconnectAttachmentName(fakePath); - assert.strictEqual(result, "locationValue"); - assert((client.pathTemplates.interconnectAttachmentPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchZoneFromInterconnectAttachmentName', () => { - const result = client.matchZoneFromInterconnectAttachmentName(fakePath); - assert.strictEqual(result, "zoneValue"); - assert((client.pathTemplates.interconnectAttachmentPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchInterconnectAttachmentFromInterconnectAttachmentName', () => { - const result = client.matchInterconnectAttachmentFromInterconnectAttachmentName(fakePath); - assert.strictEqual(result, "interconnectAttachmentValue"); - assert((client.pathTemplates.interconnectAttachmentPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - }); - - describe('location', () => { - const fakePath = "/rendered/path/location"; - const expectedParameters = { - project: "projectValue", - location: "locationValue", - }; - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - client.pathTemplates.locationPathTemplate.render = - sinon.stub().returns(fakePath); - client.pathTemplates.locationPathTemplate.match = - sinon.stub().returns(expectedParameters); - - it('locationPath', () => { - const result = client.locationPath("projectValue", "locationValue"); - assert.strictEqual(result, fakePath); - assert((client.pathTemplates.locationPathTemplate.render as SinonStub) - .getCall(-1).calledWith(expectedParameters)); - }); - - it('matchProjectFromLocationName', () => { - const result = client.matchProjectFromLocationName(fakePath); - assert.strictEqual(result, "projectValue"); - assert((client.pathTemplates.locationPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchLocationFromLocationName', () => { - const result = client.matchLocationFromLocationName(fakePath); - assert.strictEqual(result, "locationValue"); - assert((client.pathTemplates.locationPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - }); - - describe('network', () => { - const fakePath = "/rendered/path/network"; - const expectedParameters = { - project: "projectValue", - location: "locationValue", - zone: "zoneValue", - network: "networkValue", - }; - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - client.pathTemplates.networkPathTemplate.render = - sinon.stub().returns(fakePath); - client.pathTemplates.networkPathTemplate.match = - sinon.stub().returns(expectedParameters); - - it('networkPath', () => { - const result = client.networkPath("projectValue", "locationValue", "zoneValue", "networkValue"); - assert.strictEqual(result, fakePath); - assert((client.pathTemplates.networkPathTemplate.render as SinonStub) - .getCall(-1).calledWith(expectedParameters)); - }); - - it('matchProjectFromNetworkName', () => { - const result = client.matchProjectFromNetworkName(fakePath); - assert.strictEqual(result, "projectValue"); - assert((client.pathTemplates.networkPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchLocationFromNetworkName', () => { - const result = client.matchLocationFromNetworkName(fakePath); - assert.strictEqual(result, "locationValue"); - assert((client.pathTemplates.networkPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchZoneFromNetworkName', () => { - const result = client.matchZoneFromNetworkName(fakePath); - assert.strictEqual(result, "zoneValue"); - assert((client.pathTemplates.networkPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchNetworkFromNetworkName', () => { - const result = client.matchNetworkFromNetworkName(fakePath); - assert.strictEqual(result, "networkValue"); - assert((client.pathTemplates.networkPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - }); - - describe('project', () => { - const fakePath = "/rendered/path/project"; - const expectedParameters = { - project: "projectValue", - }; - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - client.pathTemplates.projectPathTemplate.render = - sinon.stub().returns(fakePath); - client.pathTemplates.projectPathTemplate.match = - sinon.stub().returns(expectedParameters); - - it('projectPath', () => { - const result = client.projectPath("projectValue"); - assert.strictEqual(result, fakePath); - assert((client.pathTemplates.projectPathTemplate.render as SinonStub) - .getCall(-1).calledWith(expectedParameters)); - }); - - it('matchProjectFromProjectName', () => { - const result = client.matchProjectFromProjectName(fakePath); - assert.strictEqual(result, "projectValue"); - assert((client.pathTemplates.projectPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - }); - - describe('router', () => { - const fakePath = "/rendered/path/router"; - const expectedParameters = { - project: "projectValue", - location: "locationValue", - zone: "zoneValue", - router: "routerValue", - }; - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - client.pathTemplates.routerPathTemplate.render = - sinon.stub().returns(fakePath); - client.pathTemplates.routerPathTemplate.match = - sinon.stub().returns(expectedParameters); - - it('routerPath', () => { - const result = client.routerPath("projectValue", "locationValue", "zoneValue", "routerValue"); - assert.strictEqual(result, fakePath); - assert((client.pathTemplates.routerPathTemplate.render as SinonStub) - .getCall(-1).calledWith(expectedParameters)); - }); - - it('matchProjectFromRouterName', () => { - const result = client.matchProjectFromRouterName(fakePath); - assert.strictEqual(result, "projectValue"); - assert((client.pathTemplates.routerPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchLocationFromRouterName', () => { - const result = client.matchLocationFromRouterName(fakePath); - assert.strictEqual(result, "locationValue"); - assert((client.pathTemplates.routerPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchZoneFromRouterName', () => { - const result = client.matchZoneFromRouterName(fakePath); - assert.strictEqual(result, "zoneValue"); - assert((client.pathTemplates.routerPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchRouterFromRouterName', () => { - const result = client.matchRouterFromRouterName(fakePath); - assert.strictEqual(result, "routerValue"); - assert((client.pathTemplates.routerPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - }); - - describe('subnet', () => { - const fakePath = "/rendered/path/subnet"; - const expectedParameters = { - project: "projectValue", - location: "locationValue", - zone: "zoneValue", - subnet: "subnetValue", - }; - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - client.pathTemplates.subnetPathTemplate.render = - sinon.stub().returns(fakePath); - client.pathTemplates.subnetPathTemplate.match = - sinon.stub().returns(expectedParameters); - - it('subnetPath', () => { - const result = client.subnetPath("projectValue", "locationValue", "zoneValue", "subnetValue"); - assert.strictEqual(result, fakePath); - assert((client.pathTemplates.subnetPathTemplate.render as SinonStub) - .getCall(-1).calledWith(expectedParameters)); - }); - - it('matchProjectFromSubnetName', () => { - const result = client.matchProjectFromSubnetName(fakePath); - assert.strictEqual(result, "projectValue"); - assert((client.pathTemplates.subnetPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchLocationFromSubnetName', () => { - const result = client.matchLocationFromSubnetName(fakePath); - assert.strictEqual(result, "locationValue"); - assert((client.pathTemplates.subnetPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchZoneFromSubnetName', () => { - const result = client.matchZoneFromSubnetName(fakePath); - assert.strictEqual(result, "zoneValue"); - assert((client.pathTemplates.subnetPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchSubnetFromSubnetName', () => { - const result = client.matchSubnetFromSubnetName(fakePath); - assert.strictEqual(result, "subnetValue"); - assert((client.pathTemplates.subnetPathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - }); - - describe('zone', () => { - const fakePath = "/rendered/path/zone"; - const expectedParameters = { - project: "projectValue", - location: "locationValue", - zone: "zoneValue", - }; - const client = new edgenetworkModule.v1.EdgeNetworkClient({ - credentials: {client_email: 'bogus', private_key: 'bogus'}, - projectId: 'bogus', - }); - client.initialize(); - client.pathTemplates.zonePathTemplate.render = - sinon.stub().returns(fakePath); - client.pathTemplates.zonePathTemplate.match = - sinon.stub().returns(expectedParameters); - - it('zonePath', () => { - const result = client.zonePath("projectValue", "locationValue", "zoneValue"); - assert.strictEqual(result, fakePath); - assert((client.pathTemplates.zonePathTemplate.render as SinonStub) - .getCall(-1).calledWith(expectedParameters)); - }); - - it('matchProjectFromZoneName', () => { - const result = client.matchProjectFromZoneName(fakePath); - assert.strictEqual(result, "projectValue"); - assert((client.pathTemplates.zonePathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchLocationFromZoneName', () => { - const result = client.matchLocationFromZoneName(fakePath); - assert.strictEqual(result, "locationValue"); - assert((client.pathTemplates.zonePathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - - it('matchZoneFromZoneName', () => { - const result = client.matchZoneFromZoneName(fakePath); - assert.strictEqual(result, "zoneValue"); - assert((client.pathTemplates.zonePathTemplate.match as SinonStub) - .getCall(-1).calledWith(fakePath)); - }); - }); - }); -}); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/.eslintignore b/packages/google-cloud-edgenetwork/.eslintignore similarity index 68% rename from owl-bot-staging/google-cloud-edgenetwork/v1/.eslintignore rename to packages/google-cloud-edgenetwork/.eslintignore index cfc348ec4d11..ea5b04aebe68 100644 --- a/owl-bot-staging/google-cloud-edgenetwork/v1/.eslintignore +++ b/packages/google-cloud-edgenetwork/.eslintignore @@ -1,7 +1,7 @@ **/node_modules -**/.coverage +**/coverage +test/fixtures build/ docs/ protos/ -system-test/ samples/generated/ diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/.eslintrc.json b/packages/google-cloud-edgenetwork/.eslintrc.json similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/.eslintrc.json rename to packages/google-cloud-edgenetwork/.eslintrc.json diff --git a/packages/google-cloud-edgenetwork/.gitattributes b/packages/google-cloud-edgenetwork/.gitattributes new file mode 100644 index 000000000000..33739cb74e44 --- /dev/null +++ b/packages/google-cloud-edgenetwork/.gitattributes @@ -0,0 +1,4 @@ +*.ts text eol=lf +*.js text eol=lf +protos/* linguist-generated +**/api-extractor.json linguist-language=JSON-with-Comments diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/.gitignore b/packages/google-cloud-edgenetwork/.gitignore similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/.gitignore rename to packages/google-cloud-edgenetwork/.gitignore diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/.jsdoc.js b/packages/google-cloud-edgenetwork/.jsdoc.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/.jsdoc.js rename to packages/google-cloud-edgenetwork/.jsdoc.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/.mocharc.js b/packages/google-cloud-edgenetwork/.mocharc.js similarity index 77% rename from owl-bot-staging/google-cloud-edgenetwork/v1/.mocharc.js rename to packages/google-cloud-edgenetwork/.mocharc.js index 1a38f257db70..49e7e228701d 100644 --- a/owl-bot-staging/google-cloud-edgenetwork/v1/.mocharc.js +++ b/packages/google-cloud-edgenetwork/.mocharc.js @@ -4,22 +4,18 @@ // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // -// https://www.apache.org/licenses/LICENSE-2.0 +// http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. -// -// ** This file is automatically generated by gapic-generator-typescript. ** -// ** https://github.com/googleapis/gapic-generator-typescript ** -// ** All changes to this file may be overwritten. ** - const config = { "enable-source-maps": true, "throw-deprecation": true, - "timeout": 10000 + "timeout": 10000, + "recursive": true } if (process.env.MOCHA_THROW_DEPRECATION === 'false') { delete config['throw-deprecation']; diff --git a/packages/google-cloud-edgenetwork/.nycrc b/packages/google-cloud-edgenetwork/.nycrc new file mode 100644 index 000000000000..b18d5472b62b --- /dev/null +++ b/packages/google-cloud-edgenetwork/.nycrc @@ -0,0 +1,24 @@ +{ + "report-dir": "./.coverage", + "reporter": ["text", "lcov"], + "exclude": [ + "**/*-test", + "**/.coverage", + "**/apis", + "**/benchmark", + "**/conformance", + "**/docs", + "**/samples", + "**/scripts", + "**/protos", + "**/test", + "**/*.d.ts", + ".jsdoc.js", + "**/.jsdoc.js", + "karma.conf.js", + "webpack-tests.config.js", + "webpack.config.js" + ], + "exclude-after-remap": false, + "all": true +} diff --git a/packages/google-cloud-edgenetwork/.prettierignore b/packages/google-cloud-edgenetwork/.prettierignore new file mode 100644 index 000000000000..9340ad9b86d3 --- /dev/null +++ b/packages/google-cloud-edgenetwork/.prettierignore @@ -0,0 +1,6 @@ +**/node_modules +**/coverage +test/fixtures +build/ +docs/ +protos/ diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/.prettierrc.js b/packages/google-cloud-edgenetwork/.prettierrc.js similarity index 70% rename from owl-bot-staging/google-cloud-edgenetwork/v1/.prettierrc.js rename to packages/google-cloud-edgenetwork/.prettierrc.js index 55639e70f9ea..1e6cec783e40 100644 --- a/owl-bot-staging/google-cloud-edgenetwork/v1/.prettierrc.js +++ b/packages/google-cloud-edgenetwork/.prettierrc.js @@ -4,18 +4,13 @@ // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // -// https://www.apache.org/licenses/LICENSE-2.0 +// https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. -// -// ** This file is automatically generated by gapic-generator-typescript. ** -// ** https://github.com/googleapis/gapic-generator-typescript ** -// ** All changes to this file may be overwritten. ** - module.exports = { ...require('gts/.prettierrc.json') diff --git a/packages/google-cloud-edgenetwork/CODE_OF_CONDUCT.md b/packages/google-cloud-edgenetwork/CODE_OF_CONDUCT.md new file mode 100644 index 000000000000..2add2547a812 --- /dev/null +++ b/packages/google-cloud-edgenetwork/CODE_OF_CONDUCT.md @@ -0,0 +1,94 @@ + +# Code of Conduct + +## Our Pledge + +In the interest of fostering an open and welcoming environment, we as +contributors and maintainers pledge to making participation in our project and +our community a harassment-free experience for everyone, regardless of age, body +size, disability, ethnicity, gender identity and expression, level of +experience, education, socio-economic status, nationality, personal appearance, +race, religion, or sexual identity and orientation. + +## Our Standards + +Examples of behavior that contributes to creating a positive environment +include: + +* Using welcoming and inclusive language +* Being respectful of differing viewpoints and experiences +* Gracefully accepting constructive criticism +* Focusing on what is best for the community +* Showing empathy towards other community members + +Examples of unacceptable behavior by participants include: + +* The use of sexualized language or imagery and unwelcome sexual attention or + advances +* Trolling, insulting/derogatory comments, and personal or political attacks +* Public or private harassment +* Publishing others' private information, such as a physical or electronic + address, without explicit permission +* Other conduct which could reasonably be considered inappropriate in a + professional setting + +## Our Responsibilities + +Project maintainers are responsible for clarifying the standards of acceptable +behavior and are expected to take appropriate and fair corrective action in +response to any instances of unacceptable behavior. + +Project maintainers have the right and responsibility to remove, edit, or reject +comments, commits, code, wiki edits, issues, and other contributions that are +not aligned to this Code of Conduct, or to ban temporarily or permanently any +contributor for other behaviors that they deem inappropriate, threatening, +offensive, or harmful. + +## Scope + +This Code of Conduct applies both within project spaces and in public spaces +when an individual is representing the project or its community. Examples of +representing a project or community include using an official project e-mail +address, posting via an official social media account, or acting as an appointed +representative at an online or offline event. Representation of a project may be +further defined and clarified by project maintainers. + +This Code of Conduct also applies outside the project spaces when the Project +Steward has a reasonable belief that an individual's behavior may have a +negative impact on the project or its community. + +## Conflict Resolution + +We do not believe that all conflict is bad; healthy debate and disagreement +often yield positive results. However, it is never okay to be disrespectful or +to engage in behavior that violates the project’s code of conduct. + +If you see someone violating the code of conduct, you are encouraged to address +the behavior directly with those involved. Many issues can be resolved quickly +and easily, and this gives people more control over the outcome of their +dispute. If you are unable to resolve the matter for any reason, or if the +behavior is threatening or harassing, report it. We are dedicated to providing +an environment where participants feel welcome and safe. + +Reports should be directed to *googleapis-stewards@google.com*, the +Project Steward(s) for *Google Cloud Client Libraries*. It is the Project Steward’s duty to +receive and address reported violations of the code of conduct. They will then +work with a committee consisting of representatives from the Open Source +Programs Office and the Google Open Source Strategy team. If for any reason you +are uncomfortable reaching out to the Project Steward, please email +opensource@google.com. + +We will investigate every complaint, but you may not receive a direct response. +We will use our discretion in determining when and how to follow up on reported +incidents, which may range from not taking action to permanent expulsion from +the project and project-sponsored spaces. We will notify the accused of the +report and provide them an opportunity to discuss it before any action is taken. +The identity of the reporter will be omitted from the details of the report +supplied to the accused. In potentially harmful situations, such as ongoing +harassment or threats to anyone's safety, we may take action without notice. + +## Attribution + +This Code of Conduct is adapted from the Contributor Covenant, version 1.4, +available at +https://www.contributor-covenant.org/version/1/4/code-of-conduct.html \ No newline at end of file diff --git a/packages/google-cloud-edgenetwork/CONTRIBUTING.md b/packages/google-cloud-edgenetwork/CONTRIBUTING.md new file mode 100644 index 000000000000..cc97fa9fa0c2 --- /dev/null +++ b/packages/google-cloud-edgenetwork/CONTRIBUTING.md @@ -0,0 +1,76 @@ +# How to become a contributor and submit your own code + +**Table of contents** + +* [Contributor License Agreements](#contributor-license-agreements) +* [Contributing a patch](#contributing-a-patch) +* [Running the tests](#running-the-tests) +* [Releasing the library](#releasing-the-library) + +## Contributor License Agreements + +We'd love to accept your sample apps and patches! Before we can take them, we +have to jump a couple of legal hurdles. + +Please fill out either the individual or corporate Contributor License Agreement +(CLA). + + * If you are an individual writing original source code and you're sure you + own the intellectual property, then you'll need to sign an [individual CLA](https://developers.google.com/open-source/cla/individual). + * If you work for a company that wants to allow you to contribute your work, + then you'll need to sign a [corporate CLA](https://developers.google.com/open-source/cla/corporate). + +Follow either of the two links above to access the appropriate CLA and +instructions for how to sign and return it. Once we receive it, we'll be able to +accept your pull requests. + +## Contributing A Patch + +1. Submit an issue describing your proposed change to the repo in question. +1. The repo owner will respond to your issue promptly. +1. If your proposed change is accepted, and you haven't already done so, sign a + Contributor License Agreement (see details above). +1. Fork the desired repo, develop and test your code changes. +1. Ensure that your code adheres to the existing style in the code to which + you are contributing. +1. Ensure that your code has an appropriate set of tests which all pass. +1. Title your pull request following [Conventional Commits](https://www.conventionalcommits.org/) styling. +1. Submit a pull request. + +### Before you begin + +1. [Select or create a Cloud Platform project][projects]. +1. [Enable billing for your project][billing]. +1. [Enable the Distributed Cloud Edge Network API API][enable_api]. +1. [Set up authentication with a service account][auth] so you can access the + API from your local workstation. + + +## Running the tests + +1. [Prepare your environment for Node.js setup][setup]. + +1. Install dependencies: + + npm install + +1. Run the tests: + + # Run unit tests. + npm test + + # Run sample integration tests. + npm run samples-test + + # Run all system tests. + npm run system-test + +1. Lint (and maybe fix) any changes: + + npm run fix + +[setup]: https://cloud.google.com/nodejs/docs/setup +[projects]: https://console.cloud.google.com/project +[billing]: https://support.google.com/cloud/answer/6293499#enable-billing +[enable_api]: https://console.cloud.google.com/flows/enableapi?apiid=edgenetwork.googleapis.com +[auth]: https://cloud.google.com/docs/authentication/getting-started \ No newline at end of file diff --git a/packages/google-cloud-edgenetwork/README.md b/packages/google-cloud-edgenetwork/README.md new file mode 100644 index 000000000000..ae0bf125471d --- /dev/null +++ b/packages/google-cloud-edgenetwork/README.md @@ -0,0 +1,214 @@ +[//]: # "This README.md file is auto-generated, all changes to this file will be lost." +[//]: # "To regenerate it, use `python -m synthtool`." +Google Cloud Platform logo + +# [Distributed Cloud Edge Network API: Node.js Client](https://github.com/googleapis/google-cloud-node/tree/main/packages/google-cloud-edgenetwork) + +[![release level](https://img.shields.io/badge/release%20level-preview-yellow.svg?style=flat)](https://cloud.google.com/terms/launch-stages) +[![npm version](https://img.shields.io/npm/v/@google-cloud/edgenetwork.svg)](https://www.npmjs.org/package/@google-cloud/edgenetwork) + + + + +Distributed Cloud Edge Network API client for Node.js + + +A comprehensive list of changes in each version may be found in +[the CHANGELOG](https://github.com/googleapis/google-cloud-node/tree/main/packages/google-cloud-edgenetwork/CHANGELOG.md). + +* [Distributed Cloud Edge Network API Node.js Client API Reference][client-docs] +* [Distributed Cloud Edge Network API Documentation][product-docs] +* [github.com/googleapis/google-cloud-node/packages/google-cloud-edgenetwork](https://github.com/googleapis/google-cloud-node/tree/main/packages/google-cloud-edgenetwork) + +Read more about the client libraries for Cloud APIs, including the older +Google APIs Client Libraries, in [Client Libraries Explained][explained]. + +[explained]: https://cloud.google.com/apis/docs/client-libraries-explained + +**Table of contents:** + + +* [Quickstart](#quickstart) + * [Before you begin](#before-you-begin) + * [Installing the client library](#installing-the-client-library) + * [Using the client library](#using-the-client-library) +* [Samples](#samples) +* [Versioning](#versioning) +* [Contributing](#contributing) +* [License](#license) + +## Quickstart + +### Before you begin + +1. [Select or create a Cloud Platform project][projects]. +1. [Enable billing for your project][billing]. +1. [Enable the Distributed Cloud Edge Network API API][enable_api]. +1. [Set up authentication with a service account][auth] so you can access the + API from your local workstation. + +### Installing the client library + +```bash +npm install @google-cloud/edgenetwork +``` + + +### Using the client library + +```javascript +/** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ +/** + * Required. Parent value for ListRoutersRequest + */ +// const parent = 'abc123' +/** + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + */ +// const pageSize = 1234 +/** + * A token identifying a page of results the server should return. + */ +// const pageToken = 'abc123' +/** + * Filtering results + */ +// const filter = 'abc123' +/** + * Hint for how to order the results + */ +// const orderBy = 'abc123' + +// Imports the Edgenetwork library +const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + +// Instantiates a client +const edgenetworkClient = new EdgeNetworkClient(); + +async function callListRouters() { + // Construct request + const request = { + parent, + }; + + // Run request + const iterable = await edgenetworkClient.listRoutersAsync(request); + for await (const response of iterable) { + console.log(response); + } +} + +callListRouters(); + +``` + + + +## Samples + +Samples are in the [`samples/`](https://github.com/googleapis/google-cloud-node/tree/main/packages/google-cloud-edgenetwork/samples) directory. Each sample's `README.md` has instructions for running its sample. + +| Sample | Source Code | Try it | +| --------------------------- | --------------------------------- | ------ | +| Edge_network.create_interconnect_attachment | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_interconnect_attachment.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_interconnect_attachment.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.create_network | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_network.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_network.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.create_router | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_router.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_router.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.create_subnet | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_subnet.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_subnet.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.delete_interconnect_attachment | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_interconnect_attachment.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_interconnect_attachment.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.delete_network | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_network.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_network.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.delete_router | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_router.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_router.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.delete_subnet | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_subnet.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_subnet.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.diagnose_interconnect | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_interconnect.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_interconnect.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.diagnose_network | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_network.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_network.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.diagnose_router | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_router.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_router.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.get_interconnect | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_interconnect.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_interconnect.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.get_interconnect_attachment | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_interconnect_attachment.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_interconnect_attachment.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.get_network | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_network.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_network.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.get_router | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_router.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_router.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.get_subnet | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_subnet.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_subnet.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.get_zone | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_zone.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_zone.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.initialize_zone | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.initialize_zone.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.initialize_zone.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.list_interconnect_attachments | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_interconnect_attachments.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_interconnect_attachments.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.list_interconnects | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_interconnects.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_interconnects.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.list_networks | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_networks.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_networks.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.list_routers | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_routers.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_routers.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.list_subnets | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_subnets.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_subnets.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.list_zones | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_zones.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_zones.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.update_router | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.update_router.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.update_router.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Edge_network.update_subnet | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.update_subnet.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.update_subnet.js,packages/google-cloud-edgenetwork/samples/README.md) | +| Quickstart | [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/quickstart.js) | [![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/quickstart.js,packages/google-cloud-edgenetwork/samples/README.md) | + + + +The [Distributed Cloud Edge Network API Node.js Client API Reference][client-docs] documentation +also contains samples. + +## Supported Node.js Versions + +Our client libraries follow the [Node.js release schedule](https://github.com/nodejs/release#release-schedule). +Libraries are compatible with all current _active_ and _maintenance_ versions of +Node.js. +If you are using an end-of-life version of Node.js, we recommend that you update +as soon as possible to an actively supported LTS version. + +Google's client libraries support legacy versions of Node.js runtimes on a +best-efforts basis with the following warnings: + +* Legacy versions are not tested in continuous integration. +* Some security patches and features cannot be backported. +* Dependencies cannot be kept up-to-date. + +Client libraries targeting some end-of-life versions of Node.js are available, and +can be installed through npm [dist-tags](https://docs.npmjs.com/cli/dist-tag). +The dist-tags follow the naming convention `legacy-(version)`. +For example, `npm install @google-cloud/edgenetwork@legacy-8` installs client libraries +for versions compatible with Node.js 8. + +## Versioning + +This library follows [Semantic Versioning](http://semver.org/). + + + + + + + +This library is considered to be in **preview**. This means it is still a +work-in-progress and under active development. Any release is subject to +backwards-incompatible changes at any time. + + +More Information: [Google Cloud Platform Launch Stages][launch_stages] + +[launch_stages]: https://cloud.google.com/terms/launch-stages + +## Contributing + +Contributions welcome! See the [Contributing Guide](https://github.com/googleapis/google-cloud-node/blob/main/CONTRIBUTING.md). + +Please note that this `README.md`, the `samples/README.md`, +and a variety of configuration files in this repository (including `.nycrc` and `tsconfig.json`) +are generated from a central template. To edit one of these files, make an edit +to its templates in +[directory](https://github.com/googleapis/synthtool). + +## License + +Apache Version 2.0 + +See [LICENSE](https://github.com/googleapis/google-cloud-node/blob/main/LICENSE) + +[client-docs]: https://cloud.google.com/nodejs/docs/reference/edgenetwork/latest +[product-docs]: https://cloud.google.com/distributed-cloud/edge/latest/docs/overview +[shell_img]: https://gstatic.com/cloudssh/images/open-btn.png +[projects]: https://console.cloud.google.com/project +[billing]: https://support.google.com/cloud/answer/6293499#enable-billing +[enable_api]: https://console.cloud.google.com/flows/enableapi?apiid=edgenetwork.googleapis.com +[auth]: https://cloud.google.com/docs/authentication/getting-started diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/protos/google/cloud/edgenetwork/v1/resources.proto b/packages/google-cloud-edgenetwork/protos/google/cloud/edgenetwork/v1/resources.proto similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/protos/google/cloud/edgenetwork/v1/resources.proto rename to packages/google-cloud-edgenetwork/protos/google/cloud/edgenetwork/v1/resources.proto diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/protos/google/cloud/edgenetwork/v1/service.proto b/packages/google-cloud-edgenetwork/protos/google/cloud/edgenetwork/v1/service.proto similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/protos/google/cloud/edgenetwork/v1/service.proto rename to packages/google-cloud-edgenetwork/protos/google/cloud/edgenetwork/v1/service.proto diff --git a/packages/google-cloud-edgenetwork/protos/protos.d.ts b/packages/google-cloud-edgenetwork/protos/protos.d.ts new file mode 100644 index 000000000000..1d1e21f82264 --- /dev/null +++ b/packages/google-cloud-edgenetwork/protos/protos.d.ts @@ -0,0 +1,14182 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +import type {protobuf as $protobuf} from "google-gax"; +import Long = require("long"); +/** Namespace google. */ +export namespace google { + + /** Namespace cloud. */ + namespace cloud { + + /** Namespace edgenetwork. */ + namespace edgenetwork { + + /** Namespace v1. */ + namespace v1 { + + /** ResourceState enum. */ + enum ResourceState { + STATE_UNKNOWN = 0, + STATE_PENDING = 1, + STATE_PROVISIONING = 2, + STATE_RUNNING = 3, + STATE_SUSPENDED = 4, + STATE_DELETING = 5 + } + + /** Properties of a Zone. */ + interface IZone { + + /** Zone name */ + name?: (string|null); + + /** Zone createTime */ + createTime?: (google.protobuf.ITimestamp|null); + + /** Zone updateTime */ + updateTime?: (google.protobuf.ITimestamp|null); + + /** Zone labels */ + labels?: ({ [k: string]: string }|null); + + /** Zone layoutName */ + layoutName?: (string|null); + } + + /** Represents a Zone. */ + class Zone implements IZone { + + /** + * Constructs a new Zone. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IZone); + + /** Zone name. */ + public name: string; + + /** Zone createTime. */ + public createTime?: (google.protobuf.ITimestamp|null); + + /** Zone updateTime. */ + public updateTime?: (google.protobuf.ITimestamp|null); + + /** Zone labels. */ + public labels: { [k: string]: string }; + + /** Zone layoutName. */ + public layoutName: string; + + /** + * Creates a new Zone instance using the specified properties. + * @param [properties] Properties to set + * @returns Zone instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IZone): google.cloud.edgenetwork.v1.Zone; + + /** + * Encodes the specified Zone message. Does not implicitly {@link google.cloud.edgenetwork.v1.Zone.verify|verify} messages. + * @param message Zone message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IZone, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Zone message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.Zone.verify|verify} messages. + * @param message Zone message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IZone, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a Zone message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Zone + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.Zone; + + /** + * Decodes a Zone message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Zone + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.Zone; + + /** + * Verifies a Zone message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a Zone message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Zone + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.Zone; + + /** + * Creates a plain object from a Zone message. Also converts values to other types if specified. + * @param message Zone + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.Zone, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Zone to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Zone + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a Network. */ + interface INetwork { + + /** Network name */ + name?: (string|null); + + /** Network createTime */ + createTime?: (google.protobuf.ITimestamp|null); + + /** Network updateTime */ + updateTime?: (google.protobuf.ITimestamp|null); + + /** Network labels */ + labels?: ({ [k: string]: string }|null); + + /** Network description */ + description?: (string|null); + + /** Network mtu */ + mtu?: (number|null); + } + + /** Represents a Network. */ + class Network implements INetwork { + + /** + * Constructs a new Network. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.INetwork); + + /** Network name. */ + public name: string; + + /** Network createTime. */ + public createTime?: (google.protobuf.ITimestamp|null); + + /** Network updateTime. */ + public updateTime?: (google.protobuf.ITimestamp|null); + + /** Network labels. */ + public labels: { [k: string]: string }; + + /** Network description. */ + public description: string; + + /** Network mtu. */ + public mtu: number; + + /** + * Creates a new Network instance using the specified properties. + * @param [properties] Properties to set + * @returns Network instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.INetwork): google.cloud.edgenetwork.v1.Network; + + /** + * Encodes the specified Network message. Does not implicitly {@link google.cloud.edgenetwork.v1.Network.verify|verify} messages. + * @param message Network message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.INetwork, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Network message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.Network.verify|verify} messages. + * @param message Network message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.INetwork, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a Network message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Network + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.Network; + + /** + * Decodes a Network message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Network + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.Network; + + /** + * Verifies a Network message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a Network message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Network + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.Network; + + /** + * Creates a plain object from a Network message. Also converts values to other types if specified. + * @param message Network + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.Network, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Network to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Network + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a Subnet. */ + interface ISubnet { + + /** Subnet name */ + name?: (string|null); + + /** Subnet createTime */ + createTime?: (google.protobuf.ITimestamp|null); + + /** Subnet updateTime */ + updateTime?: (google.protobuf.ITimestamp|null); + + /** Subnet labels */ + labels?: ({ [k: string]: string }|null); + + /** Subnet description */ + description?: (string|null); + + /** Subnet network */ + network?: (string|null); + + /** Subnet ipv4Cidr */ + ipv4Cidr?: (string[]|null); + + /** Subnet ipv6Cidr */ + ipv6Cidr?: (string[]|null); + + /** Subnet vlanId */ + vlanId?: (number|null); + + /** Subnet state */ + state?: (google.cloud.edgenetwork.v1.ResourceState|keyof typeof google.cloud.edgenetwork.v1.ResourceState|null); + } + + /** Represents a Subnet. */ + class Subnet implements ISubnet { + + /** + * Constructs a new Subnet. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.ISubnet); + + /** Subnet name. */ + public name: string; + + /** Subnet createTime. */ + public createTime?: (google.protobuf.ITimestamp|null); + + /** Subnet updateTime. */ + public updateTime?: (google.protobuf.ITimestamp|null); + + /** Subnet labels. */ + public labels: { [k: string]: string }; + + /** Subnet description. */ + public description: string; + + /** Subnet network. */ + public network: string; + + /** Subnet ipv4Cidr. */ + public ipv4Cidr: string[]; + + /** Subnet ipv6Cidr. */ + public ipv6Cidr: string[]; + + /** Subnet vlanId. */ + public vlanId: number; + + /** Subnet state. */ + public state: (google.cloud.edgenetwork.v1.ResourceState|keyof typeof google.cloud.edgenetwork.v1.ResourceState); + + /** + * Creates a new Subnet instance using the specified properties. + * @param [properties] Properties to set + * @returns Subnet instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.ISubnet): google.cloud.edgenetwork.v1.Subnet; + + /** + * Encodes the specified Subnet message. Does not implicitly {@link google.cloud.edgenetwork.v1.Subnet.verify|verify} messages. + * @param message Subnet message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.ISubnet, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Subnet message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.Subnet.verify|verify} messages. + * @param message Subnet message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.ISubnet, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a Subnet message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Subnet + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.Subnet; + + /** + * Decodes a Subnet message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Subnet + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.Subnet; + + /** + * Verifies a Subnet message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a Subnet message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Subnet + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.Subnet; + + /** + * Creates a plain object from a Subnet message. Also converts values to other types if specified. + * @param message Subnet + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.Subnet, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Subnet to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Subnet + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of an Interconnect. */ + interface IInterconnect { + + /** Interconnect name */ + name?: (string|null); + + /** Interconnect createTime */ + createTime?: (google.protobuf.ITimestamp|null); + + /** Interconnect updateTime */ + updateTime?: (google.protobuf.ITimestamp|null); + + /** Interconnect labels */ + labels?: ({ [k: string]: string }|null); + + /** Interconnect description */ + description?: (string|null); + + /** Interconnect interconnectType */ + interconnectType?: (google.cloud.edgenetwork.v1.Interconnect.InterconnectType|keyof typeof google.cloud.edgenetwork.v1.Interconnect.InterconnectType|null); + + /** Interconnect uuid */ + uuid?: (string|null); + + /** Interconnect deviceCloudResourceName */ + deviceCloudResourceName?: (string|null); + + /** Interconnect physicalPorts */ + physicalPorts?: (string[]|null); + } + + /** Represents an Interconnect. */ + class Interconnect implements IInterconnect { + + /** + * Constructs a new Interconnect. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IInterconnect); + + /** Interconnect name. */ + public name: string; + + /** Interconnect createTime. */ + public createTime?: (google.protobuf.ITimestamp|null); + + /** Interconnect updateTime. */ + public updateTime?: (google.protobuf.ITimestamp|null); + + /** Interconnect labels. */ + public labels: { [k: string]: string }; + + /** Interconnect description. */ + public description: string; + + /** Interconnect interconnectType. */ + public interconnectType: (google.cloud.edgenetwork.v1.Interconnect.InterconnectType|keyof typeof google.cloud.edgenetwork.v1.Interconnect.InterconnectType); + + /** Interconnect uuid. */ + public uuid: string; + + /** Interconnect deviceCloudResourceName. */ + public deviceCloudResourceName: string; + + /** Interconnect physicalPorts. */ + public physicalPorts: string[]; + + /** + * Creates a new Interconnect instance using the specified properties. + * @param [properties] Properties to set + * @returns Interconnect instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IInterconnect): google.cloud.edgenetwork.v1.Interconnect; + + /** + * Encodes the specified Interconnect message. Does not implicitly {@link google.cloud.edgenetwork.v1.Interconnect.verify|verify} messages. + * @param message Interconnect message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IInterconnect, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Interconnect message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.Interconnect.verify|verify} messages. + * @param message Interconnect message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IInterconnect, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an Interconnect message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Interconnect + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.Interconnect; + + /** + * Decodes an Interconnect message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Interconnect + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.Interconnect; + + /** + * Verifies an Interconnect message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an Interconnect message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Interconnect + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.Interconnect; + + /** + * Creates a plain object from an Interconnect message. Also converts values to other types if specified. + * @param message Interconnect + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.Interconnect, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Interconnect to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Interconnect + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace Interconnect { + + /** InterconnectType enum. */ + enum InterconnectType { + INTERCONNECT_TYPE_UNSPECIFIED = 0, + DEDICATED = 1 + } + } + + /** Properties of an InterconnectAttachment. */ + interface IInterconnectAttachment { + + /** InterconnectAttachment name */ + name?: (string|null); + + /** InterconnectAttachment createTime */ + createTime?: (google.protobuf.ITimestamp|null); + + /** InterconnectAttachment updateTime */ + updateTime?: (google.protobuf.ITimestamp|null); + + /** InterconnectAttachment labels */ + labels?: ({ [k: string]: string }|null); + + /** InterconnectAttachment description */ + description?: (string|null); + + /** InterconnectAttachment interconnect */ + interconnect?: (string|null); + + /** InterconnectAttachment network */ + network?: (string|null); + + /** InterconnectAttachment vlanId */ + vlanId?: (number|null); + + /** InterconnectAttachment mtu */ + mtu?: (number|null); + + /** InterconnectAttachment state */ + state?: (google.cloud.edgenetwork.v1.ResourceState|keyof typeof google.cloud.edgenetwork.v1.ResourceState|null); + } + + /** Represents an InterconnectAttachment. */ + class InterconnectAttachment implements IInterconnectAttachment { + + /** + * Constructs a new InterconnectAttachment. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IInterconnectAttachment); + + /** InterconnectAttachment name. */ + public name: string; + + /** InterconnectAttachment createTime. */ + public createTime?: (google.protobuf.ITimestamp|null); + + /** InterconnectAttachment updateTime. */ + public updateTime?: (google.protobuf.ITimestamp|null); + + /** InterconnectAttachment labels. */ + public labels: { [k: string]: string }; + + /** InterconnectAttachment description. */ + public description: string; + + /** InterconnectAttachment interconnect. */ + public interconnect: string; + + /** InterconnectAttachment network. */ + public network: string; + + /** InterconnectAttachment vlanId. */ + public vlanId: number; + + /** InterconnectAttachment mtu. */ + public mtu: number; + + /** InterconnectAttachment state. */ + public state: (google.cloud.edgenetwork.v1.ResourceState|keyof typeof google.cloud.edgenetwork.v1.ResourceState); + + /** + * Creates a new InterconnectAttachment instance using the specified properties. + * @param [properties] Properties to set + * @returns InterconnectAttachment instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IInterconnectAttachment): google.cloud.edgenetwork.v1.InterconnectAttachment; + + /** + * Encodes the specified InterconnectAttachment message. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectAttachment.verify|verify} messages. + * @param message InterconnectAttachment message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IInterconnectAttachment, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified InterconnectAttachment message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectAttachment.verify|verify} messages. + * @param message InterconnectAttachment message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IInterconnectAttachment, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an InterconnectAttachment message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns InterconnectAttachment + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.InterconnectAttachment; + + /** + * Decodes an InterconnectAttachment message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns InterconnectAttachment + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.InterconnectAttachment; + + /** + * Verifies an InterconnectAttachment message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an InterconnectAttachment message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns InterconnectAttachment + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.InterconnectAttachment; + + /** + * Creates a plain object from an InterconnectAttachment message. Also converts values to other types if specified. + * @param message InterconnectAttachment + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.InterconnectAttachment, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this InterconnectAttachment to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for InterconnectAttachment + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a Router. */ + interface IRouter { + + /** Router name */ + name?: (string|null); + + /** Router createTime */ + createTime?: (google.protobuf.ITimestamp|null); + + /** Router updateTime */ + updateTime?: (google.protobuf.ITimestamp|null); + + /** Router labels */ + labels?: ({ [k: string]: string }|null); + + /** Router description */ + description?: (string|null); + + /** Router network */ + network?: (string|null); + + /** Router interface */ + "interface"?: (google.cloud.edgenetwork.v1.Router.IInterface[]|null); + + /** Router bgpPeer */ + bgpPeer?: (google.cloud.edgenetwork.v1.Router.IBgpPeer[]|null); + + /** Router bgp */ + bgp?: (google.cloud.edgenetwork.v1.Router.IBgp|null); + + /** Router state */ + state?: (google.cloud.edgenetwork.v1.ResourceState|keyof typeof google.cloud.edgenetwork.v1.ResourceState|null); + + /** Router routeAdvertisements */ + routeAdvertisements?: (string[]|null); + } + + /** Represents a Router. */ + class Router implements IRouter { + + /** + * Constructs a new Router. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IRouter); + + /** Router name. */ + public name: string; + + /** Router createTime. */ + public createTime?: (google.protobuf.ITimestamp|null); + + /** Router updateTime. */ + public updateTime?: (google.protobuf.ITimestamp|null); + + /** Router labels. */ + public labels: { [k: string]: string }; + + /** Router description. */ + public description: string; + + /** Router network. */ + public network: string; + + /** Router interface. */ + public interface: google.cloud.edgenetwork.v1.Router.IInterface[]; + + /** Router bgpPeer. */ + public bgpPeer: google.cloud.edgenetwork.v1.Router.IBgpPeer[]; + + /** Router bgp. */ + public bgp?: (google.cloud.edgenetwork.v1.Router.IBgp|null); + + /** Router state. */ + public state: (google.cloud.edgenetwork.v1.ResourceState|keyof typeof google.cloud.edgenetwork.v1.ResourceState); + + /** Router routeAdvertisements. */ + public routeAdvertisements: string[]; + + /** + * Creates a new Router instance using the specified properties. + * @param [properties] Properties to set + * @returns Router instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IRouter): google.cloud.edgenetwork.v1.Router; + + /** + * Encodes the specified Router message. Does not implicitly {@link google.cloud.edgenetwork.v1.Router.verify|verify} messages. + * @param message Router message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IRouter, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Router message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.Router.verify|verify} messages. + * @param message Router message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IRouter, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a Router message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Router + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.Router; + + /** + * Decodes a Router message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Router + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.Router; + + /** + * Verifies a Router message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a Router message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Router + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.Router; + + /** + * Creates a plain object from a Router message. Also converts values to other types if specified. + * @param message Router + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.Router, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Router to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Router + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace Router { + + /** Properties of an Interface. */ + interface IInterface { + + /** Interface name */ + name?: (string|null); + + /** Interface ipv4Cidr */ + ipv4Cidr?: (string|null); + + /** Interface ipv6Cidr */ + ipv6Cidr?: (string|null); + + /** Interface linkedInterconnectAttachment */ + linkedInterconnectAttachment?: (string|null); + + /** Interface subnetwork */ + subnetwork?: (string|null); + + /** Interface loopbackIpAddresses */ + loopbackIpAddresses?: (string[]|null); + } + + /** Represents an Interface. */ + class Interface implements IInterface { + + /** + * Constructs a new Interface. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.Router.IInterface); + + /** Interface name. */ + public name: string; + + /** Interface ipv4Cidr. */ + public ipv4Cidr: string; + + /** Interface ipv6Cidr. */ + public ipv6Cidr: string; + + /** Interface linkedInterconnectAttachment. */ + public linkedInterconnectAttachment: string; + + /** Interface subnetwork. */ + public subnetwork: string; + + /** Interface loopbackIpAddresses. */ + public loopbackIpAddresses: string[]; + + /** + * Creates a new Interface instance using the specified properties. + * @param [properties] Properties to set + * @returns Interface instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.Router.IInterface): google.cloud.edgenetwork.v1.Router.Interface; + + /** + * Encodes the specified Interface message. Does not implicitly {@link google.cloud.edgenetwork.v1.Router.Interface.verify|verify} messages. + * @param message Interface message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.Router.IInterface, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Interface message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.Router.Interface.verify|verify} messages. + * @param message Interface message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.Router.IInterface, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an Interface message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Interface + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.Router.Interface; + + /** + * Decodes an Interface message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Interface + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.Router.Interface; + + /** + * Verifies an Interface message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an Interface message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Interface + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.Router.Interface; + + /** + * Creates a plain object from an Interface message. Also converts values to other types if specified. + * @param message Interface + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.Router.Interface, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Interface to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Interface + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a BgpPeer. */ + interface IBgpPeer { + + /** BgpPeer name */ + name?: (string|null); + + /** BgpPeer interface */ + "interface"?: (string|null); + + /** BgpPeer interfaceIpv4Cidr */ + interfaceIpv4Cidr?: (string|null); + + /** BgpPeer interfaceIpv6Cidr */ + interfaceIpv6Cidr?: (string|null); + + /** BgpPeer peerIpv4Cidr */ + peerIpv4Cidr?: (string|null); + + /** BgpPeer peerIpv6Cidr */ + peerIpv6Cidr?: (string|null); + + /** BgpPeer peerAsn */ + peerAsn?: (number|null); + + /** BgpPeer localAsn */ + localAsn?: (number|null); + } + + /** Represents a BgpPeer. */ + class BgpPeer implements IBgpPeer { + + /** + * Constructs a new BgpPeer. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.Router.IBgpPeer); + + /** BgpPeer name. */ + public name: string; + + /** BgpPeer interface. */ + public interface: string; + + /** BgpPeer interfaceIpv4Cidr. */ + public interfaceIpv4Cidr: string; + + /** BgpPeer interfaceIpv6Cidr. */ + public interfaceIpv6Cidr: string; + + /** BgpPeer peerIpv4Cidr. */ + public peerIpv4Cidr: string; + + /** BgpPeer peerIpv6Cidr. */ + public peerIpv6Cidr: string; + + /** BgpPeer peerAsn. */ + public peerAsn: number; + + /** BgpPeer localAsn. */ + public localAsn: number; + + /** + * Creates a new BgpPeer instance using the specified properties. + * @param [properties] Properties to set + * @returns BgpPeer instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.Router.IBgpPeer): google.cloud.edgenetwork.v1.Router.BgpPeer; + + /** + * Encodes the specified BgpPeer message. Does not implicitly {@link google.cloud.edgenetwork.v1.Router.BgpPeer.verify|verify} messages. + * @param message BgpPeer message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.Router.IBgpPeer, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified BgpPeer message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.Router.BgpPeer.verify|verify} messages. + * @param message BgpPeer message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.Router.IBgpPeer, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a BgpPeer message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns BgpPeer + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.Router.BgpPeer; + + /** + * Decodes a BgpPeer message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns BgpPeer + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.Router.BgpPeer; + + /** + * Verifies a BgpPeer message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a BgpPeer message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns BgpPeer + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.Router.BgpPeer; + + /** + * Creates a plain object from a BgpPeer message. Also converts values to other types if specified. + * @param message BgpPeer + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.Router.BgpPeer, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this BgpPeer to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for BgpPeer + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a Bgp. */ + interface IBgp { + + /** Bgp asn */ + asn?: (number|null); + + /** Bgp keepaliveIntervalInSeconds */ + keepaliveIntervalInSeconds?: (number|null); + } + + /** Represents a Bgp. */ + class Bgp implements IBgp { + + /** + * Constructs a new Bgp. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.Router.IBgp); + + /** Bgp asn. */ + public asn: number; + + /** Bgp keepaliveIntervalInSeconds. */ + public keepaliveIntervalInSeconds: number; + + /** + * Creates a new Bgp instance using the specified properties. + * @param [properties] Properties to set + * @returns Bgp instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.Router.IBgp): google.cloud.edgenetwork.v1.Router.Bgp; + + /** + * Encodes the specified Bgp message. Does not implicitly {@link google.cloud.edgenetwork.v1.Router.Bgp.verify|verify} messages. + * @param message Bgp message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.Router.IBgp, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Bgp message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.Router.Bgp.verify|verify} messages. + * @param message Bgp message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.Router.IBgp, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a Bgp message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Bgp + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.Router.Bgp; + + /** + * Decodes a Bgp message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Bgp + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.Router.Bgp; + + /** + * Verifies a Bgp message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a Bgp message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Bgp + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.Router.Bgp; + + /** + * Creates a plain object from a Bgp message. Also converts values to other types if specified. + * @param message Bgp + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.Router.Bgp, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Bgp to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Bgp + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + } + + /** Properties of a LinkLayerAddress. */ + interface ILinkLayerAddress { + + /** LinkLayerAddress macAddress */ + macAddress?: (string|null); + + /** LinkLayerAddress ipAddress */ + ipAddress?: (string|null); + } + + /** Represents a LinkLayerAddress. */ + class LinkLayerAddress implements ILinkLayerAddress { + + /** + * Constructs a new LinkLayerAddress. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.ILinkLayerAddress); + + /** LinkLayerAddress macAddress. */ + public macAddress: string; + + /** LinkLayerAddress ipAddress. */ + public ipAddress: string; + + /** + * Creates a new LinkLayerAddress instance using the specified properties. + * @param [properties] Properties to set + * @returns LinkLayerAddress instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.ILinkLayerAddress): google.cloud.edgenetwork.v1.LinkLayerAddress; + + /** + * Encodes the specified LinkLayerAddress message. Does not implicitly {@link google.cloud.edgenetwork.v1.LinkLayerAddress.verify|verify} messages. + * @param message LinkLayerAddress message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.ILinkLayerAddress, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified LinkLayerAddress message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.LinkLayerAddress.verify|verify} messages. + * @param message LinkLayerAddress message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.ILinkLayerAddress, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a LinkLayerAddress message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns LinkLayerAddress + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.LinkLayerAddress; + + /** + * Decodes a LinkLayerAddress message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns LinkLayerAddress + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.LinkLayerAddress; + + /** + * Verifies a LinkLayerAddress message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a LinkLayerAddress message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns LinkLayerAddress + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.LinkLayerAddress; + + /** + * Creates a plain object from a LinkLayerAddress message. Also converts values to other types if specified. + * @param message LinkLayerAddress + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.LinkLayerAddress, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this LinkLayerAddress to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for LinkLayerAddress + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a SubnetStatus. */ + interface ISubnetStatus { + + /** SubnetStatus name */ + name?: (string|null); + + /** SubnetStatus macAddress */ + macAddress?: (string|null); + + /** SubnetStatus linkLayerAddresses */ + linkLayerAddresses?: (google.cloud.edgenetwork.v1.ILinkLayerAddress[]|null); + } + + /** Represents a SubnetStatus. */ + class SubnetStatus implements ISubnetStatus { + + /** + * Constructs a new SubnetStatus. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.ISubnetStatus); + + /** SubnetStatus name. */ + public name: string; + + /** SubnetStatus macAddress. */ + public macAddress: string; + + /** SubnetStatus linkLayerAddresses. */ + public linkLayerAddresses: google.cloud.edgenetwork.v1.ILinkLayerAddress[]; + + /** + * Creates a new SubnetStatus instance using the specified properties. + * @param [properties] Properties to set + * @returns SubnetStatus instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.ISubnetStatus): google.cloud.edgenetwork.v1.SubnetStatus; + + /** + * Encodes the specified SubnetStatus message. Does not implicitly {@link google.cloud.edgenetwork.v1.SubnetStatus.verify|verify} messages. + * @param message SubnetStatus message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.ISubnetStatus, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified SubnetStatus message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.SubnetStatus.verify|verify} messages. + * @param message SubnetStatus message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.ISubnetStatus, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a SubnetStatus message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns SubnetStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.SubnetStatus; + + /** + * Decodes a SubnetStatus message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns SubnetStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.SubnetStatus; + + /** + * Verifies a SubnetStatus message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a SubnetStatus message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns SubnetStatus + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.SubnetStatus; + + /** + * Creates a plain object from a SubnetStatus message. Also converts values to other types if specified. + * @param message SubnetStatus + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.SubnetStatus, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this SubnetStatus to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for SubnetStatus + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of an InterconnectDiagnostics. */ + interface IInterconnectDiagnostics { + + /** InterconnectDiagnostics macAddress */ + macAddress?: (string|null); + + /** InterconnectDiagnostics linkLayerAddresses */ + linkLayerAddresses?: (google.cloud.edgenetwork.v1.ILinkLayerAddress[]|null); + + /** InterconnectDiagnostics links */ + links?: (google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkStatus[]|null); + } + + /** Represents an InterconnectDiagnostics. */ + class InterconnectDiagnostics implements IInterconnectDiagnostics { + + /** + * Constructs a new InterconnectDiagnostics. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IInterconnectDiagnostics); + + /** InterconnectDiagnostics macAddress. */ + public macAddress: string; + + /** InterconnectDiagnostics linkLayerAddresses. */ + public linkLayerAddresses: google.cloud.edgenetwork.v1.ILinkLayerAddress[]; + + /** InterconnectDiagnostics links. */ + public links: google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkStatus[]; + + /** + * Creates a new InterconnectDiagnostics instance using the specified properties. + * @param [properties] Properties to set + * @returns InterconnectDiagnostics instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IInterconnectDiagnostics): google.cloud.edgenetwork.v1.InterconnectDiagnostics; + + /** + * Encodes the specified InterconnectDiagnostics message. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.verify|verify} messages. + * @param message InterconnectDiagnostics message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IInterconnectDiagnostics, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified InterconnectDiagnostics message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.verify|verify} messages. + * @param message InterconnectDiagnostics message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IInterconnectDiagnostics, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an InterconnectDiagnostics message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns InterconnectDiagnostics + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.InterconnectDiagnostics; + + /** + * Decodes an InterconnectDiagnostics message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns InterconnectDiagnostics + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.InterconnectDiagnostics; + + /** + * Verifies an InterconnectDiagnostics message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an InterconnectDiagnostics message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns InterconnectDiagnostics + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.InterconnectDiagnostics; + + /** + * Creates a plain object from an InterconnectDiagnostics message. Also converts values to other types if specified. + * @param message InterconnectDiagnostics + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.InterconnectDiagnostics, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this InterconnectDiagnostics to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for InterconnectDiagnostics + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace InterconnectDiagnostics { + + /** Properties of a LinkStatus. */ + interface ILinkStatus { + + /** LinkStatus circuitId */ + circuitId?: (string|null); + + /** LinkStatus lacpStatus */ + lacpStatus?: (google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLACPStatus|null); + + /** LinkStatus lldpStatuses */ + lldpStatuses?: (google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLLDPStatus[]|null); + + /** LinkStatus packetCounts */ + packetCounts?: (google.cloud.edgenetwork.v1.InterconnectDiagnostics.IPacketCounts|null); + } + + /** Represents a LinkStatus. */ + class LinkStatus implements ILinkStatus { + + /** + * Constructs a new LinkStatus. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkStatus); + + /** LinkStatus circuitId. */ + public circuitId: string; + + /** LinkStatus lacpStatus. */ + public lacpStatus?: (google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLACPStatus|null); + + /** LinkStatus lldpStatuses. */ + public lldpStatuses: google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLLDPStatus[]; + + /** LinkStatus packetCounts. */ + public packetCounts?: (google.cloud.edgenetwork.v1.InterconnectDiagnostics.IPacketCounts|null); + + /** + * Creates a new LinkStatus instance using the specified properties. + * @param [properties] Properties to set + * @returns LinkStatus instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkStatus): google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus; + + /** + * Encodes the specified LinkStatus message. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus.verify|verify} messages. + * @param message LinkStatus message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkStatus, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified LinkStatus message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus.verify|verify} messages. + * @param message LinkStatus message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkStatus, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a LinkStatus message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns LinkStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus; + + /** + * Decodes a LinkStatus message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns LinkStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus; + + /** + * Verifies a LinkStatus message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a LinkStatus message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns LinkStatus + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus; + + /** + * Creates a plain object from a LinkStatus message. Also converts values to other types if specified. + * @param message LinkStatus + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this LinkStatus to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for LinkStatus + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a PacketCounts. */ + interface IPacketCounts { + + /** PacketCounts inboundUnicast */ + inboundUnicast?: (number|Long|string|null); + + /** PacketCounts inboundErrors */ + inboundErrors?: (number|Long|string|null); + + /** PacketCounts inboundDiscards */ + inboundDiscards?: (number|Long|string|null); + + /** PacketCounts outboundUnicast */ + outboundUnicast?: (number|Long|string|null); + + /** PacketCounts outboundErrors */ + outboundErrors?: (number|Long|string|null); + + /** PacketCounts outboundDiscards */ + outboundDiscards?: (number|Long|string|null); + } + + /** Represents a PacketCounts. */ + class PacketCounts implements IPacketCounts { + + /** + * Constructs a new PacketCounts. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.InterconnectDiagnostics.IPacketCounts); + + /** PacketCounts inboundUnicast. */ + public inboundUnicast: (number|Long|string); + + /** PacketCounts inboundErrors. */ + public inboundErrors: (number|Long|string); + + /** PacketCounts inboundDiscards. */ + public inboundDiscards: (number|Long|string); + + /** PacketCounts outboundUnicast. */ + public outboundUnicast: (number|Long|string); + + /** PacketCounts outboundErrors. */ + public outboundErrors: (number|Long|string); + + /** PacketCounts outboundDiscards. */ + public outboundDiscards: (number|Long|string); + + /** + * Creates a new PacketCounts instance using the specified properties. + * @param [properties] Properties to set + * @returns PacketCounts instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.InterconnectDiagnostics.IPacketCounts): google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts; + + /** + * Encodes the specified PacketCounts message. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts.verify|verify} messages. + * @param message PacketCounts message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.InterconnectDiagnostics.IPacketCounts, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified PacketCounts message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts.verify|verify} messages. + * @param message PacketCounts message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.InterconnectDiagnostics.IPacketCounts, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a PacketCounts message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns PacketCounts + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts; + + /** + * Decodes a PacketCounts message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns PacketCounts + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts; + + /** + * Verifies a PacketCounts message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a PacketCounts message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns PacketCounts + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts; + + /** + * Creates a plain object from a PacketCounts message. Also converts values to other types if specified. + * @param message PacketCounts + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this PacketCounts to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for PacketCounts + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a LinkLACPStatus. */ + interface ILinkLACPStatus { + + /** LinkLACPStatus state */ + state?: (google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.State|keyof typeof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.State|null); + + /** LinkLACPStatus googleSystemId */ + googleSystemId?: (string|null); + + /** LinkLACPStatus neighborSystemId */ + neighborSystemId?: (string|null); + + /** LinkLACPStatus aggregatable */ + aggregatable?: (boolean|null); + + /** LinkLACPStatus collecting */ + collecting?: (boolean|null); + + /** LinkLACPStatus distributing */ + distributing?: (boolean|null); + } + + /** Represents a LinkLACPStatus. */ + class LinkLACPStatus implements ILinkLACPStatus { + + /** + * Constructs a new LinkLACPStatus. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLACPStatus); + + /** LinkLACPStatus state. */ + public state: (google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.State|keyof typeof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.State); + + /** LinkLACPStatus googleSystemId. */ + public googleSystemId: string; + + /** LinkLACPStatus neighborSystemId. */ + public neighborSystemId: string; + + /** LinkLACPStatus aggregatable. */ + public aggregatable: boolean; + + /** LinkLACPStatus collecting. */ + public collecting: boolean; + + /** LinkLACPStatus distributing. */ + public distributing: boolean; + + /** + * Creates a new LinkLACPStatus instance using the specified properties. + * @param [properties] Properties to set + * @returns LinkLACPStatus instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLACPStatus): google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus; + + /** + * Encodes the specified LinkLACPStatus message. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.verify|verify} messages. + * @param message LinkLACPStatus message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLACPStatus, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified LinkLACPStatus message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.verify|verify} messages. + * @param message LinkLACPStatus message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLACPStatus, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a LinkLACPStatus message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns LinkLACPStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus; + + /** + * Decodes a LinkLACPStatus message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns LinkLACPStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus; + + /** + * Verifies a LinkLACPStatus message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a LinkLACPStatus message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns LinkLACPStatus + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus; + + /** + * Creates a plain object from a LinkLACPStatus message. Also converts values to other types if specified. + * @param message LinkLACPStatus + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this LinkLACPStatus to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for LinkLACPStatus + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace LinkLACPStatus { + + /** State enum. */ + enum State { + UNKNOWN = 0, + ACTIVE = 1, + DETACHED = 2 + } + } + + /** Properties of a LinkLLDPStatus. */ + interface ILinkLLDPStatus { + + /** LinkLLDPStatus peerSystemName */ + peerSystemName?: (string|null); + + /** LinkLLDPStatus peerSystemDescription */ + peerSystemDescription?: (string|null); + + /** LinkLLDPStatus peerChassisId */ + peerChassisId?: (string|null); + + /** LinkLLDPStatus peerChassisIdType */ + peerChassisIdType?: (string|null); + + /** LinkLLDPStatus peerPortId */ + peerPortId?: (string|null); + + /** LinkLLDPStatus peerPortIdType */ + peerPortIdType?: (string|null); + } + + /** Represents a LinkLLDPStatus. */ + class LinkLLDPStatus implements ILinkLLDPStatus { + + /** + * Constructs a new LinkLLDPStatus. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLLDPStatus); + + /** LinkLLDPStatus peerSystemName. */ + public peerSystemName: string; + + /** LinkLLDPStatus peerSystemDescription. */ + public peerSystemDescription: string; + + /** LinkLLDPStatus peerChassisId. */ + public peerChassisId: string; + + /** LinkLLDPStatus peerChassisIdType. */ + public peerChassisIdType: string; + + /** LinkLLDPStatus peerPortId. */ + public peerPortId: string; + + /** LinkLLDPStatus peerPortIdType. */ + public peerPortIdType: string; + + /** + * Creates a new LinkLLDPStatus instance using the specified properties. + * @param [properties] Properties to set + * @returns LinkLLDPStatus instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLLDPStatus): google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus; + + /** + * Encodes the specified LinkLLDPStatus message. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus.verify|verify} messages. + * @param message LinkLLDPStatus message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLLDPStatus, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified LinkLLDPStatus message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus.verify|verify} messages. + * @param message LinkLLDPStatus message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLLDPStatus, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a LinkLLDPStatus message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns LinkLLDPStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus; + + /** + * Decodes a LinkLLDPStatus message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns LinkLLDPStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus; + + /** + * Verifies a LinkLLDPStatus message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a LinkLLDPStatus message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns LinkLLDPStatus + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus; + + /** + * Creates a plain object from a LinkLLDPStatus message. Also converts values to other types if specified. + * @param message LinkLLDPStatus + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this LinkLLDPStatus to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for LinkLLDPStatus + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + } + + /** Properties of a RouterStatus. */ + interface IRouterStatus { + + /** RouterStatus network */ + network?: (string|null); + + /** RouterStatus bgpPeerStatus */ + bgpPeerStatus?: (google.cloud.edgenetwork.v1.RouterStatus.IBgpPeerStatus[]|null); + } + + /** Represents a RouterStatus. */ + class RouterStatus implements IRouterStatus { + + /** + * Constructs a new RouterStatus. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IRouterStatus); + + /** RouterStatus network. */ + public network: string; + + /** RouterStatus bgpPeerStatus. */ + public bgpPeerStatus: google.cloud.edgenetwork.v1.RouterStatus.IBgpPeerStatus[]; + + /** + * Creates a new RouterStatus instance using the specified properties. + * @param [properties] Properties to set + * @returns RouterStatus instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IRouterStatus): google.cloud.edgenetwork.v1.RouterStatus; + + /** + * Encodes the specified RouterStatus message. Does not implicitly {@link google.cloud.edgenetwork.v1.RouterStatus.verify|verify} messages. + * @param message RouterStatus message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IRouterStatus, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified RouterStatus message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.RouterStatus.verify|verify} messages. + * @param message RouterStatus message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IRouterStatus, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a RouterStatus message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns RouterStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.RouterStatus; + + /** + * Decodes a RouterStatus message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns RouterStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.RouterStatus; + + /** + * Verifies a RouterStatus message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a RouterStatus message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns RouterStatus + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.RouterStatus; + + /** + * Creates a plain object from a RouterStatus message. Also converts values to other types if specified. + * @param message RouterStatus + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.RouterStatus, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this RouterStatus to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for RouterStatus + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace RouterStatus { + + /** Properties of a BgpPeerStatus. */ + interface IBgpPeerStatus { + + /** BgpPeerStatus name */ + name?: (string|null); + + /** BgpPeerStatus ipAddress */ + ipAddress?: (string|null); + + /** BgpPeerStatus peerIpAddress */ + peerIpAddress?: (string|null); + + /** BgpPeerStatus status */ + status?: (google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.BgpStatus|keyof typeof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.BgpStatus|null); + + /** BgpPeerStatus state */ + state?: (string|null); + + /** BgpPeerStatus uptime */ + uptime?: (string|null); + + /** BgpPeerStatus uptimeSeconds */ + uptimeSeconds?: (number|Long|string|null); + + /** BgpPeerStatus prefixCounter */ + prefixCounter?: (google.cloud.edgenetwork.v1.RouterStatus.IPrefixCounter|null); + } + + /** Represents a BgpPeerStatus. */ + class BgpPeerStatus implements IBgpPeerStatus { + + /** + * Constructs a new BgpPeerStatus. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.RouterStatus.IBgpPeerStatus); + + /** BgpPeerStatus name. */ + public name: string; + + /** BgpPeerStatus ipAddress. */ + public ipAddress: string; + + /** BgpPeerStatus peerIpAddress. */ + public peerIpAddress: string; + + /** BgpPeerStatus status. */ + public status: (google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.BgpStatus|keyof typeof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.BgpStatus); + + /** BgpPeerStatus state. */ + public state: string; + + /** BgpPeerStatus uptime. */ + public uptime: string; + + /** BgpPeerStatus uptimeSeconds. */ + public uptimeSeconds: (number|Long|string); + + /** BgpPeerStatus prefixCounter. */ + public prefixCounter?: (google.cloud.edgenetwork.v1.RouterStatus.IPrefixCounter|null); + + /** + * Creates a new BgpPeerStatus instance using the specified properties. + * @param [properties] Properties to set + * @returns BgpPeerStatus instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.RouterStatus.IBgpPeerStatus): google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus; + + /** + * Encodes the specified BgpPeerStatus message. Does not implicitly {@link google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.verify|verify} messages. + * @param message BgpPeerStatus message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.RouterStatus.IBgpPeerStatus, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified BgpPeerStatus message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.verify|verify} messages. + * @param message BgpPeerStatus message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.RouterStatus.IBgpPeerStatus, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a BgpPeerStatus message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns BgpPeerStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus; + + /** + * Decodes a BgpPeerStatus message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns BgpPeerStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus; + + /** + * Verifies a BgpPeerStatus message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a BgpPeerStatus message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns BgpPeerStatus + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus; + + /** + * Creates a plain object from a BgpPeerStatus message. Also converts values to other types if specified. + * @param message BgpPeerStatus + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this BgpPeerStatus to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for BgpPeerStatus + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace BgpPeerStatus { + + /** BgpStatus enum. */ + enum BgpStatus { + UNKNOWN = 0, + UP = 1, + DOWN = 2 + } + } + + /** Properties of a PrefixCounter. */ + interface IPrefixCounter { + + /** PrefixCounter advertised */ + advertised?: (number|Long|string|null); + + /** PrefixCounter denied */ + denied?: (number|Long|string|null); + + /** PrefixCounter received */ + received?: (number|Long|string|null); + + /** PrefixCounter sent */ + sent?: (number|Long|string|null); + + /** PrefixCounter suppressed */ + suppressed?: (number|Long|string|null); + + /** PrefixCounter withdrawn */ + withdrawn?: (number|Long|string|null); + } + + /** Represents a PrefixCounter. */ + class PrefixCounter implements IPrefixCounter { + + /** + * Constructs a new PrefixCounter. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.RouterStatus.IPrefixCounter); + + /** PrefixCounter advertised. */ + public advertised: (number|Long|string); + + /** PrefixCounter denied. */ + public denied: (number|Long|string); + + /** PrefixCounter received. */ + public received: (number|Long|string); + + /** PrefixCounter sent. */ + public sent: (number|Long|string); + + /** PrefixCounter suppressed. */ + public suppressed: (number|Long|string); + + /** PrefixCounter withdrawn. */ + public withdrawn: (number|Long|string); + + /** + * Creates a new PrefixCounter instance using the specified properties. + * @param [properties] Properties to set + * @returns PrefixCounter instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.RouterStatus.IPrefixCounter): google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter; + + /** + * Encodes the specified PrefixCounter message. Does not implicitly {@link google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter.verify|verify} messages. + * @param message PrefixCounter message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.RouterStatus.IPrefixCounter, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified PrefixCounter message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter.verify|verify} messages. + * @param message PrefixCounter message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.RouterStatus.IPrefixCounter, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a PrefixCounter message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns PrefixCounter + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter; + + /** + * Decodes a PrefixCounter message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns PrefixCounter + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter; + + /** + * Verifies a PrefixCounter message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a PrefixCounter message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns PrefixCounter + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter; + + /** + * Creates a plain object from a PrefixCounter message. Also converts values to other types if specified. + * @param message PrefixCounter + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this PrefixCounter to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for PrefixCounter + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + } + + /** Represents an EdgeNetwork */ + class EdgeNetwork extends $protobuf.rpc.Service { + + /** + * Constructs a new EdgeNetwork service. + * @param rpcImpl RPC implementation + * @param [requestDelimited=false] Whether requests are length-delimited + * @param [responseDelimited=false] Whether responses are length-delimited + */ + constructor(rpcImpl: $protobuf.RPCImpl, requestDelimited?: boolean, responseDelimited?: boolean); + + /** + * Creates new EdgeNetwork service using the specified rpc implementation. + * @param rpcImpl RPC implementation + * @param [requestDelimited=false] Whether requests are length-delimited + * @param [responseDelimited=false] Whether responses are length-delimited + * @returns RPC service. Useful where requests and/or responses are streamed. + */ + public static create(rpcImpl: $protobuf.RPCImpl, requestDelimited?: boolean, responseDelimited?: boolean): EdgeNetwork; + + /** + * Calls InitializeZone. + * @param request InitializeZoneRequest message or plain object + * @param callback Node-style callback called with the error, if any, and InitializeZoneResponse + */ + public initializeZone(request: google.cloud.edgenetwork.v1.IInitializeZoneRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.InitializeZoneCallback): void; + + /** + * Calls InitializeZone. + * @param request InitializeZoneRequest message or plain object + * @returns Promise + */ + public initializeZone(request: google.cloud.edgenetwork.v1.IInitializeZoneRequest): Promise; + + /** + * Calls ListZones. + * @param request ListZonesRequest message or plain object + * @param callback Node-style callback called with the error, if any, and ListZonesResponse + */ + public listZones(request: google.cloud.edgenetwork.v1.IListZonesRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.ListZonesCallback): void; + + /** + * Calls ListZones. + * @param request ListZonesRequest message or plain object + * @returns Promise + */ + public listZones(request: google.cloud.edgenetwork.v1.IListZonesRequest): Promise; + + /** + * Calls GetZone. + * @param request GetZoneRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Zone + */ + public getZone(request: google.cloud.edgenetwork.v1.IGetZoneRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.GetZoneCallback): void; + + /** + * Calls GetZone. + * @param request GetZoneRequest message or plain object + * @returns Promise + */ + public getZone(request: google.cloud.edgenetwork.v1.IGetZoneRequest): Promise; + + /** + * Calls ListNetworks. + * @param request ListNetworksRequest message or plain object + * @param callback Node-style callback called with the error, if any, and ListNetworksResponse + */ + public listNetworks(request: google.cloud.edgenetwork.v1.IListNetworksRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.ListNetworksCallback): void; + + /** + * Calls ListNetworks. + * @param request ListNetworksRequest message or plain object + * @returns Promise + */ + public listNetworks(request: google.cloud.edgenetwork.v1.IListNetworksRequest): Promise; + + /** + * Calls GetNetwork. + * @param request GetNetworkRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Network + */ + public getNetwork(request: google.cloud.edgenetwork.v1.IGetNetworkRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.GetNetworkCallback): void; + + /** + * Calls GetNetwork. + * @param request GetNetworkRequest message or plain object + * @returns Promise + */ + public getNetwork(request: google.cloud.edgenetwork.v1.IGetNetworkRequest): Promise; + + /** + * Calls DiagnoseNetwork. + * @param request DiagnoseNetworkRequest message or plain object + * @param callback Node-style callback called with the error, if any, and DiagnoseNetworkResponse + */ + public diagnoseNetwork(request: google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseNetworkCallback): void; + + /** + * Calls DiagnoseNetwork. + * @param request DiagnoseNetworkRequest message or plain object + * @returns Promise + */ + public diagnoseNetwork(request: google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest): Promise; + + /** + * Calls CreateNetwork. + * @param request CreateNetworkRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Operation + */ + public createNetwork(request: google.cloud.edgenetwork.v1.ICreateNetworkRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.CreateNetworkCallback): void; + + /** + * Calls CreateNetwork. + * @param request CreateNetworkRequest message or plain object + * @returns Promise + */ + public createNetwork(request: google.cloud.edgenetwork.v1.ICreateNetworkRequest): Promise; + + /** + * Calls DeleteNetwork. + * @param request DeleteNetworkRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Operation + */ + public deleteNetwork(request: google.cloud.edgenetwork.v1.IDeleteNetworkRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.DeleteNetworkCallback): void; + + /** + * Calls DeleteNetwork. + * @param request DeleteNetworkRequest message or plain object + * @returns Promise + */ + public deleteNetwork(request: google.cloud.edgenetwork.v1.IDeleteNetworkRequest): Promise; + + /** + * Calls ListSubnets. + * @param request ListSubnetsRequest message or plain object + * @param callback Node-style callback called with the error, if any, and ListSubnetsResponse + */ + public listSubnets(request: google.cloud.edgenetwork.v1.IListSubnetsRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.ListSubnetsCallback): void; + + /** + * Calls ListSubnets. + * @param request ListSubnetsRequest message or plain object + * @returns Promise + */ + public listSubnets(request: google.cloud.edgenetwork.v1.IListSubnetsRequest): Promise; + + /** + * Calls GetSubnet. + * @param request GetSubnetRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Subnet + */ + public getSubnet(request: google.cloud.edgenetwork.v1.IGetSubnetRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.GetSubnetCallback): void; + + /** + * Calls GetSubnet. + * @param request GetSubnetRequest message or plain object + * @returns Promise + */ + public getSubnet(request: google.cloud.edgenetwork.v1.IGetSubnetRequest): Promise; + + /** + * Calls CreateSubnet. + * @param request CreateSubnetRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Operation + */ + public createSubnet(request: google.cloud.edgenetwork.v1.ICreateSubnetRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.CreateSubnetCallback): void; + + /** + * Calls CreateSubnet. + * @param request CreateSubnetRequest message or plain object + * @returns Promise + */ + public createSubnet(request: google.cloud.edgenetwork.v1.ICreateSubnetRequest): Promise; + + /** + * Calls UpdateSubnet. + * @param request UpdateSubnetRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Operation + */ + public updateSubnet(request: google.cloud.edgenetwork.v1.IUpdateSubnetRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.UpdateSubnetCallback): void; + + /** + * Calls UpdateSubnet. + * @param request UpdateSubnetRequest message or plain object + * @returns Promise + */ + public updateSubnet(request: google.cloud.edgenetwork.v1.IUpdateSubnetRequest): Promise; + + /** + * Calls DeleteSubnet. + * @param request DeleteSubnetRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Operation + */ + public deleteSubnet(request: google.cloud.edgenetwork.v1.IDeleteSubnetRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.DeleteSubnetCallback): void; + + /** + * Calls DeleteSubnet. + * @param request DeleteSubnetRequest message or plain object + * @returns Promise + */ + public deleteSubnet(request: google.cloud.edgenetwork.v1.IDeleteSubnetRequest): Promise; + + /** + * Calls ListInterconnects. + * @param request ListInterconnectsRequest message or plain object + * @param callback Node-style callback called with the error, if any, and ListInterconnectsResponse + */ + public listInterconnects(request: google.cloud.edgenetwork.v1.IListInterconnectsRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.ListInterconnectsCallback): void; + + /** + * Calls ListInterconnects. + * @param request ListInterconnectsRequest message or plain object + * @returns Promise + */ + public listInterconnects(request: google.cloud.edgenetwork.v1.IListInterconnectsRequest): Promise; + + /** + * Calls GetInterconnect. + * @param request GetInterconnectRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Interconnect + */ + public getInterconnect(request: google.cloud.edgenetwork.v1.IGetInterconnectRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.GetInterconnectCallback): void; + + /** + * Calls GetInterconnect. + * @param request GetInterconnectRequest message or plain object + * @returns Promise + */ + public getInterconnect(request: google.cloud.edgenetwork.v1.IGetInterconnectRequest): Promise; + + /** + * Calls DiagnoseInterconnect. + * @param request DiagnoseInterconnectRequest message or plain object + * @param callback Node-style callback called with the error, if any, and DiagnoseInterconnectResponse + */ + public diagnoseInterconnect(request: google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseInterconnectCallback): void; + + /** + * Calls DiagnoseInterconnect. + * @param request DiagnoseInterconnectRequest message or plain object + * @returns Promise + */ + public diagnoseInterconnect(request: google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest): Promise; + + /** + * Calls ListInterconnectAttachments. + * @param request ListInterconnectAttachmentsRequest message or plain object + * @param callback Node-style callback called with the error, if any, and ListInterconnectAttachmentsResponse + */ + public listInterconnectAttachments(request: google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.ListInterconnectAttachmentsCallback): void; + + /** + * Calls ListInterconnectAttachments. + * @param request ListInterconnectAttachmentsRequest message or plain object + * @returns Promise + */ + public listInterconnectAttachments(request: google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest): Promise; + + /** + * Calls GetInterconnectAttachment. + * @param request GetInterconnectAttachmentRequest message or plain object + * @param callback Node-style callback called with the error, if any, and InterconnectAttachment + */ + public getInterconnectAttachment(request: google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.GetInterconnectAttachmentCallback): void; + + /** + * Calls GetInterconnectAttachment. + * @param request GetInterconnectAttachmentRequest message or plain object + * @returns Promise + */ + public getInterconnectAttachment(request: google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest): Promise; + + /** + * Calls CreateInterconnectAttachment. + * @param request CreateInterconnectAttachmentRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Operation + */ + public createInterconnectAttachment(request: google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.CreateInterconnectAttachmentCallback): void; + + /** + * Calls CreateInterconnectAttachment. + * @param request CreateInterconnectAttachmentRequest message or plain object + * @returns Promise + */ + public createInterconnectAttachment(request: google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest): Promise; + + /** + * Calls DeleteInterconnectAttachment. + * @param request DeleteInterconnectAttachmentRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Operation + */ + public deleteInterconnectAttachment(request: google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.DeleteInterconnectAttachmentCallback): void; + + /** + * Calls DeleteInterconnectAttachment. + * @param request DeleteInterconnectAttachmentRequest message or plain object + * @returns Promise + */ + public deleteInterconnectAttachment(request: google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest): Promise; + + /** + * Calls ListRouters. + * @param request ListRoutersRequest message or plain object + * @param callback Node-style callback called with the error, if any, and ListRoutersResponse + */ + public listRouters(request: google.cloud.edgenetwork.v1.IListRoutersRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.ListRoutersCallback): void; + + /** + * Calls ListRouters. + * @param request ListRoutersRequest message or plain object + * @returns Promise + */ + public listRouters(request: google.cloud.edgenetwork.v1.IListRoutersRequest): Promise; + + /** + * Calls GetRouter. + * @param request GetRouterRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Router + */ + public getRouter(request: google.cloud.edgenetwork.v1.IGetRouterRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.GetRouterCallback): void; + + /** + * Calls GetRouter. + * @param request GetRouterRequest message or plain object + * @returns Promise + */ + public getRouter(request: google.cloud.edgenetwork.v1.IGetRouterRequest): Promise; + + /** + * Calls DiagnoseRouter. + * @param request DiagnoseRouterRequest message or plain object + * @param callback Node-style callback called with the error, if any, and DiagnoseRouterResponse + */ + public diagnoseRouter(request: google.cloud.edgenetwork.v1.IDiagnoseRouterRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseRouterCallback): void; + + /** + * Calls DiagnoseRouter. + * @param request DiagnoseRouterRequest message or plain object + * @returns Promise + */ + public diagnoseRouter(request: google.cloud.edgenetwork.v1.IDiagnoseRouterRequest): Promise; + + /** + * Calls CreateRouter. + * @param request CreateRouterRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Operation + */ + public createRouter(request: google.cloud.edgenetwork.v1.ICreateRouterRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.CreateRouterCallback): void; + + /** + * Calls CreateRouter. + * @param request CreateRouterRequest message or plain object + * @returns Promise + */ + public createRouter(request: google.cloud.edgenetwork.v1.ICreateRouterRequest): Promise; + + /** + * Calls UpdateRouter. + * @param request UpdateRouterRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Operation + */ + public updateRouter(request: google.cloud.edgenetwork.v1.IUpdateRouterRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.UpdateRouterCallback): void; + + /** + * Calls UpdateRouter. + * @param request UpdateRouterRequest message or plain object + * @returns Promise + */ + public updateRouter(request: google.cloud.edgenetwork.v1.IUpdateRouterRequest): Promise; + + /** + * Calls DeleteRouter. + * @param request DeleteRouterRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Operation + */ + public deleteRouter(request: google.cloud.edgenetwork.v1.IDeleteRouterRequest, callback: google.cloud.edgenetwork.v1.EdgeNetwork.DeleteRouterCallback): void; + + /** + * Calls DeleteRouter. + * @param request DeleteRouterRequest message or plain object + * @returns Promise + */ + public deleteRouter(request: google.cloud.edgenetwork.v1.IDeleteRouterRequest): Promise; + } + + namespace EdgeNetwork { + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|initializeZone}. + * @param error Error, if any + * @param [response] InitializeZoneResponse + */ + type InitializeZoneCallback = (error: (Error|null), response?: google.cloud.edgenetwork.v1.InitializeZoneResponse) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|listZones}. + * @param error Error, if any + * @param [response] ListZonesResponse + */ + type ListZonesCallback = (error: (Error|null), response?: google.cloud.edgenetwork.v1.ListZonesResponse) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|getZone}. + * @param error Error, if any + * @param [response] Zone + */ + type GetZoneCallback = (error: (Error|null), response?: google.cloud.edgenetwork.v1.Zone) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|listNetworks}. + * @param error Error, if any + * @param [response] ListNetworksResponse + */ + type ListNetworksCallback = (error: (Error|null), response?: google.cloud.edgenetwork.v1.ListNetworksResponse) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|getNetwork}. + * @param error Error, if any + * @param [response] Network + */ + type GetNetworkCallback = (error: (Error|null), response?: google.cloud.edgenetwork.v1.Network) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|diagnoseNetwork}. + * @param error Error, if any + * @param [response] DiagnoseNetworkResponse + */ + type DiagnoseNetworkCallback = (error: (Error|null), response?: google.cloud.edgenetwork.v1.DiagnoseNetworkResponse) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|createNetwork}. + * @param error Error, if any + * @param [response] Operation + */ + type CreateNetworkCallback = (error: (Error|null), response?: google.longrunning.Operation) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|deleteNetwork}. + * @param error Error, if any + * @param [response] Operation + */ + type DeleteNetworkCallback = (error: (Error|null), response?: google.longrunning.Operation) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|listSubnets}. + * @param error Error, if any + * @param [response] ListSubnetsResponse + */ + type ListSubnetsCallback = (error: (Error|null), response?: google.cloud.edgenetwork.v1.ListSubnetsResponse) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|getSubnet}. + * @param error Error, if any + * @param [response] Subnet + */ + type GetSubnetCallback = (error: (Error|null), response?: google.cloud.edgenetwork.v1.Subnet) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|createSubnet}. + * @param error Error, if any + * @param [response] Operation + */ + type CreateSubnetCallback = (error: (Error|null), response?: google.longrunning.Operation) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|updateSubnet}. + * @param error Error, if any + * @param [response] Operation + */ + type UpdateSubnetCallback = (error: (Error|null), response?: google.longrunning.Operation) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|deleteSubnet}. + * @param error Error, if any + * @param [response] Operation + */ + type DeleteSubnetCallback = (error: (Error|null), response?: google.longrunning.Operation) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|listInterconnects}. + * @param error Error, if any + * @param [response] ListInterconnectsResponse + */ + type ListInterconnectsCallback = (error: (Error|null), response?: google.cloud.edgenetwork.v1.ListInterconnectsResponse) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|getInterconnect}. + * @param error Error, if any + * @param [response] Interconnect + */ + type GetInterconnectCallback = (error: (Error|null), response?: google.cloud.edgenetwork.v1.Interconnect) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|diagnoseInterconnect}. + * @param error Error, if any + * @param [response] DiagnoseInterconnectResponse + */ + type DiagnoseInterconnectCallback = (error: (Error|null), response?: google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|listInterconnectAttachments}. + * @param error Error, if any + * @param [response] ListInterconnectAttachmentsResponse + */ + type ListInterconnectAttachmentsCallback = (error: (Error|null), response?: google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|getInterconnectAttachment}. + * @param error Error, if any + * @param [response] InterconnectAttachment + */ + type GetInterconnectAttachmentCallback = (error: (Error|null), response?: google.cloud.edgenetwork.v1.InterconnectAttachment) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|createInterconnectAttachment}. + * @param error Error, if any + * @param [response] Operation + */ + type CreateInterconnectAttachmentCallback = (error: (Error|null), response?: google.longrunning.Operation) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|deleteInterconnectAttachment}. + * @param error Error, if any + * @param [response] Operation + */ + type DeleteInterconnectAttachmentCallback = (error: (Error|null), response?: google.longrunning.Operation) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|listRouters}. + * @param error Error, if any + * @param [response] ListRoutersResponse + */ + type ListRoutersCallback = (error: (Error|null), response?: google.cloud.edgenetwork.v1.ListRoutersResponse) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|getRouter}. + * @param error Error, if any + * @param [response] Router + */ + type GetRouterCallback = (error: (Error|null), response?: google.cloud.edgenetwork.v1.Router) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|diagnoseRouter}. + * @param error Error, if any + * @param [response] DiagnoseRouterResponse + */ + type DiagnoseRouterCallback = (error: (Error|null), response?: google.cloud.edgenetwork.v1.DiagnoseRouterResponse) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|createRouter}. + * @param error Error, if any + * @param [response] Operation + */ + type CreateRouterCallback = (error: (Error|null), response?: google.longrunning.Operation) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|updateRouter}. + * @param error Error, if any + * @param [response] Operation + */ + type UpdateRouterCallback = (error: (Error|null), response?: google.longrunning.Operation) => void; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|deleteRouter}. + * @param error Error, if any + * @param [response] Operation + */ + type DeleteRouterCallback = (error: (Error|null), response?: google.longrunning.Operation) => void; + } + + /** Properties of a ListZonesRequest. */ + interface IListZonesRequest { + + /** ListZonesRequest parent */ + parent?: (string|null); + + /** ListZonesRequest pageSize */ + pageSize?: (number|null); + + /** ListZonesRequest pageToken */ + pageToken?: (string|null); + + /** ListZonesRequest filter */ + filter?: (string|null); + + /** ListZonesRequest orderBy */ + orderBy?: (string|null); + } + + /** Represents a ListZonesRequest. */ + class ListZonesRequest implements IListZonesRequest { + + /** + * Constructs a new ListZonesRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IListZonesRequest); + + /** ListZonesRequest parent. */ + public parent: string; + + /** ListZonesRequest pageSize. */ + public pageSize: number; + + /** ListZonesRequest pageToken. */ + public pageToken: string; + + /** ListZonesRequest filter. */ + public filter: string; + + /** ListZonesRequest orderBy. */ + public orderBy: string; + + /** + * Creates a new ListZonesRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns ListZonesRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IListZonesRequest): google.cloud.edgenetwork.v1.ListZonesRequest; + + /** + * Encodes the specified ListZonesRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListZonesRequest.verify|verify} messages. + * @param message ListZonesRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IListZonesRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ListZonesRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListZonesRequest.verify|verify} messages. + * @param message ListZonesRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IListZonesRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ListZonesRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ListZonesRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.ListZonesRequest; + + /** + * Decodes a ListZonesRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ListZonesRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.ListZonesRequest; + + /** + * Verifies a ListZonesRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ListZonesRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ListZonesRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.ListZonesRequest; + + /** + * Creates a plain object from a ListZonesRequest message. Also converts values to other types if specified. + * @param message ListZonesRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.ListZonesRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ListZonesRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ListZonesRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ListZonesResponse. */ + interface IListZonesResponse { + + /** ListZonesResponse zones */ + zones?: (google.cloud.edgenetwork.v1.IZone[]|null); + + /** ListZonesResponse nextPageToken */ + nextPageToken?: (string|null); + + /** ListZonesResponse unreachable */ + unreachable?: (string[]|null); + } + + /** Represents a ListZonesResponse. */ + class ListZonesResponse implements IListZonesResponse { + + /** + * Constructs a new ListZonesResponse. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IListZonesResponse); + + /** ListZonesResponse zones. */ + public zones: google.cloud.edgenetwork.v1.IZone[]; + + /** ListZonesResponse nextPageToken. */ + public nextPageToken: string; + + /** ListZonesResponse unreachable. */ + public unreachable: string[]; + + /** + * Creates a new ListZonesResponse instance using the specified properties. + * @param [properties] Properties to set + * @returns ListZonesResponse instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IListZonesResponse): google.cloud.edgenetwork.v1.ListZonesResponse; + + /** + * Encodes the specified ListZonesResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListZonesResponse.verify|verify} messages. + * @param message ListZonesResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IListZonesResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ListZonesResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListZonesResponse.verify|verify} messages. + * @param message ListZonesResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IListZonesResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ListZonesResponse message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ListZonesResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.ListZonesResponse; + + /** + * Decodes a ListZonesResponse message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ListZonesResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.ListZonesResponse; + + /** + * Verifies a ListZonesResponse message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ListZonesResponse message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ListZonesResponse + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.ListZonesResponse; + + /** + * Creates a plain object from a ListZonesResponse message. Also converts values to other types if specified. + * @param message ListZonesResponse + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.ListZonesResponse, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ListZonesResponse to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ListZonesResponse + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a GetZoneRequest. */ + interface IGetZoneRequest { + + /** GetZoneRequest name */ + name?: (string|null); + } + + /** Represents a GetZoneRequest. */ + class GetZoneRequest implements IGetZoneRequest { + + /** + * Constructs a new GetZoneRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IGetZoneRequest); + + /** GetZoneRequest name. */ + public name: string; + + /** + * Creates a new GetZoneRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns GetZoneRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IGetZoneRequest): google.cloud.edgenetwork.v1.GetZoneRequest; + + /** + * Encodes the specified GetZoneRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.GetZoneRequest.verify|verify} messages. + * @param message GetZoneRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IGetZoneRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified GetZoneRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.GetZoneRequest.verify|verify} messages. + * @param message GetZoneRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IGetZoneRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a GetZoneRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns GetZoneRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.GetZoneRequest; + + /** + * Decodes a GetZoneRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns GetZoneRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.GetZoneRequest; + + /** + * Verifies a GetZoneRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a GetZoneRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns GetZoneRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.GetZoneRequest; + + /** + * Creates a plain object from a GetZoneRequest message. Also converts values to other types if specified. + * @param message GetZoneRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.GetZoneRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this GetZoneRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for GetZoneRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ListNetworksRequest. */ + interface IListNetworksRequest { + + /** ListNetworksRequest parent */ + parent?: (string|null); + + /** ListNetworksRequest pageSize */ + pageSize?: (number|null); + + /** ListNetworksRequest pageToken */ + pageToken?: (string|null); + + /** ListNetworksRequest filter */ + filter?: (string|null); + + /** ListNetworksRequest orderBy */ + orderBy?: (string|null); + } + + /** Represents a ListNetworksRequest. */ + class ListNetworksRequest implements IListNetworksRequest { + + /** + * Constructs a new ListNetworksRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IListNetworksRequest); + + /** ListNetworksRequest parent. */ + public parent: string; + + /** ListNetworksRequest pageSize. */ + public pageSize: number; + + /** ListNetworksRequest pageToken. */ + public pageToken: string; + + /** ListNetworksRequest filter. */ + public filter: string; + + /** ListNetworksRequest orderBy. */ + public orderBy: string; + + /** + * Creates a new ListNetworksRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns ListNetworksRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IListNetworksRequest): google.cloud.edgenetwork.v1.ListNetworksRequest; + + /** + * Encodes the specified ListNetworksRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListNetworksRequest.verify|verify} messages. + * @param message ListNetworksRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IListNetworksRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ListNetworksRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListNetworksRequest.verify|verify} messages. + * @param message ListNetworksRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IListNetworksRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ListNetworksRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ListNetworksRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.ListNetworksRequest; + + /** + * Decodes a ListNetworksRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ListNetworksRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.ListNetworksRequest; + + /** + * Verifies a ListNetworksRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ListNetworksRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ListNetworksRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.ListNetworksRequest; + + /** + * Creates a plain object from a ListNetworksRequest message. Also converts values to other types if specified. + * @param message ListNetworksRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.ListNetworksRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ListNetworksRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ListNetworksRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ListNetworksResponse. */ + interface IListNetworksResponse { + + /** ListNetworksResponse networks */ + networks?: (google.cloud.edgenetwork.v1.INetwork[]|null); + + /** ListNetworksResponse nextPageToken */ + nextPageToken?: (string|null); + + /** ListNetworksResponse unreachable */ + unreachable?: (string[]|null); + } + + /** Represents a ListNetworksResponse. */ + class ListNetworksResponse implements IListNetworksResponse { + + /** + * Constructs a new ListNetworksResponse. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IListNetworksResponse); + + /** ListNetworksResponse networks. */ + public networks: google.cloud.edgenetwork.v1.INetwork[]; + + /** ListNetworksResponse nextPageToken. */ + public nextPageToken: string; + + /** ListNetworksResponse unreachable. */ + public unreachable: string[]; + + /** + * Creates a new ListNetworksResponse instance using the specified properties. + * @param [properties] Properties to set + * @returns ListNetworksResponse instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IListNetworksResponse): google.cloud.edgenetwork.v1.ListNetworksResponse; + + /** + * Encodes the specified ListNetworksResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListNetworksResponse.verify|verify} messages. + * @param message ListNetworksResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IListNetworksResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ListNetworksResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListNetworksResponse.verify|verify} messages. + * @param message ListNetworksResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IListNetworksResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ListNetworksResponse message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ListNetworksResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.ListNetworksResponse; + + /** + * Decodes a ListNetworksResponse message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ListNetworksResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.ListNetworksResponse; + + /** + * Verifies a ListNetworksResponse message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ListNetworksResponse message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ListNetworksResponse + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.ListNetworksResponse; + + /** + * Creates a plain object from a ListNetworksResponse message. Also converts values to other types if specified. + * @param message ListNetworksResponse + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.ListNetworksResponse, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ListNetworksResponse to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ListNetworksResponse + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a GetNetworkRequest. */ + interface IGetNetworkRequest { + + /** GetNetworkRequest name */ + name?: (string|null); + } + + /** Represents a GetNetworkRequest. */ + class GetNetworkRequest implements IGetNetworkRequest { + + /** + * Constructs a new GetNetworkRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IGetNetworkRequest); + + /** GetNetworkRequest name. */ + public name: string; + + /** + * Creates a new GetNetworkRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns GetNetworkRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IGetNetworkRequest): google.cloud.edgenetwork.v1.GetNetworkRequest; + + /** + * Encodes the specified GetNetworkRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.GetNetworkRequest.verify|verify} messages. + * @param message GetNetworkRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IGetNetworkRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified GetNetworkRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.GetNetworkRequest.verify|verify} messages. + * @param message GetNetworkRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IGetNetworkRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a GetNetworkRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns GetNetworkRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.GetNetworkRequest; + + /** + * Decodes a GetNetworkRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns GetNetworkRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.GetNetworkRequest; + + /** + * Verifies a GetNetworkRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a GetNetworkRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns GetNetworkRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.GetNetworkRequest; + + /** + * Creates a plain object from a GetNetworkRequest message. Also converts values to other types if specified. + * @param message GetNetworkRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.GetNetworkRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this GetNetworkRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for GetNetworkRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a CreateNetworkRequest. */ + interface ICreateNetworkRequest { + + /** CreateNetworkRequest parent */ + parent?: (string|null); + + /** CreateNetworkRequest networkId */ + networkId?: (string|null); + + /** CreateNetworkRequest network */ + network?: (google.cloud.edgenetwork.v1.INetwork|null); + + /** CreateNetworkRequest requestId */ + requestId?: (string|null); + } + + /** Represents a CreateNetworkRequest. */ + class CreateNetworkRequest implements ICreateNetworkRequest { + + /** + * Constructs a new CreateNetworkRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.ICreateNetworkRequest); + + /** CreateNetworkRequest parent. */ + public parent: string; + + /** CreateNetworkRequest networkId. */ + public networkId: string; + + /** CreateNetworkRequest network. */ + public network?: (google.cloud.edgenetwork.v1.INetwork|null); + + /** CreateNetworkRequest requestId. */ + public requestId: string; + + /** + * Creates a new CreateNetworkRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns CreateNetworkRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.ICreateNetworkRequest): google.cloud.edgenetwork.v1.CreateNetworkRequest; + + /** + * Encodes the specified CreateNetworkRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.CreateNetworkRequest.verify|verify} messages. + * @param message CreateNetworkRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.ICreateNetworkRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified CreateNetworkRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.CreateNetworkRequest.verify|verify} messages. + * @param message CreateNetworkRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.ICreateNetworkRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a CreateNetworkRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns CreateNetworkRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.CreateNetworkRequest; + + /** + * Decodes a CreateNetworkRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns CreateNetworkRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.CreateNetworkRequest; + + /** + * Verifies a CreateNetworkRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a CreateNetworkRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns CreateNetworkRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.CreateNetworkRequest; + + /** + * Creates a plain object from a CreateNetworkRequest message. Also converts values to other types if specified. + * @param message CreateNetworkRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.CreateNetworkRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this CreateNetworkRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for CreateNetworkRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a DeleteNetworkRequest. */ + interface IDeleteNetworkRequest { + + /** DeleteNetworkRequest name */ + name?: (string|null); + + /** DeleteNetworkRequest requestId */ + requestId?: (string|null); + } + + /** Represents a DeleteNetworkRequest. */ + class DeleteNetworkRequest implements IDeleteNetworkRequest { + + /** + * Constructs a new DeleteNetworkRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IDeleteNetworkRequest); + + /** DeleteNetworkRequest name. */ + public name: string; + + /** DeleteNetworkRequest requestId. */ + public requestId: string; + + /** + * Creates a new DeleteNetworkRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns DeleteNetworkRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IDeleteNetworkRequest): google.cloud.edgenetwork.v1.DeleteNetworkRequest; + + /** + * Encodes the specified DeleteNetworkRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.DeleteNetworkRequest.verify|verify} messages. + * @param message DeleteNetworkRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IDeleteNetworkRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified DeleteNetworkRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DeleteNetworkRequest.verify|verify} messages. + * @param message DeleteNetworkRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IDeleteNetworkRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a DeleteNetworkRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns DeleteNetworkRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.DeleteNetworkRequest; + + /** + * Decodes a DeleteNetworkRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns DeleteNetworkRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.DeleteNetworkRequest; + + /** + * Verifies a DeleteNetworkRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a DeleteNetworkRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns DeleteNetworkRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.DeleteNetworkRequest; + + /** + * Creates a plain object from a DeleteNetworkRequest message. Also converts values to other types if specified. + * @param message DeleteNetworkRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.DeleteNetworkRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this DeleteNetworkRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for DeleteNetworkRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ListSubnetsRequest. */ + interface IListSubnetsRequest { + + /** ListSubnetsRequest parent */ + parent?: (string|null); + + /** ListSubnetsRequest pageSize */ + pageSize?: (number|null); + + /** ListSubnetsRequest pageToken */ + pageToken?: (string|null); + + /** ListSubnetsRequest filter */ + filter?: (string|null); + + /** ListSubnetsRequest orderBy */ + orderBy?: (string|null); + } + + /** Represents a ListSubnetsRequest. */ + class ListSubnetsRequest implements IListSubnetsRequest { + + /** + * Constructs a new ListSubnetsRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IListSubnetsRequest); + + /** ListSubnetsRequest parent. */ + public parent: string; + + /** ListSubnetsRequest pageSize. */ + public pageSize: number; + + /** ListSubnetsRequest pageToken. */ + public pageToken: string; + + /** ListSubnetsRequest filter. */ + public filter: string; + + /** ListSubnetsRequest orderBy. */ + public orderBy: string; + + /** + * Creates a new ListSubnetsRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns ListSubnetsRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IListSubnetsRequest): google.cloud.edgenetwork.v1.ListSubnetsRequest; + + /** + * Encodes the specified ListSubnetsRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListSubnetsRequest.verify|verify} messages. + * @param message ListSubnetsRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IListSubnetsRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ListSubnetsRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListSubnetsRequest.verify|verify} messages. + * @param message ListSubnetsRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IListSubnetsRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ListSubnetsRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ListSubnetsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.ListSubnetsRequest; + + /** + * Decodes a ListSubnetsRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ListSubnetsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.ListSubnetsRequest; + + /** + * Verifies a ListSubnetsRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ListSubnetsRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ListSubnetsRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.ListSubnetsRequest; + + /** + * Creates a plain object from a ListSubnetsRequest message. Also converts values to other types if specified. + * @param message ListSubnetsRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.ListSubnetsRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ListSubnetsRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ListSubnetsRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ListSubnetsResponse. */ + interface IListSubnetsResponse { + + /** ListSubnetsResponse subnets */ + subnets?: (google.cloud.edgenetwork.v1.ISubnet[]|null); + + /** ListSubnetsResponse nextPageToken */ + nextPageToken?: (string|null); + + /** ListSubnetsResponse unreachable */ + unreachable?: (string[]|null); + } + + /** Represents a ListSubnetsResponse. */ + class ListSubnetsResponse implements IListSubnetsResponse { + + /** + * Constructs a new ListSubnetsResponse. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IListSubnetsResponse); + + /** ListSubnetsResponse subnets. */ + public subnets: google.cloud.edgenetwork.v1.ISubnet[]; + + /** ListSubnetsResponse nextPageToken. */ + public nextPageToken: string; + + /** ListSubnetsResponse unreachable. */ + public unreachable: string[]; + + /** + * Creates a new ListSubnetsResponse instance using the specified properties. + * @param [properties] Properties to set + * @returns ListSubnetsResponse instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IListSubnetsResponse): google.cloud.edgenetwork.v1.ListSubnetsResponse; + + /** + * Encodes the specified ListSubnetsResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListSubnetsResponse.verify|verify} messages. + * @param message ListSubnetsResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IListSubnetsResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ListSubnetsResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListSubnetsResponse.verify|verify} messages. + * @param message ListSubnetsResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IListSubnetsResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ListSubnetsResponse message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ListSubnetsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.ListSubnetsResponse; + + /** + * Decodes a ListSubnetsResponse message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ListSubnetsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.ListSubnetsResponse; + + /** + * Verifies a ListSubnetsResponse message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ListSubnetsResponse message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ListSubnetsResponse + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.ListSubnetsResponse; + + /** + * Creates a plain object from a ListSubnetsResponse message. Also converts values to other types if specified. + * @param message ListSubnetsResponse + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.ListSubnetsResponse, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ListSubnetsResponse to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ListSubnetsResponse + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a GetSubnetRequest. */ + interface IGetSubnetRequest { + + /** GetSubnetRequest name */ + name?: (string|null); + } + + /** Represents a GetSubnetRequest. */ + class GetSubnetRequest implements IGetSubnetRequest { + + /** + * Constructs a new GetSubnetRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IGetSubnetRequest); + + /** GetSubnetRequest name. */ + public name: string; + + /** + * Creates a new GetSubnetRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns GetSubnetRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IGetSubnetRequest): google.cloud.edgenetwork.v1.GetSubnetRequest; + + /** + * Encodes the specified GetSubnetRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.GetSubnetRequest.verify|verify} messages. + * @param message GetSubnetRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IGetSubnetRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified GetSubnetRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.GetSubnetRequest.verify|verify} messages. + * @param message GetSubnetRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IGetSubnetRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a GetSubnetRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns GetSubnetRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.GetSubnetRequest; + + /** + * Decodes a GetSubnetRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns GetSubnetRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.GetSubnetRequest; + + /** + * Verifies a GetSubnetRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a GetSubnetRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns GetSubnetRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.GetSubnetRequest; + + /** + * Creates a plain object from a GetSubnetRequest message. Also converts values to other types if specified. + * @param message GetSubnetRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.GetSubnetRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this GetSubnetRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for GetSubnetRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a CreateSubnetRequest. */ + interface ICreateSubnetRequest { + + /** CreateSubnetRequest parent */ + parent?: (string|null); + + /** CreateSubnetRequest subnetId */ + subnetId?: (string|null); + + /** CreateSubnetRequest subnet */ + subnet?: (google.cloud.edgenetwork.v1.ISubnet|null); + + /** CreateSubnetRequest requestId */ + requestId?: (string|null); + } + + /** Represents a CreateSubnetRequest. */ + class CreateSubnetRequest implements ICreateSubnetRequest { + + /** + * Constructs a new CreateSubnetRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.ICreateSubnetRequest); + + /** CreateSubnetRequest parent. */ + public parent: string; + + /** CreateSubnetRequest subnetId. */ + public subnetId: string; + + /** CreateSubnetRequest subnet. */ + public subnet?: (google.cloud.edgenetwork.v1.ISubnet|null); + + /** CreateSubnetRequest requestId. */ + public requestId: string; + + /** + * Creates a new CreateSubnetRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns CreateSubnetRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.ICreateSubnetRequest): google.cloud.edgenetwork.v1.CreateSubnetRequest; + + /** + * Encodes the specified CreateSubnetRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.CreateSubnetRequest.verify|verify} messages. + * @param message CreateSubnetRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.ICreateSubnetRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified CreateSubnetRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.CreateSubnetRequest.verify|verify} messages. + * @param message CreateSubnetRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.ICreateSubnetRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a CreateSubnetRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns CreateSubnetRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.CreateSubnetRequest; + + /** + * Decodes a CreateSubnetRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns CreateSubnetRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.CreateSubnetRequest; + + /** + * Verifies a CreateSubnetRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a CreateSubnetRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns CreateSubnetRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.CreateSubnetRequest; + + /** + * Creates a plain object from a CreateSubnetRequest message. Also converts values to other types if specified. + * @param message CreateSubnetRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.CreateSubnetRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this CreateSubnetRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for CreateSubnetRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of an UpdateSubnetRequest. */ + interface IUpdateSubnetRequest { + + /** UpdateSubnetRequest updateMask */ + updateMask?: (google.protobuf.IFieldMask|null); + + /** UpdateSubnetRequest subnet */ + subnet?: (google.cloud.edgenetwork.v1.ISubnet|null); + + /** UpdateSubnetRequest requestId */ + requestId?: (string|null); + } + + /** Represents an UpdateSubnetRequest. */ + class UpdateSubnetRequest implements IUpdateSubnetRequest { + + /** + * Constructs a new UpdateSubnetRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IUpdateSubnetRequest); + + /** UpdateSubnetRequest updateMask. */ + public updateMask?: (google.protobuf.IFieldMask|null); + + /** UpdateSubnetRequest subnet. */ + public subnet?: (google.cloud.edgenetwork.v1.ISubnet|null); + + /** UpdateSubnetRequest requestId. */ + public requestId: string; + + /** + * Creates a new UpdateSubnetRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns UpdateSubnetRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IUpdateSubnetRequest): google.cloud.edgenetwork.v1.UpdateSubnetRequest; + + /** + * Encodes the specified UpdateSubnetRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.UpdateSubnetRequest.verify|verify} messages. + * @param message UpdateSubnetRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IUpdateSubnetRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified UpdateSubnetRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.UpdateSubnetRequest.verify|verify} messages. + * @param message UpdateSubnetRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IUpdateSubnetRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an UpdateSubnetRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns UpdateSubnetRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.UpdateSubnetRequest; + + /** + * Decodes an UpdateSubnetRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns UpdateSubnetRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.UpdateSubnetRequest; + + /** + * Verifies an UpdateSubnetRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an UpdateSubnetRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns UpdateSubnetRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.UpdateSubnetRequest; + + /** + * Creates a plain object from an UpdateSubnetRequest message. Also converts values to other types if specified. + * @param message UpdateSubnetRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.UpdateSubnetRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this UpdateSubnetRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for UpdateSubnetRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a DeleteSubnetRequest. */ + interface IDeleteSubnetRequest { + + /** DeleteSubnetRequest name */ + name?: (string|null); + + /** DeleteSubnetRequest requestId */ + requestId?: (string|null); + } + + /** Represents a DeleteSubnetRequest. */ + class DeleteSubnetRequest implements IDeleteSubnetRequest { + + /** + * Constructs a new DeleteSubnetRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IDeleteSubnetRequest); + + /** DeleteSubnetRequest name. */ + public name: string; + + /** DeleteSubnetRequest requestId. */ + public requestId: string; + + /** + * Creates a new DeleteSubnetRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns DeleteSubnetRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IDeleteSubnetRequest): google.cloud.edgenetwork.v1.DeleteSubnetRequest; + + /** + * Encodes the specified DeleteSubnetRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.DeleteSubnetRequest.verify|verify} messages. + * @param message DeleteSubnetRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IDeleteSubnetRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified DeleteSubnetRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DeleteSubnetRequest.verify|verify} messages. + * @param message DeleteSubnetRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IDeleteSubnetRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a DeleteSubnetRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns DeleteSubnetRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.DeleteSubnetRequest; + + /** + * Decodes a DeleteSubnetRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns DeleteSubnetRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.DeleteSubnetRequest; + + /** + * Verifies a DeleteSubnetRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a DeleteSubnetRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns DeleteSubnetRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.DeleteSubnetRequest; + + /** + * Creates a plain object from a DeleteSubnetRequest message. Also converts values to other types if specified. + * @param message DeleteSubnetRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.DeleteSubnetRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this DeleteSubnetRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for DeleteSubnetRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ListInterconnectsRequest. */ + interface IListInterconnectsRequest { + + /** ListInterconnectsRequest parent */ + parent?: (string|null); + + /** ListInterconnectsRequest pageSize */ + pageSize?: (number|null); + + /** ListInterconnectsRequest pageToken */ + pageToken?: (string|null); + + /** ListInterconnectsRequest filter */ + filter?: (string|null); + + /** ListInterconnectsRequest orderBy */ + orderBy?: (string|null); + } + + /** Represents a ListInterconnectsRequest. */ + class ListInterconnectsRequest implements IListInterconnectsRequest { + + /** + * Constructs a new ListInterconnectsRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IListInterconnectsRequest); + + /** ListInterconnectsRequest parent. */ + public parent: string; + + /** ListInterconnectsRequest pageSize. */ + public pageSize: number; + + /** ListInterconnectsRequest pageToken. */ + public pageToken: string; + + /** ListInterconnectsRequest filter. */ + public filter: string; + + /** ListInterconnectsRequest orderBy. */ + public orderBy: string; + + /** + * Creates a new ListInterconnectsRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns ListInterconnectsRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IListInterconnectsRequest): google.cloud.edgenetwork.v1.ListInterconnectsRequest; + + /** + * Encodes the specified ListInterconnectsRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListInterconnectsRequest.verify|verify} messages. + * @param message ListInterconnectsRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IListInterconnectsRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ListInterconnectsRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListInterconnectsRequest.verify|verify} messages. + * @param message ListInterconnectsRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IListInterconnectsRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ListInterconnectsRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ListInterconnectsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.ListInterconnectsRequest; + + /** + * Decodes a ListInterconnectsRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ListInterconnectsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.ListInterconnectsRequest; + + /** + * Verifies a ListInterconnectsRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ListInterconnectsRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ListInterconnectsRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.ListInterconnectsRequest; + + /** + * Creates a plain object from a ListInterconnectsRequest message. Also converts values to other types if specified. + * @param message ListInterconnectsRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.ListInterconnectsRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ListInterconnectsRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ListInterconnectsRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ListInterconnectsResponse. */ + interface IListInterconnectsResponse { + + /** ListInterconnectsResponse interconnects */ + interconnects?: (google.cloud.edgenetwork.v1.IInterconnect[]|null); + + /** ListInterconnectsResponse nextPageToken */ + nextPageToken?: (string|null); + + /** ListInterconnectsResponse unreachable */ + unreachable?: (string[]|null); + } + + /** Represents a ListInterconnectsResponse. */ + class ListInterconnectsResponse implements IListInterconnectsResponse { + + /** + * Constructs a new ListInterconnectsResponse. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IListInterconnectsResponse); + + /** ListInterconnectsResponse interconnects. */ + public interconnects: google.cloud.edgenetwork.v1.IInterconnect[]; + + /** ListInterconnectsResponse nextPageToken. */ + public nextPageToken: string; + + /** ListInterconnectsResponse unreachable. */ + public unreachable: string[]; + + /** + * Creates a new ListInterconnectsResponse instance using the specified properties. + * @param [properties] Properties to set + * @returns ListInterconnectsResponse instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IListInterconnectsResponse): google.cloud.edgenetwork.v1.ListInterconnectsResponse; + + /** + * Encodes the specified ListInterconnectsResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListInterconnectsResponse.verify|verify} messages. + * @param message ListInterconnectsResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IListInterconnectsResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ListInterconnectsResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListInterconnectsResponse.verify|verify} messages. + * @param message ListInterconnectsResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IListInterconnectsResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ListInterconnectsResponse message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ListInterconnectsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.ListInterconnectsResponse; + + /** + * Decodes a ListInterconnectsResponse message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ListInterconnectsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.ListInterconnectsResponse; + + /** + * Verifies a ListInterconnectsResponse message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ListInterconnectsResponse message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ListInterconnectsResponse + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.ListInterconnectsResponse; + + /** + * Creates a plain object from a ListInterconnectsResponse message. Also converts values to other types if specified. + * @param message ListInterconnectsResponse + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.ListInterconnectsResponse, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ListInterconnectsResponse to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ListInterconnectsResponse + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a GetInterconnectRequest. */ + interface IGetInterconnectRequest { + + /** GetInterconnectRequest name */ + name?: (string|null); + } + + /** Represents a GetInterconnectRequest. */ + class GetInterconnectRequest implements IGetInterconnectRequest { + + /** + * Constructs a new GetInterconnectRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IGetInterconnectRequest); + + /** GetInterconnectRequest name. */ + public name: string; + + /** + * Creates a new GetInterconnectRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns GetInterconnectRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IGetInterconnectRequest): google.cloud.edgenetwork.v1.GetInterconnectRequest; + + /** + * Encodes the specified GetInterconnectRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.GetInterconnectRequest.verify|verify} messages. + * @param message GetInterconnectRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IGetInterconnectRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified GetInterconnectRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.GetInterconnectRequest.verify|verify} messages. + * @param message GetInterconnectRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IGetInterconnectRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a GetInterconnectRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns GetInterconnectRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.GetInterconnectRequest; + + /** + * Decodes a GetInterconnectRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns GetInterconnectRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.GetInterconnectRequest; + + /** + * Verifies a GetInterconnectRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a GetInterconnectRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns GetInterconnectRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.GetInterconnectRequest; + + /** + * Creates a plain object from a GetInterconnectRequest message. Also converts values to other types if specified. + * @param message GetInterconnectRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.GetInterconnectRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this GetInterconnectRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for GetInterconnectRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ListInterconnectAttachmentsRequest. */ + interface IListInterconnectAttachmentsRequest { + + /** ListInterconnectAttachmentsRequest parent */ + parent?: (string|null); + + /** ListInterconnectAttachmentsRequest pageSize */ + pageSize?: (number|null); + + /** ListInterconnectAttachmentsRequest pageToken */ + pageToken?: (string|null); + + /** ListInterconnectAttachmentsRequest filter */ + filter?: (string|null); + + /** ListInterconnectAttachmentsRequest orderBy */ + orderBy?: (string|null); + } + + /** Represents a ListInterconnectAttachmentsRequest. */ + class ListInterconnectAttachmentsRequest implements IListInterconnectAttachmentsRequest { + + /** + * Constructs a new ListInterconnectAttachmentsRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest); + + /** ListInterconnectAttachmentsRequest parent. */ + public parent: string; + + /** ListInterconnectAttachmentsRequest pageSize. */ + public pageSize: number; + + /** ListInterconnectAttachmentsRequest pageToken. */ + public pageToken: string; + + /** ListInterconnectAttachmentsRequest filter. */ + public filter: string; + + /** ListInterconnectAttachmentsRequest orderBy. */ + public orderBy: string; + + /** + * Creates a new ListInterconnectAttachmentsRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns ListInterconnectAttachmentsRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest): google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest; + + /** + * Encodes the specified ListInterconnectAttachmentsRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest.verify|verify} messages. + * @param message ListInterconnectAttachmentsRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ListInterconnectAttachmentsRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest.verify|verify} messages. + * @param message ListInterconnectAttachmentsRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ListInterconnectAttachmentsRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ListInterconnectAttachmentsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest; + + /** + * Decodes a ListInterconnectAttachmentsRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ListInterconnectAttachmentsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest; + + /** + * Verifies a ListInterconnectAttachmentsRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ListInterconnectAttachmentsRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ListInterconnectAttachmentsRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest; + + /** + * Creates a plain object from a ListInterconnectAttachmentsRequest message. Also converts values to other types if specified. + * @param message ListInterconnectAttachmentsRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ListInterconnectAttachmentsRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ListInterconnectAttachmentsRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ListInterconnectAttachmentsResponse. */ + interface IListInterconnectAttachmentsResponse { + + /** ListInterconnectAttachmentsResponse interconnectAttachments */ + interconnectAttachments?: (google.cloud.edgenetwork.v1.IInterconnectAttachment[]|null); + + /** ListInterconnectAttachmentsResponse nextPageToken */ + nextPageToken?: (string|null); + + /** ListInterconnectAttachmentsResponse unreachable */ + unreachable?: (string[]|null); + } + + /** Represents a ListInterconnectAttachmentsResponse. */ + class ListInterconnectAttachmentsResponse implements IListInterconnectAttachmentsResponse { + + /** + * Constructs a new ListInterconnectAttachmentsResponse. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse); + + /** ListInterconnectAttachmentsResponse interconnectAttachments. */ + public interconnectAttachments: google.cloud.edgenetwork.v1.IInterconnectAttachment[]; + + /** ListInterconnectAttachmentsResponse nextPageToken. */ + public nextPageToken: string; + + /** ListInterconnectAttachmentsResponse unreachable. */ + public unreachable: string[]; + + /** + * Creates a new ListInterconnectAttachmentsResponse instance using the specified properties. + * @param [properties] Properties to set + * @returns ListInterconnectAttachmentsResponse instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse): google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse; + + /** + * Encodes the specified ListInterconnectAttachmentsResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse.verify|verify} messages. + * @param message ListInterconnectAttachmentsResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ListInterconnectAttachmentsResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse.verify|verify} messages. + * @param message ListInterconnectAttachmentsResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ListInterconnectAttachmentsResponse message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ListInterconnectAttachmentsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse; + + /** + * Decodes a ListInterconnectAttachmentsResponse message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ListInterconnectAttachmentsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse; + + /** + * Verifies a ListInterconnectAttachmentsResponse message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ListInterconnectAttachmentsResponse message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ListInterconnectAttachmentsResponse + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse; + + /** + * Creates a plain object from a ListInterconnectAttachmentsResponse message. Also converts values to other types if specified. + * @param message ListInterconnectAttachmentsResponse + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ListInterconnectAttachmentsResponse to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ListInterconnectAttachmentsResponse + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a GetInterconnectAttachmentRequest. */ + interface IGetInterconnectAttachmentRequest { + + /** GetInterconnectAttachmentRequest name */ + name?: (string|null); + } + + /** Represents a GetInterconnectAttachmentRequest. */ + class GetInterconnectAttachmentRequest implements IGetInterconnectAttachmentRequest { + + /** + * Constructs a new GetInterconnectAttachmentRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest); + + /** GetInterconnectAttachmentRequest name. */ + public name: string; + + /** + * Creates a new GetInterconnectAttachmentRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns GetInterconnectAttachmentRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest): google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest; + + /** + * Encodes the specified GetInterconnectAttachmentRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest.verify|verify} messages. + * @param message GetInterconnectAttachmentRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified GetInterconnectAttachmentRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest.verify|verify} messages. + * @param message GetInterconnectAttachmentRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a GetInterconnectAttachmentRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns GetInterconnectAttachmentRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest; + + /** + * Decodes a GetInterconnectAttachmentRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns GetInterconnectAttachmentRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest; + + /** + * Verifies a GetInterconnectAttachmentRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a GetInterconnectAttachmentRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns GetInterconnectAttachmentRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest; + + /** + * Creates a plain object from a GetInterconnectAttachmentRequest message. Also converts values to other types if specified. + * @param message GetInterconnectAttachmentRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this GetInterconnectAttachmentRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for GetInterconnectAttachmentRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a CreateInterconnectAttachmentRequest. */ + interface ICreateInterconnectAttachmentRequest { + + /** CreateInterconnectAttachmentRequest parent */ + parent?: (string|null); + + /** CreateInterconnectAttachmentRequest interconnectAttachmentId */ + interconnectAttachmentId?: (string|null); + + /** CreateInterconnectAttachmentRequest interconnectAttachment */ + interconnectAttachment?: (google.cloud.edgenetwork.v1.IInterconnectAttachment|null); + + /** CreateInterconnectAttachmentRequest requestId */ + requestId?: (string|null); + } + + /** Represents a CreateInterconnectAttachmentRequest. */ + class CreateInterconnectAttachmentRequest implements ICreateInterconnectAttachmentRequest { + + /** + * Constructs a new CreateInterconnectAttachmentRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest); + + /** CreateInterconnectAttachmentRequest parent. */ + public parent: string; + + /** CreateInterconnectAttachmentRequest interconnectAttachmentId. */ + public interconnectAttachmentId: string; + + /** CreateInterconnectAttachmentRequest interconnectAttachment. */ + public interconnectAttachment?: (google.cloud.edgenetwork.v1.IInterconnectAttachment|null); + + /** CreateInterconnectAttachmentRequest requestId. */ + public requestId: string; + + /** + * Creates a new CreateInterconnectAttachmentRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns CreateInterconnectAttachmentRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest): google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest; + + /** + * Encodes the specified CreateInterconnectAttachmentRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest.verify|verify} messages. + * @param message CreateInterconnectAttachmentRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified CreateInterconnectAttachmentRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest.verify|verify} messages. + * @param message CreateInterconnectAttachmentRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a CreateInterconnectAttachmentRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns CreateInterconnectAttachmentRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest; + + /** + * Decodes a CreateInterconnectAttachmentRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns CreateInterconnectAttachmentRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest; + + /** + * Verifies a CreateInterconnectAttachmentRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a CreateInterconnectAttachmentRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns CreateInterconnectAttachmentRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest; + + /** + * Creates a plain object from a CreateInterconnectAttachmentRequest message. Also converts values to other types if specified. + * @param message CreateInterconnectAttachmentRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this CreateInterconnectAttachmentRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for CreateInterconnectAttachmentRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a DeleteInterconnectAttachmentRequest. */ + interface IDeleteInterconnectAttachmentRequest { + + /** DeleteInterconnectAttachmentRequest name */ + name?: (string|null); + + /** DeleteInterconnectAttachmentRequest requestId */ + requestId?: (string|null); + } + + /** Represents a DeleteInterconnectAttachmentRequest. */ + class DeleteInterconnectAttachmentRequest implements IDeleteInterconnectAttachmentRequest { + + /** + * Constructs a new DeleteInterconnectAttachmentRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest); + + /** DeleteInterconnectAttachmentRequest name. */ + public name: string; + + /** DeleteInterconnectAttachmentRequest requestId. */ + public requestId: string; + + /** + * Creates a new DeleteInterconnectAttachmentRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns DeleteInterconnectAttachmentRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest): google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest; + + /** + * Encodes the specified DeleteInterconnectAttachmentRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest.verify|verify} messages. + * @param message DeleteInterconnectAttachmentRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified DeleteInterconnectAttachmentRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest.verify|verify} messages. + * @param message DeleteInterconnectAttachmentRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a DeleteInterconnectAttachmentRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns DeleteInterconnectAttachmentRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest; + + /** + * Decodes a DeleteInterconnectAttachmentRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns DeleteInterconnectAttachmentRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest; + + /** + * Verifies a DeleteInterconnectAttachmentRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a DeleteInterconnectAttachmentRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns DeleteInterconnectAttachmentRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest; + + /** + * Creates a plain object from a DeleteInterconnectAttachmentRequest message. Also converts values to other types if specified. + * @param message DeleteInterconnectAttachmentRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this DeleteInterconnectAttachmentRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for DeleteInterconnectAttachmentRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ListRoutersRequest. */ + interface IListRoutersRequest { + + /** ListRoutersRequest parent */ + parent?: (string|null); + + /** ListRoutersRequest pageSize */ + pageSize?: (number|null); + + /** ListRoutersRequest pageToken */ + pageToken?: (string|null); + + /** ListRoutersRequest filter */ + filter?: (string|null); + + /** ListRoutersRequest orderBy */ + orderBy?: (string|null); + } + + /** Represents a ListRoutersRequest. */ + class ListRoutersRequest implements IListRoutersRequest { + + /** + * Constructs a new ListRoutersRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IListRoutersRequest); + + /** ListRoutersRequest parent. */ + public parent: string; + + /** ListRoutersRequest pageSize. */ + public pageSize: number; + + /** ListRoutersRequest pageToken. */ + public pageToken: string; + + /** ListRoutersRequest filter. */ + public filter: string; + + /** ListRoutersRequest orderBy. */ + public orderBy: string; + + /** + * Creates a new ListRoutersRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns ListRoutersRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IListRoutersRequest): google.cloud.edgenetwork.v1.ListRoutersRequest; + + /** + * Encodes the specified ListRoutersRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListRoutersRequest.verify|verify} messages. + * @param message ListRoutersRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IListRoutersRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ListRoutersRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListRoutersRequest.verify|verify} messages. + * @param message ListRoutersRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IListRoutersRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ListRoutersRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ListRoutersRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.ListRoutersRequest; + + /** + * Decodes a ListRoutersRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ListRoutersRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.ListRoutersRequest; + + /** + * Verifies a ListRoutersRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ListRoutersRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ListRoutersRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.ListRoutersRequest; + + /** + * Creates a plain object from a ListRoutersRequest message. Also converts values to other types if specified. + * @param message ListRoutersRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.ListRoutersRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ListRoutersRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ListRoutersRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ListRoutersResponse. */ + interface IListRoutersResponse { + + /** ListRoutersResponse routers */ + routers?: (google.cloud.edgenetwork.v1.IRouter[]|null); + + /** ListRoutersResponse nextPageToken */ + nextPageToken?: (string|null); + + /** ListRoutersResponse unreachable */ + unreachable?: (string[]|null); + } + + /** Represents a ListRoutersResponse. */ + class ListRoutersResponse implements IListRoutersResponse { + + /** + * Constructs a new ListRoutersResponse. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IListRoutersResponse); + + /** ListRoutersResponse routers. */ + public routers: google.cloud.edgenetwork.v1.IRouter[]; + + /** ListRoutersResponse nextPageToken. */ + public nextPageToken: string; + + /** ListRoutersResponse unreachable. */ + public unreachable: string[]; + + /** + * Creates a new ListRoutersResponse instance using the specified properties. + * @param [properties] Properties to set + * @returns ListRoutersResponse instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IListRoutersResponse): google.cloud.edgenetwork.v1.ListRoutersResponse; + + /** + * Encodes the specified ListRoutersResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListRoutersResponse.verify|verify} messages. + * @param message ListRoutersResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IListRoutersResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ListRoutersResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListRoutersResponse.verify|verify} messages. + * @param message ListRoutersResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IListRoutersResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ListRoutersResponse message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ListRoutersResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.ListRoutersResponse; + + /** + * Decodes a ListRoutersResponse message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ListRoutersResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.ListRoutersResponse; + + /** + * Verifies a ListRoutersResponse message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ListRoutersResponse message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ListRoutersResponse + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.ListRoutersResponse; + + /** + * Creates a plain object from a ListRoutersResponse message. Also converts values to other types if specified. + * @param message ListRoutersResponse + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.ListRoutersResponse, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ListRoutersResponse to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ListRoutersResponse + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a GetRouterRequest. */ + interface IGetRouterRequest { + + /** GetRouterRequest name */ + name?: (string|null); + } + + /** Represents a GetRouterRequest. */ + class GetRouterRequest implements IGetRouterRequest { + + /** + * Constructs a new GetRouterRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IGetRouterRequest); + + /** GetRouterRequest name. */ + public name: string; + + /** + * Creates a new GetRouterRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns GetRouterRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IGetRouterRequest): google.cloud.edgenetwork.v1.GetRouterRequest; + + /** + * Encodes the specified GetRouterRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.GetRouterRequest.verify|verify} messages. + * @param message GetRouterRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IGetRouterRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified GetRouterRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.GetRouterRequest.verify|verify} messages. + * @param message GetRouterRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IGetRouterRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a GetRouterRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns GetRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.GetRouterRequest; + + /** + * Decodes a GetRouterRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns GetRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.GetRouterRequest; + + /** + * Verifies a GetRouterRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a GetRouterRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns GetRouterRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.GetRouterRequest; + + /** + * Creates a plain object from a GetRouterRequest message. Also converts values to other types if specified. + * @param message GetRouterRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.GetRouterRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this GetRouterRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for GetRouterRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a CreateRouterRequest. */ + interface ICreateRouterRequest { + + /** CreateRouterRequest parent */ + parent?: (string|null); + + /** CreateRouterRequest routerId */ + routerId?: (string|null); + + /** CreateRouterRequest router */ + router?: (google.cloud.edgenetwork.v1.IRouter|null); + + /** CreateRouterRequest requestId */ + requestId?: (string|null); + } + + /** Represents a CreateRouterRequest. */ + class CreateRouterRequest implements ICreateRouterRequest { + + /** + * Constructs a new CreateRouterRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.ICreateRouterRequest); + + /** CreateRouterRequest parent. */ + public parent: string; + + /** CreateRouterRequest routerId. */ + public routerId: string; + + /** CreateRouterRequest router. */ + public router?: (google.cloud.edgenetwork.v1.IRouter|null); + + /** CreateRouterRequest requestId. */ + public requestId: string; + + /** + * Creates a new CreateRouterRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns CreateRouterRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.ICreateRouterRequest): google.cloud.edgenetwork.v1.CreateRouterRequest; + + /** + * Encodes the specified CreateRouterRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.CreateRouterRequest.verify|verify} messages. + * @param message CreateRouterRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.ICreateRouterRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified CreateRouterRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.CreateRouterRequest.verify|verify} messages. + * @param message CreateRouterRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.ICreateRouterRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a CreateRouterRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns CreateRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.CreateRouterRequest; + + /** + * Decodes a CreateRouterRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns CreateRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.CreateRouterRequest; + + /** + * Verifies a CreateRouterRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a CreateRouterRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns CreateRouterRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.CreateRouterRequest; + + /** + * Creates a plain object from a CreateRouterRequest message. Also converts values to other types if specified. + * @param message CreateRouterRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.CreateRouterRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this CreateRouterRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for CreateRouterRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of an UpdateRouterRequest. */ + interface IUpdateRouterRequest { + + /** UpdateRouterRequest updateMask */ + updateMask?: (google.protobuf.IFieldMask|null); + + /** UpdateRouterRequest router */ + router?: (google.cloud.edgenetwork.v1.IRouter|null); + + /** UpdateRouterRequest requestId */ + requestId?: (string|null); + } + + /** Represents an UpdateRouterRequest. */ + class UpdateRouterRequest implements IUpdateRouterRequest { + + /** + * Constructs a new UpdateRouterRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IUpdateRouterRequest); + + /** UpdateRouterRequest updateMask. */ + public updateMask?: (google.protobuf.IFieldMask|null); + + /** UpdateRouterRequest router. */ + public router?: (google.cloud.edgenetwork.v1.IRouter|null); + + /** UpdateRouterRequest requestId. */ + public requestId: string; + + /** + * Creates a new UpdateRouterRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns UpdateRouterRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IUpdateRouterRequest): google.cloud.edgenetwork.v1.UpdateRouterRequest; + + /** + * Encodes the specified UpdateRouterRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.UpdateRouterRequest.verify|verify} messages. + * @param message UpdateRouterRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IUpdateRouterRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified UpdateRouterRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.UpdateRouterRequest.verify|verify} messages. + * @param message UpdateRouterRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IUpdateRouterRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an UpdateRouterRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns UpdateRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.UpdateRouterRequest; + + /** + * Decodes an UpdateRouterRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns UpdateRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.UpdateRouterRequest; + + /** + * Verifies an UpdateRouterRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an UpdateRouterRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns UpdateRouterRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.UpdateRouterRequest; + + /** + * Creates a plain object from an UpdateRouterRequest message. Also converts values to other types if specified. + * @param message UpdateRouterRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.UpdateRouterRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this UpdateRouterRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for UpdateRouterRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a DeleteRouterRequest. */ + interface IDeleteRouterRequest { + + /** DeleteRouterRequest name */ + name?: (string|null); + + /** DeleteRouterRequest requestId */ + requestId?: (string|null); + } + + /** Represents a DeleteRouterRequest. */ + class DeleteRouterRequest implements IDeleteRouterRequest { + + /** + * Constructs a new DeleteRouterRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IDeleteRouterRequest); + + /** DeleteRouterRequest name. */ + public name: string; + + /** DeleteRouterRequest requestId. */ + public requestId: string; + + /** + * Creates a new DeleteRouterRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns DeleteRouterRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IDeleteRouterRequest): google.cloud.edgenetwork.v1.DeleteRouterRequest; + + /** + * Encodes the specified DeleteRouterRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.DeleteRouterRequest.verify|verify} messages. + * @param message DeleteRouterRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IDeleteRouterRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified DeleteRouterRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DeleteRouterRequest.verify|verify} messages. + * @param message DeleteRouterRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IDeleteRouterRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a DeleteRouterRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns DeleteRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.DeleteRouterRequest; + + /** + * Decodes a DeleteRouterRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns DeleteRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.DeleteRouterRequest; + + /** + * Verifies a DeleteRouterRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a DeleteRouterRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns DeleteRouterRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.DeleteRouterRequest; + + /** + * Creates a plain object from a DeleteRouterRequest message. Also converts values to other types if specified. + * @param message DeleteRouterRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.DeleteRouterRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this DeleteRouterRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for DeleteRouterRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of an OperationMetadata. */ + interface IOperationMetadata { + + /** OperationMetadata createTime */ + createTime?: (google.protobuf.ITimestamp|null); + + /** OperationMetadata endTime */ + endTime?: (google.protobuf.ITimestamp|null); + + /** OperationMetadata target */ + target?: (string|null); + + /** OperationMetadata verb */ + verb?: (string|null); + + /** OperationMetadata statusMessage */ + statusMessage?: (string|null); + + /** OperationMetadata requestedCancellation */ + requestedCancellation?: (boolean|null); + + /** OperationMetadata apiVersion */ + apiVersion?: (string|null); + } + + /** Represents an OperationMetadata. */ + class OperationMetadata implements IOperationMetadata { + + /** + * Constructs a new OperationMetadata. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IOperationMetadata); + + /** OperationMetadata createTime. */ + public createTime?: (google.protobuf.ITimestamp|null); + + /** OperationMetadata endTime. */ + public endTime?: (google.protobuf.ITimestamp|null); + + /** OperationMetadata target. */ + public target: string; + + /** OperationMetadata verb. */ + public verb: string; + + /** OperationMetadata statusMessage. */ + public statusMessage: string; + + /** OperationMetadata requestedCancellation. */ + public requestedCancellation: boolean; + + /** OperationMetadata apiVersion. */ + public apiVersion: string; + + /** + * Creates a new OperationMetadata instance using the specified properties. + * @param [properties] Properties to set + * @returns OperationMetadata instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IOperationMetadata): google.cloud.edgenetwork.v1.OperationMetadata; + + /** + * Encodes the specified OperationMetadata message. Does not implicitly {@link google.cloud.edgenetwork.v1.OperationMetadata.verify|verify} messages. + * @param message OperationMetadata message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IOperationMetadata, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified OperationMetadata message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.OperationMetadata.verify|verify} messages. + * @param message OperationMetadata message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IOperationMetadata, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an OperationMetadata message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns OperationMetadata + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.OperationMetadata; + + /** + * Decodes an OperationMetadata message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns OperationMetadata + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.OperationMetadata; + + /** + * Verifies an OperationMetadata message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an OperationMetadata message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns OperationMetadata + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.OperationMetadata; + + /** + * Creates a plain object from an OperationMetadata message. Also converts values to other types if specified. + * @param message OperationMetadata + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.OperationMetadata, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this OperationMetadata to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for OperationMetadata + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a DiagnoseNetworkRequest. */ + interface IDiagnoseNetworkRequest { + + /** DiagnoseNetworkRequest name */ + name?: (string|null); + } + + /** Represents a DiagnoseNetworkRequest. */ + class DiagnoseNetworkRequest implements IDiagnoseNetworkRequest { + + /** + * Constructs a new DiagnoseNetworkRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest); + + /** DiagnoseNetworkRequest name. */ + public name: string; + + /** + * Creates a new DiagnoseNetworkRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns DiagnoseNetworkRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest): google.cloud.edgenetwork.v1.DiagnoseNetworkRequest; + + /** + * Encodes the specified DiagnoseNetworkRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseNetworkRequest.verify|verify} messages. + * @param message DiagnoseNetworkRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified DiagnoseNetworkRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseNetworkRequest.verify|verify} messages. + * @param message DiagnoseNetworkRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a DiagnoseNetworkRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns DiagnoseNetworkRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.DiagnoseNetworkRequest; + + /** + * Decodes a DiagnoseNetworkRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns DiagnoseNetworkRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.DiagnoseNetworkRequest; + + /** + * Verifies a DiagnoseNetworkRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a DiagnoseNetworkRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns DiagnoseNetworkRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.DiagnoseNetworkRequest; + + /** + * Creates a plain object from a DiagnoseNetworkRequest message. Also converts values to other types if specified. + * @param message DiagnoseNetworkRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.DiagnoseNetworkRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this DiagnoseNetworkRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for DiagnoseNetworkRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a DiagnoseNetworkResponse. */ + interface IDiagnoseNetworkResponse { + + /** DiagnoseNetworkResponse updateTime */ + updateTime?: (google.protobuf.ITimestamp|null); + + /** DiagnoseNetworkResponse result */ + result?: (google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.INetworkStatus|null); + } + + /** Represents a DiagnoseNetworkResponse. */ + class DiagnoseNetworkResponse implements IDiagnoseNetworkResponse { + + /** + * Constructs a new DiagnoseNetworkResponse. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse); + + /** DiagnoseNetworkResponse updateTime. */ + public updateTime?: (google.protobuf.ITimestamp|null); + + /** DiagnoseNetworkResponse result. */ + public result?: (google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.INetworkStatus|null); + + /** + * Creates a new DiagnoseNetworkResponse instance using the specified properties. + * @param [properties] Properties to set + * @returns DiagnoseNetworkResponse instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse): google.cloud.edgenetwork.v1.DiagnoseNetworkResponse; + + /** + * Encodes the specified DiagnoseNetworkResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.verify|verify} messages. + * @param message DiagnoseNetworkResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified DiagnoseNetworkResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.verify|verify} messages. + * @param message DiagnoseNetworkResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a DiagnoseNetworkResponse message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns DiagnoseNetworkResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.DiagnoseNetworkResponse; + + /** + * Decodes a DiagnoseNetworkResponse message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns DiagnoseNetworkResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.DiagnoseNetworkResponse; + + /** + * Verifies a DiagnoseNetworkResponse message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a DiagnoseNetworkResponse message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns DiagnoseNetworkResponse + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.DiagnoseNetworkResponse; + + /** + * Creates a plain object from a DiagnoseNetworkResponse message. Also converts values to other types if specified. + * @param message DiagnoseNetworkResponse + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.DiagnoseNetworkResponse, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this DiagnoseNetworkResponse to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for DiagnoseNetworkResponse + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace DiagnoseNetworkResponse { + + /** Properties of a NetworkStatus. */ + interface INetworkStatus { + + /** NetworkStatus subnetStatus */ + subnetStatus?: (google.cloud.edgenetwork.v1.ISubnetStatus[]|null); + } + + /** Represents a NetworkStatus. */ + class NetworkStatus implements INetworkStatus { + + /** + * Constructs a new NetworkStatus. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.INetworkStatus); + + /** NetworkStatus subnetStatus. */ + public subnetStatus: google.cloud.edgenetwork.v1.ISubnetStatus[]; + + /** + * Creates a new NetworkStatus instance using the specified properties. + * @param [properties] Properties to set + * @returns NetworkStatus instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.INetworkStatus): google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus; + + /** + * Encodes the specified NetworkStatus message. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus.verify|verify} messages. + * @param message NetworkStatus message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.INetworkStatus, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified NetworkStatus message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus.verify|verify} messages. + * @param message NetworkStatus message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.INetworkStatus, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a NetworkStatus message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns NetworkStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus; + + /** + * Decodes a NetworkStatus message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns NetworkStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus; + + /** + * Verifies a NetworkStatus message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a NetworkStatus message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns NetworkStatus + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus; + + /** + * Creates a plain object from a NetworkStatus message. Also converts values to other types if specified. + * @param message NetworkStatus + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this NetworkStatus to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for NetworkStatus + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + } + + /** Properties of a DiagnoseInterconnectRequest. */ + interface IDiagnoseInterconnectRequest { + + /** DiagnoseInterconnectRequest name */ + name?: (string|null); + } + + /** Represents a DiagnoseInterconnectRequest. */ + class DiagnoseInterconnectRequest implements IDiagnoseInterconnectRequest { + + /** + * Constructs a new DiagnoseInterconnectRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest); + + /** DiagnoseInterconnectRequest name. */ + public name: string; + + /** + * Creates a new DiagnoseInterconnectRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns DiagnoseInterconnectRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest): google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest; + + /** + * Encodes the specified DiagnoseInterconnectRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest.verify|verify} messages. + * @param message DiagnoseInterconnectRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified DiagnoseInterconnectRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest.verify|verify} messages. + * @param message DiagnoseInterconnectRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a DiagnoseInterconnectRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns DiagnoseInterconnectRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest; + + /** + * Decodes a DiagnoseInterconnectRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns DiagnoseInterconnectRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest; + + /** + * Verifies a DiagnoseInterconnectRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a DiagnoseInterconnectRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns DiagnoseInterconnectRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest; + + /** + * Creates a plain object from a DiagnoseInterconnectRequest message. Also converts values to other types if specified. + * @param message DiagnoseInterconnectRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this DiagnoseInterconnectRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for DiagnoseInterconnectRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a DiagnoseInterconnectResponse. */ + interface IDiagnoseInterconnectResponse { + + /** DiagnoseInterconnectResponse updateTime */ + updateTime?: (google.protobuf.ITimestamp|null); + + /** DiagnoseInterconnectResponse result */ + result?: (google.cloud.edgenetwork.v1.IInterconnectDiagnostics|null); + } + + /** Represents a DiagnoseInterconnectResponse. */ + class DiagnoseInterconnectResponse implements IDiagnoseInterconnectResponse { + + /** + * Constructs a new DiagnoseInterconnectResponse. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse); + + /** DiagnoseInterconnectResponse updateTime. */ + public updateTime?: (google.protobuf.ITimestamp|null); + + /** DiagnoseInterconnectResponse result. */ + public result?: (google.cloud.edgenetwork.v1.IInterconnectDiagnostics|null); + + /** + * Creates a new DiagnoseInterconnectResponse instance using the specified properties. + * @param [properties] Properties to set + * @returns DiagnoseInterconnectResponse instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse): google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse; + + /** + * Encodes the specified DiagnoseInterconnectResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse.verify|verify} messages. + * @param message DiagnoseInterconnectResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified DiagnoseInterconnectResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse.verify|verify} messages. + * @param message DiagnoseInterconnectResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a DiagnoseInterconnectResponse message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns DiagnoseInterconnectResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse; + + /** + * Decodes a DiagnoseInterconnectResponse message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns DiagnoseInterconnectResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse; + + /** + * Verifies a DiagnoseInterconnectResponse message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a DiagnoseInterconnectResponse message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns DiagnoseInterconnectResponse + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse; + + /** + * Creates a plain object from a DiagnoseInterconnectResponse message. Also converts values to other types if specified. + * @param message DiagnoseInterconnectResponse + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this DiagnoseInterconnectResponse to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for DiagnoseInterconnectResponse + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a DiagnoseRouterRequest. */ + interface IDiagnoseRouterRequest { + + /** DiagnoseRouterRequest name */ + name?: (string|null); + } + + /** Represents a DiagnoseRouterRequest. */ + class DiagnoseRouterRequest implements IDiagnoseRouterRequest { + + /** + * Constructs a new DiagnoseRouterRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IDiagnoseRouterRequest); + + /** DiagnoseRouterRequest name. */ + public name: string; + + /** + * Creates a new DiagnoseRouterRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns DiagnoseRouterRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IDiagnoseRouterRequest): google.cloud.edgenetwork.v1.DiagnoseRouterRequest; + + /** + * Encodes the specified DiagnoseRouterRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseRouterRequest.verify|verify} messages. + * @param message DiagnoseRouterRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IDiagnoseRouterRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified DiagnoseRouterRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseRouterRequest.verify|verify} messages. + * @param message DiagnoseRouterRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IDiagnoseRouterRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a DiagnoseRouterRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns DiagnoseRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.DiagnoseRouterRequest; + + /** + * Decodes a DiagnoseRouterRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns DiagnoseRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.DiagnoseRouterRequest; + + /** + * Verifies a DiagnoseRouterRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a DiagnoseRouterRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns DiagnoseRouterRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.DiagnoseRouterRequest; + + /** + * Creates a plain object from a DiagnoseRouterRequest message. Also converts values to other types if specified. + * @param message DiagnoseRouterRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.DiagnoseRouterRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this DiagnoseRouterRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for DiagnoseRouterRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a DiagnoseRouterResponse. */ + interface IDiagnoseRouterResponse { + + /** DiagnoseRouterResponse updateTime */ + updateTime?: (google.protobuf.ITimestamp|null); + + /** DiagnoseRouterResponse result */ + result?: (google.cloud.edgenetwork.v1.IRouterStatus|null); + } + + /** Represents a DiagnoseRouterResponse. */ + class DiagnoseRouterResponse implements IDiagnoseRouterResponse { + + /** + * Constructs a new DiagnoseRouterResponse. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IDiagnoseRouterResponse); + + /** DiagnoseRouterResponse updateTime. */ + public updateTime?: (google.protobuf.ITimestamp|null); + + /** DiagnoseRouterResponse result. */ + public result?: (google.cloud.edgenetwork.v1.IRouterStatus|null); + + /** + * Creates a new DiagnoseRouterResponse instance using the specified properties. + * @param [properties] Properties to set + * @returns DiagnoseRouterResponse instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IDiagnoseRouterResponse): google.cloud.edgenetwork.v1.DiagnoseRouterResponse; + + /** + * Encodes the specified DiagnoseRouterResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseRouterResponse.verify|verify} messages. + * @param message DiagnoseRouterResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified DiagnoseRouterResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseRouterResponse.verify|verify} messages. + * @param message DiagnoseRouterResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a DiagnoseRouterResponse message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns DiagnoseRouterResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.DiagnoseRouterResponse; + + /** + * Decodes a DiagnoseRouterResponse message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns DiagnoseRouterResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.DiagnoseRouterResponse; + + /** + * Verifies a DiagnoseRouterResponse message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a DiagnoseRouterResponse message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns DiagnoseRouterResponse + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.DiagnoseRouterResponse; + + /** + * Creates a plain object from a DiagnoseRouterResponse message. Also converts values to other types if specified. + * @param message DiagnoseRouterResponse + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.DiagnoseRouterResponse, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this DiagnoseRouterResponse to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for DiagnoseRouterResponse + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of an InitializeZoneRequest. */ + interface IInitializeZoneRequest { + + /** InitializeZoneRequest name */ + name?: (string|null); + } + + /** Represents an InitializeZoneRequest. */ + class InitializeZoneRequest implements IInitializeZoneRequest { + + /** + * Constructs a new InitializeZoneRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IInitializeZoneRequest); + + /** InitializeZoneRequest name. */ + public name: string; + + /** + * Creates a new InitializeZoneRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns InitializeZoneRequest instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IInitializeZoneRequest): google.cloud.edgenetwork.v1.InitializeZoneRequest; + + /** + * Encodes the specified InitializeZoneRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.InitializeZoneRequest.verify|verify} messages. + * @param message InitializeZoneRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IInitializeZoneRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified InitializeZoneRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.InitializeZoneRequest.verify|verify} messages. + * @param message InitializeZoneRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IInitializeZoneRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an InitializeZoneRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns InitializeZoneRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.InitializeZoneRequest; + + /** + * Decodes an InitializeZoneRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns InitializeZoneRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.InitializeZoneRequest; + + /** + * Verifies an InitializeZoneRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an InitializeZoneRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns InitializeZoneRequest + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.InitializeZoneRequest; + + /** + * Creates a plain object from an InitializeZoneRequest message. Also converts values to other types if specified. + * @param message InitializeZoneRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.InitializeZoneRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this InitializeZoneRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for InitializeZoneRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of an InitializeZoneResponse. */ + interface IInitializeZoneResponse { + } + + /** Represents an InitializeZoneResponse. */ + class InitializeZoneResponse implements IInitializeZoneResponse { + + /** + * Constructs a new InitializeZoneResponse. + * @param [properties] Properties to set + */ + constructor(properties?: google.cloud.edgenetwork.v1.IInitializeZoneResponse); + + /** + * Creates a new InitializeZoneResponse instance using the specified properties. + * @param [properties] Properties to set + * @returns InitializeZoneResponse instance + */ + public static create(properties?: google.cloud.edgenetwork.v1.IInitializeZoneResponse): google.cloud.edgenetwork.v1.InitializeZoneResponse; + + /** + * Encodes the specified InitializeZoneResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.InitializeZoneResponse.verify|verify} messages. + * @param message InitializeZoneResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.cloud.edgenetwork.v1.IInitializeZoneResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified InitializeZoneResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.InitializeZoneResponse.verify|verify} messages. + * @param message InitializeZoneResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.cloud.edgenetwork.v1.IInitializeZoneResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an InitializeZoneResponse message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns InitializeZoneResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.cloud.edgenetwork.v1.InitializeZoneResponse; + + /** + * Decodes an InitializeZoneResponse message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns InitializeZoneResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.cloud.edgenetwork.v1.InitializeZoneResponse; + + /** + * Verifies an InitializeZoneResponse message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an InitializeZoneResponse message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns InitializeZoneResponse + */ + public static fromObject(object: { [k: string]: any }): google.cloud.edgenetwork.v1.InitializeZoneResponse; + + /** + * Creates a plain object from an InitializeZoneResponse message. Also converts values to other types if specified. + * @param message InitializeZoneResponse + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.cloud.edgenetwork.v1.InitializeZoneResponse, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this InitializeZoneResponse to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for InitializeZoneResponse + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + } + } + } + + /** Namespace api. */ + namespace api { + + /** FieldBehavior enum. */ + enum FieldBehavior { + FIELD_BEHAVIOR_UNSPECIFIED = 0, + OPTIONAL = 1, + REQUIRED = 2, + OUTPUT_ONLY = 3, + INPUT_ONLY = 4, + IMMUTABLE = 5, + UNORDERED_LIST = 6, + NON_EMPTY_DEFAULT = 7 + } + + /** Properties of a ResourceDescriptor. */ + interface IResourceDescriptor { + + /** ResourceDescriptor type */ + type?: (string|null); + + /** ResourceDescriptor pattern */ + pattern?: (string[]|null); + + /** ResourceDescriptor nameField */ + nameField?: (string|null); + + /** ResourceDescriptor history */ + history?: (google.api.ResourceDescriptor.History|keyof typeof google.api.ResourceDescriptor.History|null); + + /** ResourceDescriptor plural */ + plural?: (string|null); + + /** ResourceDescriptor singular */ + singular?: (string|null); + + /** ResourceDescriptor style */ + style?: (google.api.ResourceDescriptor.Style[]|null); + } + + /** Represents a ResourceDescriptor. */ + class ResourceDescriptor implements IResourceDescriptor { + + /** + * Constructs a new ResourceDescriptor. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.IResourceDescriptor); + + /** ResourceDescriptor type. */ + public type: string; + + /** ResourceDescriptor pattern. */ + public pattern: string[]; + + /** ResourceDescriptor nameField. */ + public nameField: string; + + /** ResourceDescriptor history. */ + public history: (google.api.ResourceDescriptor.History|keyof typeof google.api.ResourceDescriptor.History); + + /** ResourceDescriptor plural. */ + public plural: string; + + /** ResourceDescriptor singular. */ + public singular: string; + + /** ResourceDescriptor style. */ + public style: google.api.ResourceDescriptor.Style[]; + + /** + * Creates a new ResourceDescriptor instance using the specified properties. + * @param [properties] Properties to set + * @returns ResourceDescriptor instance + */ + public static create(properties?: google.api.IResourceDescriptor): google.api.ResourceDescriptor; + + /** + * Encodes the specified ResourceDescriptor message. Does not implicitly {@link google.api.ResourceDescriptor.verify|verify} messages. + * @param message ResourceDescriptor message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.IResourceDescriptor, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ResourceDescriptor message, length delimited. Does not implicitly {@link google.api.ResourceDescriptor.verify|verify} messages. + * @param message ResourceDescriptor message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.IResourceDescriptor, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ResourceDescriptor message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ResourceDescriptor + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.ResourceDescriptor; + + /** + * Decodes a ResourceDescriptor message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ResourceDescriptor + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.ResourceDescriptor; + + /** + * Verifies a ResourceDescriptor message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ResourceDescriptor message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ResourceDescriptor + */ + public static fromObject(object: { [k: string]: any }): google.api.ResourceDescriptor; + + /** + * Creates a plain object from a ResourceDescriptor message. Also converts values to other types if specified. + * @param message ResourceDescriptor + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.ResourceDescriptor, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ResourceDescriptor to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ResourceDescriptor + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace ResourceDescriptor { + + /** History enum. */ + enum History { + HISTORY_UNSPECIFIED = 0, + ORIGINALLY_SINGLE_PATTERN = 1, + FUTURE_MULTI_PATTERN = 2 + } + + /** Style enum. */ + enum Style { + STYLE_UNSPECIFIED = 0, + DECLARATIVE_FRIENDLY = 1 + } + } + + /** Properties of a ResourceReference. */ + interface IResourceReference { + + /** ResourceReference type */ + type?: (string|null); + + /** ResourceReference childType */ + childType?: (string|null); + } + + /** Represents a ResourceReference. */ + class ResourceReference implements IResourceReference { + + /** + * Constructs a new ResourceReference. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.IResourceReference); + + /** ResourceReference type. */ + public type: string; + + /** ResourceReference childType. */ + public childType: string; + + /** + * Creates a new ResourceReference instance using the specified properties. + * @param [properties] Properties to set + * @returns ResourceReference instance + */ + public static create(properties?: google.api.IResourceReference): google.api.ResourceReference; + + /** + * Encodes the specified ResourceReference message. Does not implicitly {@link google.api.ResourceReference.verify|verify} messages. + * @param message ResourceReference message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.IResourceReference, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ResourceReference message, length delimited. Does not implicitly {@link google.api.ResourceReference.verify|verify} messages. + * @param message ResourceReference message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.IResourceReference, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ResourceReference message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ResourceReference + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.ResourceReference; + + /** + * Decodes a ResourceReference message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ResourceReference + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.ResourceReference; + + /** + * Verifies a ResourceReference message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ResourceReference message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ResourceReference + */ + public static fromObject(object: { [k: string]: any }): google.api.ResourceReference; + + /** + * Creates a plain object from a ResourceReference message. Also converts values to other types if specified. + * @param message ResourceReference + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.ResourceReference, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ResourceReference to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ResourceReference + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a Http. */ + interface IHttp { + + /** Http rules */ + rules?: (google.api.IHttpRule[]|null); + + /** Http fullyDecodeReservedExpansion */ + fullyDecodeReservedExpansion?: (boolean|null); + } + + /** Represents a Http. */ + class Http implements IHttp { + + /** + * Constructs a new Http. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.IHttp); + + /** Http rules. */ + public rules: google.api.IHttpRule[]; + + /** Http fullyDecodeReservedExpansion. */ + public fullyDecodeReservedExpansion: boolean; + + /** + * Creates a new Http instance using the specified properties. + * @param [properties] Properties to set + * @returns Http instance + */ + public static create(properties?: google.api.IHttp): google.api.Http; + + /** + * Encodes the specified Http message. Does not implicitly {@link google.api.Http.verify|verify} messages. + * @param message Http message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.IHttp, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Http message, length delimited. Does not implicitly {@link google.api.Http.verify|verify} messages. + * @param message Http message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.IHttp, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a Http message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Http + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.Http; + + /** + * Decodes a Http message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Http + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.Http; + + /** + * Verifies a Http message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a Http message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Http + */ + public static fromObject(object: { [k: string]: any }): google.api.Http; + + /** + * Creates a plain object from a Http message. Also converts values to other types if specified. + * @param message Http + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.Http, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Http to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Http + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a HttpRule. */ + interface IHttpRule { + + /** HttpRule selector */ + selector?: (string|null); + + /** HttpRule get */ + get?: (string|null); + + /** HttpRule put */ + put?: (string|null); + + /** HttpRule post */ + post?: (string|null); + + /** HttpRule delete */ + "delete"?: (string|null); + + /** HttpRule patch */ + patch?: (string|null); + + /** HttpRule custom */ + custom?: (google.api.ICustomHttpPattern|null); + + /** HttpRule body */ + body?: (string|null); + + /** HttpRule responseBody */ + responseBody?: (string|null); + + /** HttpRule additionalBindings */ + additionalBindings?: (google.api.IHttpRule[]|null); + } + + /** Represents a HttpRule. */ + class HttpRule implements IHttpRule { + + /** + * Constructs a new HttpRule. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.IHttpRule); + + /** HttpRule selector. */ + public selector: string; + + /** HttpRule get. */ + public get?: (string|null); + + /** HttpRule put. */ + public put?: (string|null); + + /** HttpRule post. */ + public post?: (string|null); + + /** HttpRule delete. */ + public delete?: (string|null); + + /** HttpRule patch. */ + public patch?: (string|null); + + /** HttpRule custom. */ + public custom?: (google.api.ICustomHttpPattern|null); + + /** HttpRule body. */ + public body: string; + + /** HttpRule responseBody. */ + public responseBody: string; + + /** HttpRule additionalBindings. */ + public additionalBindings: google.api.IHttpRule[]; + + /** HttpRule pattern. */ + public pattern?: ("get"|"put"|"post"|"delete"|"patch"|"custom"); + + /** + * Creates a new HttpRule instance using the specified properties. + * @param [properties] Properties to set + * @returns HttpRule instance + */ + public static create(properties?: google.api.IHttpRule): google.api.HttpRule; + + /** + * Encodes the specified HttpRule message. Does not implicitly {@link google.api.HttpRule.verify|verify} messages. + * @param message HttpRule message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.IHttpRule, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified HttpRule message, length delimited. Does not implicitly {@link google.api.HttpRule.verify|verify} messages. + * @param message HttpRule message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.IHttpRule, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a HttpRule message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns HttpRule + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.HttpRule; + + /** + * Decodes a HttpRule message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns HttpRule + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.HttpRule; + + /** + * Verifies a HttpRule message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a HttpRule message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns HttpRule + */ + public static fromObject(object: { [k: string]: any }): google.api.HttpRule; + + /** + * Creates a plain object from a HttpRule message. Also converts values to other types if specified. + * @param message HttpRule + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.HttpRule, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this HttpRule to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for HttpRule + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a CustomHttpPattern. */ + interface ICustomHttpPattern { + + /** CustomHttpPattern kind */ + kind?: (string|null); + + /** CustomHttpPattern path */ + path?: (string|null); + } + + /** Represents a CustomHttpPattern. */ + class CustomHttpPattern implements ICustomHttpPattern { + + /** + * Constructs a new CustomHttpPattern. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.ICustomHttpPattern); + + /** CustomHttpPattern kind. */ + public kind: string; + + /** CustomHttpPattern path. */ + public path: string; + + /** + * Creates a new CustomHttpPattern instance using the specified properties. + * @param [properties] Properties to set + * @returns CustomHttpPattern instance + */ + public static create(properties?: google.api.ICustomHttpPattern): google.api.CustomHttpPattern; + + /** + * Encodes the specified CustomHttpPattern message. Does not implicitly {@link google.api.CustomHttpPattern.verify|verify} messages. + * @param message CustomHttpPattern message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.ICustomHttpPattern, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified CustomHttpPattern message, length delimited. Does not implicitly {@link google.api.CustomHttpPattern.verify|verify} messages. + * @param message CustomHttpPattern message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.ICustomHttpPattern, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a CustomHttpPattern message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns CustomHttpPattern + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.CustomHttpPattern; + + /** + * Decodes a CustomHttpPattern message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns CustomHttpPattern + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.CustomHttpPattern; + + /** + * Verifies a CustomHttpPattern message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a CustomHttpPattern message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns CustomHttpPattern + */ + public static fromObject(object: { [k: string]: any }): google.api.CustomHttpPattern; + + /** + * Creates a plain object from a CustomHttpPattern message. Also converts values to other types if specified. + * @param message CustomHttpPattern + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.CustomHttpPattern, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this CustomHttpPattern to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for CustomHttpPattern + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a CommonLanguageSettings. */ + interface ICommonLanguageSettings { + + /** CommonLanguageSettings referenceDocsUri */ + referenceDocsUri?: (string|null); + + /** CommonLanguageSettings destinations */ + destinations?: (google.api.ClientLibraryDestination[]|null); + } + + /** Represents a CommonLanguageSettings. */ + class CommonLanguageSettings implements ICommonLanguageSettings { + + /** + * Constructs a new CommonLanguageSettings. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.ICommonLanguageSettings); + + /** CommonLanguageSettings referenceDocsUri. */ + public referenceDocsUri: string; + + /** CommonLanguageSettings destinations. */ + public destinations: google.api.ClientLibraryDestination[]; + + /** + * Creates a new CommonLanguageSettings instance using the specified properties. + * @param [properties] Properties to set + * @returns CommonLanguageSettings instance + */ + public static create(properties?: google.api.ICommonLanguageSettings): google.api.CommonLanguageSettings; + + /** + * Encodes the specified CommonLanguageSettings message. Does not implicitly {@link google.api.CommonLanguageSettings.verify|verify} messages. + * @param message CommonLanguageSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.ICommonLanguageSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified CommonLanguageSettings message, length delimited. Does not implicitly {@link google.api.CommonLanguageSettings.verify|verify} messages. + * @param message CommonLanguageSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.ICommonLanguageSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a CommonLanguageSettings message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns CommonLanguageSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.CommonLanguageSettings; + + /** + * Decodes a CommonLanguageSettings message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns CommonLanguageSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.CommonLanguageSettings; + + /** + * Verifies a CommonLanguageSettings message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a CommonLanguageSettings message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns CommonLanguageSettings + */ + public static fromObject(object: { [k: string]: any }): google.api.CommonLanguageSettings; + + /** + * Creates a plain object from a CommonLanguageSettings message. Also converts values to other types if specified. + * @param message CommonLanguageSettings + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.CommonLanguageSettings, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this CommonLanguageSettings to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for CommonLanguageSettings + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ClientLibrarySettings. */ + interface IClientLibrarySettings { + + /** ClientLibrarySettings version */ + version?: (string|null); + + /** ClientLibrarySettings launchStage */ + launchStage?: (google.api.LaunchStage|keyof typeof google.api.LaunchStage|null); + + /** ClientLibrarySettings restNumericEnums */ + restNumericEnums?: (boolean|null); + + /** ClientLibrarySettings javaSettings */ + javaSettings?: (google.api.IJavaSettings|null); + + /** ClientLibrarySettings cppSettings */ + cppSettings?: (google.api.ICppSettings|null); + + /** ClientLibrarySettings phpSettings */ + phpSettings?: (google.api.IPhpSettings|null); + + /** ClientLibrarySettings pythonSettings */ + pythonSettings?: (google.api.IPythonSettings|null); + + /** ClientLibrarySettings nodeSettings */ + nodeSettings?: (google.api.INodeSettings|null); + + /** ClientLibrarySettings dotnetSettings */ + dotnetSettings?: (google.api.IDotnetSettings|null); + + /** ClientLibrarySettings rubySettings */ + rubySettings?: (google.api.IRubySettings|null); + + /** ClientLibrarySettings goSettings */ + goSettings?: (google.api.IGoSettings|null); + } + + /** Represents a ClientLibrarySettings. */ + class ClientLibrarySettings implements IClientLibrarySettings { + + /** + * Constructs a new ClientLibrarySettings. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.IClientLibrarySettings); + + /** ClientLibrarySettings version. */ + public version: string; + + /** ClientLibrarySettings launchStage. */ + public launchStage: (google.api.LaunchStage|keyof typeof google.api.LaunchStage); + + /** ClientLibrarySettings restNumericEnums. */ + public restNumericEnums: boolean; + + /** ClientLibrarySettings javaSettings. */ + public javaSettings?: (google.api.IJavaSettings|null); + + /** ClientLibrarySettings cppSettings. */ + public cppSettings?: (google.api.ICppSettings|null); + + /** ClientLibrarySettings phpSettings. */ + public phpSettings?: (google.api.IPhpSettings|null); + + /** ClientLibrarySettings pythonSettings. */ + public pythonSettings?: (google.api.IPythonSettings|null); + + /** ClientLibrarySettings nodeSettings. */ + public nodeSettings?: (google.api.INodeSettings|null); + + /** ClientLibrarySettings dotnetSettings. */ + public dotnetSettings?: (google.api.IDotnetSettings|null); + + /** ClientLibrarySettings rubySettings. */ + public rubySettings?: (google.api.IRubySettings|null); + + /** ClientLibrarySettings goSettings. */ + public goSettings?: (google.api.IGoSettings|null); + + /** + * Creates a new ClientLibrarySettings instance using the specified properties. + * @param [properties] Properties to set + * @returns ClientLibrarySettings instance + */ + public static create(properties?: google.api.IClientLibrarySettings): google.api.ClientLibrarySettings; + + /** + * Encodes the specified ClientLibrarySettings message. Does not implicitly {@link google.api.ClientLibrarySettings.verify|verify} messages. + * @param message ClientLibrarySettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.IClientLibrarySettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ClientLibrarySettings message, length delimited. Does not implicitly {@link google.api.ClientLibrarySettings.verify|verify} messages. + * @param message ClientLibrarySettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.IClientLibrarySettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ClientLibrarySettings message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ClientLibrarySettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.ClientLibrarySettings; + + /** + * Decodes a ClientLibrarySettings message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ClientLibrarySettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.ClientLibrarySettings; + + /** + * Verifies a ClientLibrarySettings message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ClientLibrarySettings message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ClientLibrarySettings + */ + public static fromObject(object: { [k: string]: any }): google.api.ClientLibrarySettings; + + /** + * Creates a plain object from a ClientLibrarySettings message. Also converts values to other types if specified. + * @param message ClientLibrarySettings + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.ClientLibrarySettings, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ClientLibrarySettings to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ClientLibrarySettings + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a Publishing. */ + interface IPublishing { + + /** Publishing methodSettings */ + methodSettings?: (google.api.IMethodSettings[]|null); + + /** Publishing newIssueUri */ + newIssueUri?: (string|null); + + /** Publishing documentationUri */ + documentationUri?: (string|null); + + /** Publishing apiShortName */ + apiShortName?: (string|null); + + /** Publishing githubLabel */ + githubLabel?: (string|null); + + /** Publishing codeownerGithubTeams */ + codeownerGithubTeams?: (string[]|null); + + /** Publishing docTagPrefix */ + docTagPrefix?: (string|null); + + /** Publishing organization */ + organization?: (google.api.ClientLibraryOrganization|keyof typeof google.api.ClientLibraryOrganization|null); + + /** Publishing librarySettings */ + librarySettings?: (google.api.IClientLibrarySettings[]|null); + } + + /** Represents a Publishing. */ + class Publishing implements IPublishing { + + /** + * Constructs a new Publishing. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.IPublishing); + + /** Publishing methodSettings. */ + public methodSettings: google.api.IMethodSettings[]; + + /** Publishing newIssueUri. */ + public newIssueUri: string; + + /** Publishing documentationUri. */ + public documentationUri: string; + + /** Publishing apiShortName. */ + public apiShortName: string; + + /** Publishing githubLabel. */ + public githubLabel: string; + + /** Publishing codeownerGithubTeams. */ + public codeownerGithubTeams: string[]; + + /** Publishing docTagPrefix. */ + public docTagPrefix: string; + + /** Publishing organization. */ + public organization: (google.api.ClientLibraryOrganization|keyof typeof google.api.ClientLibraryOrganization); + + /** Publishing librarySettings. */ + public librarySettings: google.api.IClientLibrarySettings[]; + + /** + * Creates a new Publishing instance using the specified properties. + * @param [properties] Properties to set + * @returns Publishing instance + */ + public static create(properties?: google.api.IPublishing): google.api.Publishing; + + /** + * Encodes the specified Publishing message. Does not implicitly {@link google.api.Publishing.verify|verify} messages. + * @param message Publishing message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.IPublishing, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Publishing message, length delimited. Does not implicitly {@link google.api.Publishing.verify|verify} messages. + * @param message Publishing message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.IPublishing, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a Publishing message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Publishing + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.Publishing; + + /** + * Decodes a Publishing message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Publishing + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.Publishing; + + /** + * Verifies a Publishing message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a Publishing message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Publishing + */ + public static fromObject(object: { [k: string]: any }): google.api.Publishing; + + /** + * Creates a plain object from a Publishing message. Also converts values to other types if specified. + * @param message Publishing + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.Publishing, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Publishing to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Publishing + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a JavaSettings. */ + interface IJavaSettings { + + /** JavaSettings libraryPackage */ + libraryPackage?: (string|null); + + /** JavaSettings serviceClassNames */ + serviceClassNames?: ({ [k: string]: string }|null); + + /** JavaSettings common */ + common?: (google.api.ICommonLanguageSettings|null); + } + + /** Represents a JavaSettings. */ + class JavaSettings implements IJavaSettings { + + /** + * Constructs a new JavaSettings. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.IJavaSettings); + + /** JavaSettings libraryPackage. */ + public libraryPackage: string; + + /** JavaSettings serviceClassNames. */ + public serviceClassNames: { [k: string]: string }; + + /** JavaSettings common. */ + public common?: (google.api.ICommonLanguageSettings|null); + + /** + * Creates a new JavaSettings instance using the specified properties. + * @param [properties] Properties to set + * @returns JavaSettings instance + */ + public static create(properties?: google.api.IJavaSettings): google.api.JavaSettings; + + /** + * Encodes the specified JavaSettings message. Does not implicitly {@link google.api.JavaSettings.verify|verify} messages. + * @param message JavaSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.IJavaSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified JavaSettings message, length delimited. Does not implicitly {@link google.api.JavaSettings.verify|verify} messages. + * @param message JavaSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.IJavaSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a JavaSettings message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns JavaSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.JavaSettings; + + /** + * Decodes a JavaSettings message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns JavaSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.JavaSettings; + + /** + * Verifies a JavaSettings message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a JavaSettings message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns JavaSettings + */ + public static fromObject(object: { [k: string]: any }): google.api.JavaSettings; + + /** + * Creates a plain object from a JavaSettings message. Also converts values to other types if specified. + * @param message JavaSettings + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.JavaSettings, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this JavaSettings to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for JavaSettings + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a CppSettings. */ + interface ICppSettings { + + /** CppSettings common */ + common?: (google.api.ICommonLanguageSettings|null); + } + + /** Represents a CppSettings. */ + class CppSettings implements ICppSettings { + + /** + * Constructs a new CppSettings. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.ICppSettings); + + /** CppSettings common. */ + public common?: (google.api.ICommonLanguageSettings|null); + + /** + * Creates a new CppSettings instance using the specified properties. + * @param [properties] Properties to set + * @returns CppSettings instance + */ + public static create(properties?: google.api.ICppSettings): google.api.CppSettings; + + /** + * Encodes the specified CppSettings message. Does not implicitly {@link google.api.CppSettings.verify|verify} messages. + * @param message CppSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.ICppSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified CppSettings message, length delimited. Does not implicitly {@link google.api.CppSettings.verify|verify} messages. + * @param message CppSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.ICppSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a CppSettings message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns CppSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.CppSettings; + + /** + * Decodes a CppSettings message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns CppSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.CppSettings; + + /** + * Verifies a CppSettings message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a CppSettings message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns CppSettings + */ + public static fromObject(object: { [k: string]: any }): google.api.CppSettings; + + /** + * Creates a plain object from a CppSettings message. Also converts values to other types if specified. + * @param message CppSettings + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.CppSettings, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this CppSettings to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for CppSettings + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a PhpSettings. */ + interface IPhpSettings { + + /** PhpSettings common */ + common?: (google.api.ICommonLanguageSettings|null); + } + + /** Represents a PhpSettings. */ + class PhpSettings implements IPhpSettings { + + /** + * Constructs a new PhpSettings. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.IPhpSettings); + + /** PhpSettings common. */ + public common?: (google.api.ICommonLanguageSettings|null); + + /** + * Creates a new PhpSettings instance using the specified properties. + * @param [properties] Properties to set + * @returns PhpSettings instance + */ + public static create(properties?: google.api.IPhpSettings): google.api.PhpSettings; + + /** + * Encodes the specified PhpSettings message. Does not implicitly {@link google.api.PhpSettings.verify|verify} messages. + * @param message PhpSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.IPhpSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified PhpSettings message, length delimited. Does not implicitly {@link google.api.PhpSettings.verify|verify} messages. + * @param message PhpSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.IPhpSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a PhpSettings message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns PhpSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.PhpSettings; + + /** + * Decodes a PhpSettings message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns PhpSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.PhpSettings; + + /** + * Verifies a PhpSettings message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a PhpSettings message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns PhpSettings + */ + public static fromObject(object: { [k: string]: any }): google.api.PhpSettings; + + /** + * Creates a plain object from a PhpSettings message. Also converts values to other types if specified. + * @param message PhpSettings + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.PhpSettings, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this PhpSettings to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for PhpSettings + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a PythonSettings. */ + interface IPythonSettings { + + /** PythonSettings common */ + common?: (google.api.ICommonLanguageSettings|null); + } + + /** Represents a PythonSettings. */ + class PythonSettings implements IPythonSettings { + + /** + * Constructs a new PythonSettings. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.IPythonSettings); + + /** PythonSettings common. */ + public common?: (google.api.ICommonLanguageSettings|null); + + /** + * Creates a new PythonSettings instance using the specified properties. + * @param [properties] Properties to set + * @returns PythonSettings instance + */ + public static create(properties?: google.api.IPythonSettings): google.api.PythonSettings; + + /** + * Encodes the specified PythonSettings message. Does not implicitly {@link google.api.PythonSettings.verify|verify} messages. + * @param message PythonSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.IPythonSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified PythonSettings message, length delimited. Does not implicitly {@link google.api.PythonSettings.verify|verify} messages. + * @param message PythonSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.IPythonSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a PythonSettings message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns PythonSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.PythonSettings; + + /** + * Decodes a PythonSettings message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns PythonSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.PythonSettings; + + /** + * Verifies a PythonSettings message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a PythonSettings message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns PythonSettings + */ + public static fromObject(object: { [k: string]: any }): google.api.PythonSettings; + + /** + * Creates a plain object from a PythonSettings message. Also converts values to other types if specified. + * @param message PythonSettings + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.PythonSettings, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this PythonSettings to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for PythonSettings + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a NodeSettings. */ + interface INodeSettings { + + /** NodeSettings common */ + common?: (google.api.ICommonLanguageSettings|null); + } + + /** Represents a NodeSettings. */ + class NodeSettings implements INodeSettings { + + /** + * Constructs a new NodeSettings. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.INodeSettings); + + /** NodeSettings common. */ + public common?: (google.api.ICommonLanguageSettings|null); + + /** + * Creates a new NodeSettings instance using the specified properties. + * @param [properties] Properties to set + * @returns NodeSettings instance + */ + public static create(properties?: google.api.INodeSettings): google.api.NodeSettings; + + /** + * Encodes the specified NodeSettings message. Does not implicitly {@link google.api.NodeSettings.verify|verify} messages. + * @param message NodeSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.INodeSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified NodeSettings message, length delimited. Does not implicitly {@link google.api.NodeSettings.verify|verify} messages. + * @param message NodeSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.INodeSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a NodeSettings message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns NodeSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.NodeSettings; + + /** + * Decodes a NodeSettings message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns NodeSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.NodeSettings; + + /** + * Verifies a NodeSettings message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a NodeSettings message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns NodeSettings + */ + public static fromObject(object: { [k: string]: any }): google.api.NodeSettings; + + /** + * Creates a plain object from a NodeSettings message. Also converts values to other types if specified. + * @param message NodeSettings + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.NodeSettings, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this NodeSettings to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for NodeSettings + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a DotnetSettings. */ + interface IDotnetSettings { + + /** DotnetSettings common */ + common?: (google.api.ICommonLanguageSettings|null); + } + + /** Represents a DotnetSettings. */ + class DotnetSettings implements IDotnetSettings { + + /** + * Constructs a new DotnetSettings. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.IDotnetSettings); + + /** DotnetSettings common. */ + public common?: (google.api.ICommonLanguageSettings|null); + + /** + * Creates a new DotnetSettings instance using the specified properties. + * @param [properties] Properties to set + * @returns DotnetSettings instance + */ + public static create(properties?: google.api.IDotnetSettings): google.api.DotnetSettings; + + /** + * Encodes the specified DotnetSettings message. Does not implicitly {@link google.api.DotnetSettings.verify|verify} messages. + * @param message DotnetSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.IDotnetSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified DotnetSettings message, length delimited. Does not implicitly {@link google.api.DotnetSettings.verify|verify} messages. + * @param message DotnetSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.IDotnetSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a DotnetSettings message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns DotnetSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.DotnetSettings; + + /** + * Decodes a DotnetSettings message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns DotnetSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.DotnetSettings; + + /** + * Verifies a DotnetSettings message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a DotnetSettings message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns DotnetSettings + */ + public static fromObject(object: { [k: string]: any }): google.api.DotnetSettings; + + /** + * Creates a plain object from a DotnetSettings message. Also converts values to other types if specified. + * @param message DotnetSettings + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.DotnetSettings, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this DotnetSettings to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for DotnetSettings + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a RubySettings. */ + interface IRubySettings { + + /** RubySettings common */ + common?: (google.api.ICommonLanguageSettings|null); + } + + /** Represents a RubySettings. */ + class RubySettings implements IRubySettings { + + /** + * Constructs a new RubySettings. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.IRubySettings); + + /** RubySettings common. */ + public common?: (google.api.ICommonLanguageSettings|null); + + /** + * Creates a new RubySettings instance using the specified properties. + * @param [properties] Properties to set + * @returns RubySettings instance + */ + public static create(properties?: google.api.IRubySettings): google.api.RubySettings; + + /** + * Encodes the specified RubySettings message. Does not implicitly {@link google.api.RubySettings.verify|verify} messages. + * @param message RubySettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.IRubySettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified RubySettings message, length delimited. Does not implicitly {@link google.api.RubySettings.verify|verify} messages. + * @param message RubySettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.IRubySettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a RubySettings message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns RubySettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.RubySettings; + + /** + * Decodes a RubySettings message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns RubySettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.RubySettings; + + /** + * Verifies a RubySettings message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a RubySettings message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns RubySettings + */ + public static fromObject(object: { [k: string]: any }): google.api.RubySettings; + + /** + * Creates a plain object from a RubySettings message. Also converts values to other types if specified. + * @param message RubySettings + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.RubySettings, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this RubySettings to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for RubySettings + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a GoSettings. */ + interface IGoSettings { + + /** GoSettings common */ + common?: (google.api.ICommonLanguageSettings|null); + } + + /** Represents a GoSettings. */ + class GoSettings implements IGoSettings { + + /** + * Constructs a new GoSettings. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.IGoSettings); + + /** GoSettings common. */ + public common?: (google.api.ICommonLanguageSettings|null); + + /** + * Creates a new GoSettings instance using the specified properties. + * @param [properties] Properties to set + * @returns GoSettings instance + */ + public static create(properties?: google.api.IGoSettings): google.api.GoSettings; + + /** + * Encodes the specified GoSettings message. Does not implicitly {@link google.api.GoSettings.verify|verify} messages. + * @param message GoSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.IGoSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified GoSettings message, length delimited. Does not implicitly {@link google.api.GoSettings.verify|verify} messages. + * @param message GoSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.IGoSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a GoSettings message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns GoSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.GoSettings; + + /** + * Decodes a GoSettings message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns GoSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.GoSettings; + + /** + * Verifies a GoSettings message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a GoSettings message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns GoSettings + */ + public static fromObject(object: { [k: string]: any }): google.api.GoSettings; + + /** + * Creates a plain object from a GoSettings message. Also converts values to other types if specified. + * @param message GoSettings + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.GoSettings, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this GoSettings to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for GoSettings + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a MethodSettings. */ + interface IMethodSettings { + + /** MethodSettings selector */ + selector?: (string|null); + + /** MethodSettings longRunning */ + longRunning?: (google.api.MethodSettings.ILongRunning|null); + } + + /** Represents a MethodSettings. */ + class MethodSettings implements IMethodSettings { + + /** + * Constructs a new MethodSettings. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.IMethodSettings); + + /** MethodSettings selector. */ + public selector: string; + + /** MethodSettings longRunning. */ + public longRunning?: (google.api.MethodSettings.ILongRunning|null); + + /** + * Creates a new MethodSettings instance using the specified properties. + * @param [properties] Properties to set + * @returns MethodSettings instance + */ + public static create(properties?: google.api.IMethodSettings): google.api.MethodSettings; + + /** + * Encodes the specified MethodSettings message. Does not implicitly {@link google.api.MethodSettings.verify|verify} messages. + * @param message MethodSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.IMethodSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified MethodSettings message, length delimited. Does not implicitly {@link google.api.MethodSettings.verify|verify} messages. + * @param message MethodSettings message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.IMethodSettings, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a MethodSettings message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns MethodSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.MethodSettings; + + /** + * Decodes a MethodSettings message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns MethodSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.MethodSettings; + + /** + * Verifies a MethodSettings message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a MethodSettings message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns MethodSettings + */ + public static fromObject(object: { [k: string]: any }): google.api.MethodSettings; + + /** + * Creates a plain object from a MethodSettings message. Also converts values to other types if specified. + * @param message MethodSettings + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.MethodSettings, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this MethodSettings to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for MethodSettings + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace MethodSettings { + + /** Properties of a LongRunning. */ + interface ILongRunning { + + /** LongRunning initialPollDelay */ + initialPollDelay?: (google.protobuf.IDuration|null); + + /** LongRunning pollDelayMultiplier */ + pollDelayMultiplier?: (number|null); + + /** LongRunning maxPollDelay */ + maxPollDelay?: (google.protobuf.IDuration|null); + + /** LongRunning totalPollTimeout */ + totalPollTimeout?: (google.protobuf.IDuration|null); + } + + /** Represents a LongRunning. */ + class LongRunning implements ILongRunning { + + /** + * Constructs a new LongRunning. + * @param [properties] Properties to set + */ + constructor(properties?: google.api.MethodSettings.ILongRunning); + + /** LongRunning initialPollDelay. */ + public initialPollDelay?: (google.protobuf.IDuration|null); + + /** LongRunning pollDelayMultiplier. */ + public pollDelayMultiplier: number; + + /** LongRunning maxPollDelay. */ + public maxPollDelay?: (google.protobuf.IDuration|null); + + /** LongRunning totalPollTimeout. */ + public totalPollTimeout?: (google.protobuf.IDuration|null); + + /** + * Creates a new LongRunning instance using the specified properties. + * @param [properties] Properties to set + * @returns LongRunning instance + */ + public static create(properties?: google.api.MethodSettings.ILongRunning): google.api.MethodSettings.LongRunning; + + /** + * Encodes the specified LongRunning message. Does not implicitly {@link google.api.MethodSettings.LongRunning.verify|verify} messages. + * @param message LongRunning message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.api.MethodSettings.ILongRunning, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified LongRunning message, length delimited. Does not implicitly {@link google.api.MethodSettings.LongRunning.verify|verify} messages. + * @param message LongRunning message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.api.MethodSettings.ILongRunning, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a LongRunning message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns LongRunning + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.api.MethodSettings.LongRunning; + + /** + * Decodes a LongRunning message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns LongRunning + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.api.MethodSettings.LongRunning; + + /** + * Verifies a LongRunning message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a LongRunning message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns LongRunning + */ + public static fromObject(object: { [k: string]: any }): google.api.MethodSettings.LongRunning; + + /** + * Creates a plain object from a LongRunning message. Also converts values to other types if specified. + * @param message LongRunning + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.api.MethodSettings.LongRunning, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this LongRunning to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for LongRunning + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + } + + /** ClientLibraryOrganization enum. */ + enum ClientLibraryOrganization { + CLIENT_LIBRARY_ORGANIZATION_UNSPECIFIED = 0, + CLOUD = 1, + ADS = 2, + PHOTOS = 3, + STREET_VIEW = 4 + } + + /** ClientLibraryDestination enum. */ + enum ClientLibraryDestination { + CLIENT_LIBRARY_DESTINATION_UNSPECIFIED = 0, + GITHUB = 10, + PACKAGE_MANAGER = 20 + } + + /** LaunchStage enum. */ + enum LaunchStage { + LAUNCH_STAGE_UNSPECIFIED = 0, + UNIMPLEMENTED = 6, + PRELAUNCH = 7, + EARLY_ACCESS = 1, + ALPHA = 2, + BETA = 3, + GA = 4, + DEPRECATED = 5 + } + } + + /** Namespace protobuf. */ + namespace protobuf { + + /** Properties of a FileDescriptorSet. */ + interface IFileDescriptorSet { + + /** FileDescriptorSet file */ + file?: (google.protobuf.IFileDescriptorProto[]|null); + } + + /** Represents a FileDescriptorSet. */ + class FileDescriptorSet implements IFileDescriptorSet { + + /** + * Constructs a new FileDescriptorSet. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IFileDescriptorSet); + + /** FileDescriptorSet file. */ + public file: google.protobuf.IFileDescriptorProto[]; + + /** + * Creates a new FileDescriptorSet instance using the specified properties. + * @param [properties] Properties to set + * @returns FileDescriptorSet instance + */ + public static create(properties?: google.protobuf.IFileDescriptorSet): google.protobuf.FileDescriptorSet; + + /** + * Encodes the specified FileDescriptorSet message. Does not implicitly {@link google.protobuf.FileDescriptorSet.verify|verify} messages. + * @param message FileDescriptorSet message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IFileDescriptorSet, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified FileDescriptorSet message, length delimited. Does not implicitly {@link google.protobuf.FileDescriptorSet.verify|verify} messages. + * @param message FileDescriptorSet message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IFileDescriptorSet, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a FileDescriptorSet message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns FileDescriptorSet + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.FileDescriptorSet; + + /** + * Decodes a FileDescriptorSet message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns FileDescriptorSet + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.FileDescriptorSet; + + /** + * Verifies a FileDescriptorSet message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a FileDescriptorSet message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns FileDescriptorSet + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.FileDescriptorSet; + + /** + * Creates a plain object from a FileDescriptorSet message. Also converts values to other types if specified. + * @param message FileDescriptorSet + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.FileDescriptorSet, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this FileDescriptorSet to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for FileDescriptorSet + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a FileDescriptorProto. */ + interface IFileDescriptorProto { + + /** FileDescriptorProto name */ + name?: (string|null); + + /** FileDescriptorProto package */ + "package"?: (string|null); + + /** FileDescriptorProto dependency */ + dependency?: (string[]|null); + + /** FileDescriptorProto publicDependency */ + publicDependency?: (number[]|null); + + /** FileDescriptorProto weakDependency */ + weakDependency?: (number[]|null); + + /** FileDescriptorProto messageType */ + messageType?: (google.protobuf.IDescriptorProto[]|null); + + /** FileDescriptorProto enumType */ + enumType?: (google.protobuf.IEnumDescriptorProto[]|null); + + /** FileDescriptorProto service */ + service?: (google.protobuf.IServiceDescriptorProto[]|null); + + /** FileDescriptorProto extension */ + extension?: (google.protobuf.IFieldDescriptorProto[]|null); + + /** FileDescriptorProto options */ + options?: (google.protobuf.IFileOptions|null); + + /** FileDescriptorProto sourceCodeInfo */ + sourceCodeInfo?: (google.protobuf.ISourceCodeInfo|null); + + /** FileDescriptorProto syntax */ + syntax?: (string|null); + + /** FileDescriptorProto edition */ + edition?: (string|null); + } + + /** Represents a FileDescriptorProto. */ + class FileDescriptorProto implements IFileDescriptorProto { + + /** + * Constructs a new FileDescriptorProto. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IFileDescriptorProto); + + /** FileDescriptorProto name. */ + public name: string; + + /** FileDescriptorProto package. */ + public package: string; + + /** FileDescriptorProto dependency. */ + public dependency: string[]; + + /** FileDescriptorProto publicDependency. */ + public publicDependency: number[]; + + /** FileDescriptorProto weakDependency. */ + public weakDependency: number[]; + + /** FileDescriptorProto messageType. */ + public messageType: google.protobuf.IDescriptorProto[]; + + /** FileDescriptorProto enumType. */ + public enumType: google.protobuf.IEnumDescriptorProto[]; + + /** FileDescriptorProto service. */ + public service: google.protobuf.IServiceDescriptorProto[]; + + /** FileDescriptorProto extension. */ + public extension: google.protobuf.IFieldDescriptorProto[]; + + /** FileDescriptorProto options. */ + public options?: (google.protobuf.IFileOptions|null); + + /** FileDescriptorProto sourceCodeInfo. */ + public sourceCodeInfo?: (google.protobuf.ISourceCodeInfo|null); + + /** FileDescriptorProto syntax. */ + public syntax: string; + + /** FileDescriptorProto edition. */ + public edition: string; + + /** + * Creates a new FileDescriptorProto instance using the specified properties. + * @param [properties] Properties to set + * @returns FileDescriptorProto instance + */ + public static create(properties?: google.protobuf.IFileDescriptorProto): google.protobuf.FileDescriptorProto; + + /** + * Encodes the specified FileDescriptorProto message. Does not implicitly {@link google.protobuf.FileDescriptorProto.verify|verify} messages. + * @param message FileDescriptorProto message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IFileDescriptorProto, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified FileDescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.FileDescriptorProto.verify|verify} messages. + * @param message FileDescriptorProto message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IFileDescriptorProto, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a FileDescriptorProto message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns FileDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.FileDescriptorProto; + + /** + * Decodes a FileDescriptorProto message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns FileDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.FileDescriptorProto; + + /** + * Verifies a FileDescriptorProto message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a FileDescriptorProto message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns FileDescriptorProto + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.FileDescriptorProto; + + /** + * Creates a plain object from a FileDescriptorProto message. Also converts values to other types if specified. + * @param message FileDescriptorProto + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.FileDescriptorProto, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this FileDescriptorProto to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for FileDescriptorProto + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a DescriptorProto. */ + interface IDescriptorProto { + + /** DescriptorProto name */ + name?: (string|null); + + /** DescriptorProto field */ + field?: (google.protobuf.IFieldDescriptorProto[]|null); + + /** DescriptorProto extension */ + extension?: (google.protobuf.IFieldDescriptorProto[]|null); + + /** DescriptorProto nestedType */ + nestedType?: (google.protobuf.IDescriptorProto[]|null); + + /** DescriptorProto enumType */ + enumType?: (google.protobuf.IEnumDescriptorProto[]|null); + + /** DescriptorProto extensionRange */ + extensionRange?: (google.protobuf.DescriptorProto.IExtensionRange[]|null); + + /** DescriptorProto oneofDecl */ + oneofDecl?: (google.protobuf.IOneofDescriptorProto[]|null); + + /** DescriptorProto options */ + options?: (google.protobuf.IMessageOptions|null); + + /** DescriptorProto reservedRange */ + reservedRange?: (google.protobuf.DescriptorProto.IReservedRange[]|null); + + /** DescriptorProto reservedName */ + reservedName?: (string[]|null); + } + + /** Represents a DescriptorProto. */ + class DescriptorProto implements IDescriptorProto { + + /** + * Constructs a new DescriptorProto. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IDescriptorProto); + + /** DescriptorProto name. */ + public name: string; + + /** DescriptorProto field. */ + public field: google.protobuf.IFieldDescriptorProto[]; + + /** DescriptorProto extension. */ + public extension: google.protobuf.IFieldDescriptorProto[]; + + /** DescriptorProto nestedType. */ + public nestedType: google.protobuf.IDescriptorProto[]; + + /** DescriptorProto enumType. */ + public enumType: google.protobuf.IEnumDescriptorProto[]; + + /** DescriptorProto extensionRange. */ + public extensionRange: google.protobuf.DescriptorProto.IExtensionRange[]; + + /** DescriptorProto oneofDecl. */ + public oneofDecl: google.protobuf.IOneofDescriptorProto[]; + + /** DescriptorProto options. */ + public options?: (google.protobuf.IMessageOptions|null); + + /** DescriptorProto reservedRange. */ + public reservedRange: google.protobuf.DescriptorProto.IReservedRange[]; + + /** DescriptorProto reservedName. */ + public reservedName: string[]; + + /** + * Creates a new DescriptorProto instance using the specified properties. + * @param [properties] Properties to set + * @returns DescriptorProto instance + */ + public static create(properties?: google.protobuf.IDescriptorProto): google.protobuf.DescriptorProto; + + /** + * Encodes the specified DescriptorProto message. Does not implicitly {@link google.protobuf.DescriptorProto.verify|verify} messages. + * @param message DescriptorProto message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IDescriptorProto, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified DescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.DescriptorProto.verify|verify} messages. + * @param message DescriptorProto message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IDescriptorProto, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a DescriptorProto message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns DescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.DescriptorProto; + + /** + * Decodes a DescriptorProto message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns DescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.DescriptorProto; + + /** + * Verifies a DescriptorProto message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a DescriptorProto message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns DescriptorProto + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.DescriptorProto; + + /** + * Creates a plain object from a DescriptorProto message. Also converts values to other types if specified. + * @param message DescriptorProto + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.DescriptorProto, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this DescriptorProto to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for DescriptorProto + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace DescriptorProto { + + /** Properties of an ExtensionRange. */ + interface IExtensionRange { + + /** ExtensionRange start */ + start?: (number|null); + + /** ExtensionRange end */ + end?: (number|null); + + /** ExtensionRange options */ + options?: (google.protobuf.IExtensionRangeOptions|null); + } + + /** Represents an ExtensionRange. */ + class ExtensionRange implements IExtensionRange { + + /** + * Constructs a new ExtensionRange. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.DescriptorProto.IExtensionRange); + + /** ExtensionRange start. */ + public start: number; + + /** ExtensionRange end. */ + public end: number; + + /** ExtensionRange options. */ + public options?: (google.protobuf.IExtensionRangeOptions|null); + + /** + * Creates a new ExtensionRange instance using the specified properties. + * @param [properties] Properties to set + * @returns ExtensionRange instance + */ + public static create(properties?: google.protobuf.DescriptorProto.IExtensionRange): google.protobuf.DescriptorProto.ExtensionRange; + + /** + * Encodes the specified ExtensionRange message. Does not implicitly {@link google.protobuf.DescriptorProto.ExtensionRange.verify|verify} messages. + * @param message ExtensionRange message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.DescriptorProto.IExtensionRange, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ExtensionRange message, length delimited. Does not implicitly {@link google.protobuf.DescriptorProto.ExtensionRange.verify|verify} messages. + * @param message ExtensionRange message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.DescriptorProto.IExtensionRange, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an ExtensionRange message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ExtensionRange + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.DescriptorProto.ExtensionRange; + + /** + * Decodes an ExtensionRange message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ExtensionRange + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.DescriptorProto.ExtensionRange; + + /** + * Verifies an ExtensionRange message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an ExtensionRange message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ExtensionRange + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.DescriptorProto.ExtensionRange; + + /** + * Creates a plain object from an ExtensionRange message. Also converts values to other types if specified. + * @param message ExtensionRange + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.DescriptorProto.ExtensionRange, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ExtensionRange to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ExtensionRange + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ReservedRange. */ + interface IReservedRange { + + /** ReservedRange start */ + start?: (number|null); + + /** ReservedRange end */ + end?: (number|null); + } + + /** Represents a ReservedRange. */ + class ReservedRange implements IReservedRange { + + /** + * Constructs a new ReservedRange. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.DescriptorProto.IReservedRange); + + /** ReservedRange start. */ + public start: number; + + /** ReservedRange end. */ + public end: number; + + /** + * Creates a new ReservedRange instance using the specified properties. + * @param [properties] Properties to set + * @returns ReservedRange instance + */ + public static create(properties?: google.protobuf.DescriptorProto.IReservedRange): google.protobuf.DescriptorProto.ReservedRange; + + /** + * Encodes the specified ReservedRange message. Does not implicitly {@link google.protobuf.DescriptorProto.ReservedRange.verify|verify} messages. + * @param message ReservedRange message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.DescriptorProto.IReservedRange, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ReservedRange message, length delimited. Does not implicitly {@link google.protobuf.DescriptorProto.ReservedRange.verify|verify} messages. + * @param message ReservedRange message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.DescriptorProto.IReservedRange, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ReservedRange message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ReservedRange + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.DescriptorProto.ReservedRange; + + /** + * Decodes a ReservedRange message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ReservedRange + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.DescriptorProto.ReservedRange; + + /** + * Verifies a ReservedRange message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ReservedRange message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ReservedRange + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.DescriptorProto.ReservedRange; + + /** + * Creates a plain object from a ReservedRange message. Also converts values to other types if specified. + * @param message ReservedRange + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.DescriptorProto.ReservedRange, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ReservedRange to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ReservedRange + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + } + + /** Properties of an ExtensionRangeOptions. */ + interface IExtensionRangeOptions { + + /** ExtensionRangeOptions uninterpretedOption */ + uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); + } + + /** Represents an ExtensionRangeOptions. */ + class ExtensionRangeOptions implements IExtensionRangeOptions { + + /** + * Constructs a new ExtensionRangeOptions. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IExtensionRangeOptions); + + /** ExtensionRangeOptions uninterpretedOption. */ + public uninterpretedOption: google.protobuf.IUninterpretedOption[]; + + /** + * Creates a new ExtensionRangeOptions instance using the specified properties. + * @param [properties] Properties to set + * @returns ExtensionRangeOptions instance + */ + public static create(properties?: google.protobuf.IExtensionRangeOptions): google.protobuf.ExtensionRangeOptions; + + /** + * Encodes the specified ExtensionRangeOptions message. Does not implicitly {@link google.protobuf.ExtensionRangeOptions.verify|verify} messages. + * @param message ExtensionRangeOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IExtensionRangeOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ExtensionRangeOptions message, length delimited. Does not implicitly {@link google.protobuf.ExtensionRangeOptions.verify|verify} messages. + * @param message ExtensionRangeOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IExtensionRangeOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an ExtensionRangeOptions message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ExtensionRangeOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.ExtensionRangeOptions; + + /** + * Decodes an ExtensionRangeOptions message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ExtensionRangeOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.ExtensionRangeOptions; + + /** + * Verifies an ExtensionRangeOptions message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an ExtensionRangeOptions message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ExtensionRangeOptions + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.ExtensionRangeOptions; + + /** + * Creates a plain object from an ExtensionRangeOptions message. Also converts values to other types if specified. + * @param message ExtensionRangeOptions + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.ExtensionRangeOptions, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ExtensionRangeOptions to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ExtensionRangeOptions + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a FieldDescriptorProto. */ + interface IFieldDescriptorProto { + + /** FieldDescriptorProto name */ + name?: (string|null); + + /** FieldDescriptorProto number */ + number?: (number|null); + + /** FieldDescriptorProto label */ + label?: (google.protobuf.FieldDescriptorProto.Label|keyof typeof google.protobuf.FieldDescriptorProto.Label|null); + + /** FieldDescriptorProto type */ + type?: (google.protobuf.FieldDescriptorProto.Type|keyof typeof google.protobuf.FieldDescriptorProto.Type|null); + + /** FieldDescriptorProto typeName */ + typeName?: (string|null); + + /** FieldDescriptorProto extendee */ + extendee?: (string|null); + + /** FieldDescriptorProto defaultValue */ + defaultValue?: (string|null); + + /** FieldDescriptorProto oneofIndex */ + oneofIndex?: (number|null); + + /** FieldDescriptorProto jsonName */ + jsonName?: (string|null); + + /** FieldDescriptorProto options */ + options?: (google.protobuf.IFieldOptions|null); + + /** FieldDescriptorProto proto3Optional */ + proto3Optional?: (boolean|null); + } + + /** Represents a FieldDescriptorProto. */ + class FieldDescriptorProto implements IFieldDescriptorProto { + + /** + * Constructs a new FieldDescriptorProto. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IFieldDescriptorProto); + + /** FieldDescriptorProto name. */ + public name: string; + + /** FieldDescriptorProto number. */ + public number: number; + + /** FieldDescriptorProto label. */ + public label: (google.protobuf.FieldDescriptorProto.Label|keyof typeof google.protobuf.FieldDescriptorProto.Label); + + /** FieldDescriptorProto type. */ + public type: (google.protobuf.FieldDescriptorProto.Type|keyof typeof google.protobuf.FieldDescriptorProto.Type); + + /** FieldDescriptorProto typeName. */ + public typeName: string; + + /** FieldDescriptorProto extendee. */ + public extendee: string; + + /** FieldDescriptorProto defaultValue. */ + public defaultValue: string; + + /** FieldDescriptorProto oneofIndex. */ + public oneofIndex: number; + + /** FieldDescriptorProto jsonName. */ + public jsonName: string; + + /** FieldDescriptorProto options. */ + public options?: (google.protobuf.IFieldOptions|null); + + /** FieldDescriptorProto proto3Optional. */ + public proto3Optional: boolean; + + /** + * Creates a new FieldDescriptorProto instance using the specified properties. + * @param [properties] Properties to set + * @returns FieldDescriptorProto instance + */ + public static create(properties?: google.protobuf.IFieldDescriptorProto): google.protobuf.FieldDescriptorProto; + + /** + * Encodes the specified FieldDescriptorProto message. Does not implicitly {@link google.protobuf.FieldDescriptorProto.verify|verify} messages. + * @param message FieldDescriptorProto message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IFieldDescriptorProto, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified FieldDescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.FieldDescriptorProto.verify|verify} messages. + * @param message FieldDescriptorProto message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IFieldDescriptorProto, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a FieldDescriptorProto message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns FieldDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.FieldDescriptorProto; + + /** + * Decodes a FieldDescriptorProto message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns FieldDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.FieldDescriptorProto; + + /** + * Verifies a FieldDescriptorProto message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a FieldDescriptorProto message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns FieldDescriptorProto + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.FieldDescriptorProto; + + /** + * Creates a plain object from a FieldDescriptorProto message. Also converts values to other types if specified. + * @param message FieldDescriptorProto + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.FieldDescriptorProto, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this FieldDescriptorProto to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for FieldDescriptorProto + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace FieldDescriptorProto { + + /** Type enum. */ + enum Type { + TYPE_DOUBLE = 1, + TYPE_FLOAT = 2, + TYPE_INT64 = 3, + TYPE_UINT64 = 4, + TYPE_INT32 = 5, + TYPE_FIXED64 = 6, + TYPE_FIXED32 = 7, + TYPE_BOOL = 8, + TYPE_STRING = 9, + TYPE_GROUP = 10, + TYPE_MESSAGE = 11, + TYPE_BYTES = 12, + TYPE_UINT32 = 13, + TYPE_ENUM = 14, + TYPE_SFIXED32 = 15, + TYPE_SFIXED64 = 16, + TYPE_SINT32 = 17, + TYPE_SINT64 = 18 + } + + /** Label enum. */ + enum Label { + LABEL_OPTIONAL = 1, + LABEL_REQUIRED = 2, + LABEL_REPEATED = 3 + } + } + + /** Properties of an OneofDescriptorProto. */ + interface IOneofDescriptorProto { + + /** OneofDescriptorProto name */ + name?: (string|null); + + /** OneofDescriptorProto options */ + options?: (google.protobuf.IOneofOptions|null); + } + + /** Represents an OneofDescriptorProto. */ + class OneofDescriptorProto implements IOneofDescriptorProto { + + /** + * Constructs a new OneofDescriptorProto. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IOneofDescriptorProto); + + /** OneofDescriptorProto name. */ + public name: string; + + /** OneofDescriptorProto options. */ + public options?: (google.protobuf.IOneofOptions|null); + + /** + * Creates a new OneofDescriptorProto instance using the specified properties. + * @param [properties] Properties to set + * @returns OneofDescriptorProto instance + */ + public static create(properties?: google.protobuf.IOneofDescriptorProto): google.protobuf.OneofDescriptorProto; + + /** + * Encodes the specified OneofDescriptorProto message. Does not implicitly {@link google.protobuf.OneofDescriptorProto.verify|verify} messages. + * @param message OneofDescriptorProto message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IOneofDescriptorProto, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified OneofDescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.OneofDescriptorProto.verify|verify} messages. + * @param message OneofDescriptorProto message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IOneofDescriptorProto, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an OneofDescriptorProto message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns OneofDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.OneofDescriptorProto; + + /** + * Decodes an OneofDescriptorProto message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns OneofDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.OneofDescriptorProto; + + /** + * Verifies an OneofDescriptorProto message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an OneofDescriptorProto message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns OneofDescriptorProto + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.OneofDescriptorProto; + + /** + * Creates a plain object from an OneofDescriptorProto message. Also converts values to other types if specified. + * @param message OneofDescriptorProto + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.OneofDescriptorProto, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this OneofDescriptorProto to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for OneofDescriptorProto + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of an EnumDescriptorProto. */ + interface IEnumDescriptorProto { + + /** EnumDescriptorProto name */ + name?: (string|null); + + /** EnumDescriptorProto value */ + value?: (google.protobuf.IEnumValueDescriptorProto[]|null); + + /** EnumDescriptorProto options */ + options?: (google.protobuf.IEnumOptions|null); + + /** EnumDescriptorProto reservedRange */ + reservedRange?: (google.protobuf.EnumDescriptorProto.IEnumReservedRange[]|null); + + /** EnumDescriptorProto reservedName */ + reservedName?: (string[]|null); + } + + /** Represents an EnumDescriptorProto. */ + class EnumDescriptorProto implements IEnumDescriptorProto { + + /** + * Constructs a new EnumDescriptorProto. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IEnumDescriptorProto); + + /** EnumDescriptorProto name. */ + public name: string; + + /** EnumDescriptorProto value. */ + public value: google.protobuf.IEnumValueDescriptorProto[]; + + /** EnumDescriptorProto options. */ + public options?: (google.protobuf.IEnumOptions|null); + + /** EnumDescriptorProto reservedRange. */ + public reservedRange: google.protobuf.EnumDescriptorProto.IEnumReservedRange[]; + + /** EnumDescriptorProto reservedName. */ + public reservedName: string[]; + + /** + * Creates a new EnumDescriptorProto instance using the specified properties. + * @param [properties] Properties to set + * @returns EnumDescriptorProto instance + */ + public static create(properties?: google.protobuf.IEnumDescriptorProto): google.protobuf.EnumDescriptorProto; + + /** + * Encodes the specified EnumDescriptorProto message. Does not implicitly {@link google.protobuf.EnumDescriptorProto.verify|verify} messages. + * @param message EnumDescriptorProto message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IEnumDescriptorProto, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified EnumDescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.EnumDescriptorProto.verify|verify} messages. + * @param message EnumDescriptorProto message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IEnumDescriptorProto, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an EnumDescriptorProto message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns EnumDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.EnumDescriptorProto; + + /** + * Decodes an EnumDescriptorProto message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns EnumDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.EnumDescriptorProto; + + /** + * Verifies an EnumDescriptorProto message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an EnumDescriptorProto message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns EnumDescriptorProto + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.EnumDescriptorProto; + + /** + * Creates a plain object from an EnumDescriptorProto message. Also converts values to other types if specified. + * @param message EnumDescriptorProto + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.EnumDescriptorProto, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this EnumDescriptorProto to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for EnumDescriptorProto + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace EnumDescriptorProto { + + /** Properties of an EnumReservedRange. */ + interface IEnumReservedRange { + + /** EnumReservedRange start */ + start?: (number|null); + + /** EnumReservedRange end */ + end?: (number|null); + } + + /** Represents an EnumReservedRange. */ + class EnumReservedRange implements IEnumReservedRange { + + /** + * Constructs a new EnumReservedRange. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.EnumDescriptorProto.IEnumReservedRange); + + /** EnumReservedRange start. */ + public start: number; + + /** EnumReservedRange end. */ + public end: number; + + /** + * Creates a new EnumReservedRange instance using the specified properties. + * @param [properties] Properties to set + * @returns EnumReservedRange instance + */ + public static create(properties?: google.protobuf.EnumDescriptorProto.IEnumReservedRange): google.protobuf.EnumDescriptorProto.EnumReservedRange; + + /** + * Encodes the specified EnumReservedRange message. Does not implicitly {@link google.protobuf.EnumDescriptorProto.EnumReservedRange.verify|verify} messages. + * @param message EnumReservedRange message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.EnumDescriptorProto.IEnumReservedRange, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified EnumReservedRange message, length delimited. Does not implicitly {@link google.protobuf.EnumDescriptorProto.EnumReservedRange.verify|verify} messages. + * @param message EnumReservedRange message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.EnumDescriptorProto.IEnumReservedRange, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an EnumReservedRange message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns EnumReservedRange + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.EnumDescriptorProto.EnumReservedRange; + + /** + * Decodes an EnumReservedRange message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns EnumReservedRange + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.EnumDescriptorProto.EnumReservedRange; + + /** + * Verifies an EnumReservedRange message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an EnumReservedRange message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns EnumReservedRange + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.EnumDescriptorProto.EnumReservedRange; + + /** + * Creates a plain object from an EnumReservedRange message. Also converts values to other types if specified. + * @param message EnumReservedRange + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.EnumDescriptorProto.EnumReservedRange, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this EnumReservedRange to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for EnumReservedRange + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + } + + /** Properties of an EnumValueDescriptorProto. */ + interface IEnumValueDescriptorProto { + + /** EnumValueDescriptorProto name */ + name?: (string|null); + + /** EnumValueDescriptorProto number */ + number?: (number|null); + + /** EnumValueDescriptorProto options */ + options?: (google.protobuf.IEnumValueOptions|null); + } + + /** Represents an EnumValueDescriptorProto. */ + class EnumValueDescriptorProto implements IEnumValueDescriptorProto { + + /** + * Constructs a new EnumValueDescriptorProto. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IEnumValueDescriptorProto); + + /** EnumValueDescriptorProto name. */ + public name: string; + + /** EnumValueDescriptorProto number. */ + public number: number; + + /** EnumValueDescriptorProto options. */ + public options?: (google.protobuf.IEnumValueOptions|null); + + /** + * Creates a new EnumValueDescriptorProto instance using the specified properties. + * @param [properties] Properties to set + * @returns EnumValueDescriptorProto instance + */ + public static create(properties?: google.protobuf.IEnumValueDescriptorProto): google.protobuf.EnumValueDescriptorProto; + + /** + * Encodes the specified EnumValueDescriptorProto message. Does not implicitly {@link google.protobuf.EnumValueDescriptorProto.verify|verify} messages. + * @param message EnumValueDescriptorProto message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IEnumValueDescriptorProto, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified EnumValueDescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.EnumValueDescriptorProto.verify|verify} messages. + * @param message EnumValueDescriptorProto message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IEnumValueDescriptorProto, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an EnumValueDescriptorProto message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns EnumValueDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.EnumValueDescriptorProto; + + /** + * Decodes an EnumValueDescriptorProto message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns EnumValueDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.EnumValueDescriptorProto; + + /** + * Verifies an EnumValueDescriptorProto message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an EnumValueDescriptorProto message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns EnumValueDescriptorProto + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.EnumValueDescriptorProto; + + /** + * Creates a plain object from an EnumValueDescriptorProto message. Also converts values to other types if specified. + * @param message EnumValueDescriptorProto + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.EnumValueDescriptorProto, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this EnumValueDescriptorProto to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for EnumValueDescriptorProto + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ServiceDescriptorProto. */ + interface IServiceDescriptorProto { + + /** ServiceDescriptorProto name */ + name?: (string|null); + + /** ServiceDescriptorProto method */ + method?: (google.protobuf.IMethodDescriptorProto[]|null); + + /** ServiceDescriptorProto options */ + options?: (google.protobuf.IServiceOptions|null); + } + + /** Represents a ServiceDescriptorProto. */ + class ServiceDescriptorProto implements IServiceDescriptorProto { + + /** + * Constructs a new ServiceDescriptorProto. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IServiceDescriptorProto); + + /** ServiceDescriptorProto name. */ + public name: string; + + /** ServiceDescriptorProto method. */ + public method: google.protobuf.IMethodDescriptorProto[]; + + /** ServiceDescriptorProto options. */ + public options?: (google.protobuf.IServiceOptions|null); + + /** + * Creates a new ServiceDescriptorProto instance using the specified properties. + * @param [properties] Properties to set + * @returns ServiceDescriptorProto instance + */ + public static create(properties?: google.protobuf.IServiceDescriptorProto): google.protobuf.ServiceDescriptorProto; + + /** + * Encodes the specified ServiceDescriptorProto message. Does not implicitly {@link google.protobuf.ServiceDescriptorProto.verify|verify} messages. + * @param message ServiceDescriptorProto message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IServiceDescriptorProto, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ServiceDescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.ServiceDescriptorProto.verify|verify} messages. + * @param message ServiceDescriptorProto message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IServiceDescriptorProto, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ServiceDescriptorProto message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ServiceDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.ServiceDescriptorProto; + + /** + * Decodes a ServiceDescriptorProto message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ServiceDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.ServiceDescriptorProto; + + /** + * Verifies a ServiceDescriptorProto message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ServiceDescriptorProto message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ServiceDescriptorProto + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.ServiceDescriptorProto; + + /** + * Creates a plain object from a ServiceDescriptorProto message. Also converts values to other types if specified. + * @param message ServiceDescriptorProto + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.ServiceDescriptorProto, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ServiceDescriptorProto to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ServiceDescriptorProto + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a MethodDescriptorProto. */ + interface IMethodDescriptorProto { + + /** MethodDescriptorProto name */ + name?: (string|null); + + /** MethodDescriptorProto inputType */ + inputType?: (string|null); + + /** MethodDescriptorProto outputType */ + outputType?: (string|null); + + /** MethodDescriptorProto options */ + options?: (google.protobuf.IMethodOptions|null); + + /** MethodDescriptorProto clientStreaming */ + clientStreaming?: (boolean|null); + + /** MethodDescriptorProto serverStreaming */ + serverStreaming?: (boolean|null); + } + + /** Represents a MethodDescriptorProto. */ + class MethodDescriptorProto implements IMethodDescriptorProto { + + /** + * Constructs a new MethodDescriptorProto. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IMethodDescriptorProto); + + /** MethodDescriptorProto name. */ + public name: string; + + /** MethodDescriptorProto inputType. */ + public inputType: string; + + /** MethodDescriptorProto outputType. */ + public outputType: string; + + /** MethodDescriptorProto options. */ + public options?: (google.protobuf.IMethodOptions|null); + + /** MethodDescriptorProto clientStreaming. */ + public clientStreaming: boolean; + + /** MethodDescriptorProto serverStreaming. */ + public serverStreaming: boolean; + + /** + * Creates a new MethodDescriptorProto instance using the specified properties. + * @param [properties] Properties to set + * @returns MethodDescriptorProto instance + */ + public static create(properties?: google.protobuf.IMethodDescriptorProto): google.protobuf.MethodDescriptorProto; + + /** + * Encodes the specified MethodDescriptorProto message. Does not implicitly {@link google.protobuf.MethodDescriptorProto.verify|verify} messages. + * @param message MethodDescriptorProto message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IMethodDescriptorProto, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified MethodDescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.MethodDescriptorProto.verify|verify} messages. + * @param message MethodDescriptorProto message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IMethodDescriptorProto, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a MethodDescriptorProto message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns MethodDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.MethodDescriptorProto; + + /** + * Decodes a MethodDescriptorProto message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns MethodDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.MethodDescriptorProto; + + /** + * Verifies a MethodDescriptorProto message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a MethodDescriptorProto message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns MethodDescriptorProto + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.MethodDescriptorProto; + + /** + * Creates a plain object from a MethodDescriptorProto message. Also converts values to other types if specified. + * @param message MethodDescriptorProto + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.MethodDescriptorProto, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this MethodDescriptorProto to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for MethodDescriptorProto + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a FileOptions. */ + interface IFileOptions { + + /** FileOptions javaPackage */ + javaPackage?: (string|null); + + /** FileOptions javaOuterClassname */ + javaOuterClassname?: (string|null); + + /** FileOptions javaMultipleFiles */ + javaMultipleFiles?: (boolean|null); + + /** FileOptions javaGenerateEqualsAndHash */ + javaGenerateEqualsAndHash?: (boolean|null); + + /** FileOptions javaStringCheckUtf8 */ + javaStringCheckUtf8?: (boolean|null); + + /** FileOptions optimizeFor */ + optimizeFor?: (google.protobuf.FileOptions.OptimizeMode|keyof typeof google.protobuf.FileOptions.OptimizeMode|null); + + /** FileOptions goPackage */ + goPackage?: (string|null); + + /** FileOptions ccGenericServices */ + ccGenericServices?: (boolean|null); + + /** FileOptions javaGenericServices */ + javaGenericServices?: (boolean|null); + + /** FileOptions pyGenericServices */ + pyGenericServices?: (boolean|null); + + /** FileOptions phpGenericServices */ + phpGenericServices?: (boolean|null); + + /** FileOptions deprecated */ + deprecated?: (boolean|null); + + /** FileOptions ccEnableArenas */ + ccEnableArenas?: (boolean|null); + + /** FileOptions objcClassPrefix */ + objcClassPrefix?: (string|null); + + /** FileOptions csharpNamespace */ + csharpNamespace?: (string|null); + + /** FileOptions swiftPrefix */ + swiftPrefix?: (string|null); + + /** FileOptions phpClassPrefix */ + phpClassPrefix?: (string|null); + + /** FileOptions phpNamespace */ + phpNamespace?: (string|null); + + /** FileOptions phpMetadataNamespace */ + phpMetadataNamespace?: (string|null); + + /** FileOptions rubyPackage */ + rubyPackage?: (string|null); + + /** FileOptions uninterpretedOption */ + uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); + + /** FileOptions .google.api.resourceDefinition */ + ".google.api.resourceDefinition"?: (google.api.IResourceDescriptor[]|null); + } + + /** Represents a FileOptions. */ + class FileOptions implements IFileOptions { + + /** + * Constructs a new FileOptions. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IFileOptions); + + /** FileOptions javaPackage. */ + public javaPackage: string; + + /** FileOptions javaOuterClassname. */ + public javaOuterClassname: string; + + /** FileOptions javaMultipleFiles. */ + public javaMultipleFiles: boolean; + + /** FileOptions javaGenerateEqualsAndHash. */ + public javaGenerateEqualsAndHash: boolean; + + /** FileOptions javaStringCheckUtf8. */ + public javaStringCheckUtf8: boolean; + + /** FileOptions optimizeFor. */ + public optimizeFor: (google.protobuf.FileOptions.OptimizeMode|keyof typeof google.protobuf.FileOptions.OptimizeMode); + + /** FileOptions goPackage. */ + public goPackage: string; + + /** FileOptions ccGenericServices. */ + public ccGenericServices: boolean; + + /** FileOptions javaGenericServices. */ + public javaGenericServices: boolean; + + /** FileOptions pyGenericServices. */ + public pyGenericServices: boolean; + + /** FileOptions phpGenericServices. */ + public phpGenericServices: boolean; + + /** FileOptions deprecated. */ + public deprecated: boolean; + + /** FileOptions ccEnableArenas. */ + public ccEnableArenas: boolean; + + /** FileOptions objcClassPrefix. */ + public objcClassPrefix: string; + + /** FileOptions csharpNamespace. */ + public csharpNamespace: string; + + /** FileOptions swiftPrefix. */ + public swiftPrefix: string; + + /** FileOptions phpClassPrefix. */ + public phpClassPrefix: string; + + /** FileOptions phpNamespace. */ + public phpNamespace: string; + + /** FileOptions phpMetadataNamespace. */ + public phpMetadataNamespace: string; + + /** FileOptions rubyPackage. */ + public rubyPackage: string; + + /** FileOptions uninterpretedOption. */ + public uninterpretedOption: google.protobuf.IUninterpretedOption[]; + + /** + * Creates a new FileOptions instance using the specified properties. + * @param [properties] Properties to set + * @returns FileOptions instance + */ + public static create(properties?: google.protobuf.IFileOptions): google.protobuf.FileOptions; + + /** + * Encodes the specified FileOptions message. Does not implicitly {@link google.protobuf.FileOptions.verify|verify} messages. + * @param message FileOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IFileOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified FileOptions message, length delimited. Does not implicitly {@link google.protobuf.FileOptions.verify|verify} messages. + * @param message FileOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IFileOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a FileOptions message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns FileOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.FileOptions; + + /** + * Decodes a FileOptions message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns FileOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.FileOptions; + + /** + * Verifies a FileOptions message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a FileOptions message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns FileOptions + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.FileOptions; + + /** + * Creates a plain object from a FileOptions message. Also converts values to other types if specified. + * @param message FileOptions + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.FileOptions, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this FileOptions to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for FileOptions + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace FileOptions { + + /** OptimizeMode enum. */ + enum OptimizeMode { + SPEED = 1, + CODE_SIZE = 2, + LITE_RUNTIME = 3 + } + } + + /** Properties of a MessageOptions. */ + interface IMessageOptions { + + /** MessageOptions messageSetWireFormat */ + messageSetWireFormat?: (boolean|null); + + /** MessageOptions noStandardDescriptorAccessor */ + noStandardDescriptorAccessor?: (boolean|null); + + /** MessageOptions deprecated */ + deprecated?: (boolean|null); + + /** MessageOptions mapEntry */ + mapEntry?: (boolean|null); + + /** MessageOptions deprecatedLegacyJsonFieldConflicts */ + deprecatedLegacyJsonFieldConflicts?: (boolean|null); + + /** MessageOptions uninterpretedOption */ + uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); + + /** MessageOptions .google.api.resource */ + ".google.api.resource"?: (google.api.IResourceDescriptor|null); + } + + /** Represents a MessageOptions. */ + class MessageOptions implements IMessageOptions { + + /** + * Constructs a new MessageOptions. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IMessageOptions); + + /** MessageOptions messageSetWireFormat. */ + public messageSetWireFormat: boolean; + + /** MessageOptions noStandardDescriptorAccessor. */ + public noStandardDescriptorAccessor: boolean; + + /** MessageOptions deprecated. */ + public deprecated: boolean; + + /** MessageOptions mapEntry. */ + public mapEntry: boolean; + + /** MessageOptions deprecatedLegacyJsonFieldConflicts. */ + public deprecatedLegacyJsonFieldConflicts: boolean; + + /** MessageOptions uninterpretedOption. */ + public uninterpretedOption: google.protobuf.IUninterpretedOption[]; + + /** + * Creates a new MessageOptions instance using the specified properties. + * @param [properties] Properties to set + * @returns MessageOptions instance + */ + public static create(properties?: google.protobuf.IMessageOptions): google.protobuf.MessageOptions; + + /** + * Encodes the specified MessageOptions message. Does not implicitly {@link google.protobuf.MessageOptions.verify|verify} messages. + * @param message MessageOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IMessageOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified MessageOptions message, length delimited. Does not implicitly {@link google.protobuf.MessageOptions.verify|verify} messages. + * @param message MessageOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IMessageOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a MessageOptions message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns MessageOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.MessageOptions; + + /** + * Decodes a MessageOptions message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns MessageOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.MessageOptions; + + /** + * Verifies a MessageOptions message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a MessageOptions message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns MessageOptions + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.MessageOptions; + + /** + * Creates a plain object from a MessageOptions message. Also converts values to other types if specified. + * @param message MessageOptions + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.MessageOptions, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this MessageOptions to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for MessageOptions + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a FieldOptions. */ + interface IFieldOptions { + + /** FieldOptions ctype */ + ctype?: (google.protobuf.FieldOptions.CType|keyof typeof google.protobuf.FieldOptions.CType|null); + + /** FieldOptions packed */ + packed?: (boolean|null); + + /** FieldOptions jstype */ + jstype?: (google.protobuf.FieldOptions.JSType|keyof typeof google.protobuf.FieldOptions.JSType|null); + + /** FieldOptions lazy */ + lazy?: (boolean|null); + + /** FieldOptions unverifiedLazy */ + unverifiedLazy?: (boolean|null); + + /** FieldOptions deprecated */ + deprecated?: (boolean|null); + + /** FieldOptions weak */ + weak?: (boolean|null); + + /** FieldOptions debugRedact */ + debugRedact?: (boolean|null); + + /** FieldOptions retention */ + retention?: (google.protobuf.FieldOptions.OptionRetention|keyof typeof google.protobuf.FieldOptions.OptionRetention|null); + + /** FieldOptions target */ + target?: (google.protobuf.FieldOptions.OptionTargetType|keyof typeof google.protobuf.FieldOptions.OptionTargetType|null); + + /** FieldOptions uninterpretedOption */ + uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); + + /** FieldOptions .google.api.fieldBehavior */ + ".google.api.fieldBehavior"?: (google.api.FieldBehavior[]|null); + + /** FieldOptions .google.api.resourceReference */ + ".google.api.resourceReference"?: (google.api.IResourceReference|null); + } + + /** Represents a FieldOptions. */ + class FieldOptions implements IFieldOptions { + + /** + * Constructs a new FieldOptions. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IFieldOptions); + + /** FieldOptions ctype. */ + public ctype: (google.protobuf.FieldOptions.CType|keyof typeof google.protobuf.FieldOptions.CType); + + /** FieldOptions packed. */ + public packed: boolean; + + /** FieldOptions jstype. */ + public jstype: (google.protobuf.FieldOptions.JSType|keyof typeof google.protobuf.FieldOptions.JSType); + + /** FieldOptions lazy. */ + public lazy: boolean; + + /** FieldOptions unverifiedLazy. */ + public unverifiedLazy: boolean; + + /** FieldOptions deprecated. */ + public deprecated: boolean; + + /** FieldOptions weak. */ + public weak: boolean; + + /** FieldOptions debugRedact. */ + public debugRedact: boolean; + + /** FieldOptions retention. */ + public retention: (google.protobuf.FieldOptions.OptionRetention|keyof typeof google.protobuf.FieldOptions.OptionRetention); + + /** FieldOptions target. */ + public target: (google.protobuf.FieldOptions.OptionTargetType|keyof typeof google.protobuf.FieldOptions.OptionTargetType); + + /** FieldOptions uninterpretedOption. */ + public uninterpretedOption: google.protobuf.IUninterpretedOption[]; + + /** + * Creates a new FieldOptions instance using the specified properties. + * @param [properties] Properties to set + * @returns FieldOptions instance + */ + public static create(properties?: google.protobuf.IFieldOptions): google.protobuf.FieldOptions; + + /** + * Encodes the specified FieldOptions message. Does not implicitly {@link google.protobuf.FieldOptions.verify|verify} messages. + * @param message FieldOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IFieldOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified FieldOptions message, length delimited. Does not implicitly {@link google.protobuf.FieldOptions.verify|verify} messages. + * @param message FieldOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IFieldOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a FieldOptions message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns FieldOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.FieldOptions; + + /** + * Decodes a FieldOptions message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns FieldOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.FieldOptions; + + /** + * Verifies a FieldOptions message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a FieldOptions message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns FieldOptions + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.FieldOptions; + + /** + * Creates a plain object from a FieldOptions message. Also converts values to other types if specified. + * @param message FieldOptions + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.FieldOptions, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this FieldOptions to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for FieldOptions + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace FieldOptions { + + /** CType enum. */ + enum CType { + STRING = 0, + CORD = 1, + STRING_PIECE = 2 + } + + /** JSType enum. */ + enum JSType { + JS_NORMAL = 0, + JS_STRING = 1, + JS_NUMBER = 2 + } + + /** OptionRetention enum. */ + enum OptionRetention { + RETENTION_UNKNOWN = 0, + RETENTION_RUNTIME = 1, + RETENTION_SOURCE = 2 + } + + /** OptionTargetType enum. */ + enum OptionTargetType { + TARGET_TYPE_UNKNOWN = 0, + TARGET_TYPE_FILE = 1, + TARGET_TYPE_EXTENSION_RANGE = 2, + TARGET_TYPE_MESSAGE = 3, + TARGET_TYPE_FIELD = 4, + TARGET_TYPE_ONEOF = 5, + TARGET_TYPE_ENUM = 6, + TARGET_TYPE_ENUM_ENTRY = 7, + TARGET_TYPE_SERVICE = 8, + TARGET_TYPE_METHOD = 9 + } + } + + /** Properties of an OneofOptions. */ + interface IOneofOptions { + + /** OneofOptions uninterpretedOption */ + uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); + } + + /** Represents an OneofOptions. */ + class OneofOptions implements IOneofOptions { + + /** + * Constructs a new OneofOptions. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IOneofOptions); + + /** OneofOptions uninterpretedOption. */ + public uninterpretedOption: google.protobuf.IUninterpretedOption[]; + + /** + * Creates a new OneofOptions instance using the specified properties. + * @param [properties] Properties to set + * @returns OneofOptions instance + */ + public static create(properties?: google.protobuf.IOneofOptions): google.protobuf.OneofOptions; + + /** + * Encodes the specified OneofOptions message. Does not implicitly {@link google.protobuf.OneofOptions.verify|verify} messages. + * @param message OneofOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IOneofOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified OneofOptions message, length delimited. Does not implicitly {@link google.protobuf.OneofOptions.verify|verify} messages. + * @param message OneofOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IOneofOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an OneofOptions message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns OneofOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.OneofOptions; + + /** + * Decodes an OneofOptions message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns OneofOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.OneofOptions; + + /** + * Verifies an OneofOptions message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an OneofOptions message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns OneofOptions + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.OneofOptions; + + /** + * Creates a plain object from an OneofOptions message. Also converts values to other types if specified. + * @param message OneofOptions + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.OneofOptions, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this OneofOptions to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for OneofOptions + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of an EnumOptions. */ + interface IEnumOptions { + + /** EnumOptions allowAlias */ + allowAlias?: (boolean|null); + + /** EnumOptions deprecated */ + deprecated?: (boolean|null); + + /** EnumOptions deprecatedLegacyJsonFieldConflicts */ + deprecatedLegacyJsonFieldConflicts?: (boolean|null); + + /** EnumOptions uninterpretedOption */ + uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); + } + + /** Represents an EnumOptions. */ + class EnumOptions implements IEnumOptions { + + /** + * Constructs a new EnumOptions. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IEnumOptions); + + /** EnumOptions allowAlias. */ + public allowAlias: boolean; + + /** EnumOptions deprecated. */ + public deprecated: boolean; + + /** EnumOptions deprecatedLegacyJsonFieldConflicts. */ + public deprecatedLegacyJsonFieldConflicts: boolean; + + /** EnumOptions uninterpretedOption. */ + public uninterpretedOption: google.protobuf.IUninterpretedOption[]; + + /** + * Creates a new EnumOptions instance using the specified properties. + * @param [properties] Properties to set + * @returns EnumOptions instance + */ + public static create(properties?: google.protobuf.IEnumOptions): google.protobuf.EnumOptions; + + /** + * Encodes the specified EnumOptions message. Does not implicitly {@link google.protobuf.EnumOptions.verify|verify} messages. + * @param message EnumOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IEnumOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified EnumOptions message, length delimited. Does not implicitly {@link google.protobuf.EnumOptions.verify|verify} messages. + * @param message EnumOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IEnumOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an EnumOptions message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns EnumOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.EnumOptions; + + /** + * Decodes an EnumOptions message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns EnumOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.EnumOptions; + + /** + * Verifies an EnumOptions message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an EnumOptions message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns EnumOptions + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.EnumOptions; + + /** + * Creates a plain object from an EnumOptions message. Also converts values to other types if specified. + * @param message EnumOptions + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.EnumOptions, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this EnumOptions to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for EnumOptions + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of an EnumValueOptions. */ + interface IEnumValueOptions { + + /** EnumValueOptions deprecated */ + deprecated?: (boolean|null); + + /** EnumValueOptions uninterpretedOption */ + uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); + } + + /** Represents an EnumValueOptions. */ + class EnumValueOptions implements IEnumValueOptions { + + /** + * Constructs a new EnumValueOptions. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IEnumValueOptions); + + /** EnumValueOptions deprecated. */ + public deprecated: boolean; + + /** EnumValueOptions uninterpretedOption. */ + public uninterpretedOption: google.protobuf.IUninterpretedOption[]; + + /** + * Creates a new EnumValueOptions instance using the specified properties. + * @param [properties] Properties to set + * @returns EnumValueOptions instance + */ + public static create(properties?: google.protobuf.IEnumValueOptions): google.protobuf.EnumValueOptions; + + /** + * Encodes the specified EnumValueOptions message. Does not implicitly {@link google.protobuf.EnumValueOptions.verify|verify} messages. + * @param message EnumValueOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IEnumValueOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified EnumValueOptions message, length delimited. Does not implicitly {@link google.protobuf.EnumValueOptions.verify|verify} messages. + * @param message EnumValueOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IEnumValueOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an EnumValueOptions message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns EnumValueOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.EnumValueOptions; + + /** + * Decodes an EnumValueOptions message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns EnumValueOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.EnumValueOptions; + + /** + * Verifies an EnumValueOptions message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an EnumValueOptions message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns EnumValueOptions + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.EnumValueOptions; + + /** + * Creates a plain object from an EnumValueOptions message. Also converts values to other types if specified. + * @param message EnumValueOptions + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.EnumValueOptions, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this EnumValueOptions to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for EnumValueOptions + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ServiceOptions. */ + interface IServiceOptions { + + /** ServiceOptions deprecated */ + deprecated?: (boolean|null); + + /** ServiceOptions uninterpretedOption */ + uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); + + /** ServiceOptions .google.api.defaultHost */ + ".google.api.defaultHost"?: (string|null); + + /** ServiceOptions .google.api.oauthScopes */ + ".google.api.oauthScopes"?: (string|null); + } + + /** Represents a ServiceOptions. */ + class ServiceOptions implements IServiceOptions { + + /** + * Constructs a new ServiceOptions. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IServiceOptions); + + /** ServiceOptions deprecated. */ + public deprecated: boolean; + + /** ServiceOptions uninterpretedOption. */ + public uninterpretedOption: google.protobuf.IUninterpretedOption[]; + + /** + * Creates a new ServiceOptions instance using the specified properties. + * @param [properties] Properties to set + * @returns ServiceOptions instance + */ + public static create(properties?: google.protobuf.IServiceOptions): google.protobuf.ServiceOptions; + + /** + * Encodes the specified ServiceOptions message. Does not implicitly {@link google.protobuf.ServiceOptions.verify|verify} messages. + * @param message ServiceOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IServiceOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ServiceOptions message, length delimited. Does not implicitly {@link google.protobuf.ServiceOptions.verify|verify} messages. + * @param message ServiceOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IServiceOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ServiceOptions message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ServiceOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.ServiceOptions; + + /** + * Decodes a ServiceOptions message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ServiceOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.ServiceOptions; + + /** + * Verifies a ServiceOptions message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ServiceOptions message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ServiceOptions + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.ServiceOptions; + + /** + * Creates a plain object from a ServiceOptions message. Also converts values to other types if specified. + * @param message ServiceOptions + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.ServiceOptions, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ServiceOptions to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ServiceOptions + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a MethodOptions. */ + interface IMethodOptions { + + /** MethodOptions deprecated */ + deprecated?: (boolean|null); + + /** MethodOptions idempotencyLevel */ + idempotencyLevel?: (google.protobuf.MethodOptions.IdempotencyLevel|keyof typeof google.protobuf.MethodOptions.IdempotencyLevel|null); + + /** MethodOptions uninterpretedOption */ + uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); + + /** MethodOptions .google.api.http */ + ".google.api.http"?: (google.api.IHttpRule|null); + + /** MethodOptions .google.api.methodSignature */ + ".google.api.methodSignature"?: (string[]|null); + + /** MethodOptions .google.longrunning.operationInfo */ + ".google.longrunning.operationInfo"?: (google.longrunning.IOperationInfo|null); + } + + /** Represents a MethodOptions. */ + class MethodOptions implements IMethodOptions { + + /** + * Constructs a new MethodOptions. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IMethodOptions); + + /** MethodOptions deprecated. */ + public deprecated: boolean; + + /** MethodOptions idempotencyLevel. */ + public idempotencyLevel: (google.protobuf.MethodOptions.IdempotencyLevel|keyof typeof google.protobuf.MethodOptions.IdempotencyLevel); + + /** MethodOptions uninterpretedOption. */ + public uninterpretedOption: google.protobuf.IUninterpretedOption[]; + + /** + * Creates a new MethodOptions instance using the specified properties. + * @param [properties] Properties to set + * @returns MethodOptions instance + */ + public static create(properties?: google.protobuf.IMethodOptions): google.protobuf.MethodOptions; + + /** + * Encodes the specified MethodOptions message. Does not implicitly {@link google.protobuf.MethodOptions.verify|verify} messages. + * @param message MethodOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IMethodOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified MethodOptions message, length delimited. Does not implicitly {@link google.protobuf.MethodOptions.verify|verify} messages. + * @param message MethodOptions message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IMethodOptions, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a MethodOptions message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns MethodOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.MethodOptions; + + /** + * Decodes a MethodOptions message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns MethodOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.MethodOptions; + + /** + * Verifies a MethodOptions message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a MethodOptions message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns MethodOptions + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.MethodOptions; + + /** + * Creates a plain object from a MethodOptions message. Also converts values to other types if specified. + * @param message MethodOptions + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.MethodOptions, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this MethodOptions to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for MethodOptions + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace MethodOptions { + + /** IdempotencyLevel enum. */ + enum IdempotencyLevel { + IDEMPOTENCY_UNKNOWN = 0, + NO_SIDE_EFFECTS = 1, + IDEMPOTENT = 2 + } + } + + /** Properties of an UninterpretedOption. */ + interface IUninterpretedOption { + + /** UninterpretedOption name */ + name?: (google.protobuf.UninterpretedOption.INamePart[]|null); + + /** UninterpretedOption identifierValue */ + identifierValue?: (string|null); + + /** UninterpretedOption positiveIntValue */ + positiveIntValue?: (number|Long|string|null); + + /** UninterpretedOption negativeIntValue */ + negativeIntValue?: (number|Long|string|null); + + /** UninterpretedOption doubleValue */ + doubleValue?: (number|null); + + /** UninterpretedOption stringValue */ + stringValue?: (Uint8Array|string|null); + + /** UninterpretedOption aggregateValue */ + aggregateValue?: (string|null); + } + + /** Represents an UninterpretedOption. */ + class UninterpretedOption implements IUninterpretedOption { + + /** + * Constructs a new UninterpretedOption. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IUninterpretedOption); + + /** UninterpretedOption name. */ + public name: google.protobuf.UninterpretedOption.INamePart[]; + + /** UninterpretedOption identifierValue. */ + public identifierValue: string; + + /** UninterpretedOption positiveIntValue. */ + public positiveIntValue: (number|Long|string); + + /** UninterpretedOption negativeIntValue. */ + public negativeIntValue: (number|Long|string); + + /** UninterpretedOption doubleValue. */ + public doubleValue: number; + + /** UninterpretedOption stringValue. */ + public stringValue: (Uint8Array|string); + + /** UninterpretedOption aggregateValue. */ + public aggregateValue: string; + + /** + * Creates a new UninterpretedOption instance using the specified properties. + * @param [properties] Properties to set + * @returns UninterpretedOption instance + */ + public static create(properties?: google.protobuf.IUninterpretedOption): google.protobuf.UninterpretedOption; + + /** + * Encodes the specified UninterpretedOption message. Does not implicitly {@link google.protobuf.UninterpretedOption.verify|verify} messages. + * @param message UninterpretedOption message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IUninterpretedOption, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified UninterpretedOption message, length delimited. Does not implicitly {@link google.protobuf.UninterpretedOption.verify|verify} messages. + * @param message UninterpretedOption message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IUninterpretedOption, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an UninterpretedOption message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns UninterpretedOption + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.UninterpretedOption; + + /** + * Decodes an UninterpretedOption message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns UninterpretedOption + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.UninterpretedOption; + + /** + * Verifies an UninterpretedOption message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an UninterpretedOption message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns UninterpretedOption + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.UninterpretedOption; + + /** + * Creates a plain object from an UninterpretedOption message. Also converts values to other types if specified. + * @param message UninterpretedOption + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.UninterpretedOption, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this UninterpretedOption to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for UninterpretedOption + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace UninterpretedOption { + + /** Properties of a NamePart. */ + interface INamePart { + + /** NamePart namePart */ + namePart: string; + + /** NamePart isExtension */ + isExtension: boolean; + } + + /** Represents a NamePart. */ + class NamePart implements INamePart { + + /** + * Constructs a new NamePart. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.UninterpretedOption.INamePart); + + /** NamePart namePart. */ + public namePart: string; + + /** NamePart isExtension. */ + public isExtension: boolean; + + /** + * Creates a new NamePart instance using the specified properties. + * @param [properties] Properties to set + * @returns NamePart instance + */ + public static create(properties?: google.protobuf.UninterpretedOption.INamePart): google.protobuf.UninterpretedOption.NamePart; + + /** + * Encodes the specified NamePart message. Does not implicitly {@link google.protobuf.UninterpretedOption.NamePart.verify|verify} messages. + * @param message NamePart message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.UninterpretedOption.INamePart, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified NamePart message, length delimited. Does not implicitly {@link google.protobuf.UninterpretedOption.NamePart.verify|verify} messages. + * @param message NamePart message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.UninterpretedOption.INamePart, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a NamePart message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns NamePart + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.UninterpretedOption.NamePart; + + /** + * Decodes a NamePart message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns NamePart + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.UninterpretedOption.NamePart; + + /** + * Verifies a NamePart message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a NamePart message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns NamePart + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.UninterpretedOption.NamePart; + + /** + * Creates a plain object from a NamePart message. Also converts values to other types if specified. + * @param message NamePart + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.UninterpretedOption.NamePart, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this NamePart to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for NamePart + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + } + + /** Properties of a SourceCodeInfo. */ + interface ISourceCodeInfo { + + /** SourceCodeInfo location */ + location?: (google.protobuf.SourceCodeInfo.ILocation[]|null); + } + + /** Represents a SourceCodeInfo. */ + class SourceCodeInfo implements ISourceCodeInfo { + + /** + * Constructs a new SourceCodeInfo. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.ISourceCodeInfo); + + /** SourceCodeInfo location. */ + public location: google.protobuf.SourceCodeInfo.ILocation[]; + + /** + * Creates a new SourceCodeInfo instance using the specified properties. + * @param [properties] Properties to set + * @returns SourceCodeInfo instance + */ + public static create(properties?: google.protobuf.ISourceCodeInfo): google.protobuf.SourceCodeInfo; + + /** + * Encodes the specified SourceCodeInfo message. Does not implicitly {@link google.protobuf.SourceCodeInfo.verify|verify} messages. + * @param message SourceCodeInfo message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.ISourceCodeInfo, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified SourceCodeInfo message, length delimited. Does not implicitly {@link google.protobuf.SourceCodeInfo.verify|verify} messages. + * @param message SourceCodeInfo message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.ISourceCodeInfo, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a SourceCodeInfo message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns SourceCodeInfo + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.SourceCodeInfo; + + /** + * Decodes a SourceCodeInfo message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns SourceCodeInfo + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.SourceCodeInfo; + + /** + * Verifies a SourceCodeInfo message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a SourceCodeInfo message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns SourceCodeInfo + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.SourceCodeInfo; + + /** + * Creates a plain object from a SourceCodeInfo message. Also converts values to other types if specified. + * @param message SourceCodeInfo + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.SourceCodeInfo, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this SourceCodeInfo to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for SourceCodeInfo + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace SourceCodeInfo { + + /** Properties of a Location. */ + interface ILocation { + + /** Location path */ + path?: (number[]|null); + + /** Location span */ + span?: (number[]|null); + + /** Location leadingComments */ + leadingComments?: (string|null); + + /** Location trailingComments */ + trailingComments?: (string|null); + + /** Location leadingDetachedComments */ + leadingDetachedComments?: (string[]|null); + } + + /** Represents a Location. */ + class Location implements ILocation { + + /** + * Constructs a new Location. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.SourceCodeInfo.ILocation); + + /** Location path. */ + public path: number[]; + + /** Location span. */ + public span: number[]; + + /** Location leadingComments. */ + public leadingComments: string; + + /** Location trailingComments. */ + public trailingComments: string; + + /** Location leadingDetachedComments. */ + public leadingDetachedComments: string[]; + + /** + * Creates a new Location instance using the specified properties. + * @param [properties] Properties to set + * @returns Location instance + */ + public static create(properties?: google.protobuf.SourceCodeInfo.ILocation): google.protobuf.SourceCodeInfo.Location; + + /** + * Encodes the specified Location message. Does not implicitly {@link google.protobuf.SourceCodeInfo.Location.verify|verify} messages. + * @param message Location message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.SourceCodeInfo.ILocation, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Location message, length delimited. Does not implicitly {@link google.protobuf.SourceCodeInfo.Location.verify|verify} messages. + * @param message Location message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.SourceCodeInfo.ILocation, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a Location message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Location + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.SourceCodeInfo.Location; + + /** + * Decodes a Location message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Location + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.SourceCodeInfo.Location; + + /** + * Verifies a Location message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a Location message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Location + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.SourceCodeInfo.Location; + + /** + * Creates a plain object from a Location message. Also converts values to other types if specified. + * @param message Location + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.SourceCodeInfo.Location, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Location to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Location + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + } + + /** Properties of a GeneratedCodeInfo. */ + interface IGeneratedCodeInfo { + + /** GeneratedCodeInfo annotation */ + annotation?: (google.protobuf.GeneratedCodeInfo.IAnnotation[]|null); + } + + /** Represents a GeneratedCodeInfo. */ + class GeneratedCodeInfo implements IGeneratedCodeInfo { + + /** + * Constructs a new GeneratedCodeInfo. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IGeneratedCodeInfo); + + /** GeneratedCodeInfo annotation. */ + public annotation: google.protobuf.GeneratedCodeInfo.IAnnotation[]; + + /** + * Creates a new GeneratedCodeInfo instance using the specified properties. + * @param [properties] Properties to set + * @returns GeneratedCodeInfo instance + */ + public static create(properties?: google.protobuf.IGeneratedCodeInfo): google.protobuf.GeneratedCodeInfo; + + /** + * Encodes the specified GeneratedCodeInfo message. Does not implicitly {@link google.protobuf.GeneratedCodeInfo.verify|verify} messages. + * @param message GeneratedCodeInfo message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IGeneratedCodeInfo, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified GeneratedCodeInfo message, length delimited. Does not implicitly {@link google.protobuf.GeneratedCodeInfo.verify|verify} messages. + * @param message GeneratedCodeInfo message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IGeneratedCodeInfo, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a GeneratedCodeInfo message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns GeneratedCodeInfo + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.GeneratedCodeInfo; + + /** + * Decodes a GeneratedCodeInfo message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns GeneratedCodeInfo + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.GeneratedCodeInfo; + + /** + * Verifies a GeneratedCodeInfo message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a GeneratedCodeInfo message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns GeneratedCodeInfo + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.GeneratedCodeInfo; + + /** + * Creates a plain object from a GeneratedCodeInfo message. Also converts values to other types if specified. + * @param message GeneratedCodeInfo + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.GeneratedCodeInfo, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this GeneratedCodeInfo to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for GeneratedCodeInfo + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace GeneratedCodeInfo { + + /** Properties of an Annotation. */ + interface IAnnotation { + + /** Annotation path */ + path?: (number[]|null); + + /** Annotation sourceFile */ + sourceFile?: (string|null); + + /** Annotation begin */ + begin?: (number|null); + + /** Annotation end */ + end?: (number|null); + + /** Annotation semantic */ + semantic?: (google.protobuf.GeneratedCodeInfo.Annotation.Semantic|keyof typeof google.protobuf.GeneratedCodeInfo.Annotation.Semantic|null); + } + + /** Represents an Annotation. */ + class Annotation implements IAnnotation { + + /** + * Constructs a new Annotation. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.GeneratedCodeInfo.IAnnotation); + + /** Annotation path. */ + public path: number[]; + + /** Annotation sourceFile. */ + public sourceFile: string; + + /** Annotation begin. */ + public begin: number; + + /** Annotation end. */ + public end: number; + + /** Annotation semantic. */ + public semantic: (google.protobuf.GeneratedCodeInfo.Annotation.Semantic|keyof typeof google.protobuf.GeneratedCodeInfo.Annotation.Semantic); + + /** + * Creates a new Annotation instance using the specified properties. + * @param [properties] Properties to set + * @returns Annotation instance + */ + public static create(properties?: google.protobuf.GeneratedCodeInfo.IAnnotation): google.protobuf.GeneratedCodeInfo.Annotation; + + /** + * Encodes the specified Annotation message. Does not implicitly {@link google.protobuf.GeneratedCodeInfo.Annotation.verify|verify} messages. + * @param message Annotation message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.GeneratedCodeInfo.IAnnotation, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Annotation message, length delimited. Does not implicitly {@link google.protobuf.GeneratedCodeInfo.Annotation.verify|verify} messages. + * @param message Annotation message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.GeneratedCodeInfo.IAnnotation, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an Annotation message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Annotation + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.GeneratedCodeInfo.Annotation; + + /** + * Decodes an Annotation message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Annotation + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.GeneratedCodeInfo.Annotation; + + /** + * Verifies an Annotation message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an Annotation message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Annotation + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.GeneratedCodeInfo.Annotation; + + /** + * Creates a plain object from an Annotation message. Also converts values to other types if specified. + * @param message Annotation + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.GeneratedCodeInfo.Annotation, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Annotation to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Annotation + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace Annotation { + + /** Semantic enum. */ + enum Semantic { + NONE = 0, + SET = 1, + ALIAS = 2 + } + } + } + + /** Properties of a Timestamp. */ + interface ITimestamp { + + /** Timestamp seconds */ + seconds?: (number|Long|string|null); + + /** Timestamp nanos */ + nanos?: (number|null); + } + + /** Represents a Timestamp. */ + class Timestamp implements ITimestamp { + + /** + * Constructs a new Timestamp. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.ITimestamp); + + /** Timestamp seconds. */ + public seconds: (number|Long|string); + + /** Timestamp nanos. */ + public nanos: number; + + /** + * Creates a new Timestamp instance using the specified properties. + * @param [properties] Properties to set + * @returns Timestamp instance + */ + public static create(properties?: google.protobuf.ITimestamp): google.protobuf.Timestamp; + + /** + * Encodes the specified Timestamp message. Does not implicitly {@link google.protobuf.Timestamp.verify|verify} messages. + * @param message Timestamp message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.ITimestamp, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Timestamp message, length delimited. Does not implicitly {@link google.protobuf.Timestamp.verify|verify} messages. + * @param message Timestamp message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.ITimestamp, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a Timestamp message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Timestamp + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.Timestamp; + + /** + * Decodes a Timestamp message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Timestamp + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.Timestamp; + + /** + * Verifies a Timestamp message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a Timestamp message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Timestamp + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.Timestamp; + + /** + * Creates a plain object from a Timestamp message. Also converts values to other types if specified. + * @param message Timestamp + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.Timestamp, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Timestamp to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Timestamp + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a Duration. */ + interface IDuration { + + /** Duration seconds */ + seconds?: (number|Long|string|null); + + /** Duration nanos */ + nanos?: (number|null); + } + + /** Represents a Duration. */ + class Duration implements IDuration { + + /** + * Constructs a new Duration. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IDuration); + + /** Duration seconds. */ + public seconds: (number|Long|string); + + /** Duration nanos. */ + public nanos: number; + + /** + * Creates a new Duration instance using the specified properties. + * @param [properties] Properties to set + * @returns Duration instance + */ + public static create(properties?: google.protobuf.IDuration): google.protobuf.Duration; + + /** + * Encodes the specified Duration message. Does not implicitly {@link google.protobuf.Duration.verify|verify} messages. + * @param message Duration message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IDuration, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Duration message, length delimited. Does not implicitly {@link google.protobuf.Duration.verify|verify} messages. + * @param message Duration message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IDuration, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a Duration message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Duration + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.Duration; + + /** + * Decodes a Duration message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Duration + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.Duration; + + /** + * Verifies a Duration message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a Duration message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Duration + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.Duration; + + /** + * Creates a plain object from a Duration message. Also converts values to other types if specified. + * @param message Duration + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.Duration, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Duration to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Duration + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of an Any. */ + interface IAny { + + /** Any type_url */ + type_url?: (string|null); + + /** Any value */ + value?: (Uint8Array|string|null); + } + + /** Represents an Any. */ + class Any implements IAny { + + /** + * Constructs a new Any. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IAny); + + /** Any type_url. */ + public type_url: string; + + /** Any value. */ + public value: (Uint8Array|string); + + /** + * Creates a new Any instance using the specified properties. + * @param [properties] Properties to set + * @returns Any instance + */ + public static create(properties?: google.protobuf.IAny): google.protobuf.Any; + + /** + * Encodes the specified Any message. Does not implicitly {@link google.protobuf.Any.verify|verify} messages. + * @param message Any message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IAny, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Any message, length delimited. Does not implicitly {@link google.protobuf.Any.verify|verify} messages. + * @param message Any message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IAny, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an Any message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Any + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.Any; + + /** + * Decodes an Any message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Any + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.Any; + + /** + * Verifies an Any message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an Any message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Any + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.Any; + + /** + * Creates a plain object from an Any message. Also converts values to other types if specified. + * @param message Any + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.Any, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Any to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Any + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of an Empty. */ + interface IEmpty { + } + + /** Represents an Empty. */ + class Empty implements IEmpty { + + /** + * Constructs a new Empty. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IEmpty); + + /** + * Creates a new Empty instance using the specified properties. + * @param [properties] Properties to set + * @returns Empty instance + */ + public static create(properties?: google.protobuf.IEmpty): google.protobuf.Empty; + + /** + * Encodes the specified Empty message. Does not implicitly {@link google.protobuf.Empty.verify|verify} messages. + * @param message Empty message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IEmpty, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Empty message, length delimited. Does not implicitly {@link google.protobuf.Empty.verify|verify} messages. + * @param message Empty message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IEmpty, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an Empty message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Empty + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.Empty; + + /** + * Decodes an Empty message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Empty + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.Empty; + + /** + * Verifies an Empty message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an Empty message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Empty + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.Empty; + + /** + * Creates a plain object from an Empty message. Also converts values to other types if specified. + * @param message Empty + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.Empty, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Empty to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Empty + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a FieldMask. */ + interface IFieldMask { + + /** FieldMask paths */ + paths?: (string[]|null); + } + + /** Represents a FieldMask. */ + class FieldMask implements IFieldMask { + + /** + * Constructs a new FieldMask. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IFieldMask); + + /** FieldMask paths. */ + public paths: string[]; + + /** + * Creates a new FieldMask instance using the specified properties. + * @param [properties] Properties to set + * @returns FieldMask instance + */ + public static create(properties?: google.protobuf.IFieldMask): google.protobuf.FieldMask; + + /** + * Encodes the specified FieldMask message. Does not implicitly {@link google.protobuf.FieldMask.verify|verify} messages. + * @param message FieldMask message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IFieldMask, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified FieldMask message, length delimited. Does not implicitly {@link google.protobuf.FieldMask.verify|verify} messages. + * @param message FieldMask message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IFieldMask, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a FieldMask message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns FieldMask + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.FieldMask; + + /** + * Decodes a FieldMask message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns FieldMask + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.FieldMask; + + /** + * Verifies a FieldMask message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a FieldMask message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns FieldMask + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.FieldMask; + + /** + * Creates a plain object from a FieldMask message. Also converts values to other types if specified. + * @param message FieldMask + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.FieldMask, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this FieldMask to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for FieldMask + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + } + + /** Namespace longrunning. */ + namespace longrunning { + + /** Represents an Operations */ + class Operations extends $protobuf.rpc.Service { + + /** + * Constructs a new Operations service. + * @param rpcImpl RPC implementation + * @param [requestDelimited=false] Whether requests are length-delimited + * @param [responseDelimited=false] Whether responses are length-delimited + */ + constructor(rpcImpl: $protobuf.RPCImpl, requestDelimited?: boolean, responseDelimited?: boolean); + + /** + * Creates new Operations service using the specified rpc implementation. + * @param rpcImpl RPC implementation + * @param [requestDelimited=false] Whether requests are length-delimited + * @param [responseDelimited=false] Whether responses are length-delimited + * @returns RPC service. Useful where requests and/or responses are streamed. + */ + public static create(rpcImpl: $protobuf.RPCImpl, requestDelimited?: boolean, responseDelimited?: boolean): Operations; + + /** + * Calls ListOperations. + * @param request ListOperationsRequest message or plain object + * @param callback Node-style callback called with the error, if any, and ListOperationsResponse + */ + public listOperations(request: google.longrunning.IListOperationsRequest, callback: google.longrunning.Operations.ListOperationsCallback): void; + + /** + * Calls ListOperations. + * @param request ListOperationsRequest message or plain object + * @returns Promise + */ + public listOperations(request: google.longrunning.IListOperationsRequest): Promise; + + /** + * Calls GetOperation. + * @param request GetOperationRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Operation + */ + public getOperation(request: google.longrunning.IGetOperationRequest, callback: google.longrunning.Operations.GetOperationCallback): void; + + /** + * Calls GetOperation. + * @param request GetOperationRequest message or plain object + * @returns Promise + */ + public getOperation(request: google.longrunning.IGetOperationRequest): Promise; + + /** + * Calls DeleteOperation. + * @param request DeleteOperationRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Empty + */ + public deleteOperation(request: google.longrunning.IDeleteOperationRequest, callback: google.longrunning.Operations.DeleteOperationCallback): void; + + /** + * Calls DeleteOperation. + * @param request DeleteOperationRequest message or plain object + * @returns Promise + */ + public deleteOperation(request: google.longrunning.IDeleteOperationRequest): Promise; + + /** + * Calls CancelOperation. + * @param request CancelOperationRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Empty + */ + public cancelOperation(request: google.longrunning.ICancelOperationRequest, callback: google.longrunning.Operations.CancelOperationCallback): void; + + /** + * Calls CancelOperation. + * @param request CancelOperationRequest message or plain object + * @returns Promise + */ + public cancelOperation(request: google.longrunning.ICancelOperationRequest): Promise; + + /** + * Calls WaitOperation. + * @param request WaitOperationRequest message or plain object + * @param callback Node-style callback called with the error, if any, and Operation + */ + public waitOperation(request: google.longrunning.IWaitOperationRequest, callback: google.longrunning.Operations.WaitOperationCallback): void; + + /** + * Calls WaitOperation. + * @param request WaitOperationRequest message or plain object + * @returns Promise + */ + public waitOperation(request: google.longrunning.IWaitOperationRequest): Promise; + } + + namespace Operations { + + /** + * Callback as used by {@link google.longrunning.Operations|listOperations}. + * @param error Error, if any + * @param [response] ListOperationsResponse + */ + type ListOperationsCallback = (error: (Error|null), response?: google.longrunning.ListOperationsResponse) => void; + + /** + * Callback as used by {@link google.longrunning.Operations|getOperation}. + * @param error Error, if any + * @param [response] Operation + */ + type GetOperationCallback = (error: (Error|null), response?: google.longrunning.Operation) => void; + + /** + * Callback as used by {@link google.longrunning.Operations|deleteOperation}. + * @param error Error, if any + * @param [response] Empty + */ + type DeleteOperationCallback = (error: (Error|null), response?: google.protobuf.Empty) => void; + + /** + * Callback as used by {@link google.longrunning.Operations|cancelOperation}. + * @param error Error, if any + * @param [response] Empty + */ + type CancelOperationCallback = (error: (Error|null), response?: google.protobuf.Empty) => void; + + /** + * Callback as used by {@link google.longrunning.Operations|waitOperation}. + * @param error Error, if any + * @param [response] Operation + */ + type WaitOperationCallback = (error: (Error|null), response?: google.longrunning.Operation) => void; + } + + /** Properties of an Operation. */ + interface IOperation { + + /** Operation name */ + name?: (string|null); + + /** Operation metadata */ + metadata?: (google.protobuf.IAny|null); + + /** Operation done */ + done?: (boolean|null); + + /** Operation error */ + error?: (google.rpc.IStatus|null); + + /** Operation response */ + response?: (google.protobuf.IAny|null); + } + + /** Represents an Operation. */ + class Operation implements IOperation { + + /** + * Constructs a new Operation. + * @param [properties] Properties to set + */ + constructor(properties?: google.longrunning.IOperation); + + /** Operation name. */ + public name: string; + + /** Operation metadata. */ + public metadata?: (google.protobuf.IAny|null); + + /** Operation done. */ + public done: boolean; + + /** Operation error. */ + public error?: (google.rpc.IStatus|null); + + /** Operation response. */ + public response?: (google.protobuf.IAny|null); + + /** Operation result. */ + public result?: ("error"|"response"); + + /** + * Creates a new Operation instance using the specified properties. + * @param [properties] Properties to set + * @returns Operation instance + */ + public static create(properties?: google.longrunning.IOperation): google.longrunning.Operation; + + /** + * Encodes the specified Operation message. Does not implicitly {@link google.longrunning.Operation.verify|verify} messages. + * @param message Operation message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.longrunning.IOperation, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Operation message, length delimited. Does not implicitly {@link google.longrunning.Operation.verify|verify} messages. + * @param message Operation message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.longrunning.IOperation, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an Operation message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Operation + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.longrunning.Operation; + + /** + * Decodes an Operation message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Operation + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.longrunning.Operation; + + /** + * Verifies an Operation message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an Operation message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Operation + */ + public static fromObject(object: { [k: string]: any }): google.longrunning.Operation; + + /** + * Creates a plain object from an Operation message. Also converts values to other types if specified. + * @param message Operation + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.longrunning.Operation, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Operation to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Operation + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a GetOperationRequest. */ + interface IGetOperationRequest { + + /** GetOperationRequest name */ + name?: (string|null); + } + + /** Represents a GetOperationRequest. */ + class GetOperationRequest implements IGetOperationRequest { + + /** + * Constructs a new GetOperationRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.longrunning.IGetOperationRequest); + + /** GetOperationRequest name. */ + public name: string; + + /** + * Creates a new GetOperationRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns GetOperationRequest instance + */ + public static create(properties?: google.longrunning.IGetOperationRequest): google.longrunning.GetOperationRequest; + + /** + * Encodes the specified GetOperationRequest message. Does not implicitly {@link google.longrunning.GetOperationRequest.verify|verify} messages. + * @param message GetOperationRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.longrunning.IGetOperationRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified GetOperationRequest message, length delimited. Does not implicitly {@link google.longrunning.GetOperationRequest.verify|verify} messages. + * @param message GetOperationRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.longrunning.IGetOperationRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a GetOperationRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns GetOperationRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.longrunning.GetOperationRequest; + + /** + * Decodes a GetOperationRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns GetOperationRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.longrunning.GetOperationRequest; + + /** + * Verifies a GetOperationRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a GetOperationRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns GetOperationRequest + */ + public static fromObject(object: { [k: string]: any }): google.longrunning.GetOperationRequest; + + /** + * Creates a plain object from a GetOperationRequest message. Also converts values to other types if specified. + * @param message GetOperationRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.longrunning.GetOperationRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this GetOperationRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for GetOperationRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ListOperationsRequest. */ + interface IListOperationsRequest { + + /** ListOperationsRequest name */ + name?: (string|null); + + /** ListOperationsRequest filter */ + filter?: (string|null); + + /** ListOperationsRequest pageSize */ + pageSize?: (number|null); + + /** ListOperationsRequest pageToken */ + pageToken?: (string|null); + } + + /** Represents a ListOperationsRequest. */ + class ListOperationsRequest implements IListOperationsRequest { + + /** + * Constructs a new ListOperationsRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.longrunning.IListOperationsRequest); + + /** ListOperationsRequest name. */ + public name: string; + + /** ListOperationsRequest filter. */ + public filter: string; + + /** ListOperationsRequest pageSize. */ + public pageSize: number; + + /** ListOperationsRequest pageToken. */ + public pageToken: string; + + /** + * Creates a new ListOperationsRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns ListOperationsRequest instance + */ + public static create(properties?: google.longrunning.IListOperationsRequest): google.longrunning.ListOperationsRequest; + + /** + * Encodes the specified ListOperationsRequest message. Does not implicitly {@link google.longrunning.ListOperationsRequest.verify|verify} messages. + * @param message ListOperationsRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.longrunning.IListOperationsRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ListOperationsRequest message, length delimited. Does not implicitly {@link google.longrunning.ListOperationsRequest.verify|verify} messages. + * @param message ListOperationsRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.longrunning.IListOperationsRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ListOperationsRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ListOperationsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.longrunning.ListOperationsRequest; + + /** + * Decodes a ListOperationsRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ListOperationsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.longrunning.ListOperationsRequest; + + /** + * Verifies a ListOperationsRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ListOperationsRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ListOperationsRequest + */ + public static fromObject(object: { [k: string]: any }): google.longrunning.ListOperationsRequest; + + /** + * Creates a plain object from a ListOperationsRequest message. Also converts values to other types if specified. + * @param message ListOperationsRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.longrunning.ListOperationsRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ListOperationsRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ListOperationsRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a ListOperationsResponse. */ + interface IListOperationsResponse { + + /** ListOperationsResponse operations */ + operations?: (google.longrunning.IOperation[]|null); + + /** ListOperationsResponse nextPageToken */ + nextPageToken?: (string|null); + } + + /** Represents a ListOperationsResponse. */ + class ListOperationsResponse implements IListOperationsResponse { + + /** + * Constructs a new ListOperationsResponse. + * @param [properties] Properties to set + */ + constructor(properties?: google.longrunning.IListOperationsResponse); + + /** ListOperationsResponse operations. */ + public operations: google.longrunning.IOperation[]; + + /** ListOperationsResponse nextPageToken. */ + public nextPageToken: string; + + /** + * Creates a new ListOperationsResponse instance using the specified properties. + * @param [properties] Properties to set + * @returns ListOperationsResponse instance + */ + public static create(properties?: google.longrunning.IListOperationsResponse): google.longrunning.ListOperationsResponse; + + /** + * Encodes the specified ListOperationsResponse message. Does not implicitly {@link google.longrunning.ListOperationsResponse.verify|verify} messages. + * @param message ListOperationsResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.longrunning.IListOperationsResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified ListOperationsResponse message, length delimited. Does not implicitly {@link google.longrunning.ListOperationsResponse.verify|verify} messages. + * @param message ListOperationsResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.longrunning.IListOperationsResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ListOperationsResponse message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ListOperationsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.longrunning.ListOperationsResponse; + + /** + * Decodes a ListOperationsResponse message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns ListOperationsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.longrunning.ListOperationsResponse; + + /** + * Verifies a ListOperationsResponse message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a ListOperationsResponse message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns ListOperationsResponse + */ + public static fromObject(object: { [k: string]: any }): google.longrunning.ListOperationsResponse; + + /** + * Creates a plain object from a ListOperationsResponse message. Also converts values to other types if specified. + * @param message ListOperationsResponse + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.longrunning.ListOperationsResponse, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this ListOperationsResponse to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for ListOperationsResponse + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a CancelOperationRequest. */ + interface ICancelOperationRequest { + + /** CancelOperationRequest name */ + name?: (string|null); + } + + /** Represents a CancelOperationRequest. */ + class CancelOperationRequest implements ICancelOperationRequest { + + /** + * Constructs a new CancelOperationRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.longrunning.ICancelOperationRequest); + + /** CancelOperationRequest name. */ + public name: string; + + /** + * Creates a new CancelOperationRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns CancelOperationRequest instance + */ + public static create(properties?: google.longrunning.ICancelOperationRequest): google.longrunning.CancelOperationRequest; + + /** + * Encodes the specified CancelOperationRequest message. Does not implicitly {@link google.longrunning.CancelOperationRequest.verify|verify} messages. + * @param message CancelOperationRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.longrunning.ICancelOperationRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified CancelOperationRequest message, length delimited. Does not implicitly {@link google.longrunning.CancelOperationRequest.verify|verify} messages. + * @param message CancelOperationRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.longrunning.ICancelOperationRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a CancelOperationRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns CancelOperationRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.longrunning.CancelOperationRequest; + + /** + * Decodes a CancelOperationRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns CancelOperationRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.longrunning.CancelOperationRequest; + + /** + * Verifies a CancelOperationRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a CancelOperationRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns CancelOperationRequest + */ + public static fromObject(object: { [k: string]: any }): google.longrunning.CancelOperationRequest; + + /** + * Creates a plain object from a CancelOperationRequest message. Also converts values to other types if specified. + * @param message CancelOperationRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.longrunning.CancelOperationRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this CancelOperationRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for CancelOperationRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a DeleteOperationRequest. */ + interface IDeleteOperationRequest { + + /** DeleteOperationRequest name */ + name?: (string|null); + } + + /** Represents a DeleteOperationRequest. */ + class DeleteOperationRequest implements IDeleteOperationRequest { + + /** + * Constructs a new DeleteOperationRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.longrunning.IDeleteOperationRequest); + + /** DeleteOperationRequest name. */ + public name: string; + + /** + * Creates a new DeleteOperationRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns DeleteOperationRequest instance + */ + public static create(properties?: google.longrunning.IDeleteOperationRequest): google.longrunning.DeleteOperationRequest; + + /** + * Encodes the specified DeleteOperationRequest message. Does not implicitly {@link google.longrunning.DeleteOperationRequest.verify|verify} messages. + * @param message DeleteOperationRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.longrunning.IDeleteOperationRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified DeleteOperationRequest message, length delimited. Does not implicitly {@link google.longrunning.DeleteOperationRequest.verify|verify} messages. + * @param message DeleteOperationRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.longrunning.IDeleteOperationRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a DeleteOperationRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns DeleteOperationRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.longrunning.DeleteOperationRequest; + + /** + * Decodes a DeleteOperationRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns DeleteOperationRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.longrunning.DeleteOperationRequest; + + /** + * Verifies a DeleteOperationRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a DeleteOperationRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns DeleteOperationRequest + */ + public static fromObject(object: { [k: string]: any }): google.longrunning.DeleteOperationRequest; + + /** + * Creates a plain object from a DeleteOperationRequest message. Also converts values to other types if specified. + * @param message DeleteOperationRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.longrunning.DeleteOperationRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this DeleteOperationRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for DeleteOperationRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of a WaitOperationRequest. */ + interface IWaitOperationRequest { + + /** WaitOperationRequest name */ + name?: (string|null); + + /** WaitOperationRequest timeout */ + timeout?: (google.protobuf.IDuration|null); + } + + /** Represents a WaitOperationRequest. */ + class WaitOperationRequest implements IWaitOperationRequest { + + /** + * Constructs a new WaitOperationRequest. + * @param [properties] Properties to set + */ + constructor(properties?: google.longrunning.IWaitOperationRequest); + + /** WaitOperationRequest name. */ + public name: string; + + /** WaitOperationRequest timeout. */ + public timeout?: (google.protobuf.IDuration|null); + + /** + * Creates a new WaitOperationRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns WaitOperationRequest instance + */ + public static create(properties?: google.longrunning.IWaitOperationRequest): google.longrunning.WaitOperationRequest; + + /** + * Encodes the specified WaitOperationRequest message. Does not implicitly {@link google.longrunning.WaitOperationRequest.verify|verify} messages. + * @param message WaitOperationRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.longrunning.IWaitOperationRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified WaitOperationRequest message, length delimited. Does not implicitly {@link google.longrunning.WaitOperationRequest.verify|verify} messages. + * @param message WaitOperationRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.longrunning.IWaitOperationRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a WaitOperationRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns WaitOperationRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.longrunning.WaitOperationRequest; + + /** + * Decodes a WaitOperationRequest message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns WaitOperationRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.longrunning.WaitOperationRequest; + + /** + * Verifies a WaitOperationRequest message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a WaitOperationRequest message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns WaitOperationRequest + */ + public static fromObject(object: { [k: string]: any }): google.longrunning.WaitOperationRequest; + + /** + * Creates a plain object from a WaitOperationRequest message. Also converts values to other types if specified. + * @param message WaitOperationRequest + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.longrunning.WaitOperationRequest, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this WaitOperationRequest to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for WaitOperationRequest + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** Properties of an OperationInfo. */ + interface IOperationInfo { + + /** OperationInfo responseType */ + responseType?: (string|null); + + /** OperationInfo metadataType */ + metadataType?: (string|null); + } + + /** Represents an OperationInfo. */ + class OperationInfo implements IOperationInfo { + + /** + * Constructs a new OperationInfo. + * @param [properties] Properties to set + */ + constructor(properties?: google.longrunning.IOperationInfo); + + /** OperationInfo responseType. */ + public responseType: string; + + /** OperationInfo metadataType. */ + public metadataType: string; + + /** + * Creates a new OperationInfo instance using the specified properties. + * @param [properties] Properties to set + * @returns OperationInfo instance + */ + public static create(properties?: google.longrunning.IOperationInfo): google.longrunning.OperationInfo; + + /** + * Encodes the specified OperationInfo message. Does not implicitly {@link google.longrunning.OperationInfo.verify|verify} messages. + * @param message OperationInfo message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.longrunning.IOperationInfo, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified OperationInfo message, length delimited. Does not implicitly {@link google.longrunning.OperationInfo.verify|verify} messages. + * @param message OperationInfo message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.longrunning.IOperationInfo, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an OperationInfo message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns OperationInfo + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.longrunning.OperationInfo; + + /** + * Decodes an OperationInfo message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns OperationInfo + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.longrunning.OperationInfo; + + /** + * Verifies an OperationInfo message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an OperationInfo message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns OperationInfo + */ + public static fromObject(object: { [k: string]: any }): google.longrunning.OperationInfo; + + /** + * Creates a plain object from an OperationInfo message. Also converts values to other types if specified. + * @param message OperationInfo + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.longrunning.OperationInfo, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this OperationInfo to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for OperationInfo + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + } + + /** Namespace rpc. */ + namespace rpc { + + /** Properties of a Status. */ + interface IStatus { + + /** Status code */ + code?: (number|null); + + /** Status message */ + message?: (string|null); + + /** Status details */ + details?: (google.protobuf.IAny[]|null); + } + + /** Represents a Status. */ + class Status implements IStatus { + + /** + * Constructs a new Status. + * @param [properties] Properties to set + */ + constructor(properties?: google.rpc.IStatus); + + /** Status code. */ + public code: number; + + /** Status message. */ + public message: string; + + /** Status details. */ + public details: google.protobuf.IAny[]; + + /** + * Creates a new Status instance using the specified properties. + * @param [properties] Properties to set + * @returns Status instance + */ + public static create(properties?: google.rpc.IStatus): google.rpc.Status; + + /** + * Encodes the specified Status message. Does not implicitly {@link google.rpc.Status.verify|verify} messages. + * @param message Status message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.rpc.IStatus, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Status message, length delimited. Does not implicitly {@link google.rpc.Status.verify|verify} messages. + * @param message Status message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.rpc.IStatus, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a Status message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Status + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.rpc.Status; + + /** + * Decodes a Status message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Status + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.rpc.Status; + + /** + * Verifies a Status message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a Status message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Status + */ + public static fromObject(object: { [k: string]: any }): google.rpc.Status; + + /** + * Creates a plain object from a Status message. Also converts values to other types if specified. + * @param message Status + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.rpc.Status, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Status to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Status + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + } +} diff --git a/packages/google-cloud-edgenetwork/protos/protos.js b/packages/google-cloud-edgenetwork/protos/protos.js new file mode 100644 index 000000000000..9fb7a9007736 --- /dev/null +++ b/packages/google-cloud-edgenetwork/protos/protos.js @@ -0,0 +1,36000 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +/*eslint-disable block-scoped-var, id-length, no-control-regex, no-magic-numbers, no-prototype-builtins, no-redeclare, no-shadow, no-var, sort-vars*/ +(function(global, factory) { /* global define, require, module */ + + /* AMD */ if (typeof define === 'function' && define.amd) + define(["protobufjs/minimal"], factory); + + /* CommonJS */ else if (typeof require === 'function' && typeof module === 'object' && module && module.exports) + module.exports = factory(require("google-gax/build/src/protobuf").protobufMinimal); + +})(this, function($protobuf) { + "use strict"; + + // Common aliases + var $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util; + + // Exported root namespace + var $root = $protobuf.roots._google_cloud_edgenetwork_protos || ($protobuf.roots._google_cloud_edgenetwork_protos = {}); + + $root.google = (function() { + + /** + * Namespace google. + * @exports google + * @namespace + */ + var google = {}; + + google.cloud = (function() { + + /** + * Namespace cloud. + * @memberof google + * @namespace + */ + var cloud = {}; + + cloud.edgenetwork = (function() { + + /** + * Namespace edgenetwork. + * @memberof google.cloud + * @namespace + */ + var edgenetwork = {}; + + edgenetwork.v1 = (function() { + + /** + * Namespace v1. + * @memberof google.cloud.edgenetwork + * @namespace + */ + var v1 = {}; + + /** + * ResourceState enum. + * @name google.cloud.edgenetwork.v1.ResourceState + * @enum {number} + * @property {number} STATE_UNKNOWN=0 STATE_UNKNOWN value + * @property {number} STATE_PENDING=1 STATE_PENDING value + * @property {number} STATE_PROVISIONING=2 STATE_PROVISIONING value + * @property {number} STATE_RUNNING=3 STATE_RUNNING value + * @property {number} STATE_SUSPENDED=4 STATE_SUSPENDED value + * @property {number} STATE_DELETING=5 STATE_DELETING value + */ + v1.ResourceState = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "STATE_UNKNOWN"] = 0; + values[valuesById[1] = "STATE_PENDING"] = 1; + values[valuesById[2] = "STATE_PROVISIONING"] = 2; + values[valuesById[3] = "STATE_RUNNING"] = 3; + values[valuesById[4] = "STATE_SUSPENDED"] = 4; + values[valuesById[5] = "STATE_DELETING"] = 5; + return values; + })(); + + v1.Zone = (function() { + + /** + * Properties of a Zone. + * @memberof google.cloud.edgenetwork.v1 + * @interface IZone + * @property {string|null} [name] Zone name + * @property {google.protobuf.ITimestamp|null} [createTime] Zone createTime + * @property {google.protobuf.ITimestamp|null} [updateTime] Zone updateTime + * @property {Object.|null} [labels] Zone labels + * @property {string|null} [layoutName] Zone layoutName + */ + + /** + * Constructs a new Zone. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a Zone. + * @implements IZone + * @constructor + * @param {google.cloud.edgenetwork.v1.IZone=} [properties] Properties to set + */ + function Zone(properties) { + this.labels = {}; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Zone name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.Zone + * @instance + */ + Zone.prototype.name = ""; + + /** + * Zone createTime. + * @member {google.protobuf.ITimestamp|null|undefined} createTime + * @memberof google.cloud.edgenetwork.v1.Zone + * @instance + */ + Zone.prototype.createTime = null; + + /** + * Zone updateTime. + * @member {google.protobuf.ITimestamp|null|undefined} updateTime + * @memberof google.cloud.edgenetwork.v1.Zone + * @instance + */ + Zone.prototype.updateTime = null; + + /** + * Zone labels. + * @member {Object.} labels + * @memberof google.cloud.edgenetwork.v1.Zone + * @instance + */ + Zone.prototype.labels = $util.emptyObject; + + /** + * Zone layoutName. + * @member {string} layoutName + * @memberof google.cloud.edgenetwork.v1.Zone + * @instance + */ + Zone.prototype.layoutName = ""; + + /** + * Creates a new Zone instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.Zone + * @static + * @param {google.cloud.edgenetwork.v1.IZone=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.Zone} Zone instance + */ + Zone.create = function create(properties) { + return new Zone(properties); + }; + + /** + * Encodes the specified Zone message. Does not implicitly {@link google.cloud.edgenetwork.v1.Zone.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.Zone + * @static + * @param {google.cloud.edgenetwork.v1.IZone} message Zone message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Zone.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.createTime != null && Object.hasOwnProperty.call(message, "createTime")) + $root.google.protobuf.Timestamp.encode(message.createTime, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.updateTime != null && Object.hasOwnProperty.call(message, "updateTime")) + $root.google.protobuf.Timestamp.encode(message.updateTime, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + if (message.labels != null && Object.hasOwnProperty.call(message, "labels")) + for (var keys = Object.keys(message.labels), i = 0; i < keys.length; ++i) + writer.uint32(/* id 4, wireType 2 =*/34).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]).uint32(/* id 2, wireType 2 =*/18).string(message.labels[keys[i]]).ldelim(); + if (message.layoutName != null && Object.hasOwnProperty.call(message, "layoutName")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.layoutName); + return writer; + }; + + /** + * Encodes the specified Zone message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.Zone.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.Zone + * @static + * @param {google.cloud.edgenetwork.v1.IZone} message Zone message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Zone.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a Zone message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.Zone + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.Zone} Zone + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Zone.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.Zone(), key, value; + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.createTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 3: { + message.updateTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 4: { + if (message.labels === $util.emptyObject) + message.labels = {}; + var end2 = reader.uint32() + reader.pos; + key = ""; + value = ""; + while (reader.pos < end2) { + var tag2 = reader.uint32(); + switch (tag2 >>> 3) { + case 1: + key = reader.string(); + break; + case 2: + value = reader.string(); + break; + default: + reader.skipType(tag2 & 7); + break; + } + } + message.labels[key] = value; + break; + } + case 5: { + message.layoutName = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a Zone message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.Zone + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.Zone} Zone + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Zone.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a Zone message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.Zone + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Zone.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.createTime != null && message.hasOwnProperty("createTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.createTime); + if (error) + return "createTime." + error; + } + if (message.updateTime != null && message.hasOwnProperty("updateTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.updateTime); + if (error) + return "updateTime." + error; + } + if (message.labels != null && message.hasOwnProperty("labels")) { + if (!$util.isObject(message.labels)) + return "labels: object expected"; + var key = Object.keys(message.labels); + for (var i = 0; i < key.length; ++i) + if (!$util.isString(message.labels[key[i]])) + return "labels: string{k:string} expected"; + } + if (message.layoutName != null && message.hasOwnProperty("layoutName")) + if (!$util.isString(message.layoutName)) + return "layoutName: string expected"; + return null; + }; + + /** + * Creates a Zone message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.Zone + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.Zone} Zone + */ + Zone.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.Zone) + return object; + var message = new $root.google.cloud.edgenetwork.v1.Zone(); + if (object.name != null) + message.name = String(object.name); + if (object.createTime != null) { + if (typeof object.createTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Zone.createTime: object expected"); + message.createTime = $root.google.protobuf.Timestamp.fromObject(object.createTime); + } + if (object.updateTime != null) { + if (typeof object.updateTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Zone.updateTime: object expected"); + message.updateTime = $root.google.protobuf.Timestamp.fromObject(object.updateTime); + } + if (object.labels) { + if (typeof object.labels !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Zone.labels: object expected"); + message.labels = {}; + for (var keys = Object.keys(object.labels), i = 0; i < keys.length; ++i) + message.labels[keys[i]] = String(object.labels[keys[i]]); + } + if (object.layoutName != null) + message.layoutName = String(object.layoutName); + return message; + }; + + /** + * Creates a plain object from a Zone message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.Zone + * @static + * @param {google.cloud.edgenetwork.v1.Zone} message Zone + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Zone.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.objects || options.defaults) + object.labels = {}; + if (options.defaults) { + object.name = ""; + object.createTime = null; + object.updateTime = null; + object.layoutName = ""; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.createTime != null && message.hasOwnProperty("createTime")) + object.createTime = $root.google.protobuf.Timestamp.toObject(message.createTime, options); + if (message.updateTime != null && message.hasOwnProperty("updateTime")) + object.updateTime = $root.google.protobuf.Timestamp.toObject(message.updateTime, options); + var keys2; + if (message.labels && (keys2 = Object.keys(message.labels)).length) { + object.labels = {}; + for (var j = 0; j < keys2.length; ++j) + object.labels[keys2[j]] = message.labels[keys2[j]]; + } + if (message.layoutName != null && message.hasOwnProperty("layoutName")) + object.layoutName = message.layoutName; + return object; + }; + + /** + * Converts this Zone to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.Zone + * @instance + * @returns {Object.} JSON object + */ + Zone.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Zone + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.Zone + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Zone.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.Zone"; + }; + + return Zone; + })(); + + v1.Network = (function() { + + /** + * Properties of a Network. + * @memberof google.cloud.edgenetwork.v1 + * @interface INetwork + * @property {string|null} [name] Network name + * @property {google.protobuf.ITimestamp|null} [createTime] Network createTime + * @property {google.protobuf.ITimestamp|null} [updateTime] Network updateTime + * @property {Object.|null} [labels] Network labels + * @property {string|null} [description] Network description + * @property {number|null} [mtu] Network mtu + */ + + /** + * Constructs a new Network. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a Network. + * @implements INetwork + * @constructor + * @param {google.cloud.edgenetwork.v1.INetwork=} [properties] Properties to set + */ + function Network(properties) { + this.labels = {}; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Network name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.Network + * @instance + */ + Network.prototype.name = ""; + + /** + * Network createTime. + * @member {google.protobuf.ITimestamp|null|undefined} createTime + * @memberof google.cloud.edgenetwork.v1.Network + * @instance + */ + Network.prototype.createTime = null; + + /** + * Network updateTime. + * @member {google.protobuf.ITimestamp|null|undefined} updateTime + * @memberof google.cloud.edgenetwork.v1.Network + * @instance + */ + Network.prototype.updateTime = null; + + /** + * Network labels. + * @member {Object.} labels + * @memberof google.cloud.edgenetwork.v1.Network + * @instance + */ + Network.prototype.labels = $util.emptyObject; + + /** + * Network description. + * @member {string} description + * @memberof google.cloud.edgenetwork.v1.Network + * @instance + */ + Network.prototype.description = ""; + + /** + * Network mtu. + * @member {number} mtu + * @memberof google.cloud.edgenetwork.v1.Network + * @instance + */ + Network.prototype.mtu = 0; + + /** + * Creates a new Network instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.Network + * @static + * @param {google.cloud.edgenetwork.v1.INetwork=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.Network} Network instance + */ + Network.create = function create(properties) { + return new Network(properties); + }; + + /** + * Encodes the specified Network message. Does not implicitly {@link google.cloud.edgenetwork.v1.Network.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.Network + * @static + * @param {google.cloud.edgenetwork.v1.INetwork} message Network message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Network.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.createTime != null && Object.hasOwnProperty.call(message, "createTime")) + $root.google.protobuf.Timestamp.encode(message.createTime, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.updateTime != null && Object.hasOwnProperty.call(message, "updateTime")) + $root.google.protobuf.Timestamp.encode(message.updateTime, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + if (message.labels != null && Object.hasOwnProperty.call(message, "labels")) + for (var keys = Object.keys(message.labels), i = 0; i < keys.length; ++i) + writer.uint32(/* id 4, wireType 2 =*/34).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]).uint32(/* id 2, wireType 2 =*/18).string(message.labels[keys[i]]).ldelim(); + if (message.description != null && Object.hasOwnProperty.call(message, "description")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.description); + if (message.mtu != null && Object.hasOwnProperty.call(message, "mtu")) + writer.uint32(/* id 6, wireType 0 =*/48).int32(message.mtu); + return writer; + }; + + /** + * Encodes the specified Network message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.Network.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.Network + * @static + * @param {google.cloud.edgenetwork.v1.INetwork} message Network message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Network.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a Network message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.Network + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.Network} Network + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Network.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.Network(), key, value; + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.createTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 3: { + message.updateTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 4: { + if (message.labels === $util.emptyObject) + message.labels = {}; + var end2 = reader.uint32() + reader.pos; + key = ""; + value = ""; + while (reader.pos < end2) { + var tag2 = reader.uint32(); + switch (tag2 >>> 3) { + case 1: + key = reader.string(); + break; + case 2: + value = reader.string(); + break; + default: + reader.skipType(tag2 & 7); + break; + } + } + message.labels[key] = value; + break; + } + case 5: { + message.description = reader.string(); + break; + } + case 6: { + message.mtu = reader.int32(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a Network message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.Network + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.Network} Network + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Network.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a Network message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.Network + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Network.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.createTime != null && message.hasOwnProperty("createTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.createTime); + if (error) + return "createTime." + error; + } + if (message.updateTime != null && message.hasOwnProperty("updateTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.updateTime); + if (error) + return "updateTime." + error; + } + if (message.labels != null && message.hasOwnProperty("labels")) { + if (!$util.isObject(message.labels)) + return "labels: object expected"; + var key = Object.keys(message.labels); + for (var i = 0; i < key.length; ++i) + if (!$util.isString(message.labels[key[i]])) + return "labels: string{k:string} expected"; + } + if (message.description != null && message.hasOwnProperty("description")) + if (!$util.isString(message.description)) + return "description: string expected"; + if (message.mtu != null && message.hasOwnProperty("mtu")) + if (!$util.isInteger(message.mtu)) + return "mtu: integer expected"; + return null; + }; + + /** + * Creates a Network message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.Network + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.Network} Network + */ + Network.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.Network) + return object; + var message = new $root.google.cloud.edgenetwork.v1.Network(); + if (object.name != null) + message.name = String(object.name); + if (object.createTime != null) { + if (typeof object.createTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Network.createTime: object expected"); + message.createTime = $root.google.protobuf.Timestamp.fromObject(object.createTime); + } + if (object.updateTime != null) { + if (typeof object.updateTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Network.updateTime: object expected"); + message.updateTime = $root.google.protobuf.Timestamp.fromObject(object.updateTime); + } + if (object.labels) { + if (typeof object.labels !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Network.labels: object expected"); + message.labels = {}; + for (var keys = Object.keys(object.labels), i = 0; i < keys.length; ++i) + message.labels[keys[i]] = String(object.labels[keys[i]]); + } + if (object.description != null) + message.description = String(object.description); + if (object.mtu != null) + message.mtu = object.mtu | 0; + return message; + }; + + /** + * Creates a plain object from a Network message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.Network + * @static + * @param {google.cloud.edgenetwork.v1.Network} message Network + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Network.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.objects || options.defaults) + object.labels = {}; + if (options.defaults) { + object.name = ""; + object.createTime = null; + object.updateTime = null; + object.description = ""; + object.mtu = 0; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.createTime != null && message.hasOwnProperty("createTime")) + object.createTime = $root.google.protobuf.Timestamp.toObject(message.createTime, options); + if (message.updateTime != null && message.hasOwnProperty("updateTime")) + object.updateTime = $root.google.protobuf.Timestamp.toObject(message.updateTime, options); + var keys2; + if (message.labels && (keys2 = Object.keys(message.labels)).length) { + object.labels = {}; + for (var j = 0; j < keys2.length; ++j) + object.labels[keys2[j]] = message.labels[keys2[j]]; + } + if (message.description != null && message.hasOwnProperty("description")) + object.description = message.description; + if (message.mtu != null && message.hasOwnProperty("mtu")) + object.mtu = message.mtu; + return object; + }; + + /** + * Converts this Network to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.Network + * @instance + * @returns {Object.} JSON object + */ + Network.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Network + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.Network + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Network.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.Network"; + }; + + return Network; + })(); + + v1.Subnet = (function() { + + /** + * Properties of a Subnet. + * @memberof google.cloud.edgenetwork.v1 + * @interface ISubnet + * @property {string|null} [name] Subnet name + * @property {google.protobuf.ITimestamp|null} [createTime] Subnet createTime + * @property {google.protobuf.ITimestamp|null} [updateTime] Subnet updateTime + * @property {Object.|null} [labels] Subnet labels + * @property {string|null} [description] Subnet description + * @property {string|null} [network] Subnet network + * @property {Array.|null} [ipv4Cidr] Subnet ipv4Cidr + * @property {Array.|null} [ipv6Cidr] Subnet ipv6Cidr + * @property {number|null} [vlanId] Subnet vlanId + * @property {google.cloud.edgenetwork.v1.ResourceState|null} [state] Subnet state + */ + + /** + * Constructs a new Subnet. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a Subnet. + * @implements ISubnet + * @constructor + * @param {google.cloud.edgenetwork.v1.ISubnet=} [properties] Properties to set + */ + function Subnet(properties) { + this.labels = {}; + this.ipv4Cidr = []; + this.ipv6Cidr = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Subnet name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.Subnet + * @instance + */ + Subnet.prototype.name = ""; + + /** + * Subnet createTime. + * @member {google.protobuf.ITimestamp|null|undefined} createTime + * @memberof google.cloud.edgenetwork.v1.Subnet + * @instance + */ + Subnet.prototype.createTime = null; + + /** + * Subnet updateTime. + * @member {google.protobuf.ITimestamp|null|undefined} updateTime + * @memberof google.cloud.edgenetwork.v1.Subnet + * @instance + */ + Subnet.prototype.updateTime = null; + + /** + * Subnet labels. + * @member {Object.} labels + * @memberof google.cloud.edgenetwork.v1.Subnet + * @instance + */ + Subnet.prototype.labels = $util.emptyObject; + + /** + * Subnet description. + * @member {string} description + * @memberof google.cloud.edgenetwork.v1.Subnet + * @instance + */ + Subnet.prototype.description = ""; + + /** + * Subnet network. + * @member {string} network + * @memberof google.cloud.edgenetwork.v1.Subnet + * @instance + */ + Subnet.prototype.network = ""; + + /** + * Subnet ipv4Cidr. + * @member {Array.} ipv4Cidr + * @memberof google.cloud.edgenetwork.v1.Subnet + * @instance + */ + Subnet.prototype.ipv4Cidr = $util.emptyArray; + + /** + * Subnet ipv6Cidr. + * @member {Array.} ipv6Cidr + * @memberof google.cloud.edgenetwork.v1.Subnet + * @instance + */ + Subnet.prototype.ipv6Cidr = $util.emptyArray; + + /** + * Subnet vlanId. + * @member {number} vlanId + * @memberof google.cloud.edgenetwork.v1.Subnet + * @instance + */ + Subnet.prototype.vlanId = 0; + + /** + * Subnet state. + * @member {google.cloud.edgenetwork.v1.ResourceState} state + * @memberof google.cloud.edgenetwork.v1.Subnet + * @instance + */ + Subnet.prototype.state = 0; + + /** + * Creates a new Subnet instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.Subnet + * @static + * @param {google.cloud.edgenetwork.v1.ISubnet=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.Subnet} Subnet instance + */ + Subnet.create = function create(properties) { + return new Subnet(properties); + }; + + /** + * Encodes the specified Subnet message. Does not implicitly {@link google.cloud.edgenetwork.v1.Subnet.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.Subnet + * @static + * @param {google.cloud.edgenetwork.v1.ISubnet} message Subnet message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Subnet.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.createTime != null && Object.hasOwnProperty.call(message, "createTime")) + $root.google.protobuf.Timestamp.encode(message.createTime, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.updateTime != null && Object.hasOwnProperty.call(message, "updateTime")) + $root.google.protobuf.Timestamp.encode(message.updateTime, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + if (message.labels != null && Object.hasOwnProperty.call(message, "labels")) + for (var keys = Object.keys(message.labels), i = 0; i < keys.length; ++i) + writer.uint32(/* id 4, wireType 2 =*/34).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]).uint32(/* id 2, wireType 2 =*/18).string(message.labels[keys[i]]).ldelim(); + if (message.description != null && Object.hasOwnProperty.call(message, "description")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.description); + if (message.network != null && Object.hasOwnProperty.call(message, "network")) + writer.uint32(/* id 6, wireType 2 =*/50).string(message.network); + if (message.ipv4Cidr != null && message.ipv4Cidr.length) + for (var i = 0; i < message.ipv4Cidr.length; ++i) + writer.uint32(/* id 7, wireType 2 =*/58).string(message.ipv4Cidr[i]); + if (message.ipv6Cidr != null && message.ipv6Cidr.length) + for (var i = 0; i < message.ipv6Cidr.length; ++i) + writer.uint32(/* id 8, wireType 2 =*/66).string(message.ipv6Cidr[i]); + if (message.vlanId != null && Object.hasOwnProperty.call(message, "vlanId")) + writer.uint32(/* id 9, wireType 0 =*/72).int32(message.vlanId); + if (message.state != null && Object.hasOwnProperty.call(message, "state")) + writer.uint32(/* id 10, wireType 0 =*/80).int32(message.state); + return writer; + }; + + /** + * Encodes the specified Subnet message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.Subnet.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.Subnet + * @static + * @param {google.cloud.edgenetwork.v1.ISubnet} message Subnet message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Subnet.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a Subnet message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.Subnet + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.Subnet} Subnet + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Subnet.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.Subnet(), key, value; + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.createTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 3: { + message.updateTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 4: { + if (message.labels === $util.emptyObject) + message.labels = {}; + var end2 = reader.uint32() + reader.pos; + key = ""; + value = ""; + while (reader.pos < end2) { + var tag2 = reader.uint32(); + switch (tag2 >>> 3) { + case 1: + key = reader.string(); + break; + case 2: + value = reader.string(); + break; + default: + reader.skipType(tag2 & 7); + break; + } + } + message.labels[key] = value; + break; + } + case 5: { + message.description = reader.string(); + break; + } + case 6: { + message.network = reader.string(); + break; + } + case 7: { + if (!(message.ipv4Cidr && message.ipv4Cidr.length)) + message.ipv4Cidr = []; + message.ipv4Cidr.push(reader.string()); + break; + } + case 8: { + if (!(message.ipv6Cidr && message.ipv6Cidr.length)) + message.ipv6Cidr = []; + message.ipv6Cidr.push(reader.string()); + break; + } + case 9: { + message.vlanId = reader.int32(); + break; + } + case 10: { + message.state = reader.int32(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a Subnet message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.Subnet + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.Subnet} Subnet + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Subnet.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a Subnet message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.Subnet + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Subnet.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.createTime != null && message.hasOwnProperty("createTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.createTime); + if (error) + return "createTime." + error; + } + if (message.updateTime != null && message.hasOwnProperty("updateTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.updateTime); + if (error) + return "updateTime." + error; + } + if (message.labels != null && message.hasOwnProperty("labels")) { + if (!$util.isObject(message.labels)) + return "labels: object expected"; + var key = Object.keys(message.labels); + for (var i = 0; i < key.length; ++i) + if (!$util.isString(message.labels[key[i]])) + return "labels: string{k:string} expected"; + } + if (message.description != null && message.hasOwnProperty("description")) + if (!$util.isString(message.description)) + return "description: string expected"; + if (message.network != null && message.hasOwnProperty("network")) + if (!$util.isString(message.network)) + return "network: string expected"; + if (message.ipv4Cidr != null && message.hasOwnProperty("ipv4Cidr")) { + if (!Array.isArray(message.ipv4Cidr)) + return "ipv4Cidr: array expected"; + for (var i = 0; i < message.ipv4Cidr.length; ++i) + if (!$util.isString(message.ipv4Cidr[i])) + return "ipv4Cidr: string[] expected"; + } + if (message.ipv6Cidr != null && message.hasOwnProperty("ipv6Cidr")) { + if (!Array.isArray(message.ipv6Cidr)) + return "ipv6Cidr: array expected"; + for (var i = 0; i < message.ipv6Cidr.length; ++i) + if (!$util.isString(message.ipv6Cidr[i])) + return "ipv6Cidr: string[] expected"; + } + if (message.vlanId != null && message.hasOwnProperty("vlanId")) + if (!$util.isInteger(message.vlanId)) + return "vlanId: integer expected"; + if (message.state != null && message.hasOwnProperty("state")) + switch (message.state) { + default: + return "state: enum value expected"; + case 0: + case 1: + case 2: + case 3: + case 4: + case 5: + break; + } + return null; + }; + + /** + * Creates a Subnet message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.Subnet + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.Subnet} Subnet + */ + Subnet.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.Subnet) + return object; + var message = new $root.google.cloud.edgenetwork.v1.Subnet(); + if (object.name != null) + message.name = String(object.name); + if (object.createTime != null) { + if (typeof object.createTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Subnet.createTime: object expected"); + message.createTime = $root.google.protobuf.Timestamp.fromObject(object.createTime); + } + if (object.updateTime != null) { + if (typeof object.updateTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Subnet.updateTime: object expected"); + message.updateTime = $root.google.protobuf.Timestamp.fromObject(object.updateTime); + } + if (object.labels) { + if (typeof object.labels !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Subnet.labels: object expected"); + message.labels = {}; + for (var keys = Object.keys(object.labels), i = 0; i < keys.length; ++i) + message.labels[keys[i]] = String(object.labels[keys[i]]); + } + if (object.description != null) + message.description = String(object.description); + if (object.network != null) + message.network = String(object.network); + if (object.ipv4Cidr) { + if (!Array.isArray(object.ipv4Cidr)) + throw TypeError(".google.cloud.edgenetwork.v1.Subnet.ipv4Cidr: array expected"); + message.ipv4Cidr = []; + for (var i = 0; i < object.ipv4Cidr.length; ++i) + message.ipv4Cidr[i] = String(object.ipv4Cidr[i]); + } + if (object.ipv6Cidr) { + if (!Array.isArray(object.ipv6Cidr)) + throw TypeError(".google.cloud.edgenetwork.v1.Subnet.ipv6Cidr: array expected"); + message.ipv6Cidr = []; + for (var i = 0; i < object.ipv6Cidr.length; ++i) + message.ipv6Cidr[i] = String(object.ipv6Cidr[i]); + } + if (object.vlanId != null) + message.vlanId = object.vlanId | 0; + switch (object.state) { + default: + if (typeof object.state === "number") { + message.state = object.state; + break; + } + break; + case "STATE_UNKNOWN": + case 0: + message.state = 0; + break; + case "STATE_PENDING": + case 1: + message.state = 1; + break; + case "STATE_PROVISIONING": + case 2: + message.state = 2; + break; + case "STATE_RUNNING": + case 3: + message.state = 3; + break; + case "STATE_SUSPENDED": + case 4: + message.state = 4; + break; + case "STATE_DELETING": + case 5: + message.state = 5; + break; + } + return message; + }; + + /** + * Creates a plain object from a Subnet message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.Subnet + * @static + * @param {google.cloud.edgenetwork.v1.Subnet} message Subnet + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Subnet.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.ipv4Cidr = []; + object.ipv6Cidr = []; + } + if (options.objects || options.defaults) + object.labels = {}; + if (options.defaults) { + object.name = ""; + object.createTime = null; + object.updateTime = null; + object.description = ""; + object.network = ""; + object.vlanId = 0; + object.state = options.enums === String ? "STATE_UNKNOWN" : 0; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.createTime != null && message.hasOwnProperty("createTime")) + object.createTime = $root.google.protobuf.Timestamp.toObject(message.createTime, options); + if (message.updateTime != null && message.hasOwnProperty("updateTime")) + object.updateTime = $root.google.protobuf.Timestamp.toObject(message.updateTime, options); + var keys2; + if (message.labels && (keys2 = Object.keys(message.labels)).length) { + object.labels = {}; + for (var j = 0; j < keys2.length; ++j) + object.labels[keys2[j]] = message.labels[keys2[j]]; + } + if (message.description != null && message.hasOwnProperty("description")) + object.description = message.description; + if (message.network != null && message.hasOwnProperty("network")) + object.network = message.network; + if (message.ipv4Cidr && message.ipv4Cidr.length) { + object.ipv4Cidr = []; + for (var j = 0; j < message.ipv4Cidr.length; ++j) + object.ipv4Cidr[j] = message.ipv4Cidr[j]; + } + if (message.ipv6Cidr && message.ipv6Cidr.length) { + object.ipv6Cidr = []; + for (var j = 0; j < message.ipv6Cidr.length; ++j) + object.ipv6Cidr[j] = message.ipv6Cidr[j]; + } + if (message.vlanId != null && message.hasOwnProperty("vlanId")) + object.vlanId = message.vlanId; + if (message.state != null && message.hasOwnProperty("state")) + object.state = options.enums === String ? $root.google.cloud.edgenetwork.v1.ResourceState[message.state] === undefined ? message.state : $root.google.cloud.edgenetwork.v1.ResourceState[message.state] : message.state; + return object; + }; + + /** + * Converts this Subnet to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.Subnet + * @instance + * @returns {Object.} JSON object + */ + Subnet.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Subnet + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.Subnet + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Subnet.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.Subnet"; + }; + + return Subnet; + })(); + + v1.Interconnect = (function() { + + /** + * Properties of an Interconnect. + * @memberof google.cloud.edgenetwork.v1 + * @interface IInterconnect + * @property {string|null} [name] Interconnect name + * @property {google.protobuf.ITimestamp|null} [createTime] Interconnect createTime + * @property {google.protobuf.ITimestamp|null} [updateTime] Interconnect updateTime + * @property {Object.|null} [labels] Interconnect labels + * @property {string|null} [description] Interconnect description + * @property {google.cloud.edgenetwork.v1.Interconnect.InterconnectType|null} [interconnectType] Interconnect interconnectType + * @property {string|null} [uuid] Interconnect uuid + * @property {string|null} [deviceCloudResourceName] Interconnect deviceCloudResourceName + * @property {Array.|null} [physicalPorts] Interconnect physicalPorts + */ + + /** + * Constructs a new Interconnect. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents an Interconnect. + * @implements IInterconnect + * @constructor + * @param {google.cloud.edgenetwork.v1.IInterconnect=} [properties] Properties to set + */ + function Interconnect(properties) { + this.labels = {}; + this.physicalPorts = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Interconnect name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @instance + */ + Interconnect.prototype.name = ""; + + /** + * Interconnect createTime. + * @member {google.protobuf.ITimestamp|null|undefined} createTime + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @instance + */ + Interconnect.prototype.createTime = null; + + /** + * Interconnect updateTime. + * @member {google.protobuf.ITimestamp|null|undefined} updateTime + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @instance + */ + Interconnect.prototype.updateTime = null; + + /** + * Interconnect labels. + * @member {Object.} labels + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @instance + */ + Interconnect.prototype.labels = $util.emptyObject; + + /** + * Interconnect description. + * @member {string} description + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @instance + */ + Interconnect.prototype.description = ""; + + /** + * Interconnect interconnectType. + * @member {google.cloud.edgenetwork.v1.Interconnect.InterconnectType} interconnectType + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @instance + */ + Interconnect.prototype.interconnectType = 0; + + /** + * Interconnect uuid. + * @member {string} uuid + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @instance + */ + Interconnect.prototype.uuid = ""; + + /** + * Interconnect deviceCloudResourceName. + * @member {string} deviceCloudResourceName + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @instance + */ + Interconnect.prototype.deviceCloudResourceName = ""; + + /** + * Interconnect physicalPorts. + * @member {Array.} physicalPorts + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @instance + */ + Interconnect.prototype.physicalPorts = $util.emptyArray; + + /** + * Creates a new Interconnect instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @static + * @param {google.cloud.edgenetwork.v1.IInterconnect=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.Interconnect} Interconnect instance + */ + Interconnect.create = function create(properties) { + return new Interconnect(properties); + }; + + /** + * Encodes the specified Interconnect message. Does not implicitly {@link google.cloud.edgenetwork.v1.Interconnect.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @static + * @param {google.cloud.edgenetwork.v1.IInterconnect} message Interconnect message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Interconnect.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.createTime != null && Object.hasOwnProperty.call(message, "createTime")) + $root.google.protobuf.Timestamp.encode(message.createTime, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.updateTime != null && Object.hasOwnProperty.call(message, "updateTime")) + $root.google.protobuf.Timestamp.encode(message.updateTime, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + if (message.labels != null && Object.hasOwnProperty.call(message, "labels")) + for (var keys = Object.keys(message.labels), i = 0; i < keys.length; ++i) + writer.uint32(/* id 4, wireType 2 =*/34).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]).uint32(/* id 2, wireType 2 =*/18).string(message.labels[keys[i]]).ldelim(); + if (message.description != null && Object.hasOwnProperty.call(message, "description")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.description); + if (message.interconnectType != null && Object.hasOwnProperty.call(message, "interconnectType")) + writer.uint32(/* id 6, wireType 0 =*/48).int32(message.interconnectType); + if (message.uuid != null && Object.hasOwnProperty.call(message, "uuid")) + writer.uint32(/* id 7, wireType 2 =*/58).string(message.uuid); + if (message.deviceCloudResourceName != null && Object.hasOwnProperty.call(message, "deviceCloudResourceName")) + writer.uint32(/* id 8, wireType 2 =*/66).string(message.deviceCloudResourceName); + if (message.physicalPorts != null && message.physicalPorts.length) + for (var i = 0; i < message.physicalPorts.length; ++i) + writer.uint32(/* id 9, wireType 2 =*/74).string(message.physicalPorts[i]); + return writer; + }; + + /** + * Encodes the specified Interconnect message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.Interconnect.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @static + * @param {google.cloud.edgenetwork.v1.IInterconnect} message Interconnect message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Interconnect.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an Interconnect message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.Interconnect} Interconnect + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Interconnect.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.Interconnect(), key, value; + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.createTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 3: { + message.updateTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 4: { + if (message.labels === $util.emptyObject) + message.labels = {}; + var end2 = reader.uint32() + reader.pos; + key = ""; + value = ""; + while (reader.pos < end2) { + var tag2 = reader.uint32(); + switch (tag2 >>> 3) { + case 1: + key = reader.string(); + break; + case 2: + value = reader.string(); + break; + default: + reader.skipType(tag2 & 7); + break; + } + } + message.labels[key] = value; + break; + } + case 5: { + message.description = reader.string(); + break; + } + case 6: { + message.interconnectType = reader.int32(); + break; + } + case 7: { + message.uuid = reader.string(); + break; + } + case 8: { + message.deviceCloudResourceName = reader.string(); + break; + } + case 9: { + if (!(message.physicalPorts && message.physicalPorts.length)) + message.physicalPorts = []; + message.physicalPorts.push(reader.string()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an Interconnect message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.Interconnect} Interconnect + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Interconnect.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an Interconnect message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Interconnect.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.createTime != null && message.hasOwnProperty("createTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.createTime); + if (error) + return "createTime." + error; + } + if (message.updateTime != null && message.hasOwnProperty("updateTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.updateTime); + if (error) + return "updateTime." + error; + } + if (message.labels != null && message.hasOwnProperty("labels")) { + if (!$util.isObject(message.labels)) + return "labels: object expected"; + var key = Object.keys(message.labels); + for (var i = 0; i < key.length; ++i) + if (!$util.isString(message.labels[key[i]])) + return "labels: string{k:string} expected"; + } + if (message.description != null && message.hasOwnProperty("description")) + if (!$util.isString(message.description)) + return "description: string expected"; + if (message.interconnectType != null && message.hasOwnProperty("interconnectType")) + switch (message.interconnectType) { + default: + return "interconnectType: enum value expected"; + case 0: + case 1: + break; + } + if (message.uuid != null && message.hasOwnProperty("uuid")) + if (!$util.isString(message.uuid)) + return "uuid: string expected"; + if (message.deviceCloudResourceName != null && message.hasOwnProperty("deviceCloudResourceName")) + if (!$util.isString(message.deviceCloudResourceName)) + return "deviceCloudResourceName: string expected"; + if (message.physicalPorts != null && message.hasOwnProperty("physicalPorts")) { + if (!Array.isArray(message.physicalPorts)) + return "physicalPorts: array expected"; + for (var i = 0; i < message.physicalPorts.length; ++i) + if (!$util.isString(message.physicalPorts[i])) + return "physicalPorts: string[] expected"; + } + return null; + }; + + /** + * Creates an Interconnect message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.Interconnect} Interconnect + */ + Interconnect.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.Interconnect) + return object; + var message = new $root.google.cloud.edgenetwork.v1.Interconnect(); + if (object.name != null) + message.name = String(object.name); + if (object.createTime != null) { + if (typeof object.createTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Interconnect.createTime: object expected"); + message.createTime = $root.google.protobuf.Timestamp.fromObject(object.createTime); + } + if (object.updateTime != null) { + if (typeof object.updateTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Interconnect.updateTime: object expected"); + message.updateTime = $root.google.protobuf.Timestamp.fromObject(object.updateTime); + } + if (object.labels) { + if (typeof object.labels !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Interconnect.labels: object expected"); + message.labels = {}; + for (var keys = Object.keys(object.labels), i = 0; i < keys.length; ++i) + message.labels[keys[i]] = String(object.labels[keys[i]]); + } + if (object.description != null) + message.description = String(object.description); + switch (object.interconnectType) { + default: + if (typeof object.interconnectType === "number") { + message.interconnectType = object.interconnectType; + break; + } + break; + case "INTERCONNECT_TYPE_UNSPECIFIED": + case 0: + message.interconnectType = 0; + break; + case "DEDICATED": + case 1: + message.interconnectType = 1; + break; + } + if (object.uuid != null) + message.uuid = String(object.uuid); + if (object.deviceCloudResourceName != null) + message.deviceCloudResourceName = String(object.deviceCloudResourceName); + if (object.physicalPorts) { + if (!Array.isArray(object.physicalPorts)) + throw TypeError(".google.cloud.edgenetwork.v1.Interconnect.physicalPorts: array expected"); + message.physicalPorts = []; + for (var i = 0; i < object.physicalPorts.length; ++i) + message.physicalPorts[i] = String(object.physicalPorts[i]); + } + return message; + }; + + /** + * Creates a plain object from an Interconnect message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @static + * @param {google.cloud.edgenetwork.v1.Interconnect} message Interconnect + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Interconnect.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.physicalPorts = []; + if (options.objects || options.defaults) + object.labels = {}; + if (options.defaults) { + object.name = ""; + object.createTime = null; + object.updateTime = null; + object.description = ""; + object.interconnectType = options.enums === String ? "INTERCONNECT_TYPE_UNSPECIFIED" : 0; + object.uuid = ""; + object.deviceCloudResourceName = ""; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.createTime != null && message.hasOwnProperty("createTime")) + object.createTime = $root.google.protobuf.Timestamp.toObject(message.createTime, options); + if (message.updateTime != null && message.hasOwnProperty("updateTime")) + object.updateTime = $root.google.protobuf.Timestamp.toObject(message.updateTime, options); + var keys2; + if (message.labels && (keys2 = Object.keys(message.labels)).length) { + object.labels = {}; + for (var j = 0; j < keys2.length; ++j) + object.labels[keys2[j]] = message.labels[keys2[j]]; + } + if (message.description != null && message.hasOwnProperty("description")) + object.description = message.description; + if (message.interconnectType != null && message.hasOwnProperty("interconnectType")) + object.interconnectType = options.enums === String ? $root.google.cloud.edgenetwork.v1.Interconnect.InterconnectType[message.interconnectType] === undefined ? message.interconnectType : $root.google.cloud.edgenetwork.v1.Interconnect.InterconnectType[message.interconnectType] : message.interconnectType; + if (message.uuid != null && message.hasOwnProperty("uuid")) + object.uuid = message.uuid; + if (message.deviceCloudResourceName != null && message.hasOwnProperty("deviceCloudResourceName")) + object.deviceCloudResourceName = message.deviceCloudResourceName; + if (message.physicalPorts && message.physicalPorts.length) { + object.physicalPorts = []; + for (var j = 0; j < message.physicalPorts.length; ++j) + object.physicalPorts[j] = message.physicalPorts[j]; + } + return object; + }; + + /** + * Converts this Interconnect to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @instance + * @returns {Object.} JSON object + */ + Interconnect.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Interconnect + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.Interconnect + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Interconnect.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.Interconnect"; + }; + + /** + * InterconnectType enum. + * @name google.cloud.edgenetwork.v1.Interconnect.InterconnectType + * @enum {number} + * @property {number} INTERCONNECT_TYPE_UNSPECIFIED=0 INTERCONNECT_TYPE_UNSPECIFIED value + * @property {number} DEDICATED=1 DEDICATED value + */ + Interconnect.InterconnectType = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "INTERCONNECT_TYPE_UNSPECIFIED"] = 0; + values[valuesById[1] = "DEDICATED"] = 1; + return values; + })(); + + return Interconnect; + })(); + + v1.InterconnectAttachment = (function() { + + /** + * Properties of an InterconnectAttachment. + * @memberof google.cloud.edgenetwork.v1 + * @interface IInterconnectAttachment + * @property {string|null} [name] InterconnectAttachment name + * @property {google.protobuf.ITimestamp|null} [createTime] InterconnectAttachment createTime + * @property {google.protobuf.ITimestamp|null} [updateTime] InterconnectAttachment updateTime + * @property {Object.|null} [labels] InterconnectAttachment labels + * @property {string|null} [description] InterconnectAttachment description + * @property {string|null} [interconnect] InterconnectAttachment interconnect + * @property {string|null} [network] InterconnectAttachment network + * @property {number|null} [vlanId] InterconnectAttachment vlanId + * @property {number|null} [mtu] InterconnectAttachment mtu + * @property {google.cloud.edgenetwork.v1.ResourceState|null} [state] InterconnectAttachment state + */ + + /** + * Constructs a new InterconnectAttachment. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents an InterconnectAttachment. + * @implements IInterconnectAttachment + * @constructor + * @param {google.cloud.edgenetwork.v1.IInterconnectAttachment=} [properties] Properties to set + */ + function InterconnectAttachment(properties) { + this.labels = {}; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * InterconnectAttachment name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @instance + */ + InterconnectAttachment.prototype.name = ""; + + /** + * InterconnectAttachment createTime. + * @member {google.protobuf.ITimestamp|null|undefined} createTime + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @instance + */ + InterconnectAttachment.prototype.createTime = null; + + /** + * InterconnectAttachment updateTime. + * @member {google.protobuf.ITimestamp|null|undefined} updateTime + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @instance + */ + InterconnectAttachment.prototype.updateTime = null; + + /** + * InterconnectAttachment labels. + * @member {Object.} labels + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @instance + */ + InterconnectAttachment.prototype.labels = $util.emptyObject; + + /** + * InterconnectAttachment description. + * @member {string} description + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @instance + */ + InterconnectAttachment.prototype.description = ""; + + /** + * InterconnectAttachment interconnect. + * @member {string} interconnect + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @instance + */ + InterconnectAttachment.prototype.interconnect = ""; + + /** + * InterconnectAttachment network. + * @member {string} network + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @instance + */ + InterconnectAttachment.prototype.network = ""; + + /** + * InterconnectAttachment vlanId. + * @member {number} vlanId + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @instance + */ + InterconnectAttachment.prototype.vlanId = 0; + + /** + * InterconnectAttachment mtu. + * @member {number} mtu + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @instance + */ + InterconnectAttachment.prototype.mtu = 0; + + /** + * InterconnectAttachment state. + * @member {google.cloud.edgenetwork.v1.ResourceState} state + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @instance + */ + InterconnectAttachment.prototype.state = 0; + + /** + * Creates a new InterconnectAttachment instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @static + * @param {google.cloud.edgenetwork.v1.IInterconnectAttachment=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.InterconnectAttachment} InterconnectAttachment instance + */ + InterconnectAttachment.create = function create(properties) { + return new InterconnectAttachment(properties); + }; + + /** + * Encodes the specified InterconnectAttachment message. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectAttachment.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @static + * @param {google.cloud.edgenetwork.v1.IInterconnectAttachment} message InterconnectAttachment message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + InterconnectAttachment.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.createTime != null && Object.hasOwnProperty.call(message, "createTime")) + $root.google.protobuf.Timestamp.encode(message.createTime, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.updateTime != null && Object.hasOwnProperty.call(message, "updateTime")) + $root.google.protobuf.Timestamp.encode(message.updateTime, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + if (message.labels != null && Object.hasOwnProperty.call(message, "labels")) + for (var keys = Object.keys(message.labels), i = 0; i < keys.length; ++i) + writer.uint32(/* id 4, wireType 2 =*/34).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]).uint32(/* id 2, wireType 2 =*/18).string(message.labels[keys[i]]).ldelim(); + if (message.description != null && Object.hasOwnProperty.call(message, "description")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.description); + if (message.interconnect != null && Object.hasOwnProperty.call(message, "interconnect")) + writer.uint32(/* id 6, wireType 2 =*/50).string(message.interconnect); + if (message.vlanId != null && Object.hasOwnProperty.call(message, "vlanId")) + writer.uint32(/* id 8, wireType 0 =*/64).int32(message.vlanId); + if (message.mtu != null && Object.hasOwnProperty.call(message, "mtu")) + writer.uint32(/* id 9, wireType 0 =*/72).int32(message.mtu); + if (message.state != null && Object.hasOwnProperty.call(message, "state")) + writer.uint32(/* id 10, wireType 0 =*/80).int32(message.state); + if (message.network != null && Object.hasOwnProperty.call(message, "network")) + writer.uint32(/* id 11, wireType 2 =*/90).string(message.network); + return writer; + }; + + /** + * Encodes the specified InterconnectAttachment message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectAttachment.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @static + * @param {google.cloud.edgenetwork.v1.IInterconnectAttachment} message InterconnectAttachment message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + InterconnectAttachment.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an InterconnectAttachment message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.InterconnectAttachment} InterconnectAttachment + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + InterconnectAttachment.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.InterconnectAttachment(), key, value; + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.createTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 3: { + message.updateTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 4: { + if (message.labels === $util.emptyObject) + message.labels = {}; + var end2 = reader.uint32() + reader.pos; + key = ""; + value = ""; + while (reader.pos < end2) { + var tag2 = reader.uint32(); + switch (tag2 >>> 3) { + case 1: + key = reader.string(); + break; + case 2: + value = reader.string(); + break; + default: + reader.skipType(tag2 & 7); + break; + } + } + message.labels[key] = value; + break; + } + case 5: { + message.description = reader.string(); + break; + } + case 6: { + message.interconnect = reader.string(); + break; + } + case 11: { + message.network = reader.string(); + break; + } + case 8: { + message.vlanId = reader.int32(); + break; + } + case 9: { + message.mtu = reader.int32(); + break; + } + case 10: { + message.state = reader.int32(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an InterconnectAttachment message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.InterconnectAttachment} InterconnectAttachment + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + InterconnectAttachment.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an InterconnectAttachment message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + InterconnectAttachment.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.createTime != null && message.hasOwnProperty("createTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.createTime); + if (error) + return "createTime." + error; + } + if (message.updateTime != null && message.hasOwnProperty("updateTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.updateTime); + if (error) + return "updateTime." + error; + } + if (message.labels != null && message.hasOwnProperty("labels")) { + if (!$util.isObject(message.labels)) + return "labels: object expected"; + var key = Object.keys(message.labels); + for (var i = 0; i < key.length; ++i) + if (!$util.isString(message.labels[key[i]])) + return "labels: string{k:string} expected"; + } + if (message.description != null && message.hasOwnProperty("description")) + if (!$util.isString(message.description)) + return "description: string expected"; + if (message.interconnect != null && message.hasOwnProperty("interconnect")) + if (!$util.isString(message.interconnect)) + return "interconnect: string expected"; + if (message.network != null && message.hasOwnProperty("network")) + if (!$util.isString(message.network)) + return "network: string expected"; + if (message.vlanId != null && message.hasOwnProperty("vlanId")) + if (!$util.isInteger(message.vlanId)) + return "vlanId: integer expected"; + if (message.mtu != null && message.hasOwnProperty("mtu")) + if (!$util.isInteger(message.mtu)) + return "mtu: integer expected"; + if (message.state != null && message.hasOwnProperty("state")) + switch (message.state) { + default: + return "state: enum value expected"; + case 0: + case 1: + case 2: + case 3: + case 4: + case 5: + break; + } + return null; + }; + + /** + * Creates an InterconnectAttachment message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.InterconnectAttachment} InterconnectAttachment + */ + InterconnectAttachment.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.InterconnectAttachment) + return object; + var message = new $root.google.cloud.edgenetwork.v1.InterconnectAttachment(); + if (object.name != null) + message.name = String(object.name); + if (object.createTime != null) { + if (typeof object.createTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.InterconnectAttachment.createTime: object expected"); + message.createTime = $root.google.protobuf.Timestamp.fromObject(object.createTime); + } + if (object.updateTime != null) { + if (typeof object.updateTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.InterconnectAttachment.updateTime: object expected"); + message.updateTime = $root.google.protobuf.Timestamp.fromObject(object.updateTime); + } + if (object.labels) { + if (typeof object.labels !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.InterconnectAttachment.labels: object expected"); + message.labels = {}; + for (var keys = Object.keys(object.labels), i = 0; i < keys.length; ++i) + message.labels[keys[i]] = String(object.labels[keys[i]]); + } + if (object.description != null) + message.description = String(object.description); + if (object.interconnect != null) + message.interconnect = String(object.interconnect); + if (object.network != null) + message.network = String(object.network); + if (object.vlanId != null) + message.vlanId = object.vlanId | 0; + if (object.mtu != null) + message.mtu = object.mtu | 0; + switch (object.state) { + default: + if (typeof object.state === "number") { + message.state = object.state; + break; + } + break; + case "STATE_UNKNOWN": + case 0: + message.state = 0; + break; + case "STATE_PENDING": + case 1: + message.state = 1; + break; + case "STATE_PROVISIONING": + case 2: + message.state = 2; + break; + case "STATE_RUNNING": + case 3: + message.state = 3; + break; + case "STATE_SUSPENDED": + case 4: + message.state = 4; + break; + case "STATE_DELETING": + case 5: + message.state = 5; + break; + } + return message; + }; + + /** + * Creates a plain object from an InterconnectAttachment message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectAttachment} message InterconnectAttachment + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + InterconnectAttachment.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.objects || options.defaults) + object.labels = {}; + if (options.defaults) { + object.name = ""; + object.createTime = null; + object.updateTime = null; + object.description = ""; + object.interconnect = ""; + object.vlanId = 0; + object.mtu = 0; + object.state = options.enums === String ? "STATE_UNKNOWN" : 0; + object.network = ""; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.createTime != null && message.hasOwnProperty("createTime")) + object.createTime = $root.google.protobuf.Timestamp.toObject(message.createTime, options); + if (message.updateTime != null && message.hasOwnProperty("updateTime")) + object.updateTime = $root.google.protobuf.Timestamp.toObject(message.updateTime, options); + var keys2; + if (message.labels && (keys2 = Object.keys(message.labels)).length) { + object.labels = {}; + for (var j = 0; j < keys2.length; ++j) + object.labels[keys2[j]] = message.labels[keys2[j]]; + } + if (message.description != null && message.hasOwnProperty("description")) + object.description = message.description; + if (message.interconnect != null && message.hasOwnProperty("interconnect")) + object.interconnect = message.interconnect; + if (message.vlanId != null && message.hasOwnProperty("vlanId")) + object.vlanId = message.vlanId; + if (message.mtu != null && message.hasOwnProperty("mtu")) + object.mtu = message.mtu; + if (message.state != null && message.hasOwnProperty("state")) + object.state = options.enums === String ? $root.google.cloud.edgenetwork.v1.ResourceState[message.state] === undefined ? message.state : $root.google.cloud.edgenetwork.v1.ResourceState[message.state] : message.state; + if (message.network != null && message.hasOwnProperty("network")) + object.network = message.network; + return object; + }; + + /** + * Converts this InterconnectAttachment to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @instance + * @returns {Object.} JSON object + */ + InterconnectAttachment.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for InterconnectAttachment + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.InterconnectAttachment + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + InterconnectAttachment.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.InterconnectAttachment"; + }; + + return InterconnectAttachment; + })(); + + v1.Router = (function() { + + /** + * Properties of a Router. + * @memberof google.cloud.edgenetwork.v1 + * @interface IRouter + * @property {string|null} [name] Router name + * @property {google.protobuf.ITimestamp|null} [createTime] Router createTime + * @property {google.protobuf.ITimestamp|null} [updateTime] Router updateTime + * @property {Object.|null} [labels] Router labels + * @property {string|null} [description] Router description + * @property {string|null} [network] Router network + * @property {Array.|null} ["interface"] Router interface + * @property {Array.|null} [bgpPeer] Router bgpPeer + * @property {google.cloud.edgenetwork.v1.Router.IBgp|null} [bgp] Router bgp + * @property {google.cloud.edgenetwork.v1.ResourceState|null} [state] Router state + * @property {Array.|null} [routeAdvertisements] Router routeAdvertisements + */ + + /** + * Constructs a new Router. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a Router. + * @implements IRouter + * @constructor + * @param {google.cloud.edgenetwork.v1.IRouter=} [properties] Properties to set + */ + function Router(properties) { + this.labels = {}; + this["interface"] = []; + this.bgpPeer = []; + this.routeAdvertisements = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Router name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.Router + * @instance + */ + Router.prototype.name = ""; + + /** + * Router createTime. + * @member {google.protobuf.ITimestamp|null|undefined} createTime + * @memberof google.cloud.edgenetwork.v1.Router + * @instance + */ + Router.prototype.createTime = null; + + /** + * Router updateTime. + * @member {google.protobuf.ITimestamp|null|undefined} updateTime + * @memberof google.cloud.edgenetwork.v1.Router + * @instance + */ + Router.prototype.updateTime = null; + + /** + * Router labels. + * @member {Object.} labels + * @memberof google.cloud.edgenetwork.v1.Router + * @instance + */ + Router.prototype.labels = $util.emptyObject; + + /** + * Router description. + * @member {string} description + * @memberof google.cloud.edgenetwork.v1.Router + * @instance + */ + Router.prototype.description = ""; + + /** + * Router network. + * @member {string} network + * @memberof google.cloud.edgenetwork.v1.Router + * @instance + */ + Router.prototype.network = ""; + + /** + * Router interface. + * @member {Array.} interface + * @memberof google.cloud.edgenetwork.v1.Router + * @instance + */ + Router.prototype["interface"] = $util.emptyArray; + + /** + * Router bgpPeer. + * @member {Array.} bgpPeer + * @memberof google.cloud.edgenetwork.v1.Router + * @instance + */ + Router.prototype.bgpPeer = $util.emptyArray; + + /** + * Router bgp. + * @member {google.cloud.edgenetwork.v1.Router.IBgp|null|undefined} bgp + * @memberof google.cloud.edgenetwork.v1.Router + * @instance + */ + Router.prototype.bgp = null; + + /** + * Router state. + * @member {google.cloud.edgenetwork.v1.ResourceState} state + * @memberof google.cloud.edgenetwork.v1.Router + * @instance + */ + Router.prototype.state = 0; + + /** + * Router routeAdvertisements. + * @member {Array.} routeAdvertisements + * @memberof google.cloud.edgenetwork.v1.Router + * @instance + */ + Router.prototype.routeAdvertisements = $util.emptyArray; + + /** + * Creates a new Router instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.Router + * @static + * @param {google.cloud.edgenetwork.v1.IRouter=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.Router} Router instance + */ + Router.create = function create(properties) { + return new Router(properties); + }; + + /** + * Encodes the specified Router message. Does not implicitly {@link google.cloud.edgenetwork.v1.Router.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.Router + * @static + * @param {google.cloud.edgenetwork.v1.IRouter} message Router message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Router.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.createTime != null && Object.hasOwnProperty.call(message, "createTime")) + $root.google.protobuf.Timestamp.encode(message.createTime, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.updateTime != null && Object.hasOwnProperty.call(message, "updateTime")) + $root.google.protobuf.Timestamp.encode(message.updateTime, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + if (message.labels != null && Object.hasOwnProperty.call(message, "labels")) + for (var keys = Object.keys(message.labels), i = 0; i < keys.length; ++i) + writer.uint32(/* id 4, wireType 2 =*/34).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]).uint32(/* id 2, wireType 2 =*/18).string(message.labels[keys[i]]).ldelim(); + if (message.description != null && Object.hasOwnProperty.call(message, "description")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.description); + if (message.network != null && Object.hasOwnProperty.call(message, "network")) + writer.uint32(/* id 6, wireType 2 =*/50).string(message.network); + if (message["interface"] != null && message["interface"].length) + for (var i = 0; i < message["interface"].length; ++i) + $root.google.cloud.edgenetwork.v1.Router.Interface.encode(message["interface"][i], writer.uint32(/* id 7, wireType 2 =*/58).fork()).ldelim(); + if (message.bgpPeer != null && message.bgpPeer.length) + for (var i = 0; i < message.bgpPeer.length; ++i) + $root.google.cloud.edgenetwork.v1.Router.BgpPeer.encode(message.bgpPeer[i], writer.uint32(/* id 8, wireType 2 =*/66).fork()).ldelim(); + if (message.bgp != null && Object.hasOwnProperty.call(message, "bgp")) + $root.google.cloud.edgenetwork.v1.Router.Bgp.encode(message.bgp, writer.uint32(/* id 9, wireType 2 =*/74).fork()).ldelim(); + if (message.state != null && Object.hasOwnProperty.call(message, "state")) + writer.uint32(/* id 10, wireType 0 =*/80).int32(message.state); + if (message.routeAdvertisements != null && message.routeAdvertisements.length) + for (var i = 0; i < message.routeAdvertisements.length; ++i) + writer.uint32(/* id 11, wireType 2 =*/90).string(message.routeAdvertisements[i]); + return writer; + }; + + /** + * Encodes the specified Router message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.Router.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.Router + * @static + * @param {google.cloud.edgenetwork.v1.IRouter} message Router message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Router.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a Router message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.Router + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.Router} Router + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Router.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.Router(), key, value; + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.createTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 3: { + message.updateTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 4: { + if (message.labels === $util.emptyObject) + message.labels = {}; + var end2 = reader.uint32() + reader.pos; + key = ""; + value = ""; + while (reader.pos < end2) { + var tag2 = reader.uint32(); + switch (tag2 >>> 3) { + case 1: + key = reader.string(); + break; + case 2: + value = reader.string(); + break; + default: + reader.skipType(tag2 & 7); + break; + } + } + message.labels[key] = value; + break; + } + case 5: { + message.description = reader.string(); + break; + } + case 6: { + message.network = reader.string(); + break; + } + case 7: { + if (!(message["interface"] && message["interface"].length)) + message["interface"] = []; + message["interface"].push($root.google.cloud.edgenetwork.v1.Router.Interface.decode(reader, reader.uint32())); + break; + } + case 8: { + if (!(message.bgpPeer && message.bgpPeer.length)) + message.bgpPeer = []; + message.bgpPeer.push($root.google.cloud.edgenetwork.v1.Router.BgpPeer.decode(reader, reader.uint32())); + break; + } + case 9: { + message.bgp = $root.google.cloud.edgenetwork.v1.Router.Bgp.decode(reader, reader.uint32()); + break; + } + case 10: { + message.state = reader.int32(); + break; + } + case 11: { + if (!(message.routeAdvertisements && message.routeAdvertisements.length)) + message.routeAdvertisements = []; + message.routeAdvertisements.push(reader.string()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a Router message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.Router + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.Router} Router + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Router.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a Router message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.Router + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Router.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.createTime != null && message.hasOwnProperty("createTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.createTime); + if (error) + return "createTime." + error; + } + if (message.updateTime != null && message.hasOwnProperty("updateTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.updateTime); + if (error) + return "updateTime." + error; + } + if (message.labels != null && message.hasOwnProperty("labels")) { + if (!$util.isObject(message.labels)) + return "labels: object expected"; + var key = Object.keys(message.labels); + for (var i = 0; i < key.length; ++i) + if (!$util.isString(message.labels[key[i]])) + return "labels: string{k:string} expected"; + } + if (message.description != null && message.hasOwnProperty("description")) + if (!$util.isString(message.description)) + return "description: string expected"; + if (message.network != null && message.hasOwnProperty("network")) + if (!$util.isString(message.network)) + return "network: string expected"; + if (message["interface"] != null && message.hasOwnProperty("interface")) { + if (!Array.isArray(message["interface"])) + return "interface: array expected"; + for (var i = 0; i < message["interface"].length; ++i) { + var error = $root.google.cloud.edgenetwork.v1.Router.Interface.verify(message["interface"][i]); + if (error) + return "interface." + error; + } + } + if (message.bgpPeer != null && message.hasOwnProperty("bgpPeer")) { + if (!Array.isArray(message.bgpPeer)) + return "bgpPeer: array expected"; + for (var i = 0; i < message.bgpPeer.length; ++i) { + var error = $root.google.cloud.edgenetwork.v1.Router.BgpPeer.verify(message.bgpPeer[i]); + if (error) + return "bgpPeer." + error; + } + } + if (message.bgp != null && message.hasOwnProperty("bgp")) { + var error = $root.google.cloud.edgenetwork.v1.Router.Bgp.verify(message.bgp); + if (error) + return "bgp." + error; + } + if (message.state != null && message.hasOwnProperty("state")) + switch (message.state) { + default: + return "state: enum value expected"; + case 0: + case 1: + case 2: + case 3: + case 4: + case 5: + break; + } + if (message.routeAdvertisements != null && message.hasOwnProperty("routeAdvertisements")) { + if (!Array.isArray(message.routeAdvertisements)) + return "routeAdvertisements: array expected"; + for (var i = 0; i < message.routeAdvertisements.length; ++i) + if (!$util.isString(message.routeAdvertisements[i])) + return "routeAdvertisements: string[] expected"; + } + return null; + }; + + /** + * Creates a Router message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.Router + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.Router} Router + */ + Router.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.Router) + return object; + var message = new $root.google.cloud.edgenetwork.v1.Router(); + if (object.name != null) + message.name = String(object.name); + if (object.createTime != null) { + if (typeof object.createTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Router.createTime: object expected"); + message.createTime = $root.google.protobuf.Timestamp.fromObject(object.createTime); + } + if (object.updateTime != null) { + if (typeof object.updateTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Router.updateTime: object expected"); + message.updateTime = $root.google.protobuf.Timestamp.fromObject(object.updateTime); + } + if (object.labels) { + if (typeof object.labels !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Router.labels: object expected"); + message.labels = {}; + for (var keys = Object.keys(object.labels), i = 0; i < keys.length; ++i) + message.labels[keys[i]] = String(object.labels[keys[i]]); + } + if (object.description != null) + message.description = String(object.description); + if (object.network != null) + message.network = String(object.network); + if (object["interface"]) { + if (!Array.isArray(object["interface"])) + throw TypeError(".google.cloud.edgenetwork.v1.Router.interface: array expected"); + message["interface"] = []; + for (var i = 0; i < object["interface"].length; ++i) { + if (typeof object["interface"][i] !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Router.interface: object expected"); + message["interface"][i] = $root.google.cloud.edgenetwork.v1.Router.Interface.fromObject(object["interface"][i]); + } + } + if (object.bgpPeer) { + if (!Array.isArray(object.bgpPeer)) + throw TypeError(".google.cloud.edgenetwork.v1.Router.bgpPeer: array expected"); + message.bgpPeer = []; + for (var i = 0; i < object.bgpPeer.length; ++i) { + if (typeof object.bgpPeer[i] !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Router.bgpPeer: object expected"); + message.bgpPeer[i] = $root.google.cloud.edgenetwork.v1.Router.BgpPeer.fromObject(object.bgpPeer[i]); + } + } + if (object.bgp != null) { + if (typeof object.bgp !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.Router.bgp: object expected"); + message.bgp = $root.google.cloud.edgenetwork.v1.Router.Bgp.fromObject(object.bgp); + } + switch (object.state) { + default: + if (typeof object.state === "number") { + message.state = object.state; + break; + } + break; + case "STATE_UNKNOWN": + case 0: + message.state = 0; + break; + case "STATE_PENDING": + case 1: + message.state = 1; + break; + case "STATE_PROVISIONING": + case 2: + message.state = 2; + break; + case "STATE_RUNNING": + case 3: + message.state = 3; + break; + case "STATE_SUSPENDED": + case 4: + message.state = 4; + break; + case "STATE_DELETING": + case 5: + message.state = 5; + break; + } + if (object.routeAdvertisements) { + if (!Array.isArray(object.routeAdvertisements)) + throw TypeError(".google.cloud.edgenetwork.v1.Router.routeAdvertisements: array expected"); + message.routeAdvertisements = []; + for (var i = 0; i < object.routeAdvertisements.length; ++i) + message.routeAdvertisements[i] = String(object.routeAdvertisements[i]); + } + return message; + }; + + /** + * Creates a plain object from a Router message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.Router + * @static + * @param {google.cloud.edgenetwork.v1.Router} message Router + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Router.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object["interface"] = []; + object.bgpPeer = []; + object.routeAdvertisements = []; + } + if (options.objects || options.defaults) + object.labels = {}; + if (options.defaults) { + object.name = ""; + object.createTime = null; + object.updateTime = null; + object.description = ""; + object.network = ""; + object.bgp = null; + object.state = options.enums === String ? "STATE_UNKNOWN" : 0; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.createTime != null && message.hasOwnProperty("createTime")) + object.createTime = $root.google.protobuf.Timestamp.toObject(message.createTime, options); + if (message.updateTime != null && message.hasOwnProperty("updateTime")) + object.updateTime = $root.google.protobuf.Timestamp.toObject(message.updateTime, options); + var keys2; + if (message.labels && (keys2 = Object.keys(message.labels)).length) { + object.labels = {}; + for (var j = 0; j < keys2.length; ++j) + object.labels[keys2[j]] = message.labels[keys2[j]]; + } + if (message.description != null && message.hasOwnProperty("description")) + object.description = message.description; + if (message.network != null && message.hasOwnProperty("network")) + object.network = message.network; + if (message["interface"] && message["interface"].length) { + object["interface"] = []; + for (var j = 0; j < message["interface"].length; ++j) + object["interface"][j] = $root.google.cloud.edgenetwork.v1.Router.Interface.toObject(message["interface"][j], options); + } + if (message.bgpPeer && message.bgpPeer.length) { + object.bgpPeer = []; + for (var j = 0; j < message.bgpPeer.length; ++j) + object.bgpPeer[j] = $root.google.cloud.edgenetwork.v1.Router.BgpPeer.toObject(message.bgpPeer[j], options); + } + if (message.bgp != null && message.hasOwnProperty("bgp")) + object.bgp = $root.google.cloud.edgenetwork.v1.Router.Bgp.toObject(message.bgp, options); + if (message.state != null && message.hasOwnProperty("state")) + object.state = options.enums === String ? $root.google.cloud.edgenetwork.v1.ResourceState[message.state] === undefined ? message.state : $root.google.cloud.edgenetwork.v1.ResourceState[message.state] : message.state; + if (message.routeAdvertisements && message.routeAdvertisements.length) { + object.routeAdvertisements = []; + for (var j = 0; j < message.routeAdvertisements.length; ++j) + object.routeAdvertisements[j] = message.routeAdvertisements[j]; + } + return object; + }; + + /** + * Converts this Router to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.Router + * @instance + * @returns {Object.} JSON object + */ + Router.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Router + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.Router + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Router.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.Router"; + }; + + Router.Interface = (function() { + + /** + * Properties of an Interface. + * @memberof google.cloud.edgenetwork.v1.Router + * @interface IInterface + * @property {string|null} [name] Interface name + * @property {string|null} [ipv4Cidr] Interface ipv4Cidr + * @property {string|null} [ipv6Cidr] Interface ipv6Cidr + * @property {string|null} [linkedInterconnectAttachment] Interface linkedInterconnectAttachment + * @property {string|null} [subnetwork] Interface subnetwork + * @property {Array.|null} [loopbackIpAddresses] Interface loopbackIpAddresses + */ + + /** + * Constructs a new Interface. + * @memberof google.cloud.edgenetwork.v1.Router + * @classdesc Represents an Interface. + * @implements IInterface + * @constructor + * @param {google.cloud.edgenetwork.v1.Router.IInterface=} [properties] Properties to set + */ + function Interface(properties) { + this.loopbackIpAddresses = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Interface name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.Router.Interface + * @instance + */ + Interface.prototype.name = ""; + + /** + * Interface ipv4Cidr. + * @member {string} ipv4Cidr + * @memberof google.cloud.edgenetwork.v1.Router.Interface + * @instance + */ + Interface.prototype.ipv4Cidr = ""; + + /** + * Interface ipv6Cidr. + * @member {string} ipv6Cidr + * @memberof google.cloud.edgenetwork.v1.Router.Interface + * @instance + */ + Interface.prototype.ipv6Cidr = ""; + + /** + * Interface linkedInterconnectAttachment. + * @member {string} linkedInterconnectAttachment + * @memberof google.cloud.edgenetwork.v1.Router.Interface + * @instance + */ + Interface.prototype.linkedInterconnectAttachment = ""; + + /** + * Interface subnetwork. + * @member {string} subnetwork + * @memberof google.cloud.edgenetwork.v1.Router.Interface + * @instance + */ + Interface.prototype.subnetwork = ""; + + /** + * Interface loopbackIpAddresses. + * @member {Array.} loopbackIpAddresses + * @memberof google.cloud.edgenetwork.v1.Router.Interface + * @instance + */ + Interface.prototype.loopbackIpAddresses = $util.emptyArray; + + /** + * Creates a new Interface instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.Router.Interface + * @static + * @param {google.cloud.edgenetwork.v1.Router.IInterface=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.Router.Interface} Interface instance + */ + Interface.create = function create(properties) { + return new Interface(properties); + }; + + /** + * Encodes the specified Interface message. Does not implicitly {@link google.cloud.edgenetwork.v1.Router.Interface.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.Router.Interface + * @static + * @param {google.cloud.edgenetwork.v1.Router.IInterface} message Interface message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Interface.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.linkedInterconnectAttachment != null && Object.hasOwnProperty.call(message, "linkedInterconnectAttachment")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.linkedInterconnectAttachment); + if (message.ipv4Cidr != null && Object.hasOwnProperty.call(message, "ipv4Cidr")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.ipv4Cidr); + if (message.subnetwork != null && Object.hasOwnProperty.call(message, "subnetwork")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.subnetwork); + if (message.loopbackIpAddresses != null && message.loopbackIpAddresses.length) + for (var i = 0; i < message.loopbackIpAddresses.length; ++i) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.loopbackIpAddresses[i]); + if (message.ipv6Cidr != null && Object.hasOwnProperty.call(message, "ipv6Cidr")) + writer.uint32(/* id 6, wireType 2 =*/50).string(message.ipv6Cidr); + return writer; + }; + + /** + * Encodes the specified Interface message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.Router.Interface.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.Router.Interface + * @static + * @param {google.cloud.edgenetwork.v1.Router.IInterface} message Interface message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Interface.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an Interface message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.Router.Interface + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.Router.Interface} Interface + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Interface.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.Router.Interface(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 3: { + message.ipv4Cidr = reader.string(); + break; + } + case 6: { + message.ipv6Cidr = reader.string(); + break; + } + case 2: { + message.linkedInterconnectAttachment = reader.string(); + break; + } + case 4: { + message.subnetwork = reader.string(); + break; + } + case 5: { + if (!(message.loopbackIpAddresses && message.loopbackIpAddresses.length)) + message.loopbackIpAddresses = []; + message.loopbackIpAddresses.push(reader.string()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an Interface message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.Router.Interface + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.Router.Interface} Interface + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Interface.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an Interface message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.Router.Interface + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Interface.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.ipv4Cidr != null && message.hasOwnProperty("ipv4Cidr")) + if (!$util.isString(message.ipv4Cidr)) + return "ipv4Cidr: string expected"; + if (message.ipv6Cidr != null && message.hasOwnProperty("ipv6Cidr")) + if (!$util.isString(message.ipv6Cidr)) + return "ipv6Cidr: string expected"; + if (message.linkedInterconnectAttachment != null && message.hasOwnProperty("linkedInterconnectAttachment")) + if (!$util.isString(message.linkedInterconnectAttachment)) + return "linkedInterconnectAttachment: string expected"; + if (message.subnetwork != null && message.hasOwnProperty("subnetwork")) + if (!$util.isString(message.subnetwork)) + return "subnetwork: string expected"; + if (message.loopbackIpAddresses != null && message.hasOwnProperty("loopbackIpAddresses")) { + if (!Array.isArray(message.loopbackIpAddresses)) + return "loopbackIpAddresses: array expected"; + for (var i = 0; i < message.loopbackIpAddresses.length; ++i) + if (!$util.isString(message.loopbackIpAddresses[i])) + return "loopbackIpAddresses: string[] expected"; + } + return null; + }; + + /** + * Creates an Interface message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.Router.Interface + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.Router.Interface} Interface + */ + Interface.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.Router.Interface) + return object; + var message = new $root.google.cloud.edgenetwork.v1.Router.Interface(); + if (object.name != null) + message.name = String(object.name); + if (object.ipv4Cidr != null) + message.ipv4Cidr = String(object.ipv4Cidr); + if (object.ipv6Cidr != null) + message.ipv6Cidr = String(object.ipv6Cidr); + if (object.linkedInterconnectAttachment != null) + message.linkedInterconnectAttachment = String(object.linkedInterconnectAttachment); + if (object.subnetwork != null) + message.subnetwork = String(object.subnetwork); + if (object.loopbackIpAddresses) { + if (!Array.isArray(object.loopbackIpAddresses)) + throw TypeError(".google.cloud.edgenetwork.v1.Router.Interface.loopbackIpAddresses: array expected"); + message.loopbackIpAddresses = []; + for (var i = 0; i < object.loopbackIpAddresses.length; ++i) + message.loopbackIpAddresses[i] = String(object.loopbackIpAddresses[i]); + } + return message; + }; + + /** + * Creates a plain object from an Interface message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.Router.Interface + * @static + * @param {google.cloud.edgenetwork.v1.Router.Interface} message Interface + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Interface.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.loopbackIpAddresses = []; + if (options.defaults) { + object.name = ""; + object.linkedInterconnectAttachment = ""; + object.ipv4Cidr = ""; + object.subnetwork = ""; + object.ipv6Cidr = ""; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.linkedInterconnectAttachment != null && message.hasOwnProperty("linkedInterconnectAttachment")) + object.linkedInterconnectAttachment = message.linkedInterconnectAttachment; + if (message.ipv4Cidr != null && message.hasOwnProperty("ipv4Cidr")) + object.ipv4Cidr = message.ipv4Cidr; + if (message.subnetwork != null && message.hasOwnProperty("subnetwork")) + object.subnetwork = message.subnetwork; + if (message.loopbackIpAddresses && message.loopbackIpAddresses.length) { + object.loopbackIpAddresses = []; + for (var j = 0; j < message.loopbackIpAddresses.length; ++j) + object.loopbackIpAddresses[j] = message.loopbackIpAddresses[j]; + } + if (message.ipv6Cidr != null && message.hasOwnProperty("ipv6Cidr")) + object.ipv6Cidr = message.ipv6Cidr; + return object; + }; + + /** + * Converts this Interface to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.Router.Interface + * @instance + * @returns {Object.} JSON object + */ + Interface.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Interface + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.Router.Interface + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Interface.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.Router.Interface"; + }; + + return Interface; + })(); + + Router.BgpPeer = (function() { + + /** + * Properties of a BgpPeer. + * @memberof google.cloud.edgenetwork.v1.Router + * @interface IBgpPeer + * @property {string|null} [name] BgpPeer name + * @property {string|null} ["interface"] BgpPeer interface + * @property {string|null} [interfaceIpv4Cidr] BgpPeer interfaceIpv4Cidr + * @property {string|null} [interfaceIpv6Cidr] BgpPeer interfaceIpv6Cidr + * @property {string|null} [peerIpv4Cidr] BgpPeer peerIpv4Cidr + * @property {string|null} [peerIpv6Cidr] BgpPeer peerIpv6Cidr + * @property {number|null} [peerAsn] BgpPeer peerAsn + * @property {number|null} [localAsn] BgpPeer localAsn + */ + + /** + * Constructs a new BgpPeer. + * @memberof google.cloud.edgenetwork.v1.Router + * @classdesc Represents a BgpPeer. + * @implements IBgpPeer + * @constructor + * @param {google.cloud.edgenetwork.v1.Router.IBgpPeer=} [properties] Properties to set + */ + function BgpPeer(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * BgpPeer name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @instance + */ + BgpPeer.prototype.name = ""; + + /** + * BgpPeer interface. + * @member {string} interface + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @instance + */ + BgpPeer.prototype["interface"] = ""; + + /** + * BgpPeer interfaceIpv4Cidr. + * @member {string} interfaceIpv4Cidr + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @instance + */ + BgpPeer.prototype.interfaceIpv4Cidr = ""; + + /** + * BgpPeer interfaceIpv6Cidr. + * @member {string} interfaceIpv6Cidr + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @instance + */ + BgpPeer.prototype.interfaceIpv6Cidr = ""; + + /** + * BgpPeer peerIpv4Cidr. + * @member {string} peerIpv4Cidr + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @instance + */ + BgpPeer.prototype.peerIpv4Cidr = ""; + + /** + * BgpPeer peerIpv6Cidr. + * @member {string} peerIpv6Cidr + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @instance + */ + BgpPeer.prototype.peerIpv6Cidr = ""; + + /** + * BgpPeer peerAsn. + * @member {number} peerAsn + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @instance + */ + BgpPeer.prototype.peerAsn = 0; + + /** + * BgpPeer localAsn. + * @member {number} localAsn + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @instance + */ + BgpPeer.prototype.localAsn = 0; + + /** + * Creates a new BgpPeer instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @static + * @param {google.cloud.edgenetwork.v1.Router.IBgpPeer=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.Router.BgpPeer} BgpPeer instance + */ + BgpPeer.create = function create(properties) { + return new BgpPeer(properties); + }; + + /** + * Encodes the specified BgpPeer message. Does not implicitly {@link google.cloud.edgenetwork.v1.Router.BgpPeer.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @static + * @param {google.cloud.edgenetwork.v1.Router.IBgpPeer} message BgpPeer message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + BgpPeer.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message["interface"] != null && Object.hasOwnProperty.call(message, "interface")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message["interface"]); + if (message.interfaceIpv4Cidr != null && Object.hasOwnProperty.call(message, "interfaceIpv4Cidr")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.interfaceIpv4Cidr); + if (message.peerIpv4Cidr != null && Object.hasOwnProperty.call(message, "peerIpv4Cidr")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.peerIpv4Cidr); + if (message.peerAsn != null && Object.hasOwnProperty.call(message, "peerAsn")) + writer.uint32(/* id 5, wireType 0 =*/40).uint32(message.peerAsn); + if (message.peerIpv6Cidr != null && Object.hasOwnProperty.call(message, "peerIpv6Cidr")) + writer.uint32(/* id 6, wireType 2 =*/50).string(message.peerIpv6Cidr); + if (message.interfaceIpv6Cidr != null && Object.hasOwnProperty.call(message, "interfaceIpv6Cidr")) + writer.uint32(/* id 7, wireType 2 =*/58).string(message.interfaceIpv6Cidr); + if (message.localAsn != null && Object.hasOwnProperty.call(message, "localAsn")) + writer.uint32(/* id 8, wireType 0 =*/64).uint32(message.localAsn); + return writer; + }; + + /** + * Encodes the specified BgpPeer message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.Router.BgpPeer.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @static + * @param {google.cloud.edgenetwork.v1.Router.IBgpPeer} message BgpPeer message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + BgpPeer.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a BgpPeer message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.Router.BgpPeer} BgpPeer + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + BgpPeer.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.Router.BgpPeer(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message["interface"] = reader.string(); + break; + } + case 3: { + message.interfaceIpv4Cidr = reader.string(); + break; + } + case 7: { + message.interfaceIpv6Cidr = reader.string(); + break; + } + case 4: { + message.peerIpv4Cidr = reader.string(); + break; + } + case 6: { + message.peerIpv6Cidr = reader.string(); + break; + } + case 5: { + message.peerAsn = reader.uint32(); + break; + } + case 8: { + message.localAsn = reader.uint32(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a BgpPeer message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.Router.BgpPeer} BgpPeer + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + BgpPeer.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a BgpPeer message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + BgpPeer.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message["interface"] != null && message.hasOwnProperty("interface")) + if (!$util.isString(message["interface"])) + return "interface: string expected"; + if (message.interfaceIpv4Cidr != null && message.hasOwnProperty("interfaceIpv4Cidr")) + if (!$util.isString(message.interfaceIpv4Cidr)) + return "interfaceIpv4Cidr: string expected"; + if (message.interfaceIpv6Cidr != null && message.hasOwnProperty("interfaceIpv6Cidr")) + if (!$util.isString(message.interfaceIpv6Cidr)) + return "interfaceIpv6Cidr: string expected"; + if (message.peerIpv4Cidr != null && message.hasOwnProperty("peerIpv4Cidr")) + if (!$util.isString(message.peerIpv4Cidr)) + return "peerIpv4Cidr: string expected"; + if (message.peerIpv6Cidr != null && message.hasOwnProperty("peerIpv6Cidr")) + if (!$util.isString(message.peerIpv6Cidr)) + return "peerIpv6Cidr: string expected"; + if (message.peerAsn != null && message.hasOwnProperty("peerAsn")) + if (!$util.isInteger(message.peerAsn)) + return "peerAsn: integer expected"; + if (message.localAsn != null && message.hasOwnProperty("localAsn")) + if (!$util.isInteger(message.localAsn)) + return "localAsn: integer expected"; + return null; + }; + + /** + * Creates a BgpPeer message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.Router.BgpPeer} BgpPeer + */ + BgpPeer.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.Router.BgpPeer) + return object; + var message = new $root.google.cloud.edgenetwork.v1.Router.BgpPeer(); + if (object.name != null) + message.name = String(object.name); + if (object["interface"] != null) + message["interface"] = String(object["interface"]); + if (object.interfaceIpv4Cidr != null) + message.interfaceIpv4Cidr = String(object.interfaceIpv4Cidr); + if (object.interfaceIpv6Cidr != null) + message.interfaceIpv6Cidr = String(object.interfaceIpv6Cidr); + if (object.peerIpv4Cidr != null) + message.peerIpv4Cidr = String(object.peerIpv4Cidr); + if (object.peerIpv6Cidr != null) + message.peerIpv6Cidr = String(object.peerIpv6Cidr); + if (object.peerAsn != null) + message.peerAsn = object.peerAsn >>> 0; + if (object.localAsn != null) + message.localAsn = object.localAsn >>> 0; + return message; + }; + + /** + * Creates a plain object from a BgpPeer message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @static + * @param {google.cloud.edgenetwork.v1.Router.BgpPeer} message BgpPeer + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + BgpPeer.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.name = ""; + object["interface"] = ""; + object.interfaceIpv4Cidr = ""; + object.peerIpv4Cidr = ""; + object.peerAsn = 0; + object.peerIpv6Cidr = ""; + object.interfaceIpv6Cidr = ""; + object.localAsn = 0; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message["interface"] != null && message.hasOwnProperty("interface")) + object["interface"] = message["interface"]; + if (message.interfaceIpv4Cidr != null && message.hasOwnProperty("interfaceIpv4Cidr")) + object.interfaceIpv4Cidr = message.interfaceIpv4Cidr; + if (message.peerIpv4Cidr != null && message.hasOwnProperty("peerIpv4Cidr")) + object.peerIpv4Cidr = message.peerIpv4Cidr; + if (message.peerAsn != null && message.hasOwnProperty("peerAsn")) + object.peerAsn = message.peerAsn; + if (message.peerIpv6Cidr != null && message.hasOwnProperty("peerIpv6Cidr")) + object.peerIpv6Cidr = message.peerIpv6Cidr; + if (message.interfaceIpv6Cidr != null && message.hasOwnProperty("interfaceIpv6Cidr")) + object.interfaceIpv6Cidr = message.interfaceIpv6Cidr; + if (message.localAsn != null && message.hasOwnProperty("localAsn")) + object.localAsn = message.localAsn; + return object; + }; + + /** + * Converts this BgpPeer to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @instance + * @returns {Object.} JSON object + */ + BgpPeer.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for BgpPeer + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.Router.BgpPeer + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + BgpPeer.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.Router.BgpPeer"; + }; + + return BgpPeer; + })(); + + Router.Bgp = (function() { + + /** + * Properties of a Bgp. + * @memberof google.cloud.edgenetwork.v1.Router + * @interface IBgp + * @property {number|null} [asn] Bgp asn + * @property {number|null} [keepaliveIntervalInSeconds] Bgp keepaliveIntervalInSeconds + */ + + /** + * Constructs a new Bgp. + * @memberof google.cloud.edgenetwork.v1.Router + * @classdesc Represents a Bgp. + * @implements IBgp + * @constructor + * @param {google.cloud.edgenetwork.v1.Router.IBgp=} [properties] Properties to set + */ + function Bgp(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Bgp asn. + * @member {number} asn + * @memberof google.cloud.edgenetwork.v1.Router.Bgp + * @instance + */ + Bgp.prototype.asn = 0; + + /** + * Bgp keepaliveIntervalInSeconds. + * @member {number} keepaliveIntervalInSeconds + * @memberof google.cloud.edgenetwork.v1.Router.Bgp + * @instance + */ + Bgp.prototype.keepaliveIntervalInSeconds = 0; + + /** + * Creates a new Bgp instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.Router.Bgp + * @static + * @param {google.cloud.edgenetwork.v1.Router.IBgp=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.Router.Bgp} Bgp instance + */ + Bgp.create = function create(properties) { + return new Bgp(properties); + }; + + /** + * Encodes the specified Bgp message. Does not implicitly {@link google.cloud.edgenetwork.v1.Router.Bgp.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.Router.Bgp + * @static + * @param {google.cloud.edgenetwork.v1.Router.IBgp} message Bgp message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Bgp.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.asn != null && Object.hasOwnProperty.call(message, "asn")) + writer.uint32(/* id 1, wireType 0 =*/8).uint32(message.asn); + if (message.keepaliveIntervalInSeconds != null && Object.hasOwnProperty.call(message, "keepaliveIntervalInSeconds")) + writer.uint32(/* id 2, wireType 0 =*/16).uint32(message.keepaliveIntervalInSeconds); + return writer; + }; + + /** + * Encodes the specified Bgp message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.Router.Bgp.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.Router.Bgp + * @static + * @param {google.cloud.edgenetwork.v1.Router.IBgp} message Bgp message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Bgp.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a Bgp message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.Router.Bgp + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.Router.Bgp} Bgp + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Bgp.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.Router.Bgp(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.asn = reader.uint32(); + break; + } + case 2: { + message.keepaliveIntervalInSeconds = reader.uint32(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a Bgp message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.Router.Bgp + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.Router.Bgp} Bgp + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Bgp.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a Bgp message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.Router.Bgp + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Bgp.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.asn != null && message.hasOwnProperty("asn")) + if (!$util.isInteger(message.asn)) + return "asn: integer expected"; + if (message.keepaliveIntervalInSeconds != null && message.hasOwnProperty("keepaliveIntervalInSeconds")) + if (!$util.isInteger(message.keepaliveIntervalInSeconds)) + return "keepaliveIntervalInSeconds: integer expected"; + return null; + }; + + /** + * Creates a Bgp message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.Router.Bgp + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.Router.Bgp} Bgp + */ + Bgp.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.Router.Bgp) + return object; + var message = new $root.google.cloud.edgenetwork.v1.Router.Bgp(); + if (object.asn != null) + message.asn = object.asn >>> 0; + if (object.keepaliveIntervalInSeconds != null) + message.keepaliveIntervalInSeconds = object.keepaliveIntervalInSeconds >>> 0; + return message; + }; + + /** + * Creates a plain object from a Bgp message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.Router.Bgp + * @static + * @param {google.cloud.edgenetwork.v1.Router.Bgp} message Bgp + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Bgp.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.asn = 0; + object.keepaliveIntervalInSeconds = 0; + } + if (message.asn != null && message.hasOwnProperty("asn")) + object.asn = message.asn; + if (message.keepaliveIntervalInSeconds != null && message.hasOwnProperty("keepaliveIntervalInSeconds")) + object.keepaliveIntervalInSeconds = message.keepaliveIntervalInSeconds; + return object; + }; + + /** + * Converts this Bgp to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.Router.Bgp + * @instance + * @returns {Object.} JSON object + */ + Bgp.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Bgp + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.Router.Bgp + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Bgp.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.Router.Bgp"; + }; + + return Bgp; + })(); + + return Router; + })(); + + v1.LinkLayerAddress = (function() { + + /** + * Properties of a LinkLayerAddress. + * @memberof google.cloud.edgenetwork.v1 + * @interface ILinkLayerAddress + * @property {string|null} [macAddress] LinkLayerAddress macAddress + * @property {string|null} [ipAddress] LinkLayerAddress ipAddress + */ + + /** + * Constructs a new LinkLayerAddress. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a LinkLayerAddress. + * @implements ILinkLayerAddress + * @constructor + * @param {google.cloud.edgenetwork.v1.ILinkLayerAddress=} [properties] Properties to set + */ + function LinkLayerAddress(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * LinkLayerAddress macAddress. + * @member {string} macAddress + * @memberof google.cloud.edgenetwork.v1.LinkLayerAddress + * @instance + */ + LinkLayerAddress.prototype.macAddress = ""; + + /** + * LinkLayerAddress ipAddress. + * @member {string} ipAddress + * @memberof google.cloud.edgenetwork.v1.LinkLayerAddress + * @instance + */ + LinkLayerAddress.prototype.ipAddress = ""; + + /** + * Creates a new LinkLayerAddress instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.LinkLayerAddress + * @static + * @param {google.cloud.edgenetwork.v1.ILinkLayerAddress=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.LinkLayerAddress} LinkLayerAddress instance + */ + LinkLayerAddress.create = function create(properties) { + return new LinkLayerAddress(properties); + }; + + /** + * Encodes the specified LinkLayerAddress message. Does not implicitly {@link google.cloud.edgenetwork.v1.LinkLayerAddress.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.LinkLayerAddress + * @static + * @param {google.cloud.edgenetwork.v1.ILinkLayerAddress} message LinkLayerAddress message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + LinkLayerAddress.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.macAddress != null && Object.hasOwnProperty.call(message, "macAddress")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.macAddress); + if (message.ipAddress != null && Object.hasOwnProperty.call(message, "ipAddress")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.ipAddress); + return writer; + }; + + /** + * Encodes the specified LinkLayerAddress message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.LinkLayerAddress.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.LinkLayerAddress + * @static + * @param {google.cloud.edgenetwork.v1.ILinkLayerAddress} message LinkLayerAddress message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + LinkLayerAddress.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a LinkLayerAddress message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.LinkLayerAddress + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.LinkLayerAddress} LinkLayerAddress + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + LinkLayerAddress.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.LinkLayerAddress(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.macAddress = reader.string(); + break; + } + case 2: { + message.ipAddress = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a LinkLayerAddress message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.LinkLayerAddress + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.LinkLayerAddress} LinkLayerAddress + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + LinkLayerAddress.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a LinkLayerAddress message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.LinkLayerAddress + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + LinkLayerAddress.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.macAddress != null && message.hasOwnProperty("macAddress")) + if (!$util.isString(message.macAddress)) + return "macAddress: string expected"; + if (message.ipAddress != null && message.hasOwnProperty("ipAddress")) + if (!$util.isString(message.ipAddress)) + return "ipAddress: string expected"; + return null; + }; + + /** + * Creates a LinkLayerAddress message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.LinkLayerAddress + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.LinkLayerAddress} LinkLayerAddress + */ + LinkLayerAddress.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.LinkLayerAddress) + return object; + var message = new $root.google.cloud.edgenetwork.v1.LinkLayerAddress(); + if (object.macAddress != null) + message.macAddress = String(object.macAddress); + if (object.ipAddress != null) + message.ipAddress = String(object.ipAddress); + return message; + }; + + /** + * Creates a plain object from a LinkLayerAddress message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.LinkLayerAddress + * @static + * @param {google.cloud.edgenetwork.v1.LinkLayerAddress} message LinkLayerAddress + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + LinkLayerAddress.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.macAddress = ""; + object.ipAddress = ""; + } + if (message.macAddress != null && message.hasOwnProperty("macAddress")) + object.macAddress = message.macAddress; + if (message.ipAddress != null && message.hasOwnProperty("ipAddress")) + object.ipAddress = message.ipAddress; + return object; + }; + + /** + * Converts this LinkLayerAddress to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.LinkLayerAddress + * @instance + * @returns {Object.} JSON object + */ + LinkLayerAddress.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for LinkLayerAddress + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.LinkLayerAddress + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + LinkLayerAddress.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.LinkLayerAddress"; + }; + + return LinkLayerAddress; + })(); + + v1.SubnetStatus = (function() { + + /** + * Properties of a SubnetStatus. + * @memberof google.cloud.edgenetwork.v1 + * @interface ISubnetStatus + * @property {string|null} [name] SubnetStatus name + * @property {string|null} [macAddress] SubnetStatus macAddress + * @property {Array.|null} [linkLayerAddresses] SubnetStatus linkLayerAddresses + */ + + /** + * Constructs a new SubnetStatus. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a SubnetStatus. + * @implements ISubnetStatus + * @constructor + * @param {google.cloud.edgenetwork.v1.ISubnetStatus=} [properties] Properties to set + */ + function SubnetStatus(properties) { + this.linkLayerAddresses = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * SubnetStatus name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.SubnetStatus + * @instance + */ + SubnetStatus.prototype.name = ""; + + /** + * SubnetStatus macAddress. + * @member {string} macAddress + * @memberof google.cloud.edgenetwork.v1.SubnetStatus + * @instance + */ + SubnetStatus.prototype.macAddress = ""; + + /** + * SubnetStatus linkLayerAddresses. + * @member {Array.} linkLayerAddresses + * @memberof google.cloud.edgenetwork.v1.SubnetStatus + * @instance + */ + SubnetStatus.prototype.linkLayerAddresses = $util.emptyArray; + + /** + * Creates a new SubnetStatus instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.SubnetStatus + * @static + * @param {google.cloud.edgenetwork.v1.ISubnetStatus=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.SubnetStatus} SubnetStatus instance + */ + SubnetStatus.create = function create(properties) { + return new SubnetStatus(properties); + }; + + /** + * Encodes the specified SubnetStatus message. Does not implicitly {@link google.cloud.edgenetwork.v1.SubnetStatus.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.SubnetStatus + * @static + * @param {google.cloud.edgenetwork.v1.ISubnetStatus} message SubnetStatus message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + SubnetStatus.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.macAddress != null && Object.hasOwnProperty.call(message, "macAddress")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.macAddress); + if (message.linkLayerAddresses != null && message.linkLayerAddresses.length) + for (var i = 0; i < message.linkLayerAddresses.length; ++i) + $root.google.cloud.edgenetwork.v1.LinkLayerAddress.encode(message.linkLayerAddresses[i], writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified SubnetStatus message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.SubnetStatus.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.SubnetStatus + * @static + * @param {google.cloud.edgenetwork.v1.ISubnetStatus} message SubnetStatus message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + SubnetStatus.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a SubnetStatus message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.SubnetStatus + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.SubnetStatus} SubnetStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + SubnetStatus.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.SubnetStatus(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.macAddress = reader.string(); + break; + } + case 3: { + if (!(message.linkLayerAddresses && message.linkLayerAddresses.length)) + message.linkLayerAddresses = []; + message.linkLayerAddresses.push($root.google.cloud.edgenetwork.v1.LinkLayerAddress.decode(reader, reader.uint32())); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a SubnetStatus message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.SubnetStatus + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.SubnetStatus} SubnetStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + SubnetStatus.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a SubnetStatus message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.SubnetStatus + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + SubnetStatus.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.macAddress != null && message.hasOwnProperty("macAddress")) + if (!$util.isString(message.macAddress)) + return "macAddress: string expected"; + if (message.linkLayerAddresses != null && message.hasOwnProperty("linkLayerAddresses")) { + if (!Array.isArray(message.linkLayerAddresses)) + return "linkLayerAddresses: array expected"; + for (var i = 0; i < message.linkLayerAddresses.length; ++i) { + var error = $root.google.cloud.edgenetwork.v1.LinkLayerAddress.verify(message.linkLayerAddresses[i]); + if (error) + return "linkLayerAddresses." + error; + } + } + return null; + }; + + /** + * Creates a SubnetStatus message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.SubnetStatus + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.SubnetStatus} SubnetStatus + */ + SubnetStatus.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.SubnetStatus) + return object; + var message = new $root.google.cloud.edgenetwork.v1.SubnetStatus(); + if (object.name != null) + message.name = String(object.name); + if (object.macAddress != null) + message.macAddress = String(object.macAddress); + if (object.linkLayerAddresses) { + if (!Array.isArray(object.linkLayerAddresses)) + throw TypeError(".google.cloud.edgenetwork.v1.SubnetStatus.linkLayerAddresses: array expected"); + message.linkLayerAddresses = []; + for (var i = 0; i < object.linkLayerAddresses.length; ++i) { + if (typeof object.linkLayerAddresses[i] !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.SubnetStatus.linkLayerAddresses: object expected"); + message.linkLayerAddresses[i] = $root.google.cloud.edgenetwork.v1.LinkLayerAddress.fromObject(object.linkLayerAddresses[i]); + } + } + return message; + }; + + /** + * Creates a plain object from a SubnetStatus message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.SubnetStatus + * @static + * @param {google.cloud.edgenetwork.v1.SubnetStatus} message SubnetStatus + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + SubnetStatus.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.linkLayerAddresses = []; + if (options.defaults) { + object.name = ""; + object.macAddress = ""; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.macAddress != null && message.hasOwnProperty("macAddress")) + object.macAddress = message.macAddress; + if (message.linkLayerAddresses && message.linkLayerAddresses.length) { + object.linkLayerAddresses = []; + for (var j = 0; j < message.linkLayerAddresses.length; ++j) + object.linkLayerAddresses[j] = $root.google.cloud.edgenetwork.v1.LinkLayerAddress.toObject(message.linkLayerAddresses[j], options); + } + return object; + }; + + /** + * Converts this SubnetStatus to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.SubnetStatus + * @instance + * @returns {Object.} JSON object + */ + SubnetStatus.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for SubnetStatus + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.SubnetStatus + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + SubnetStatus.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.SubnetStatus"; + }; + + return SubnetStatus; + })(); + + v1.InterconnectDiagnostics = (function() { + + /** + * Properties of an InterconnectDiagnostics. + * @memberof google.cloud.edgenetwork.v1 + * @interface IInterconnectDiagnostics + * @property {string|null} [macAddress] InterconnectDiagnostics macAddress + * @property {Array.|null} [linkLayerAddresses] InterconnectDiagnostics linkLayerAddresses + * @property {Array.|null} [links] InterconnectDiagnostics links + */ + + /** + * Constructs a new InterconnectDiagnostics. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents an InterconnectDiagnostics. + * @implements IInterconnectDiagnostics + * @constructor + * @param {google.cloud.edgenetwork.v1.IInterconnectDiagnostics=} [properties] Properties to set + */ + function InterconnectDiagnostics(properties) { + this.linkLayerAddresses = []; + this.links = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * InterconnectDiagnostics macAddress. + * @member {string} macAddress + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @instance + */ + InterconnectDiagnostics.prototype.macAddress = ""; + + /** + * InterconnectDiagnostics linkLayerAddresses. + * @member {Array.} linkLayerAddresses + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @instance + */ + InterconnectDiagnostics.prototype.linkLayerAddresses = $util.emptyArray; + + /** + * InterconnectDiagnostics links. + * @member {Array.} links + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @instance + */ + InterconnectDiagnostics.prototype.links = $util.emptyArray; + + /** + * Creates a new InterconnectDiagnostics instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @static + * @param {google.cloud.edgenetwork.v1.IInterconnectDiagnostics=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics} InterconnectDiagnostics instance + */ + InterconnectDiagnostics.create = function create(properties) { + return new InterconnectDiagnostics(properties); + }; + + /** + * Encodes the specified InterconnectDiagnostics message. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @static + * @param {google.cloud.edgenetwork.v1.IInterconnectDiagnostics} message InterconnectDiagnostics message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + InterconnectDiagnostics.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.macAddress != null && Object.hasOwnProperty.call(message, "macAddress")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.macAddress); + if (message.linkLayerAddresses != null && message.linkLayerAddresses.length) + for (var i = 0; i < message.linkLayerAddresses.length; ++i) + $root.google.cloud.edgenetwork.v1.LinkLayerAddress.encode(message.linkLayerAddresses[i], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.links != null && message.links.length) + for (var i = 0; i < message.links.length; ++i) + $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus.encode(message.links[i], writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified InterconnectDiagnostics message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @static + * @param {google.cloud.edgenetwork.v1.IInterconnectDiagnostics} message InterconnectDiagnostics message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + InterconnectDiagnostics.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an InterconnectDiagnostics message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics} InterconnectDiagnostics + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + InterconnectDiagnostics.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.macAddress = reader.string(); + break; + } + case 2: { + if (!(message.linkLayerAddresses && message.linkLayerAddresses.length)) + message.linkLayerAddresses = []; + message.linkLayerAddresses.push($root.google.cloud.edgenetwork.v1.LinkLayerAddress.decode(reader, reader.uint32())); + break; + } + case 3: { + if (!(message.links && message.links.length)) + message.links = []; + message.links.push($root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus.decode(reader, reader.uint32())); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an InterconnectDiagnostics message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics} InterconnectDiagnostics + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + InterconnectDiagnostics.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an InterconnectDiagnostics message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + InterconnectDiagnostics.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.macAddress != null && message.hasOwnProperty("macAddress")) + if (!$util.isString(message.macAddress)) + return "macAddress: string expected"; + if (message.linkLayerAddresses != null && message.hasOwnProperty("linkLayerAddresses")) { + if (!Array.isArray(message.linkLayerAddresses)) + return "linkLayerAddresses: array expected"; + for (var i = 0; i < message.linkLayerAddresses.length; ++i) { + var error = $root.google.cloud.edgenetwork.v1.LinkLayerAddress.verify(message.linkLayerAddresses[i]); + if (error) + return "linkLayerAddresses." + error; + } + } + if (message.links != null && message.hasOwnProperty("links")) { + if (!Array.isArray(message.links)) + return "links: array expected"; + for (var i = 0; i < message.links.length; ++i) { + var error = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus.verify(message.links[i]); + if (error) + return "links." + error; + } + } + return null; + }; + + /** + * Creates an InterconnectDiagnostics message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics} InterconnectDiagnostics + */ + InterconnectDiagnostics.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics) + return object; + var message = new $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics(); + if (object.macAddress != null) + message.macAddress = String(object.macAddress); + if (object.linkLayerAddresses) { + if (!Array.isArray(object.linkLayerAddresses)) + throw TypeError(".google.cloud.edgenetwork.v1.InterconnectDiagnostics.linkLayerAddresses: array expected"); + message.linkLayerAddresses = []; + for (var i = 0; i < object.linkLayerAddresses.length; ++i) { + if (typeof object.linkLayerAddresses[i] !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.InterconnectDiagnostics.linkLayerAddresses: object expected"); + message.linkLayerAddresses[i] = $root.google.cloud.edgenetwork.v1.LinkLayerAddress.fromObject(object.linkLayerAddresses[i]); + } + } + if (object.links) { + if (!Array.isArray(object.links)) + throw TypeError(".google.cloud.edgenetwork.v1.InterconnectDiagnostics.links: array expected"); + message.links = []; + for (var i = 0; i < object.links.length; ++i) { + if (typeof object.links[i] !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.InterconnectDiagnostics.links: object expected"); + message.links[i] = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus.fromObject(object.links[i]); + } + } + return message; + }; + + /** + * Creates a plain object from an InterconnectDiagnostics message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics} message InterconnectDiagnostics + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + InterconnectDiagnostics.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.linkLayerAddresses = []; + object.links = []; + } + if (options.defaults) + object.macAddress = ""; + if (message.macAddress != null && message.hasOwnProperty("macAddress")) + object.macAddress = message.macAddress; + if (message.linkLayerAddresses && message.linkLayerAddresses.length) { + object.linkLayerAddresses = []; + for (var j = 0; j < message.linkLayerAddresses.length; ++j) + object.linkLayerAddresses[j] = $root.google.cloud.edgenetwork.v1.LinkLayerAddress.toObject(message.linkLayerAddresses[j], options); + } + if (message.links && message.links.length) { + object.links = []; + for (var j = 0; j < message.links.length; ++j) + object.links[j] = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus.toObject(message.links[j], options); + } + return object; + }; + + /** + * Converts this InterconnectDiagnostics to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @instance + * @returns {Object.} JSON object + */ + InterconnectDiagnostics.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for InterconnectDiagnostics + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + InterconnectDiagnostics.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.InterconnectDiagnostics"; + }; + + InterconnectDiagnostics.LinkStatus = (function() { + + /** + * Properties of a LinkStatus. + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @interface ILinkStatus + * @property {string|null} [circuitId] LinkStatus circuitId + * @property {google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLACPStatus|null} [lacpStatus] LinkStatus lacpStatus + * @property {Array.|null} [lldpStatuses] LinkStatus lldpStatuses + * @property {google.cloud.edgenetwork.v1.InterconnectDiagnostics.IPacketCounts|null} [packetCounts] LinkStatus packetCounts + */ + + /** + * Constructs a new LinkStatus. + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @classdesc Represents a LinkStatus. + * @implements ILinkStatus + * @constructor + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkStatus=} [properties] Properties to set + */ + function LinkStatus(properties) { + this.lldpStatuses = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * LinkStatus circuitId. + * @member {string} circuitId + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus + * @instance + */ + LinkStatus.prototype.circuitId = ""; + + /** + * LinkStatus lacpStatus. + * @member {google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLACPStatus|null|undefined} lacpStatus + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus + * @instance + */ + LinkStatus.prototype.lacpStatus = null; + + /** + * LinkStatus lldpStatuses. + * @member {Array.} lldpStatuses + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus + * @instance + */ + LinkStatus.prototype.lldpStatuses = $util.emptyArray; + + /** + * LinkStatus packetCounts. + * @member {google.cloud.edgenetwork.v1.InterconnectDiagnostics.IPacketCounts|null|undefined} packetCounts + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus + * @instance + */ + LinkStatus.prototype.packetCounts = null; + + /** + * Creates a new LinkStatus instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkStatus=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus} LinkStatus instance + */ + LinkStatus.create = function create(properties) { + return new LinkStatus(properties); + }; + + /** + * Encodes the specified LinkStatus message. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkStatus} message LinkStatus message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + LinkStatus.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.circuitId != null && Object.hasOwnProperty.call(message, "circuitId")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.circuitId); + if (message.lacpStatus != null && Object.hasOwnProperty.call(message, "lacpStatus")) + $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.encode(message.lacpStatus, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.lldpStatuses != null && message.lldpStatuses.length) + for (var i = 0; i < message.lldpStatuses.length; ++i) + $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus.encode(message.lldpStatuses[i], writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + if (message.packetCounts != null && Object.hasOwnProperty.call(message, "packetCounts")) + $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts.encode(message.packetCounts, writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified LinkStatus message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkStatus} message LinkStatus message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + LinkStatus.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a LinkStatus message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus} LinkStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + LinkStatus.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.circuitId = reader.string(); + break; + } + case 2: { + message.lacpStatus = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.decode(reader, reader.uint32()); + break; + } + case 3: { + if (!(message.lldpStatuses && message.lldpStatuses.length)) + message.lldpStatuses = []; + message.lldpStatuses.push($root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus.decode(reader, reader.uint32())); + break; + } + case 4: { + message.packetCounts = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a LinkStatus message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus} LinkStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + LinkStatus.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a LinkStatus message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + LinkStatus.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.circuitId != null && message.hasOwnProperty("circuitId")) + if (!$util.isString(message.circuitId)) + return "circuitId: string expected"; + if (message.lacpStatus != null && message.hasOwnProperty("lacpStatus")) { + var error = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.verify(message.lacpStatus); + if (error) + return "lacpStatus." + error; + } + if (message.lldpStatuses != null && message.hasOwnProperty("lldpStatuses")) { + if (!Array.isArray(message.lldpStatuses)) + return "lldpStatuses: array expected"; + for (var i = 0; i < message.lldpStatuses.length; ++i) { + var error = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus.verify(message.lldpStatuses[i]); + if (error) + return "lldpStatuses." + error; + } + } + if (message.packetCounts != null && message.hasOwnProperty("packetCounts")) { + var error = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts.verify(message.packetCounts); + if (error) + return "packetCounts." + error; + } + return null; + }; + + /** + * Creates a LinkStatus message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus} LinkStatus + */ + LinkStatus.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus) + return object; + var message = new $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus(); + if (object.circuitId != null) + message.circuitId = String(object.circuitId); + if (object.lacpStatus != null) { + if (typeof object.lacpStatus !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus.lacpStatus: object expected"); + message.lacpStatus = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.fromObject(object.lacpStatus); + } + if (object.lldpStatuses) { + if (!Array.isArray(object.lldpStatuses)) + throw TypeError(".google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus.lldpStatuses: array expected"); + message.lldpStatuses = []; + for (var i = 0; i < object.lldpStatuses.length; ++i) { + if (typeof object.lldpStatuses[i] !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus.lldpStatuses: object expected"); + message.lldpStatuses[i] = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus.fromObject(object.lldpStatuses[i]); + } + } + if (object.packetCounts != null) { + if (typeof object.packetCounts !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus.packetCounts: object expected"); + message.packetCounts = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts.fromObject(object.packetCounts); + } + return message; + }; + + /** + * Creates a plain object from a LinkStatus message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus} message LinkStatus + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + LinkStatus.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.lldpStatuses = []; + if (options.defaults) { + object.circuitId = ""; + object.lacpStatus = null; + object.packetCounts = null; + } + if (message.circuitId != null && message.hasOwnProperty("circuitId")) + object.circuitId = message.circuitId; + if (message.lacpStatus != null && message.hasOwnProperty("lacpStatus")) + object.lacpStatus = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.toObject(message.lacpStatus, options); + if (message.lldpStatuses && message.lldpStatuses.length) { + object.lldpStatuses = []; + for (var j = 0; j < message.lldpStatuses.length; ++j) + object.lldpStatuses[j] = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus.toObject(message.lldpStatuses[j], options); + } + if (message.packetCounts != null && message.hasOwnProperty("packetCounts")) + object.packetCounts = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts.toObject(message.packetCounts, options); + return object; + }; + + /** + * Converts this LinkStatus to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus + * @instance + * @returns {Object.} JSON object + */ + LinkStatus.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for LinkStatus + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + LinkStatus.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkStatus"; + }; + + return LinkStatus; + })(); + + InterconnectDiagnostics.PacketCounts = (function() { + + /** + * Properties of a PacketCounts. + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @interface IPacketCounts + * @property {number|Long|null} [inboundUnicast] PacketCounts inboundUnicast + * @property {number|Long|null} [inboundErrors] PacketCounts inboundErrors + * @property {number|Long|null} [inboundDiscards] PacketCounts inboundDiscards + * @property {number|Long|null} [outboundUnicast] PacketCounts outboundUnicast + * @property {number|Long|null} [outboundErrors] PacketCounts outboundErrors + * @property {number|Long|null} [outboundDiscards] PacketCounts outboundDiscards + */ + + /** + * Constructs a new PacketCounts. + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @classdesc Represents a PacketCounts. + * @implements IPacketCounts + * @constructor + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.IPacketCounts=} [properties] Properties to set + */ + function PacketCounts(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * PacketCounts inboundUnicast. + * @member {number|Long} inboundUnicast + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts + * @instance + */ + PacketCounts.prototype.inboundUnicast = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * PacketCounts inboundErrors. + * @member {number|Long} inboundErrors + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts + * @instance + */ + PacketCounts.prototype.inboundErrors = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * PacketCounts inboundDiscards. + * @member {number|Long} inboundDiscards + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts + * @instance + */ + PacketCounts.prototype.inboundDiscards = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * PacketCounts outboundUnicast. + * @member {number|Long} outboundUnicast + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts + * @instance + */ + PacketCounts.prototype.outboundUnicast = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * PacketCounts outboundErrors. + * @member {number|Long} outboundErrors + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts + * @instance + */ + PacketCounts.prototype.outboundErrors = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * PacketCounts outboundDiscards. + * @member {number|Long} outboundDiscards + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts + * @instance + */ + PacketCounts.prototype.outboundDiscards = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * Creates a new PacketCounts instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.IPacketCounts=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts} PacketCounts instance + */ + PacketCounts.create = function create(properties) { + return new PacketCounts(properties); + }; + + /** + * Encodes the specified PacketCounts message. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.IPacketCounts} message PacketCounts message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + PacketCounts.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.inboundUnicast != null && Object.hasOwnProperty.call(message, "inboundUnicast")) + writer.uint32(/* id 1, wireType 0 =*/8).int64(message.inboundUnicast); + if (message.inboundErrors != null && Object.hasOwnProperty.call(message, "inboundErrors")) + writer.uint32(/* id 2, wireType 0 =*/16).int64(message.inboundErrors); + if (message.inboundDiscards != null && Object.hasOwnProperty.call(message, "inboundDiscards")) + writer.uint32(/* id 3, wireType 0 =*/24).int64(message.inboundDiscards); + if (message.outboundUnicast != null && Object.hasOwnProperty.call(message, "outboundUnicast")) + writer.uint32(/* id 4, wireType 0 =*/32).int64(message.outboundUnicast); + if (message.outboundErrors != null && Object.hasOwnProperty.call(message, "outboundErrors")) + writer.uint32(/* id 5, wireType 0 =*/40).int64(message.outboundErrors); + if (message.outboundDiscards != null && Object.hasOwnProperty.call(message, "outboundDiscards")) + writer.uint32(/* id 6, wireType 0 =*/48).int64(message.outboundDiscards); + return writer; + }; + + /** + * Encodes the specified PacketCounts message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.IPacketCounts} message PacketCounts message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + PacketCounts.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a PacketCounts message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts} PacketCounts + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + PacketCounts.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.inboundUnicast = reader.int64(); + break; + } + case 2: { + message.inboundErrors = reader.int64(); + break; + } + case 3: { + message.inboundDiscards = reader.int64(); + break; + } + case 4: { + message.outboundUnicast = reader.int64(); + break; + } + case 5: { + message.outboundErrors = reader.int64(); + break; + } + case 6: { + message.outboundDiscards = reader.int64(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a PacketCounts message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts} PacketCounts + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + PacketCounts.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a PacketCounts message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + PacketCounts.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.inboundUnicast != null && message.hasOwnProperty("inboundUnicast")) + if (!$util.isInteger(message.inboundUnicast) && !(message.inboundUnicast && $util.isInteger(message.inboundUnicast.low) && $util.isInteger(message.inboundUnicast.high))) + return "inboundUnicast: integer|Long expected"; + if (message.inboundErrors != null && message.hasOwnProperty("inboundErrors")) + if (!$util.isInteger(message.inboundErrors) && !(message.inboundErrors && $util.isInteger(message.inboundErrors.low) && $util.isInteger(message.inboundErrors.high))) + return "inboundErrors: integer|Long expected"; + if (message.inboundDiscards != null && message.hasOwnProperty("inboundDiscards")) + if (!$util.isInteger(message.inboundDiscards) && !(message.inboundDiscards && $util.isInteger(message.inboundDiscards.low) && $util.isInteger(message.inboundDiscards.high))) + return "inboundDiscards: integer|Long expected"; + if (message.outboundUnicast != null && message.hasOwnProperty("outboundUnicast")) + if (!$util.isInteger(message.outboundUnicast) && !(message.outboundUnicast && $util.isInteger(message.outboundUnicast.low) && $util.isInteger(message.outboundUnicast.high))) + return "outboundUnicast: integer|Long expected"; + if (message.outboundErrors != null && message.hasOwnProperty("outboundErrors")) + if (!$util.isInteger(message.outboundErrors) && !(message.outboundErrors && $util.isInteger(message.outboundErrors.low) && $util.isInteger(message.outboundErrors.high))) + return "outboundErrors: integer|Long expected"; + if (message.outboundDiscards != null && message.hasOwnProperty("outboundDiscards")) + if (!$util.isInteger(message.outboundDiscards) && !(message.outboundDiscards && $util.isInteger(message.outboundDiscards.low) && $util.isInteger(message.outboundDiscards.high))) + return "outboundDiscards: integer|Long expected"; + return null; + }; + + /** + * Creates a PacketCounts message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts} PacketCounts + */ + PacketCounts.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts) + return object; + var message = new $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts(); + if (object.inboundUnicast != null) + if ($util.Long) + (message.inboundUnicast = $util.Long.fromValue(object.inboundUnicast)).unsigned = false; + else if (typeof object.inboundUnicast === "string") + message.inboundUnicast = parseInt(object.inboundUnicast, 10); + else if (typeof object.inboundUnicast === "number") + message.inboundUnicast = object.inboundUnicast; + else if (typeof object.inboundUnicast === "object") + message.inboundUnicast = new $util.LongBits(object.inboundUnicast.low >>> 0, object.inboundUnicast.high >>> 0).toNumber(); + if (object.inboundErrors != null) + if ($util.Long) + (message.inboundErrors = $util.Long.fromValue(object.inboundErrors)).unsigned = false; + else if (typeof object.inboundErrors === "string") + message.inboundErrors = parseInt(object.inboundErrors, 10); + else if (typeof object.inboundErrors === "number") + message.inboundErrors = object.inboundErrors; + else if (typeof object.inboundErrors === "object") + message.inboundErrors = new $util.LongBits(object.inboundErrors.low >>> 0, object.inboundErrors.high >>> 0).toNumber(); + if (object.inboundDiscards != null) + if ($util.Long) + (message.inboundDiscards = $util.Long.fromValue(object.inboundDiscards)).unsigned = false; + else if (typeof object.inboundDiscards === "string") + message.inboundDiscards = parseInt(object.inboundDiscards, 10); + else if (typeof object.inboundDiscards === "number") + message.inboundDiscards = object.inboundDiscards; + else if (typeof object.inboundDiscards === "object") + message.inboundDiscards = new $util.LongBits(object.inboundDiscards.low >>> 0, object.inboundDiscards.high >>> 0).toNumber(); + if (object.outboundUnicast != null) + if ($util.Long) + (message.outboundUnicast = $util.Long.fromValue(object.outboundUnicast)).unsigned = false; + else if (typeof object.outboundUnicast === "string") + message.outboundUnicast = parseInt(object.outboundUnicast, 10); + else if (typeof object.outboundUnicast === "number") + message.outboundUnicast = object.outboundUnicast; + else if (typeof object.outboundUnicast === "object") + message.outboundUnicast = new $util.LongBits(object.outboundUnicast.low >>> 0, object.outboundUnicast.high >>> 0).toNumber(); + if (object.outboundErrors != null) + if ($util.Long) + (message.outboundErrors = $util.Long.fromValue(object.outboundErrors)).unsigned = false; + else if (typeof object.outboundErrors === "string") + message.outboundErrors = parseInt(object.outboundErrors, 10); + else if (typeof object.outboundErrors === "number") + message.outboundErrors = object.outboundErrors; + else if (typeof object.outboundErrors === "object") + message.outboundErrors = new $util.LongBits(object.outboundErrors.low >>> 0, object.outboundErrors.high >>> 0).toNumber(); + if (object.outboundDiscards != null) + if ($util.Long) + (message.outboundDiscards = $util.Long.fromValue(object.outboundDiscards)).unsigned = false; + else if (typeof object.outboundDiscards === "string") + message.outboundDiscards = parseInt(object.outboundDiscards, 10); + else if (typeof object.outboundDiscards === "number") + message.outboundDiscards = object.outboundDiscards; + else if (typeof object.outboundDiscards === "object") + message.outboundDiscards = new $util.LongBits(object.outboundDiscards.low >>> 0, object.outboundDiscards.high >>> 0).toNumber(); + return message; + }; + + /** + * Creates a plain object from a PacketCounts message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts} message PacketCounts + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + PacketCounts.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + if ($util.Long) { + var long = new $util.Long(0, 0, false); + object.inboundUnicast = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.inboundUnicast = options.longs === String ? "0" : 0; + if ($util.Long) { + var long = new $util.Long(0, 0, false); + object.inboundErrors = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.inboundErrors = options.longs === String ? "0" : 0; + if ($util.Long) { + var long = new $util.Long(0, 0, false); + object.inboundDiscards = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.inboundDiscards = options.longs === String ? "0" : 0; + if ($util.Long) { + var long = new $util.Long(0, 0, false); + object.outboundUnicast = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.outboundUnicast = options.longs === String ? "0" : 0; + if ($util.Long) { + var long = new $util.Long(0, 0, false); + object.outboundErrors = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.outboundErrors = options.longs === String ? "0" : 0; + if ($util.Long) { + var long = new $util.Long(0, 0, false); + object.outboundDiscards = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.outboundDiscards = options.longs === String ? "0" : 0; + } + if (message.inboundUnicast != null && message.hasOwnProperty("inboundUnicast")) + if (typeof message.inboundUnicast === "number") + object.inboundUnicast = options.longs === String ? String(message.inboundUnicast) : message.inboundUnicast; + else + object.inboundUnicast = options.longs === String ? $util.Long.prototype.toString.call(message.inboundUnicast) : options.longs === Number ? new $util.LongBits(message.inboundUnicast.low >>> 0, message.inboundUnicast.high >>> 0).toNumber() : message.inboundUnicast; + if (message.inboundErrors != null && message.hasOwnProperty("inboundErrors")) + if (typeof message.inboundErrors === "number") + object.inboundErrors = options.longs === String ? String(message.inboundErrors) : message.inboundErrors; + else + object.inboundErrors = options.longs === String ? $util.Long.prototype.toString.call(message.inboundErrors) : options.longs === Number ? new $util.LongBits(message.inboundErrors.low >>> 0, message.inboundErrors.high >>> 0).toNumber() : message.inboundErrors; + if (message.inboundDiscards != null && message.hasOwnProperty("inboundDiscards")) + if (typeof message.inboundDiscards === "number") + object.inboundDiscards = options.longs === String ? String(message.inboundDiscards) : message.inboundDiscards; + else + object.inboundDiscards = options.longs === String ? $util.Long.prototype.toString.call(message.inboundDiscards) : options.longs === Number ? new $util.LongBits(message.inboundDiscards.low >>> 0, message.inboundDiscards.high >>> 0).toNumber() : message.inboundDiscards; + if (message.outboundUnicast != null && message.hasOwnProperty("outboundUnicast")) + if (typeof message.outboundUnicast === "number") + object.outboundUnicast = options.longs === String ? String(message.outboundUnicast) : message.outboundUnicast; + else + object.outboundUnicast = options.longs === String ? $util.Long.prototype.toString.call(message.outboundUnicast) : options.longs === Number ? new $util.LongBits(message.outboundUnicast.low >>> 0, message.outboundUnicast.high >>> 0).toNumber() : message.outboundUnicast; + if (message.outboundErrors != null && message.hasOwnProperty("outboundErrors")) + if (typeof message.outboundErrors === "number") + object.outboundErrors = options.longs === String ? String(message.outboundErrors) : message.outboundErrors; + else + object.outboundErrors = options.longs === String ? $util.Long.prototype.toString.call(message.outboundErrors) : options.longs === Number ? new $util.LongBits(message.outboundErrors.low >>> 0, message.outboundErrors.high >>> 0).toNumber() : message.outboundErrors; + if (message.outboundDiscards != null && message.hasOwnProperty("outboundDiscards")) + if (typeof message.outboundDiscards === "number") + object.outboundDiscards = options.longs === String ? String(message.outboundDiscards) : message.outboundDiscards; + else + object.outboundDiscards = options.longs === String ? $util.Long.prototype.toString.call(message.outboundDiscards) : options.longs === Number ? new $util.LongBits(message.outboundDiscards.low >>> 0, message.outboundDiscards.high >>> 0).toNumber() : message.outboundDiscards; + return object; + }; + + /** + * Converts this PacketCounts to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts + * @instance + * @returns {Object.} JSON object + */ + PacketCounts.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for PacketCounts + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + PacketCounts.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.InterconnectDiagnostics.PacketCounts"; + }; + + return PacketCounts; + })(); + + InterconnectDiagnostics.LinkLACPStatus = (function() { + + /** + * Properties of a LinkLACPStatus. + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @interface ILinkLACPStatus + * @property {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.State|null} [state] LinkLACPStatus state + * @property {string|null} [googleSystemId] LinkLACPStatus googleSystemId + * @property {string|null} [neighborSystemId] LinkLACPStatus neighborSystemId + * @property {boolean|null} [aggregatable] LinkLACPStatus aggregatable + * @property {boolean|null} [collecting] LinkLACPStatus collecting + * @property {boolean|null} [distributing] LinkLACPStatus distributing + */ + + /** + * Constructs a new LinkLACPStatus. + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @classdesc Represents a LinkLACPStatus. + * @implements ILinkLACPStatus + * @constructor + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLACPStatus=} [properties] Properties to set + */ + function LinkLACPStatus(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * LinkLACPStatus state. + * @member {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.State} state + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus + * @instance + */ + LinkLACPStatus.prototype.state = 0; + + /** + * LinkLACPStatus googleSystemId. + * @member {string} googleSystemId + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus + * @instance + */ + LinkLACPStatus.prototype.googleSystemId = ""; + + /** + * LinkLACPStatus neighborSystemId. + * @member {string} neighborSystemId + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus + * @instance + */ + LinkLACPStatus.prototype.neighborSystemId = ""; + + /** + * LinkLACPStatus aggregatable. + * @member {boolean} aggregatable + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus + * @instance + */ + LinkLACPStatus.prototype.aggregatable = false; + + /** + * LinkLACPStatus collecting. + * @member {boolean} collecting + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus + * @instance + */ + LinkLACPStatus.prototype.collecting = false; + + /** + * LinkLACPStatus distributing. + * @member {boolean} distributing + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus + * @instance + */ + LinkLACPStatus.prototype.distributing = false; + + /** + * Creates a new LinkLACPStatus instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLACPStatus=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus} LinkLACPStatus instance + */ + LinkLACPStatus.create = function create(properties) { + return new LinkLACPStatus(properties); + }; + + /** + * Encodes the specified LinkLACPStatus message. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLACPStatus} message LinkLACPStatus message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + LinkLACPStatus.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.state != null && Object.hasOwnProperty.call(message, "state")) + writer.uint32(/* id 1, wireType 0 =*/8).int32(message.state); + if (message.googleSystemId != null && Object.hasOwnProperty.call(message, "googleSystemId")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.googleSystemId); + if (message.neighborSystemId != null && Object.hasOwnProperty.call(message, "neighborSystemId")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.neighborSystemId); + if (message.aggregatable != null && Object.hasOwnProperty.call(message, "aggregatable")) + writer.uint32(/* id 4, wireType 0 =*/32).bool(message.aggregatable); + if (message.collecting != null && Object.hasOwnProperty.call(message, "collecting")) + writer.uint32(/* id 5, wireType 0 =*/40).bool(message.collecting); + if (message.distributing != null && Object.hasOwnProperty.call(message, "distributing")) + writer.uint32(/* id 6, wireType 0 =*/48).bool(message.distributing); + return writer; + }; + + /** + * Encodes the specified LinkLACPStatus message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLACPStatus} message LinkLACPStatus message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + LinkLACPStatus.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a LinkLACPStatus message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus} LinkLACPStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + LinkLACPStatus.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.state = reader.int32(); + break; + } + case 2: { + message.googleSystemId = reader.string(); + break; + } + case 3: { + message.neighborSystemId = reader.string(); + break; + } + case 4: { + message.aggregatable = reader.bool(); + break; + } + case 5: { + message.collecting = reader.bool(); + break; + } + case 6: { + message.distributing = reader.bool(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a LinkLACPStatus message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus} LinkLACPStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + LinkLACPStatus.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a LinkLACPStatus message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + LinkLACPStatus.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.state != null && message.hasOwnProperty("state")) + switch (message.state) { + default: + return "state: enum value expected"; + case 0: + case 1: + case 2: + break; + } + if (message.googleSystemId != null && message.hasOwnProperty("googleSystemId")) + if (!$util.isString(message.googleSystemId)) + return "googleSystemId: string expected"; + if (message.neighborSystemId != null && message.hasOwnProperty("neighborSystemId")) + if (!$util.isString(message.neighborSystemId)) + return "neighborSystemId: string expected"; + if (message.aggregatable != null && message.hasOwnProperty("aggregatable")) + if (typeof message.aggregatable !== "boolean") + return "aggregatable: boolean expected"; + if (message.collecting != null && message.hasOwnProperty("collecting")) + if (typeof message.collecting !== "boolean") + return "collecting: boolean expected"; + if (message.distributing != null && message.hasOwnProperty("distributing")) + if (typeof message.distributing !== "boolean") + return "distributing: boolean expected"; + return null; + }; + + /** + * Creates a LinkLACPStatus message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus} LinkLACPStatus + */ + LinkLACPStatus.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus) + return object; + var message = new $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus(); + switch (object.state) { + default: + if (typeof object.state === "number") { + message.state = object.state; + break; + } + break; + case "UNKNOWN": + case 0: + message.state = 0; + break; + case "ACTIVE": + case 1: + message.state = 1; + break; + case "DETACHED": + case 2: + message.state = 2; + break; + } + if (object.googleSystemId != null) + message.googleSystemId = String(object.googleSystemId); + if (object.neighborSystemId != null) + message.neighborSystemId = String(object.neighborSystemId); + if (object.aggregatable != null) + message.aggregatable = Boolean(object.aggregatable); + if (object.collecting != null) + message.collecting = Boolean(object.collecting); + if (object.distributing != null) + message.distributing = Boolean(object.distributing); + return message; + }; + + /** + * Creates a plain object from a LinkLACPStatus message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus} message LinkLACPStatus + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + LinkLACPStatus.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.state = options.enums === String ? "UNKNOWN" : 0; + object.googleSystemId = ""; + object.neighborSystemId = ""; + object.aggregatable = false; + object.collecting = false; + object.distributing = false; + } + if (message.state != null && message.hasOwnProperty("state")) + object.state = options.enums === String ? $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.State[message.state] === undefined ? message.state : $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.State[message.state] : message.state; + if (message.googleSystemId != null && message.hasOwnProperty("googleSystemId")) + object.googleSystemId = message.googleSystemId; + if (message.neighborSystemId != null && message.hasOwnProperty("neighborSystemId")) + object.neighborSystemId = message.neighborSystemId; + if (message.aggregatable != null && message.hasOwnProperty("aggregatable")) + object.aggregatable = message.aggregatable; + if (message.collecting != null && message.hasOwnProperty("collecting")) + object.collecting = message.collecting; + if (message.distributing != null && message.hasOwnProperty("distributing")) + object.distributing = message.distributing; + return object; + }; + + /** + * Converts this LinkLACPStatus to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus + * @instance + * @returns {Object.} JSON object + */ + LinkLACPStatus.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for LinkLACPStatus + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + LinkLACPStatus.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus"; + }; + + /** + * State enum. + * @name google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLACPStatus.State + * @enum {number} + * @property {number} UNKNOWN=0 UNKNOWN value + * @property {number} ACTIVE=1 ACTIVE value + * @property {number} DETACHED=2 DETACHED value + */ + LinkLACPStatus.State = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "UNKNOWN"] = 0; + values[valuesById[1] = "ACTIVE"] = 1; + values[valuesById[2] = "DETACHED"] = 2; + return values; + })(); + + return LinkLACPStatus; + })(); + + InterconnectDiagnostics.LinkLLDPStatus = (function() { + + /** + * Properties of a LinkLLDPStatus. + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @interface ILinkLLDPStatus + * @property {string|null} [peerSystemName] LinkLLDPStatus peerSystemName + * @property {string|null} [peerSystemDescription] LinkLLDPStatus peerSystemDescription + * @property {string|null} [peerChassisId] LinkLLDPStatus peerChassisId + * @property {string|null} [peerChassisIdType] LinkLLDPStatus peerChassisIdType + * @property {string|null} [peerPortId] LinkLLDPStatus peerPortId + * @property {string|null} [peerPortIdType] LinkLLDPStatus peerPortIdType + */ + + /** + * Constructs a new LinkLLDPStatus. + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics + * @classdesc Represents a LinkLLDPStatus. + * @implements ILinkLLDPStatus + * @constructor + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLLDPStatus=} [properties] Properties to set + */ + function LinkLLDPStatus(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * LinkLLDPStatus peerSystemName. + * @member {string} peerSystemName + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus + * @instance + */ + LinkLLDPStatus.prototype.peerSystemName = ""; + + /** + * LinkLLDPStatus peerSystemDescription. + * @member {string} peerSystemDescription + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus + * @instance + */ + LinkLLDPStatus.prototype.peerSystemDescription = ""; + + /** + * LinkLLDPStatus peerChassisId. + * @member {string} peerChassisId + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus + * @instance + */ + LinkLLDPStatus.prototype.peerChassisId = ""; + + /** + * LinkLLDPStatus peerChassisIdType. + * @member {string} peerChassisIdType + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus + * @instance + */ + LinkLLDPStatus.prototype.peerChassisIdType = ""; + + /** + * LinkLLDPStatus peerPortId. + * @member {string} peerPortId + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus + * @instance + */ + LinkLLDPStatus.prototype.peerPortId = ""; + + /** + * LinkLLDPStatus peerPortIdType. + * @member {string} peerPortIdType + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus + * @instance + */ + LinkLLDPStatus.prototype.peerPortIdType = ""; + + /** + * Creates a new LinkLLDPStatus instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLLDPStatus=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus} LinkLLDPStatus instance + */ + LinkLLDPStatus.create = function create(properties) { + return new LinkLLDPStatus(properties); + }; + + /** + * Encodes the specified LinkLLDPStatus message. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLLDPStatus} message LinkLLDPStatus message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + LinkLLDPStatus.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.peerSystemName != null && Object.hasOwnProperty.call(message, "peerSystemName")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.peerSystemName); + if (message.peerSystemDescription != null && Object.hasOwnProperty.call(message, "peerSystemDescription")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.peerSystemDescription); + if (message.peerChassisId != null && Object.hasOwnProperty.call(message, "peerChassisId")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.peerChassisId); + if (message.peerChassisIdType != null && Object.hasOwnProperty.call(message, "peerChassisIdType")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.peerChassisIdType); + if (message.peerPortId != null && Object.hasOwnProperty.call(message, "peerPortId")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.peerPortId); + if (message.peerPortIdType != null && Object.hasOwnProperty.call(message, "peerPortIdType")) + writer.uint32(/* id 6, wireType 2 =*/50).string(message.peerPortIdType); + return writer; + }; + + /** + * Encodes the specified LinkLLDPStatus message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.ILinkLLDPStatus} message LinkLLDPStatus message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + LinkLLDPStatus.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a LinkLLDPStatus message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus} LinkLLDPStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + LinkLLDPStatus.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.peerSystemName = reader.string(); + break; + } + case 2: { + message.peerSystemDescription = reader.string(); + break; + } + case 3: { + message.peerChassisId = reader.string(); + break; + } + case 4: { + message.peerChassisIdType = reader.string(); + break; + } + case 5: { + message.peerPortId = reader.string(); + break; + } + case 6: { + message.peerPortIdType = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a LinkLLDPStatus message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus} LinkLLDPStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + LinkLLDPStatus.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a LinkLLDPStatus message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + LinkLLDPStatus.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.peerSystemName != null && message.hasOwnProperty("peerSystemName")) + if (!$util.isString(message.peerSystemName)) + return "peerSystemName: string expected"; + if (message.peerSystemDescription != null && message.hasOwnProperty("peerSystemDescription")) + if (!$util.isString(message.peerSystemDescription)) + return "peerSystemDescription: string expected"; + if (message.peerChassisId != null && message.hasOwnProperty("peerChassisId")) + if (!$util.isString(message.peerChassisId)) + return "peerChassisId: string expected"; + if (message.peerChassisIdType != null && message.hasOwnProperty("peerChassisIdType")) + if (!$util.isString(message.peerChassisIdType)) + return "peerChassisIdType: string expected"; + if (message.peerPortId != null && message.hasOwnProperty("peerPortId")) + if (!$util.isString(message.peerPortId)) + return "peerPortId: string expected"; + if (message.peerPortIdType != null && message.hasOwnProperty("peerPortIdType")) + if (!$util.isString(message.peerPortIdType)) + return "peerPortIdType: string expected"; + return null; + }; + + /** + * Creates a LinkLLDPStatus message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus} LinkLLDPStatus + */ + LinkLLDPStatus.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus) + return object; + var message = new $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus(); + if (object.peerSystemName != null) + message.peerSystemName = String(object.peerSystemName); + if (object.peerSystemDescription != null) + message.peerSystemDescription = String(object.peerSystemDescription); + if (object.peerChassisId != null) + message.peerChassisId = String(object.peerChassisId); + if (object.peerChassisIdType != null) + message.peerChassisIdType = String(object.peerChassisIdType); + if (object.peerPortId != null) + message.peerPortId = String(object.peerPortId); + if (object.peerPortIdType != null) + message.peerPortIdType = String(object.peerPortIdType); + return message; + }; + + /** + * Creates a plain object from a LinkLLDPStatus message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus + * @static + * @param {google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus} message LinkLLDPStatus + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + LinkLLDPStatus.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.peerSystemName = ""; + object.peerSystemDescription = ""; + object.peerChassisId = ""; + object.peerChassisIdType = ""; + object.peerPortId = ""; + object.peerPortIdType = ""; + } + if (message.peerSystemName != null && message.hasOwnProperty("peerSystemName")) + object.peerSystemName = message.peerSystemName; + if (message.peerSystemDescription != null && message.hasOwnProperty("peerSystemDescription")) + object.peerSystemDescription = message.peerSystemDescription; + if (message.peerChassisId != null && message.hasOwnProperty("peerChassisId")) + object.peerChassisId = message.peerChassisId; + if (message.peerChassisIdType != null && message.hasOwnProperty("peerChassisIdType")) + object.peerChassisIdType = message.peerChassisIdType; + if (message.peerPortId != null && message.hasOwnProperty("peerPortId")) + object.peerPortId = message.peerPortId; + if (message.peerPortIdType != null && message.hasOwnProperty("peerPortIdType")) + object.peerPortIdType = message.peerPortIdType; + return object; + }; + + /** + * Converts this LinkLLDPStatus to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus + * @instance + * @returns {Object.} JSON object + */ + LinkLLDPStatus.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for LinkLLDPStatus + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + LinkLLDPStatus.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.InterconnectDiagnostics.LinkLLDPStatus"; + }; + + return LinkLLDPStatus; + })(); + + return InterconnectDiagnostics; + })(); + + v1.RouterStatus = (function() { + + /** + * Properties of a RouterStatus. + * @memberof google.cloud.edgenetwork.v1 + * @interface IRouterStatus + * @property {string|null} [network] RouterStatus network + * @property {Array.|null} [bgpPeerStatus] RouterStatus bgpPeerStatus + */ + + /** + * Constructs a new RouterStatus. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a RouterStatus. + * @implements IRouterStatus + * @constructor + * @param {google.cloud.edgenetwork.v1.IRouterStatus=} [properties] Properties to set + */ + function RouterStatus(properties) { + this.bgpPeerStatus = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * RouterStatus network. + * @member {string} network + * @memberof google.cloud.edgenetwork.v1.RouterStatus + * @instance + */ + RouterStatus.prototype.network = ""; + + /** + * RouterStatus bgpPeerStatus. + * @member {Array.} bgpPeerStatus + * @memberof google.cloud.edgenetwork.v1.RouterStatus + * @instance + */ + RouterStatus.prototype.bgpPeerStatus = $util.emptyArray; + + /** + * Creates a new RouterStatus instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.RouterStatus + * @static + * @param {google.cloud.edgenetwork.v1.IRouterStatus=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.RouterStatus} RouterStatus instance + */ + RouterStatus.create = function create(properties) { + return new RouterStatus(properties); + }; + + /** + * Encodes the specified RouterStatus message. Does not implicitly {@link google.cloud.edgenetwork.v1.RouterStatus.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.RouterStatus + * @static + * @param {google.cloud.edgenetwork.v1.IRouterStatus} message RouterStatus message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + RouterStatus.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.network != null && Object.hasOwnProperty.call(message, "network")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.network); + if (message.bgpPeerStatus != null && message.bgpPeerStatus.length) + for (var i = 0; i < message.bgpPeerStatus.length; ++i) + $root.google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.encode(message.bgpPeerStatus[i], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified RouterStatus message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.RouterStatus.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.RouterStatus + * @static + * @param {google.cloud.edgenetwork.v1.IRouterStatus} message RouterStatus message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + RouterStatus.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a RouterStatus message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.RouterStatus + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.RouterStatus} RouterStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + RouterStatus.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.RouterStatus(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.network = reader.string(); + break; + } + case 2: { + if (!(message.bgpPeerStatus && message.bgpPeerStatus.length)) + message.bgpPeerStatus = []; + message.bgpPeerStatus.push($root.google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.decode(reader, reader.uint32())); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a RouterStatus message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.RouterStatus + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.RouterStatus} RouterStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + RouterStatus.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a RouterStatus message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.RouterStatus + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + RouterStatus.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.network != null && message.hasOwnProperty("network")) + if (!$util.isString(message.network)) + return "network: string expected"; + if (message.bgpPeerStatus != null && message.hasOwnProperty("bgpPeerStatus")) { + if (!Array.isArray(message.bgpPeerStatus)) + return "bgpPeerStatus: array expected"; + for (var i = 0; i < message.bgpPeerStatus.length; ++i) { + var error = $root.google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.verify(message.bgpPeerStatus[i]); + if (error) + return "bgpPeerStatus." + error; + } + } + return null; + }; + + /** + * Creates a RouterStatus message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.RouterStatus + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.RouterStatus} RouterStatus + */ + RouterStatus.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.RouterStatus) + return object; + var message = new $root.google.cloud.edgenetwork.v1.RouterStatus(); + if (object.network != null) + message.network = String(object.network); + if (object.bgpPeerStatus) { + if (!Array.isArray(object.bgpPeerStatus)) + throw TypeError(".google.cloud.edgenetwork.v1.RouterStatus.bgpPeerStatus: array expected"); + message.bgpPeerStatus = []; + for (var i = 0; i < object.bgpPeerStatus.length; ++i) { + if (typeof object.bgpPeerStatus[i] !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.RouterStatus.bgpPeerStatus: object expected"); + message.bgpPeerStatus[i] = $root.google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.fromObject(object.bgpPeerStatus[i]); + } + } + return message; + }; + + /** + * Creates a plain object from a RouterStatus message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.RouterStatus + * @static + * @param {google.cloud.edgenetwork.v1.RouterStatus} message RouterStatus + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + RouterStatus.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.bgpPeerStatus = []; + if (options.defaults) + object.network = ""; + if (message.network != null && message.hasOwnProperty("network")) + object.network = message.network; + if (message.bgpPeerStatus && message.bgpPeerStatus.length) { + object.bgpPeerStatus = []; + for (var j = 0; j < message.bgpPeerStatus.length; ++j) + object.bgpPeerStatus[j] = $root.google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.toObject(message.bgpPeerStatus[j], options); + } + return object; + }; + + /** + * Converts this RouterStatus to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.RouterStatus + * @instance + * @returns {Object.} JSON object + */ + RouterStatus.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for RouterStatus + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.RouterStatus + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + RouterStatus.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.RouterStatus"; + }; + + RouterStatus.BgpPeerStatus = (function() { + + /** + * Properties of a BgpPeerStatus. + * @memberof google.cloud.edgenetwork.v1.RouterStatus + * @interface IBgpPeerStatus + * @property {string|null} [name] BgpPeerStatus name + * @property {string|null} [ipAddress] BgpPeerStatus ipAddress + * @property {string|null} [peerIpAddress] BgpPeerStatus peerIpAddress + * @property {google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.BgpStatus|null} [status] BgpPeerStatus status + * @property {string|null} [state] BgpPeerStatus state + * @property {string|null} [uptime] BgpPeerStatus uptime + * @property {number|Long|null} [uptimeSeconds] BgpPeerStatus uptimeSeconds + * @property {google.cloud.edgenetwork.v1.RouterStatus.IPrefixCounter|null} [prefixCounter] BgpPeerStatus prefixCounter + */ + + /** + * Constructs a new BgpPeerStatus. + * @memberof google.cloud.edgenetwork.v1.RouterStatus + * @classdesc Represents a BgpPeerStatus. + * @implements IBgpPeerStatus + * @constructor + * @param {google.cloud.edgenetwork.v1.RouterStatus.IBgpPeerStatus=} [properties] Properties to set + */ + function BgpPeerStatus(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * BgpPeerStatus name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @instance + */ + BgpPeerStatus.prototype.name = ""; + + /** + * BgpPeerStatus ipAddress. + * @member {string} ipAddress + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @instance + */ + BgpPeerStatus.prototype.ipAddress = ""; + + /** + * BgpPeerStatus peerIpAddress. + * @member {string} peerIpAddress + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @instance + */ + BgpPeerStatus.prototype.peerIpAddress = ""; + + /** + * BgpPeerStatus status. + * @member {google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.BgpStatus} status + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @instance + */ + BgpPeerStatus.prototype.status = 0; + + /** + * BgpPeerStatus state. + * @member {string} state + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @instance + */ + BgpPeerStatus.prototype.state = ""; + + /** + * BgpPeerStatus uptime. + * @member {string} uptime + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @instance + */ + BgpPeerStatus.prototype.uptime = ""; + + /** + * BgpPeerStatus uptimeSeconds. + * @member {number|Long} uptimeSeconds + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @instance + */ + BgpPeerStatus.prototype.uptimeSeconds = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * BgpPeerStatus prefixCounter. + * @member {google.cloud.edgenetwork.v1.RouterStatus.IPrefixCounter|null|undefined} prefixCounter + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @instance + */ + BgpPeerStatus.prototype.prefixCounter = null; + + /** + * Creates a new BgpPeerStatus instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @static + * @param {google.cloud.edgenetwork.v1.RouterStatus.IBgpPeerStatus=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus} BgpPeerStatus instance + */ + BgpPeerStatus.create = function create(properties) { + return new BgpPeerStatus(properties); + }; + + /** + * Encodes the specified BgpPeerStatus message. Does not implicitly {@link google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @static + * @param {google.cloud.edgenetwork.v1.RouterStatus.IBgpPeerStatus} message BgpPeerStatus message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + BgpPeerStatus.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.ipAddress != null && Object.hasOwnProperty.call(message, "ipAddress")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.ipAddress); + if (message.peerIpAddress != null && Object.hasOwnProperty.call(message, "peerIpAddress")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.peerIpAddress); + if (message.status != null && Object.hasOwnProperty.call(message, "status")) + writer.uint32(/* id 4, wireType 0 =*/32).int32(message.status); + if (message.state != null && Object.hasOwnProperty.call(message, "state")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.state); + if (message.uptime != null && Object.hasOwnProperty.call(message, "uptime")) + writer.uint32(/* id 6, wireType 2 =*/50).string(message.uptime); + if (message.uptimeSeconds != null && Object.hasOwnProperty.call(message, "uptimeSeconds")) + writer.uint32(/* id 7, wireType 0 =*/56).int64(message.uptimeSeconds); + if (message.prefixCounter != null && Object.hasOwnProperty.call(message, "prefixCounter")) + $root.google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter.encode(message.prefixCounter, writer.uint32(/* id 8, wireType 2 =*/66).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified BgpPeerStatus message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @static + * @param {google.cloud.edgenetwork.v1.RouterStatus.IBgpPeerStatus} message BgpPeerStatus message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + BgpPeerStatus.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a BgpPeerStatus message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus} BgpPeerStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + BgpPeerStatus.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.ipAddress = reader.string(); + break; + } + case 3: { + message.peerIpAddress = reader.string(); + break; + } + case 4: { + message.status = reader.int32(); + break; + } + case 5: { + message.state = reader.string(); + break; + } + case 6: { + message.uptime = reader.string(); + break; + } + case 7: { + message.uptimeSeconds = reader.int64(); + break; + } + case 8: { + message.prefixCounter = $root.google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a BgpPeerStatus message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus} BgpPeerStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + BgpPeerStatus.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a BgpPeerStatus message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + BgpPeerStatus.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.ipAddress != null && message.hasOwnProperty("ipAddress")) + if (!$util.isString(message.ipAddress)) + return "ipAddress: string expected"; + if (message.peerIpAddress != null && message.hasOwnProperty("peerIpAddress")) + if (!$util.isString(message.peerIpAddress)) + return "peerIpAddress: string expected"; + if (message.status != null && message.hasOwnProperty("status")) + switch (message.status) { + default: + return "status: enum value expected"; + case 0: + case 1: + case 2: + break; + } + if (message.state != null && message.hasOwnProperty("state")) + if (!$util.isString(message.state)) + return "state: string expected"; + if (message.uptime != null && message.hasOwnProperty("uptime")) + if (!$util.isString(message.uptime)) + return "uptime: string expected"; + if (message.uptimeSeconds != null && message.hasOwnProperty("uptimeSeconds")) + if (!$util.isInteger(message.uptimeSeconds) && !(message.uptimeSeconds && $util.isInteger(message.uptimeSeconds.low) && $util.isInteger(message.uptimeSeconds.high))) + return "uptimeSeconds: integer|Long expected"; + if (message.prefixCounter != null && message.hasOwnProperty("prefixCounter")) { + var error = $root.google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter.verify(message.prefixCounter); + if (error) + return "prefixCounter." + error; + } + return null; + }; + + /** + * Creates a BgpPeerStatus message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus} BgpPeerStatus + */ + BgpPeerStatus.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus) + return object; + var message = new $root.google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus(); + if (object.name != null) + message.name = String(object.name); + if (object.ipAddress != null) + message.ipAddress = String(object.ipAddress); + if (object.peerIpAddress != null) + message.peerIpAddress = String(object.peerIpAddress); + switch (object.status) { + default: + if (typeof object.status === "number") { + message.status = object.status; + break; + } + break; + case "UNKNOWN": + case 0: + message.status = 0; + break; + case "UP": + case 1: + message.status = 1; + break; + case "DOWN": + case 2: + message.status = 2; + break; + } + if (object.state != null) + message.state = String(object.state); + if (object.uptime != null) + message.uptime = String(object.uptime); + if (object.uptimeSeconds != null) + if ($util.Long) + (message.uptimeSeconds = $util.Long.fromValue(object.uptimeSeconds)).unsigned = false; + else if (typeof object.uptimeSeconds === "string") + message.uptimeSeconds = parseInt(object.uptimeSeconds, 10); + else if (typeof object.uptimeSeconds === "number") + message.uptimeSeconds = object.uptimeSeconds; + else if (typeof object.uptimeSeconds === "object") + message.uptimeSeconds = new $util.LongBits(object.uptimeSeconds.low >>> 0, object.uptimeSeconds.high >>> 0).toNumber(); + if (object.prefixCounter != null) { + if (typeof object.prefixCounter !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.prefixCounter: object expected"); + message.prefixCounter = $root.google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter.fromObject(object.prefixCounter); + } + return message; + }; + + /** + * Creates a plain object from a BgpPeerStatus message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @static + * @param {google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus} message BgpPeerStatus + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + BgpPeerStatus.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.name = ""; + object.ipAddress = ""; + object.peerIpAddress = ""; + object.status = options.enums === String ? "UNKNOWN" : 0; + object.state = ""; + object.uptime = ""; + if ($util.Long) { + var long = new $util.Long(0, 0, false); + object.uptimeSeconds = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.uptimeSeconds = options.longs === String ? "0" : 0; + object.prefixCounter = null; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.ipAddress != null && message.hasOwnProperty("ipAddress")) + object.ipAddress = message.ipAddress; + if (message.peerIpAddress != null && message.hasOwnProperty("peerIpAddress")) + object.peerIpAddress = message.peerIpAddress; + if (message.status != null && message.hasOwnProperty("status")) + object.status = options.enums === String ? $root.google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.BgpStatus[message.status] === undefined ? message.status : $root.google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.BgpStatus[message.status] : message.status; + if (message.state != null && message.hasOwnProperty("state")) + object.state = message.state; + if (message.uptime != null && message.hasOwnProperty("uptime")) + object.uptime = message.uptime; + if (message.uptimeSeconds != null && message.hasOwnProperty("uptimeSeconds")) + if (typeof message.uptimeSeconds === "number") + object.uptimeSeconds = options.longs === String ? String(message.uptimeSeconds) : message.uptimeSeconds; + else + object.uptimeSeconds = options.longs === String ? $util.Long.prototype.toString.call(message.uptimeSeconds) : options.longs === Number ? new $util.LongBits(message.uptimeSeconds.low >>> 0, message.uptimeSeconds.high >>> 0).toNumber() : message.uptimeSeconds; + if (message.prefixCounter != null && message.hasOwnProperty("prefixCounter")) + object.prefixCounter = $root.google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter.toObject(message.prefixCounter, options); + return object; + }; + + /** + * Converts this BgpPeerStatus to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @instance + * @returns {Object.} JSON object + */ + BgpPeerStatus.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for BgpPeerStatus + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + BgpPeerStatus.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus"; + }; + + /** + * BgpStatus enum. + * @name google.cloud.edgenetwork.v1.RouterStatus.BgpPeerStatus.BgpStatus + * @enum {number} + * @property {number} UNKNOWN=0 UNKNOWN value + * @property {number} UP=1 UP value + * @property {number} DOWN=2 DOWN value + */ + BgpPeerStatus.BgpStatus = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "UNKNOWN"] = 0; + values[valuesById[1] = "UP"] = 1; + values[valuesById[2] = "DOWN"] = 2; + return values; + })(); + + return BgpPeerStatus; + })(); + + RouterStatus.PrefixCounter = (function() { + + /** + * Properties of a PrefixCounter. + * @memberof google.cloud.edgenetwork.v1.RouterStatus + * @interface IPrefixCounter + * @property {number|Long|null} [advertised] PrefixCounter advertised + * @property {number|Long|null} [denied] PrefixCounter denied + * @property {number|Long|null} [received] PrefixCounter received + * @property {number|Long|null} [sent] PrefixCounter sent + * @property {number|Long|null} [suppressed] PrefixCounter suppressed + * @property {number|Long|null} [withdrawn] PrefixCounter withdrawn + */ + + /** + * Constructs a new PrefixCounter. + * @memberof google.cloud.edgenetwork.v1.RouterStatus + * @classdesc Represents a PrefixCounter. + * @implements IPrefixCounter + * @constructor + * @param {google.cloud.edgenetwork.v1.RouterStatus.IPrefixCounter=} [properties] Properties to set + */ + function PrefixCounter(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * PrefixCounter advertised. + * @member {number|Long} advertised + * @memberof google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter + * @instance + */ + PrefixCounter.prototype.advertised = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * PrefixCounter denied. + * @member {number|Long} denied + * @memberof google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter + * @instance + */ + PrefixCounter.prototype.denied = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * PrefixCounter received. + * @member {number|Long} received + * @memberof google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter + * @instance + */ + PrefixCounter.prototype.received = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * PrefixCounter sent. + * @member {number|Long} sent + * @memberof google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter + * @instance + */ + PrefixCounter.prototype.sent = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * PrefixCounter suppressed. + * @member {number|Long} suppressed + * @memberof google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter + * @instance + */ + PrefixCounter.prototype.suppressed = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * PrefixCounter withdrawn. + * @member {number|Long} withdrawn + * @memberof google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter + * @instance + */ + PrefixCounter.prototype.withdrawn = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * Creates a new PrefixCounter instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter + * @static + * @param {google.cloud.edgenetwork.v1.RouterStatus.IPrefixCounter=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter} PrefixCounter instance + */ + PrefixCounter.create = function create(properties) { + return new PrefixCounter(properties); + }; + + /** + * Encodes the specified PrefixCounter message. Does not implicitly {@link google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter + * @static + * @param {google.cloud.edgenetwork.v1.RouterStatus.IPrefixCounter} message PrefixCounter message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + PrefixCounter.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.advertised != null && Object.hasOwnProperty.call(message, "advertised")) + writer.uint32(/* id 1, wireType 0 =*/8).int64(message.advertised); + if (message.denied != null && Object.hasOwnProperty.call(message, "denied")) + writer.uint32(/* id 2, wireType 0 =*/16).int64(message.denied); + if (message.received != null && Object.hasOwnProperty.call(message, "received")) + writer.uint32(/* id 3, wireType 0 =*/24).int64(message.received); + if (message.sent != null && Object.hasOwnProperty.call(message, "sent")) + writer.uint32(/* id 4, wireType 0 =*/32).int64(message.sent); + if (message.suppressed != null && Object.hasOwnProperty.call(message, "suppressed")) + writer.uint32(/* id 5, wireType 0 =*/40).int64(message.suppressed); + if (message.withdrawn != null && Object.hasOwnProperty.call(message, "withdrawn")) + writer.uint32(/* id 6, wireType 0 =*/48).int64(message.withdrawn); + return writer; + }; + + /** + * Encodes the specified PrefixCounter message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter + * @static + * @param {google.cloud.edgenetwork.v1.RouterStatus.IPrefixCounter} message PrefixCounter message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + PrefixCounter.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a PrefixCounter message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter} PrefixCounter + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + PrefixCounter.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.advertised = reader.int64(); + break; + } + case 2: { + message.denied = reader.int64(); + break; + } + case 3: { + message.received = reader.int64(); + break; + } + case 4: { + message.sent = reader.int64(); + break; + } + case 5: { + message.suppressed = reader.int64(); + break; + } + case 6: { + message.withdrawn = reader.int64(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a PrefixCounter message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter} PrefixCounter + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + PrefixCounter.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a PrefixCounter message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + PrefixCounter.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.advertised != null && message.hasOwnProperty("advertised")) + if (!$util.isInteger(message.advertised) && !(message.advertised && $util.isInteger(message.advertised.low) && $util.isInteger(message.advertised.high))) + return "advertised: integer|Long expected"; + if (message.denied != null && message.hasOwnProperty("denied")) + if (!$util.isInteger(message.denied) && !(message.denied && $util.isInteger(message.denied.low) && $util.isInteger(message.denied.high))) + return "denied: integer|Long expected"; + if (message.received != null && message.hasOwnProperty("received")) + if (!$util.isInteger(message.received) && !(message.received && $util.isInteger(message.received.low) && $util.isInteger(message.received.high))) + return "received: integer|Long expected"; + if (message.sent != null && message.hasOwnProperty("sent")) + if (!$util.isInteger(message.sent) && !(message.sent && $util.isInteger(message.sent.low) && $util.isInteger(message.sent.high))) + return "sent: integer|Long expected"; + if (message.suppressed != null && message.hasOwnProperty("suppressed")) + if (!$util.isInteger(message.suppressed) && !(message.suppressed && $util.isInteger(message.suppressed.low) && $util.isInteger(message.suppressed.high))) + return "suppressed: integer|Long expected"; + if (message.withdrawn != null && message.hasOwnProperty("withdrawn")) + if (!$util.isInteger(message.withdrawn) && !(message.withdrawn && $util.isInteger(message.withdrawn.low) && $util.isInteger(message.withdrawn.high))) + return "withdrawn: integer|Long expected"; + return null; + }; + + /** + * Creates a PrefixCounter message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter} PrefixCounter + */ + PrefixCounter.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter) + return object; + var message = new $root.google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter(); + if (object.advertised != null) + if ($util.Long) + (message.advertised = $util.Long.fromValue(object.advertised)).unsigned = false; + else if (typeof object.advertised === "string") + message.advertised = parseInt(object.advertised, 10); + else if (typeof object.advertised === "number") + message.advertised = object.advertised; + else if (typeof object.advertised === "object") + message.advertised = new $util.LongBits(object.advertised.low >>> 0, object.advertised.high >>> 0).toNumber(); + if (object.denied != null) + if ($util.Long) + (message.denied = $util.Long.fromValue(object.denied)).unsigned = false; + else if (typeof object.denied === "string") + message.denied = parseInt(object.denied, 10); + else if (typeof object.denied === "number") + message.denied = object.denied; + else if (typeof object.denied === "object") + message.denied = new $util.LongBits(object.denied.low >>> 0, object.denied.high >>> 0).toNumber(); + if (object.received != null) + if ($util.Long) + (message.received = $util.Long.fromValue(object.received)).unsigned = false; + else if (typeof object.received === "string") + message.received = parseInt(object.received, 10); + else if (typeof object.received === "number") + message.received = object.received; + else if (typeof object.received === "object") + message.received = new $util.LongBits(object.received.low >>> 0, object.received.high >>> 0).toNumber(); + if (object.sent != null) + if ($util.Long) + (message.sent = $util.Long.fromValue(object.sent)).unsigned = false; + else if (typeof object.sent === "string") + message.sent = parseInt(object.sent, 10); + else if (typeof object.sent === "number") + message.sent = object.sent; + else if (typeof object.sent === "object") + message.sent = new $util.LongBits(object.sent.low >>> 0, object.sent.high >>> 0).toNumber(); + if (object.suppressed != null) + if ($util.Long) + (message.suppressed = $util.Long.fromValue(object.suppressed)).unsigned = false; + else if (typeof object.suppressed === "string") + message.suppressed = parseInt(object.suppressed, 10); + else if (typeof object.suppressed === "number") + message.suppressed = object.suppressed; + else if (typeof object.suppressed === "object") + message.suppressed = new $util.LongBits(object.suppressed.low >>> 0, object.suppressed.high >>> 0).toNumber(); + if (object.withdrawn != null) + if ($util.Long) + (message.withdrawn = $util.Long.fromValue(object.withdrawn)).unsigned = false; + else if (typeof object.withdrawn === "string") + message.withdrawn = parseInt(object.withdrawn, 10); + else if (typeof object.withdrawn === "number") + message.withdrawn = object.withdrawn; + else if (typeof object.withdrawn === "object") + message.withdrawn = new $util.LongBits(object.withdrawn.low >>> 0, object.withdrawn.high >>> 0).toNumber(); + return message; + }; + + /** + * Creates a plain object from a PrefixCounter message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter + * @static + * @param {google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter} message PrefixCounter + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + PrefixCounter.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + if ($util.Long) { + var long = new $util.Long(0, 0, false); + object.advertised = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.advertised = options.longs === String ? "0" : 0; + if ($util.Long) { + var long = new $util.Long(0, 0, false); + object.denied = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.denied = options.longs === String ? "0" : 0; + if ($util.Long) { + var long = new $util.Long(0, 0, false); + object.received = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.received = options.longs === String ? "0" : 0; + if ($util.Long) { + var long = new $util.Long(0, 0, false); + object.sent = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.sent = options.longs === String ? "0" : 0; + if ($util.Long) { + var long = new $util.Long(0, 0, false); + object.suppressed = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.suppressed = options.longs === String ? "0" : 0; + if ($util.Long) { + var long = new $util.Long(0, 0, false); + object.withdrawn = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.withdrawn = options.longs === String ? "0" : 0; + } + if (message.advertised != null && message.hasOwnProperty("advertised")) + if (typeof message.advertised === "number") + object.advertised = options.longs === String ? String(message.advertised) : message.advertised; + else + object.advertised = options.longs === String ? $util.Long.prototype.toString.call(message.advertised) : options.longs === Number ? new $util.LongBits(message.advertised.low >>> 0, message.advertised.high >>> 0).toNumber() : message.advertised; + if (message.denied != null && message.hasOwnProperty("denied")) + if (typeof message.denied === "number") + object.denied = options.longs === String ? String(message.denied) : message.denied; + else + object.denied = options.longs === String ? $util.Long.prototype.toString.call(message.denied) : options.longs === Number ? new $util.LongBits(message.denied.low >>> 0, message.denied.high >>> 0).toNumber() : message.denied; + if (message.received != null && message.hasOwnProperty("received")) + if (typeof message.received === "number") + object.received = options.longs === String ? String(message.received) : message.received; + else + object.received = options.longs === String ? $util.Long.prototype.toString.call(message.received) : options.longs === Number ? new $util.LongBits(message.received.low >>> 0, message.received.high >>> 0).toNumber() : message.received; + if (message.sent != null && message.hasOwnProperty("sent")) + if (typeof message.sent === "number") + object.sent = options.longs === String ? String(message.sent) : message.sent; + else + object.sent = options.longs === String ? $util.Long.prototype.toString.call(message.sent) : options.longs === Number ? new $util.LongBits(message.sent.low >>> 0, message.sent.high >>> 0).toNumber() : message.sent; + if (message.suppressed != null && message.hasOwnProperty("suppressed")) + if (typeof message.suppressed === "number") + object.suppressed = options.longs === String ? String(message.suppressed) : message.suppressed; + else + object.suppressed = options.longs === String ? $util.Long.prototype.toString.call(message.suppressed) : options.longs === Number ? new $util.LongBits(message.suppressed.low >>> 0, message.suppressed.high >>> 0).toNumber() : message.suppressed; + if (message.withdrawn != null && message.hasOwnProperty("withdrawn")) + if (typeof message.withdrawn === "number") + object.withdrawn = options.longs === String ? String(message.withdrawn) : message.withdrawn; + else + object.withdrawn = options.longs === String ? $util.Long.prototype.toString.call(message.withdrawn) : options.longs === Number ? new $util.LongBits(message.withdrawn.low >>> 0, message.withdrawn.high >>> 0).toNumber() : message.withdrawn; + return object; + }; + + /** + * Converts this PrefixCounter to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter + * @instance + * @returns {Object.} JSON object + */ + PrefixCounter.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for PrefixCounter + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + PrefixCounter.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.RouterStatus.PrefixCounter"; + }; + + return PrefixCounter; + })(); + + return RouterStatus; + })(); + + v1.EdgeNetwork = (function() { + + /** + * Constructs a new EdgeNetwork service. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents an EdgeNetwork + * @extends $protobuf.rpc.Service + * @constructor + * @param {$protobuf.RPCImpl} rpcImpl RPC implementation + * @param {boolean} [requestDelimited=false] Whether requests are length-delimited + * @param {boolean} [responseDelimited=false] Whether responses are length-delimited + */ + function EdgeNetwork(rpcImpl, requestDelimited, responseDelimited) { + $protobuf.rpc.Service.call(this, rpcImpl, requestDelimited, responseDelimited); + } + + (EdgeNetwork.prototype = Object.create($protobuf.rpc.Service.prototype)).constructor = EdgeNetwork; + + /** + * Creates new EdgeNetwork service using the specified rpc implementation. + * @function create + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @static + * @param {$protobuf.RPCImpl} rpcImpl RPC implementation + * @param {boolean} [requestDelimited=false] Whether requests are length-delimited + * @param {boolean} [responseDelimited=false] Whether responses are length-delimited + * @returns {EdgeNetwork} RPC service. Useful where requests and/or responses are streamed. + */ + EdgeNetwork.create = function create(rpcImpl, requestDelimited, responseDelimited) { + return new this(rpcImpl, requestDelimited, responseDelimited); + }; + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|initializeZone}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef InitializeZoneCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.cloud.edgenetwork.v1.InitializeZoneResponse} [response] InitializeZoneResponse + */ + + /** + * Calls InitializeZone. + * @function initializeZone + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IInitializeZoneRequest} request InitializeZoneRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.InitializeZoneCallback} callback Node-style callback called with the error, if any, and InitializeZoneResponse + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.initializeZone = function initializeZone(request, callback) { + return this.rpcCall(initializeZone, $root.google.cloud.edgenetwork.v1.InitializeZoneRequest, $root.google.cloud.edgenetwork.v1.InitializeZoneResponse, request, callback); + }, "name", { value: "InitializeZone" }); + + /** + * Calls InitializeZone. + * @function initializeZone + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IInitializeZoneRequest} request InitializeZoneRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|listZones}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef ListZonesCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.cloud.edgenetwork.v1.ListZonesResponse} [response] ListZonesResponse + */ + + /** + * Calls ListZones. + * @function listZones + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IListZonesRequest} request ListZonesRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.ListZonesCallback} callback Node-style callback called with the error, if any, and ListZonesResponse + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.listZones = function listZones(request, callback) { + return this.rpcCall(listZones, $root.google.cloud.edgenetwork.v1.ListZonesRequest, $root.google.cloud.edgenetwork.v1.ListZonesResponse, request, callback); + }, "name", { value: "ListZones" }); + + /** + * Calls ListZones. + * @function listZones + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IListZonesRequest} request ListZonesRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|getZone}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef GetZoneCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.cloud.edgenetwork.v1.Zone} [response] Zone + */ + + /** + * Calls GetZone. + * @function getZone + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IGetZoneRequest} request GetZoneRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.GetZoneCallback} callback Node-style callback called with the error, if any, and Zone + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.getZone = function getZone(request, callback) { + return this.rpcCall(getZone, $root.google.cloud.edgenetwork.v1.GetZoneRequest, $root.google.cloud.edgenetwork.v1.Zone, request, callback); + }, "name", { value: "GetZone" }); + + /** + * Calls GetZone. + * @function getZone + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IGetZoneRequest} request GetZoneRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|listNetworks}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef ListNetworksCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.cloud.edgenetwork.v1.ListNetworksResponse} [response] ListNetworksResponse + */ + + /** + * Calls ListNetworks. + * @function listNetworks + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IListNetworksRequest} request ListNetworksRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.ListNetworksCallback} callback Node-style callback called with the error, if any, and ListNetworksResponse + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.listNetworks = function listNetworks(request, callback) { + return this.rpcCall(listNetworks, $root.google.cloud.edgenetwork.v1.ListNetworksRequest, $root.google.cloud.edgenetwork.v1.ListNetworksResponse, request, callback); + }, "name", { value: "ListNetworks" }); + + /** + * Calls ListNetworks. + * @function listNetworks + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IListNetworksRequest} request ListNetworksRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|getNetwork}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef GetNetworkCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.cloud.edgenetwork.v1.Network} [response] Network + */ + + /** + * Calls GetNetwork. + * @function getNetwork + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IGetNetworkRequest} request GetNetworkRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.GetNetworkCallback} callback Node-style callback called with the error, if any, and Network + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.getNetwork = function getNetwork(request, callback) { + return this.rpcCall(getNetwork, $root.google.cloud.edgenetwork.v1.GetNetworkRequest, $root.google.cloud.edgenetwork.v1.Network, request, callback); + }, "name", { value: "GetNetwork" }); + + /** + * Calls GetNetwork. + * @function getNetwork + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IGetNetworkRequest} request GetNetworkRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|diagnoseNetwork}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef DiagnoseNetworkCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse} [response] DiagnoseNetworkResponse + */ + + /** + * Calls DiagnoseNetwork. + * @function diagnoseNetwork + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest} request DiagnoseNetworkRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseNetworkCallback} callback Node-style callback called with the error, if any, and DiagnoseNetworkResponse + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.diagnoseNetwork = function diagnoseNetwork(request, callback) { + return this.rpcCall(diagnoseNetwork, $root.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest, $root.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse, request, callback); + }, "name", { value: "DiagnoseNetwork" }); + + /** + * Calls DiagnoseNetwork. + * @function diagnoseNetwork + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest} request DiagnoseNetworkRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|createNetwork}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef CreateNetworkCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.longrunning.Operation} [response] Operation + */ + + /** + * Calls CreateNetwork. + * @function createNetwork + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.ICreateNetworkRequest} request CreateNetworkRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.CreateNetworkCallback} callback Node-style callback called with the error, if any, and Operation + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.createNetwork = function createNetwork(request, callback) { + return this.rpcCall(createNetwork, $root.google.cloud.edgenetwork.v1.CreateNetworkRequest, $root.google.longrunning.Operation, request, callback); + }, "name", { value: "CreateNetwork" }); + + /** + * Calls CreateNetwork. + * @function createNetwork + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.ICreateNetworkRequest} request CreateNetworkRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|deleteNetwork}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef DeleteNetworkCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.longrunning.Operation} [response] Operation + */ + + /** + * Calls DeleteNetwork. + * @function deleteNetwork + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IDeleteNetworkRequest} request DeleteNetworkRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.DeleteNetworkCallback} callback Node-style callback called with the error, if any, and Operation + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.deleteNetwork = function deleteNetwork(request, callback) { + return this.rpcCall(deleteNetwork, $root.google.cloud.edgenetwork.v1.DeleteNetworkRequest, $root.google.longrunning.Operation, request, callback); + }, "name", { value: "DeleteNetwork" }); + + /** + * Calls DeleteNetwork. + * @function deleteNetwork + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IDeleteNetworkRequest} request DeleteNetworkRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|listSubnets}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef ListSubnetsCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.cloud.edgenetwork.v1.ListSubnetsResponse} [response] ListSubnetsResponse + */ + + /** + * Calls ListSubnets. + * @function listSubnets + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IListSubnetsRequest} request ListSubnetsRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.ListSubnetsCallback} callback Node-style callback called with the error, if any, and ListSubnetsResponse + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.listSubnets = function listSubnets(request, callback) { + return this.rpcCall(listSubnets, $root.google.cloud.edgenetwork.v1.ListSubnetsRequest, $root.google.cloud.edgenetwork.v1.ListSubnetsResponse, request, callback); + }, "name", { value: "ListSubnets" }); + + /** + * Calls ListSubnets. + * @function listSubnets + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IListSubnetsRequest} request ListSubnetsRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|getSubnet}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef GetSubnetCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.cloud.edgenetwork.v1.Subnet} [response] Subnet + */ + + /** + * Calls GetSubnet. + * @function getSubnet + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IGetSubnetRequest} request GetSubnetRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.GetSubnetCallback} callback Node-style callback called with the error, if any, and Subnet + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.getSubnet = function getSubnet(request, callback) { + return this.rpcCall(getSubnet, $root.google.cloud.edgenetwork.v1.GetSubnetRequest, $root.google.cloud.edgenetwork.v1.Subnet, request, callback); + }, "name", { value: "GetSubnet" }); + + /** + * Calls GetSubnet. + * @function getSubnet + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IGetSubnetRequest} request GetSubnetRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|createSubnet}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef CreateSubnetCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.longrunning.Operation} [response] Operation + */ + + /** + * Calls CreateSubnet. + * @function createSubnet + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.ICreateSubnetRequest} request CreateSubnetRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.CreateSubnetCallback} callback Node-style callback called with the error, if any, and Operation + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.createSubnet = function createSubnet(request, callback) { + return this.rpcCall(createSubnet, $root.google.cloud.edgenetwork.v1.CreateSubnetRequest, $root.google.longrunning.Operation, request, callback); + }, "name", { value: "CreateSubnet" }); + + /** + * Calls CreateSubnet. + * @function createSubnet + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.ICreateSubnetRequest} request CreateSubnetRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|updateSubnet}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef UpdateSubnetCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.longrunning.Operation} [response] Operation + */ + + /** + * Calls UpdateSubnet. + * @function updateSubnet + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IUpdateSubnetRequest} request UpdateSubnetRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.UpdateSubnetCallback} callback Node-style callback called with the error, if any, and Operation + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.updateSubnet = function updateSubnet(request, callback) { + return this.rpcCall(updateSubnet, $root.google.cloud.edgenetwork.v1.UpdateSubnetRequest, $root.google.longrunning.Operation, request, callback); + }, "name", { value: "UpdateSubnet" }); + + /** + * Calls UpdateSubnet. + * @function updateSubnet + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IUpdateSubnetRequest} request UpdateSubnetRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|deleteSubnet}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef DeleteSubnetCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.longrunning.Operation} [response] Operation + */ + + /** + * Calls DeleteSubnet. + * @function deleteSubnet + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IDeleteSubnetRequest} request DeleteSubnetRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.DeleteSubnetCallback} callback Node-style callback called with the error, if any, and Operation + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.deleteSubnet = function deleteSubnet(request, callback) { + return this.rpcCall(deleteSubnet, $root.google.cloud.edgenetwork.v1.DeleteSubnetRequest, $root.google.longrunning.Operation, request, callback); + }, "name", { value: "DeleteSubnet" }); + + /** + * Calls DeleteSubnet. + * @function deleteSubnet + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IDeleteSubnetRequest} request DeleteSubnetRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|listInterconnects}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef ListInterconnectsCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.cloud.edgenetwork.v1.ListInterconnectsResponse} [response] ListInterconnectsResponse + */ + + /** + * Calls ListInterconnects. + * @function listInterconnects + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IListInterconnectsRequest} request ListInterconnectsRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.ListInterconnectsCallback} callback Node-style callback called with the error, if any, and ListInterconnectsResponse + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.listInterconnects = function listInterconnects(request, callback) { + return this.rpcCall(listInterconnects, $root.google.cloud.edgenetwork.v1.ListInterconnectsRequest, $root.google.cloud.edgenetwork.v1.ListInterconnectsResponse, request, callback); + }, "name", { value: "ListInterconnects" }); + + /** + * Calls ListInterconnects. + * @function listInterconnects + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IListInterconnectsRequest} request ListInterconnectsRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|getInterconnect}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef GetInterconnectCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.cloud.edgenetwork.v1.Interconnect} [response] Interconnect + */ + + /** + * Calls GetInterconnect. + * @function getInterconnect + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IGetInterconnectRequest} request GetInterconnectRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.GetInterconnectCallback} callback Node-style callback called with the error, if any, and Interconnect + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.getInterconnect = function getInterconnect(request, callback) { + return this.rpcCall(getInterconnect, $root.google.cloud.edgenetwork.v1.GetInterconnectRequest, $root.google.cloud.edgenetwork.v1.Interconnect, request, callback); + }, "name", { value: "GetInterconnect" }); + + /** + * Calls GetInterconnect. + * @function getInterconnect + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IGetInterconnectRequest} request GetInterconnectRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|diagnoseInterconnect}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef DiagnoseInterconnectCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse} [response] DiagnoseInterconnectResponse + */ + + /** + * Calls DiagnoseInterconnect. + * @function diagnoseInterconnect + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest} request DiagnoseInterconnectRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseInterconnectCallback} callback Node-style callback called with the error, if any, and DiagnoseInterconnectResponse + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.diagnoseInterconnect = function diagnoseInterconnect(request, callback) { + return this.rpcCall(diagnoseInterconnect, $root.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest, $root.google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse, request, callback); + }, "name", { value: "DiagnoseInterconnect" }); + + /** + * Calls DiagnoseInterconnect. + * @function diagnoseInterconnect + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest} request DiagnoseInterconnectRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|listInterconnectAttachments}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef ListInterconnectAttachmentsCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse} [response] ListInterconnectAttachmentsResponse + */ + + /** + * Calls ListInterconnectAttachments. + * @function listInterconnectAttachments + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest} request ListInterconnectAttachmentsRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.ListInterconnectAttachmentsCallback} callback Node-style callback called with the error, if any, and ListInterconnectAttachmentsResponse + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.listInterconnectAttachments = function listInterconnectAttachments(request, callback) { + return this.rpcCall(listInterconnectAttachments, $root.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest, $root.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse, request, callback); + }, "name", { value: "ListInterconnectAttachments" }); + + /** + * Calls ListInterconnectAttachments. + * @function listInterconnectAttachments + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest} request ListInterconnectAttachmentsRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|getInterconnectAttachment}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef GetInterconnectAttachmentCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.cloud.edgenetwork.v1.InterconnectAttachment} [response] InterconnectAttachment + */ + + /** + * Calls GetInterconnectAttachment. + * @function getInterconnectAttachment + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest} request GetInterconnectAttachmentRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.GetInterconnectAttachmentCallback} callback Node-style callback called with the error, if any, and InterconnectAttachment + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.getInterconnectAttachment = function getInterconnectAttachment(request, callback) { + return this.rpcCall(getInterconnectAttachment, $root.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest, $root.google.cloud.edgenetwork.v1.InterconnectAttachment, request, callback); + }, "name", { value: "GetInterconnectAttachment" }); + + /** + * Calls GetInterconnectAttachment. + * @function getInterconnectAttachment + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest} request GetInterconnectAttachmentRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|createInterconnectAttachment}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef CreateInterconnectAttachmentCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.longrunning.Operation} [response] Operation + */ + + /** + * Calls CreateInterconnectAttachment. + * @function createInterconnectAttachment + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest} request CreateInterconnectAttachmentRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.CreateInterconnectAttachmentCallback} callback Node-style callback called with the error, if any, and Operation + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.createInterconnectAttachment = function createInterconnectAttachment(request, callback) { + return this.rpcCall(createInterconnectAttachment, $root.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest, $root.google.longrunning.Operation, request, callback); + }, "name", { value: "CreateInterconnectAttachment" }); + + /** + * Calls CreateInterconnectAttachment. + * @function createInterconnectAttachment + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest} request CreateInterconnectAttachmentRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|deleteInterconnectAttachment}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef DeleteInterconnectAttachmentCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.longrunning.Operation} [response] Operation + */ + + /** + * Calls DeleteInterconnectAttachment. + * @function deleteInterconnectAttachment + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest} request DeleteInterconnectAttachmentRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.DeleteInterconnectAttachmentCallback} callback Node-style callback called with the error, if any, and Operation + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.deleteInterconnectAttachment = function deleteInterconnectAttachment(request, callback) { + return this.rpcCall(deleteInterconnectAttachment, $root.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest, $root.google.longrunning.Operation, request, callback); + }, "name", { value: "DeleteInterconnectAttachment" }); + + /** + * Calls DeleteInterconnectAttachment. + * @function deleteInterconnectAttachment + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest} request DeleteInterconnectAttachmentRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|listRouters}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef ListRoutersCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.cloud.edgenetwork.v1.ListRoutersResponse} [response] ListRoutersResponse + */ + + /** + * Calls ListRouters. + * @function listRouters + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IListRoutersRequest} request ListRoutersRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.ListRoutersCallback} callback Node-style callback called with the error, if any, and ListRoutersResponse + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.listRouters = function listRouters(request, callback) { + return this.rpcCall(listRouters, $root.google.cloud.edgenetwork.v1.ListRoutersRequest, $root.google.cloud.edgenetwork.v1.ListRoutersResponse, request, callback); + }, "name", { value: "ListRouters" }); + + /** + * Calls ListRouters. + * @function listRouters + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IListRoutersRequest} request ListRoutersRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|getRouter}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef GetRouterCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.cloud.edgenetwork.v1.Router} [response] Router + */ + + /** + * Calls GetRouter. + * @function getRouter + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IGetRouterRequest} request GetRouterRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.GetRouterCallback} callback Node-style callback called with the error, if any, and Router + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.getRouter = function getRouter(request, callback) { + return this.rpcCall(getRouter, $root.google.cloud.edgenetwork.v1.GetRouterRequest, $root.google.cloud.edgenetwork.v1.Router, request, callback); + }, "name", { value: "GetRouter" }); + + /** + * Calls GetRouter. + * @function getRouter + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IGetRouterRequest} request GetRouterRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|diagnoseRouter}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef DiagnoseRouterCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.cloud.edgenetwork.v1.DiagnoseRouterResponse} [response] DiagnoseRouterResponse + */ + + /** + * Calls DiagnoseRouter. + * @function diagnoseRouter + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IDiagnoseRouterRequest} request DiagnoseRouterRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseRouterCallback} callback Node-style callback called with the error, if any, and DiagnoseRouterResponse + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.diagnoseRouter = function diagnoseRouter(request, callback) { + return this.rpcCall(diagnoseRouter, $root.google.cloud.edgenetwork.v1.DiagnoseRouterRequest, $root.google.cloud.edgenetwork.v1.DiagnoseRouterResponse, request, callback); + }, "name", { value: "DiagnoseRouter" }); + + /** + * Calls DiagnoseRouter. + * @function diagnoseRouter + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IDiagnoseRouterRequest} request DiagnoseRouterRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|createRouter}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef CreateRouterCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.longrunning.Operation} [response] Operation + */ + + /** + * Calls CreateRouter. + * @function createRouter + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.ICreateRouterRequest} request CreateRouterRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.CreateRouterCallback} callback Node-style callback called with the error, if any, and Operation + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.createRouter = function createRouter(request, callback) { + return this.rpcCall(createRouter, $root.google.cloud.edgenetwork.v1.CreateRouterRequest, $root.google.longrunning.Operation, request, callback); + }, "name", { value: "CreateRouter" }); + + /** + * Calls CreateRouter. + * @function createRouter + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.ICreateRouterRequest} request CreateRouterRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|updateRouter}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef UpdateRouterCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.longrunning.Operation} [response] Operation + */ + + /** + * Calls UpdateRouter. + * @function updateRouter + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IUpdateRouterRequest} request UpdateRouterRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.UpdateRouterCallback} callback Node-style callback called with the error, if any, and Operation + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.updateRouter = function updateRouter(request, callback) { + return this.rpcCall(updateRouter, $root.google.cloud.edgenetwork.v1.UpdateRouterRequest, $root.google.longrunning.Operation, request, callback); + }, "name", { value: "UpdateRouter" }); + + /** + * Calls UpdateRouter. + * @function updateRouter + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IUpdateRouterRequest} request UpdateRouterRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.cloud.edgenetwork.v1.EdgeNetwork|deleteRouter}. + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @typedef DeleteRouterCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.longrunning.Operation} [response] Operation + */ + + /** + * Calls DeleteRouter. + * @function deleteRouter + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IDeleteRouterRequest} request DeleteRouterRequest message or plain object + * @param {google.cloud.edgenetwork.v1.EdgeNetwork.DeleteRouterCallback} callback Node-style callback called with the error, if any, and Operation + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(EdgeNetwork.prototype.deleteRouter = function deleteRouter(request, callback) { + return this.rpcCall(deleteRouter, $root.google.cloud.edgenetwork.v1.DeleteRouterRequest, $root.google.longrunning.Operation, request, callback); + }, "name", { value: "DeleteRouter" }); + + /** + * Calls DeleteRouter. + * @function deleteRouter + * @memberof google.cloud.edgenetwork.v1.EdgeNetwork + * @instance + * @param {google.cloud.edgenetwork.v1.IDeleteRouterRequest} request DeleteRouterRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + return EdgeNetwork; + })(); + + v1.ListZonesRequest = (function() { + + /** + * Properties of a ListZonesRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IListZonesRequest + * @property {string|null} [parent] ListZonesRequest parent + * @property {number|null} [pageSize] ListZonesRequest pageSize + * @property {string|null} [pageToken] ListZonesRequest pageToken + * @property {string|null} [filter] ListZonesRequest filter + * @property {string|null} [orderBy] ListZonesRequest orderBy + */ + + /** + * Constructs a new ListZonesRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a ListZonesRequest. + * @implements IListZonesRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IListZonesRequest=} [properties] Properties to set + */ + function ListZonesRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ListZonesRequest parent. + * @member {string} parent + * @memberof google.cloud.edgenetwork.v1.ListZonesRequest + * @instance + */ + ListZonesRequest.prototype.parent = ""; + + /** + * ListZonesRequest pageSize. + * @member {number} pageSize + * @memberof google.cloud.edgenetwork.v1.ListZonesRequest + * @instance + */ + ListZonesRequest.prototype.pageSize = 0; + + /** + * ListZonesRequest pageToken. + * @member {string} pageToken + * @memberof google.cloud.edgenetwork.v1.ListZonesRequest + * @instance + */ + ListZonesRequest.prototype.pageToken = ""; + + /** + * ListZonesRequest filter. + * @member {string} filter + * @memberof google.cloud.edgenetwork.v1.ListZonesRequest + * @instance + */ + ListZonesRequest.prototype.filter = ""; + + /** + * ListZonesRequest orderBy. + * @member {string} orderBy + * @memberof google.cloud.edgenetwork.v1.ListZonesRequest + * @instance + */ + ListZonesRequest.prototype.orderBy = ""; + + /** + * Creates a new ListZonesRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.ListZonesRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListZonesRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.ListZonesRequest} ListZonesRequest instance + */ + ListZonesRequest.create = function create(properties) { + return new ListZonesRequest(properties); + }; + + /** + * Encodes the specified ListZonesRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListZonesRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.ListZonesRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListZonesRequest} message ListZonesRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListZonesRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.parent != null && Object.hasOwnProperty.call(message, "parent")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.parent); + if (message.pageSize != null && Object.hasOwnProperty.call(message, "pageSize")) + writer.uint32(/* id 2, wireType 0 =*/16).int32(message.pageSize); + if (message.pageToken != null && Object.hasOwnProperty.call(message, "pageToken")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.pageToken); + if (message.filter != null && Object.hasOwnProperty.call(message, "filter")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.filter); + if (message.orderBy != null && Object.hasOwnProperty.call(message, "orderBy")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.orderBy); + return writer; + }; + + /** + * Encodes the specified ListZonesRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListZonesRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListZonesRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListZonesRequest} message ListZonesRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListZonesRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ListZonesRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.ListZonesRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.ListZonesRequest} ListZonesRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListZonesRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.ListZonesRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.parent = reader.string(); + break; + } + case 2: { + message.pageSize = reader.int32(); + break; + } + case 3: { + message.pageToken = reader.string(); + break; + } + case 4: { + message.filter = reader.string(); + break; + } + case 5: { + message.orderBy = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ListZonesRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListZonesRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.ListZonesRequest} ListZonesRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListZonesRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ListZonesRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.ListZonesRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ListZonesRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.parent != null && message.hasOwnProperty("parent")) + if (!$util.isString(message.parent)) + return "parent: string expected"; + if (message.pageSize != null && message.hasOwnProperty("pageSize")) + if (!$util.isInteger(message.pageSize)) + return "pageSize: integer expected"; + if (message.pageToken != null && message.hasOwnProperty("pageToken")) + if (!$util.isString(message.pageToken)) + return "pageToken: string expected"; + if (message.filter != null && message.hasOwnProperty("filter")) + if (!$util.isString(message.filter)) + return "filter: string expected"; + if (message.orderBy != null && message.hasOwnProperty("orderBy")) + if (!$util.isString(message.orderBy)) + return "orderBy: string expected"; + return null; + }; + + /** + * Creates a ListZonesRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.ListZonesRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.ListZonesRequest} ListZonesRequest + */ + ListZonesRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.ListZonesRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.ListZonesRequest(); + if (object.parent != null) + message.parent = String(object.parent); + if (object.pageSize != null) + message.pageSize = object.pageSize | 0; + if (object.pageToken != null) + message.pageToken = String(object.pageToken); + if (object.filter != null) + message.filter = String(object.filter); + if (object.orderBy != null) + message.orderBy = String(object.orderBy); + return message; + }; + + /** + * Creates a plain object from a ListZonesRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.ListZonesRequest + * @static + * @param {google.cloud.edgenetwork.v1.ListZonesRequest} message ListZonesRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ListZonesRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.parent = ""; + object.pageSize = 0; + object.pageToken = ""; + object.filter = ""; + object.orderBy = ""; + } + if (message.parent != null && message.hasOwnProperty("parent")) + object.parent = message.parent; + if (message.pageSize != null && message.hasOwnProperty("pageSize")) + object.pageSize = message.pageSize; + if (message.pageToken != null && message.hasOwnProperty("pageToken")) + object.pageToken = message.pageToken; + if (message.filter != null && message.hasOwnProperty("filter")) + object.filter = message.filter; + if (message.orderBy != null && message.hasOwnProperty("orderBy")) + object.orderBy = message.orderBy; + return object; + }; + + /** + * Converts this ListZonesRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.ListZonesRequest + * @instance + * @returns {Object.} JSON object + */ + ListZonesRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ListZonesRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.ListZonesRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ListZonesRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.ListZonesRequest"; + }; + + return ListZonesRequest; + })(); + + v1.ListZonesResponse = (function() { + + /** + * Properties of a ListZonesResponse. + * @memberof google.cloud.edgenetwork.v1 + * @interface IListZonesResponse + * @property {Array.|null} [zones] ListZonesResponse zones + * @property {string|null} [nextPageToken] ListZonesResponse nextPageToken + * @property {Array.|null} [unreachable] ListZonesResponse unreachable + */ + + /** + * Constructs a new ListZonesResponse. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a ListZonesResponse. + * @implements IListZonesResponse + * @constructor + * @param {google.cloud.edgenetwork.v1.IListZonesResponse=} [properties] Properties to set + */ + function ListZonesResponse(properties) { + this.zones = []; + this.unreachable = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ListZonesResponse zones. + * @member {Array.} zones + * @memberof google.cloud.edgenetwork.v1.ListZonesResponse + * @instance + */ + ListZonesResponse.prototype.zones = $util.emptyArray; + + /** + * ListZonesResponse nextPageToken. + * @member {string} nextPageToken + * @memberof google.cloud.edgenetwork.v1.ListZonesResponse + * @instance + */ + ListZonesResponse.prototype.nextPageToken = ""; + + /** + * ListZonesResponse unreachable. + * @member {Array.} unreachable + * @memberof google.cloud.edgenetwork.v1.ListZonesResponse + * @instance + */ + ListZonesResponse.prototype.unreachable = $util.emptyArray; + + /** + * Creates a new ListZonesResponse instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.ListZonesResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListZonesResponse=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.ListZonesResponse} ListZonesResponse instance + */ + ListZonesResponse.create = function create(properties) { + return new ListZonesResponse(properties); + }; + + /** + * Encodes the specified ListZonesResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListZonesResponse.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.ListZonesResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListZonesResponse} message ListZonesResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListZonesResponse.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.zones != null && message.zones.length) + for (var i = 0; i < message.zones.length; ++i) + $root.google.cloud.edgenetwork.v1.Zone.encode(message.zones[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.nextPageToken != null && Object.hasOwnProperty.call(message, "nextPageToken")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.nextPageToken); + if (message.unreachable != null && message.unreachable.length) + for (var i = 0; i < message.unreachable.length; ++i) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.unreachable[i]); + return writer; + }; + + /** + * Encodes the specified ListZonesResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListZonesResponse.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListZonesResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListZonesResponse} message ListZonesResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListZonesResponse.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ListZonesResponse message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.ListZonesResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.ListZonesResponse} ListZonesResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListZonesResponse.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.ListZonesResponse(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + if (!(message.zones && message.zones.length)) + message.zones = []; + message.zones.push($root.google.cloud.edgenetwork.v1.Zone.decode(reader, reader.uint32())); + break; + } + case 2: { + message.nextPageToken = reader.string(); + break; + } + case 3: { + if (!(message.unreachable && message.unreachable.length)) + message.unreachable = []; + message.unreachable.push(reader.string()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ListZonesResponse message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListZonesResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.ListZonesResponse} ListZonesResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListZonesResponse.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ListZonesResponse message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.ListZonesResponse + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ListZonesResponse.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.zones != null && message.hasOwnProperty("zones")) { + if (!Array.isArray(message.zones)) + return "zones: array expected"; + for (var i = 0; i < message.zones.length; ++i) { + var error = $root.google.cloud.edgenetwork.v1.Zone.verify(message.zones[i]); + if (error) + return "zones." + error; + } + } + if (message.nextPageToken != null && message.hasOwnProperty("nextPageToken")) + if (!$util.isString(message.nextPageToken)) + return "nextPageToken: string expected"; + if (message.unreachable != null && message.hasOwnProperty("unreachable")) { + if (!Array.isArray(message.unreachable)) + return "unreachable: array expected"; + for (var i = 0; i < message.unreachable.length; ++i) + if (!$util.isString(message.unreachable[i])) + return "unreachable: string[] expected"; + } + return null; + }; + + /** + * Creates a ListZonesResponse message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.ListZonesResponse + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.ListZonesResponse} ListZonesResponse + */ + ListZonesResponse.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.ListZonesResponse) + return object; + var message = new $root.google.cloud.edgenetwork.v1.ListZonesResponse(); + if (object.zones) { + if (!Array.isArray(object.zones)) + throw TypeError(".google.cloud.edgenetwork.v1.ListZonesResponse.zones: array expected"); + message.zones = []; + for (var i = 0; i < object.zones.length; ++i) { + if (typeof object.zones[i] !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.ListZonesResponse.zones: object expected"); + message.zones[i] = $root.google.cloud.edgenetwork.v1.Zone.fromObject(object.zones[i]); + } + } + if (object.nextPageToken != null) + message.nextPageToken = String(object.nextPageToken); + if (object.unreachable) { + if (!Array.isArray(object.unreachable)) + throw TypeError(".google.cloud.edgenetwork.v1.ListZonesResponse.unreachable: array expected"); + message.unreachable = []; + for (var i = 0; i < object.unreachable.length; ++i) + message.unreachable[i] = String(object.unreachable[i]); + } + return message; + }; + + /** + * Creates a plain object from a ListZonesResponse message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.ListZonesResponse + * @static + * @param {google.cloud.edgenetwork.v1.ListZonesResponse} message ListZonesResponse + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ListZonesResponse.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.zones = []; + object.unreachable = []; + } + if (options.defaults) + object.nextPageToken = ""; + if (message.zones && message.zones.length) { + object.zones = []; + for (var j = 0; j < message.zones.length; ++j) + object.zones[j] = $root.google.cloud.edgenetwork.v1.Zone.toObject(message.zones[j], options); + } + if (message.nextPageToken != null && message.hasOwnProperty("nextPageToken")) + object.nextPageToken = message.nextPageToken; + if (message.unreachable && message.unreachable.length) { + object.unreachable = []; + for (var j = 0; j < message.unreachable.length; ++j) + object.unreachable[j] = message.unreachable[j]; + } + return object; + }; + + /** + * Converts this ListZonesResponse to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.ListZonesResponse + * @instance + * @returns {Object.} JSON object + */ + ListZonesResponse.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ListZonesResponse + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.ListZonesResponse + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ListZonesResponse.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.ListZonesResponse"; + }; + + return ListZonesResponse; + })(); + + v1.GetZoneRequest = (function() { + + /** + * Properties of a GetZoneRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IGetZoneRequest + * @property {string|null} [name] GetZoneRequest name + */ + + /** + * Constructs a new GetZoneRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a GetZoneRequest. + * @implements IGetZoneRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IGetZoneRequest=} [properties] Properties to set + */ + function GetZoneRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * GetZoneRequest name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.GetZoneRequest + * @instance + */ + GetZoneRequest.prototype.name = ""; + + /** + * Creates a new GetZoneRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.GetZoneRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetZoneRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.GetZoneRequest} GetZoneRequest instance + */ + GetZoneRequest.create = function create(properties) { + return new GetZoneRequest(properties); + }; + + /** + * Encodes the specified GetZoneRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.GetZoneRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.GetZoneRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetZoneRequest} message GetZoneRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GetZoneRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + return writer; + }; + + /** + * Encodes the specified GetZoneRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.GetZoneRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.GetZoneRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetZoneRequest} message GetZoneRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GetZoneRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a GetZoneRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.GetZoneRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.GetZoneRequest} GetZoneRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GetZoneRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.GetZoneRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a GetZoneRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.GetZoneRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.GetZoneRequest} GetZoneRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GetZoneRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a GetZoneRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.GetZoneRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + GetZoneRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + return null; + }; + + /** + * Creates a GetZoneRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.GetZoneRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.GetZoneRequest} GetZoneRequest + */ + GetZoneRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.GetZoneRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.GetZoneRequest(); + if (object.name != null) + message.name = String(object.name); + return message; + }; + + /** + * Creates a plain object from a GetZoneRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.GetZoneRequest + * @static + * @param {google.cloud.edgenetwork.v1.GetZoneRequest} message GetZoneRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + GetZoneRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.name = ""; + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + return object; + }; + + /** + * Converts this GetZoneRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.GetZoneRequest + * @instance + * @returns {Object.} JSON object + */ + GetZoneRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for GetZoneRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.GetZoneRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + GetZoneRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.GetZoneRequest"; + }; + + return GetZoneRequest; + })(); + + v1.ListNetworksRequest = (function() { + + /** + * Properties of a ListNetworksRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IListNetworksRequest + * @property {string|null} [parent] ListNetworksRequest parent + * @property {number|null} [pageSize] ListNetworksRequest pageSize + * @property {string|null} [pageToken] ListNetworksRequest pageToken + * @property {string|null} [filter] ListNetworksRequest filter + * @property {string|null} [orderBy] ListNetworksRequest orderBy + */ + + /** + * Constructs a new ListNetworksRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a ListNetworksRequest. + * @implements IListNetworksRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IListNetworksRequest=} [properties] Properties to set + */ + function ListNetworksRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ListNetworksRequest parent. + * @member {string} parent + * @memberof google.cloud.edgenetwork.v1.ListNetworksRequest + * @instance + */ + ListNetworksRequest.prototype.parent = ""; + + /** + * ListNetworksRequest pageSize. + * @member {number} pageSize + * @memberof google.cloud.edgenetwork.v1.ListNetworksRequest + * @instance + */ + ListNetworksRequest.prototype.pageSize = 0; + + /** + * ListNetworksRequest pageToken. + * @member {string} pageToken + * @memberof google.cloud.edgenetwork.v1.ListNetworksRequest + * @instance + */ + ListNetworksRequest.prototype.pageToken = ""; + + /** + * ListNetworksRequest filter. + * @member {string} filter + * @memberof google.cloud.edgenetwork.v1.ListNetworksRequest + * @instance + */ + ListNetworksRequest.prototype.filter = ""; + + /** + * ListNetworksRequest orderBy. + * @member {string} orderBy + * @memberof google.cloud.edgenetwork.v1.ListNetworksRequest + * @instance + */ + ListNetworksRequest.prototype.orderBy = ""; + + /** + * Creates a new ListNetworksRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.ListNetworksRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListNetworksRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.ListNetworksRequest} ListNetworksRequest instance + */ + ListNetworksRequest.create = function create(properties) { + return new ListNetworksRequest(properties); + }; + + /** + * Encodes the specified ListNetworksRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListNetworksRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.ListNetworksRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListNetworksRequest} message ListNetworksRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListNetworksRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.parent != null && Object.hasOwnProperty.call(message, "parent")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.parent); + if (message.pageSize != null && Object.hasOwnProperty.call(message, "pageSize")) + writer.uint32(/* id 2, wireType 0 =*/16).int32(message.pageSize); + if (message.pageToken != null && Object.hasOwnProperty.call(message, "pageToken")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.pageToken); + if (message.filter != null && Object.hasOwnProperty.call(message, "filter")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.filter); + if (message.orderBy != null && Object.hasOwnProperty.call(message, "orderBy")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.orderBy); + return writer; + }; + + /** + * Encodes the specified ListNetworksRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListNetworksRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListNetworksRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListNetworksRequest} message ListNetworksRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListNetworksRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ListNetworksRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.ListNetworksRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.ListNetworksRequest} ListNetworksRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListNetworksRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.ListNetworksRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.parent = reader.string(); + break; + } + case 2: { + message.pageSize = reader.int32(); + break; + } + case 3: { + message.pageToken = reader.string(); + break; + } + case 4: { + message.filter = reader.string(); + break; + } + case 5: { + message.orderBy = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ListNetworksRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListNetworksRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.ListNetworksRequest} ListNetworksRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListNetworksRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ListNetworksRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.ListNetworksRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ListNetworksRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.parent != null && message.hasOwnProperty("parent")) + if (!$util.isString(message.parent)) + return "parent: string expected"; + if (message.pageSize != null && message.hasOwnProperty("pageSize")) + if (!$util.isInteger(message.pageSize)) + return "pageSize: integer expected"; + if (message.pageToken != null && message.hasOwnProperty("pageToken")) + if (!$util.isString(message.pageToken)) + return "pageToken: string expected"; + if (message.filter != null && message.hasOwnProperty("filter")) + if (!$util.isString(message.filter)) + return "filter: string expected"; + if (message.orderBy != null && message.hasOwnProperty("orderBy")) + if (!$util.isString(message.orderBy)) + return "orderBy: string expected"; + return null; + }; + + /** + * Creates a ListNetworksRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.ListNetworksRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.ListNetworksRequest} ListNetworksRequest + */ + ListNetworksRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.ListNetworksRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.ListNetworksRequest(); + if (object.parent != null) + message.parent = String(object.parent); + if (object.pageSize != null) + message.pageSize = object.pageSize | 0; + if (object.pageToken != null) + message.pageToken = String(object.pageToken); + if (object.filter != null) + message.filter = String(object.filter); + if (object.orderBy != null) + message.orderBy = String(object.orderBy); + return message; + }; + + /** + * Creates a plain object from a ListNetworksRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.ListNetworksRequest + * @static + * @param {google.cloud.edgenetwork.v1.ListNetworksRequest} message ListNetworksRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ListNetworksRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.parent = ""; + object.pageSize = 0; + object.pageToken = ""; + object.filter = ""; + object.orderBy = ""; + } + if (message.parent != null && message.hasOwnProperty("parent")) + object.parent = message.parent; + if (message.pageSize != null && message.hasOwnProperty("pageSize")) + object.pageSize = message.pageSize; + if (message.pageToken != null && message.hasOwnProperty("pageToken")) + object.pageToken = message.pageToken; + if (message.filter != null && message.hasOwnProperty("filter")) + object.filter = message.filter; + if (message.orderBy != null && message.hasOwnProperty("orderBy")) + object.orderBy = message.orderBy; + return object; + }; + + /** + * Converts this ListNetworksRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.ListNetworksRequest + * @instance + * @returns {Object.} JSON object + */ + ListNetworksRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ListNetworksRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.ListNetworksRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ListNetworksRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.ListNetworksRequest"; + }; + + return ListNetworksRequest; + })(); + + v1.ListNetworksResponse = (function() { + + /** + * Properties of a ListNetworksResponse. + * @memberof google.cloud.edgenetwork.v1 + * @interface IListNetworksResponse + * @property {Array.|null} [networks] ListNetworksResponse networks + * @property {string|null} [nextPageToken] ListNetworksResponse nextPageToken + * @property {Array.|null} [unreachable] ListNetworksResponse unreachable + */ + + /** + * Constructs a new ListNetworksResponse. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a ListNetworksResponse. + * @implements IListNetworksResponse + * @constructor + * @param {google.cloud.edgenetwork.v1.IListNetworksResponse=} [properties] Properties to set + */ + function ListNetworksResponse(properties) { + this.networks = []; + this.unreachable = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ListNetworksResponse networks. + * @member {Array.} networks + * @memberof google.cloud.edgenetwork.v1.ListNetworksResponse + * @instance + */ + ListNetworksResponse.prototype.networks = $util.emptyArray; + + /** + * ListNetworksResponse nextPageToken. + * @member {string} nextPageToken + * @memberof google.cloud.edgenetwork.v1.ListNetworksResponse + * @instance + */ + ListNetworksResponse.prototype.nextPageToken = ""; + + /** + * ListNetworksResponse unreachable. + * @member {Array.} unreachable + * @memberof google.cloud.edgenetwork.v1.ListNetworksResponse + * @instance + */ + ListNetworksResponse.prototype.unreachable = $util.emptyArray; + + /** + * Creates a new ListNetworksResponse instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.ListNetworksResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListNetworksResponse=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.ListNetworksResponse} ListNetworksResponse instance + */ + ListNetworksResponse.create = function create(properties) { + return new ListNetworksResponse(properties); + }; + + /** + * Encodes the specified ListNetworksResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListNetworksResponse.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.ListNetworksResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListNetworksResponse} message ListNetworksResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListNetworksResponse.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.networks != null && message.networks.length) + for (var i = 0; i < message.networks.length; ++i) + $root.google.cloud.edgenetwork.v1.Network.encode(message.networks[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.nextPageToken != null && Object.hasOwnProperty.call(message, "nextPageToken")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.nextPageToken); + if (message.unreachable != null && message.unreachable.length) + for (var i = 0; i < message.unreachable.length; ++i) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.unreachable[i]); + return writer; + }; + + /** + * Encodes the specified ListNetworksResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListNetworksResponse.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListNetworksResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListNetworksResponse} message ListNetworksResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListNetworksResponse.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ListNetworksResponse message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.ListNetworksResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.ListNetworksResponse} ListNetworksResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListNetworksResponse.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.ListNetworksResponse(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + if (!(message.networks && message.networks.length)) + message.networks = []; + message.networks.push($root.google.cloud.edgenetwork.v1.Network.decode(reader, reader.uint32())); + break; + } + case 2: { + message.nextPageToken = reader.string(); + break; + } + case 3: { + if (!(message.unreachable && message.unreachable.length)) + message.unreachable = []; + message.unreachable.push(reader.string()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ListNetworksResponse message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListNetworksResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.ListNetworksResponse} ListNetworksResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListNetworksResponse.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ListNetworksResponse message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.ListNetworksResponse + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ListNetworksResponse.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.networks != null && message.hasOwnProperty("networks")) { + if (!Array.isArray(message.networks)) + return "networks: array expected"; + for (var i = 0; i < message.networks.length; ++i) { + var error = $root.google.cloud.edgenetwork.v1.Network.verify(message.networks[i]); + if (error) + return "networks." + error; + } + } + if (message.nextPageToken != null && message.hasOwnProperty("nextPageToken")) + if (!$util.isString(message.nextPageToken)) + return "nextPageToken: string expected"; + if (message.unreachable != null && message.hasOwnProperty("unreachable")) { + if (!Array.isArray(message.unreachable)) + return "unreachable: array expected"; + for (var i = 0; i < message.unreachable.length; ++i) + if (!$util.isString(message.unreachable[i])) + return "unreachable: string[] expected"; + } + return null; + }; + + /** + * Creates a ListNetworksResponse message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.ListNetworksResponse + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.ListNetworksResponse} ListNetworksResponse + */ + ListNetworksResponse.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.ListNetworksResponse) + return object; + var message = new $root.google.cloud.edgenetwork.v1.ListNetworksResponse(); + if (object.networks) { + if (!Array.isArray(object.networks)) + throw TypeError(".google.cloud.edgenetwork.v1.ListNetworksResponse.networks: array expected"); + message.networks = []; + for (var i = 0; i < object.networks.length; ++i) { + if (typeof object.networks[i] !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.ListNetworksResponse.networks: object expected"); + message.networks[i] = $root.google.cloud.edgenetwork.v1.Network.fromObject(object.networks[i]); + } + } + if (object.nextPageToken != null) + message.nextPageToken = String(object.nextPageToken); + if (object.unreachable) { + if (!Array.isArray(object.unreachable)) + throw TypeError(".google.cloud.edgenetwork.v1.ListNetworksResponse.unreachable: array expected"); + message.unreachable = []; + for (var i = 0; i < object.unreachable.length; ++i) + message.unreachable[i] = String(object.unreachable[i]); + } + return message; + }; + + /** + * Creates a plain object from a ListNetworksResponse message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.ListNetworksResponse + * @static + * @param {google.cloud.edgenetwork.v1.ListNetworksResponse} message ListNetworksResponse + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ListNetworksResponse.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.networks = []; + object.unreachable = []; + } + if (options.defaults) + object.nextPageToken = ""; + if (message.networks && message.networks.length) { + object.networks = []; + for (var j = 0; j < message.networks.length; ++j) + object.networks[j] = $root.google.cloud.edgenetwork.v1.Network.toObject(message.networks[j], options); + } + if (message.nextPageToken != null && message.hasOwnProperty("nextPageToken")) + object.nextPageToken = message.nextPageToken; + if (message.unreachable && message.unreachable.length) { + object.unreachable = []; + for (var j = 0; j < message.unreachable.length; ++j) + object.unreachable[j] = message.unreachable[j]; + } + return object; + }; + + /** + * Converts this ListNetworksResponse to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.ListNetworksResponse + * @instance + * @returns {Object.} JSON object + */ + ListNetworksResponse.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ListNetworksResponse + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.ListNetworksResponse + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ListNetworksResponse.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.ListNetworksResponse"; + }; + + return ListNetworksResponse; + })(); + + v1.GetNetworkRequest = (function() { + + /** + * Properties of a GetNetworkRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IGetNetworkRequest + * @property {string|null} [name] GetNetworkRequest name + */ + + /** + * Constructs a new GetNetworkRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a GetNetworkRequest. + * @implements IGetNetworkRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IGetNetworkRequest=} [properties] Properties to set + */ + function GetNetworkRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * GetNetworkRequest name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.GetNetworkRequest + * @instance + */ + GetNetworkRequest.prototype.name = ""; + + /** + * Creates a new GetNetworkRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.GetNetworkRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetNetworkRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.GetNetworkRequest} GetNetworkRequest instance + */ + GetNetworkRequest.create = function create(properties) { + return new GetNetworkRequest(properties); + }; + + /** + * Encodes the specified GetNetworkRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.GetNetworkRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.GetNetworkRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetNetworkRequest} message GetNetworkRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GetNetworkRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + return writer; + }; + + /** + * Encodes the specified GetNetworkRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.GetNetworkRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.GetNetworkRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetNetworkRequest} message GetNetworkRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GetNetworkRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a GetNetworkRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.GetNetworkRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.GetNetworkRequest} GetNetworkRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GetNetworkRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.GetNetworkRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a GetNetworkRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.GetNetworkRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.GetNetworkRequest} GetNetworkRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GetNetworkRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a GetNetworkRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.GetNetworkRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + GetNetworkRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + return null; + }; + + /** + * Creates a GetNetworkRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.GetNetworkRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.GetNetworkRequest} GetNetworkRequest + */ + GetNetworkRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.GetNetworkRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.GetNetworkRequest(); + if (object.name != null) + message.name = String(object.name); + return message; + }; + + /** + * Creates a plain object from a GetNetworkRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.GetNetworkRequest + * @static + * @param {google.cloud.edgenetwork.v1.GetNetworkRequest} message GetNetworkRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + GetNetworkRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.name = ""; + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + return object; + }; + + /** + * Converts this GetNetworkRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.GetNetworkRequest + * @instance + * @returns {Object.} JSON object + */ + GetNetworkRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for GetNetworkRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.GetNetworkRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + GetNetworkRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.GetNetworkRequest"; + }; + + return GetNetworkRequest; + })(); + + v1.CreateNetworkRequest = (function() { + + /** + * Properties of a CreateNetworkRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface ICreateNetworkRequest + * @property {string|null} [parent] CreateNetworkRequest parent + * @property {string|null} [networkId] CreateNetworkRequest networkId + * @property {google.cloud.edgenetwork.v1.INetwork|null} [network] CreateNetworkRequest network + * @property {string|null} [requestId] CreateNetworkRequest requestId + */ + + /** + * Constructs a new CreateNetworkRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a CreateNetworkRequest. + * @implements ICreateNetworkRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.ICreateNetworkRequest=} [properties] Properties to set + */ + function CreateNetworkRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * CreateNetworkRequest parent. + * @member {string} parent + * @memberof google.cloud.edgenetwork.v1.CreateNetworkRequest + * @instance + */ + CreateNetworkRequest.prototype.parent = ""; + + /** + * CreateNetworkRequest networkId. + * @member {string} networkId + * @memberof google.cloud.edgenetwork.v1.CreateNetworkRequest + * @instance + */ + CreateNetworkRequest.prototype.networkId = ""; + + /** + * CreateNetworkRequest network. + * @member {google.cloud.edgenetwork.v1.INetwork|null|undefined} network + * @memberof google.cloud.edgenetwork.v1.CreateNetworkRequest + * @instance + */ + CreateNetworkRequest.prototype.network = null; + + /** + * CreateNetworkRequest requestId. + * @member {string} requestId + * @memberof google.cloud.edgenetwork.v1.CreateNetworkRequest + * @instance + */ + CreateNetworkRequest.prototype.requestId = ""; + + /** + * Creates a new CreateNetworkRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.CreateNetworkRequest + * @static + * @param {google.cloud.edgenetwork.v1.ICreateNetworkRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.CreateNetworkRequest} CreateNetworkRequest instance + */ + CreateNetworkRequest.create = function create(properties) { + return new CreateNetworkRequest(properties); + }; + + /** + * Encodes the specified CreateNetworkRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.CreateNetworkRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.CreateNetworkRequest + * @static + * @param {google.cloud.edgenetwork.v1.ICreateNetworkRequest} message CreateNetworkRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + CreateNetworkRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.parent != null && Object.hasOwnProperty.call(message, "parent")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.parent); + if (message.networkId != null && Object.hasOwnProperty.call(message, "networkId")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.networkId); + if (message.network != null && Object.hasOwnProperty.call(message, "network")) + $root.google.cloud.edgenetwork.v1.Network.encode(message.network, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + if (message.requestId != null && Object.hasOwnProperty.call(message, "requestId")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.requestId); + return writer; + }; + + /** + * Encodes the specified CreateNetworkRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.CreateNetworkRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.CreateNetworkRequest + * @static + * @param {google.cloud.edgenetwork.v1.ICreateNetworkRequest} message CreateNetworkRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + CreateNetworkRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a CreateNetworkRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.CreateNetworkRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.CreateNetworkRequest} CreateNetworkRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + CreateNetworkRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.CreateNetworkRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.parent = reader.string(); + break; + } + case 2: { + message.networkId = reader.string(); + break; + } + case 3: { + message.network = $root.google.cloud.edgenetwork.v1.Network.decode(reader, reader.uint32()); + break; + } + case 4: { + message.requestId = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a CreateNetworkRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.CreateNetworkRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.CreateNetworkRequest} CreateNetworkRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + CreateNetworkRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a CreateNetworkRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.CreateNetworkRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + CreateNetworkRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.parent != null && message.hasOwnProperty("parent")) + if (!$util.isString(message.parent)) + return "parent: string expected"; + if (message.networkId != null && message.hasOwnProperty("networkId")) + if (!$util.isString(message.networkId)) + return "networkId: string expected"; + if (message.network != null && message.hasOwnProperty("network")) { + var error = $root.google.cloud.edgenetwork.v1.Network.verify(message.network); + if (error) + return "network." + error; + } + if (message.requestId != null && message.hasOwnProperty("requestId")) + if (!$util.isString(message.requestId)) + return "requestId: string expected"; + return null; + }; + + /** + * Creates a CreateNetworkRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.CreateNetworkRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.CreateNetworkRequest} CreateNetworkRequest + */ + CreateNetworkRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.CreateNetworkRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.CreateNetworkRequest(); + if (object.parent != null) + message.parent = String(object.parent); + if (object.networkId != null) + message.networkId = String(object.networkId); + if (object.network != null) { + if (typeof object.network !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.CreateNetworkRequest.network: object expected"); + message.network = $root.google.cloud.edgenetwork.v1.Network.fromObject(object.network); + } + if (object.requestId != null) + message.requestId = String(object.requestId); + return message; + }; + + /** + * Creates a plain object from a CreateNetworkRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.CreateNetworkRequest + * @static + * @param {google.cloud.edgenetwork.v1.CreateNetworkRequest} message CreateNetworkRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + CreateNetworkRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.parent = ""; + object.networkId = ""; + object.network = null; + object.requestId = ""; + } + if (message.parent != null && message.hasOwnProperty("parent")) + object.parent = message.parent; + if (message.networkId != null && message.hasOwnProperty("networkId")) + object.networkId = message.networkId; + if (message.network != null && message.hasOwnProperty("network")) + object.network = $root.google.cloud.edgenetwork.v1.Network.toObject(message.network, options); + if (message.requestId != null && message.hasOwnProperty("requestId")) + object.requestId = message.requestId; + return object; + }; + + /** + * Converts this CreateNetworkRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.CreateNetworkRequest + * @instance + * @returns {Object.} JSON object + */ + CreateNetworkRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for CreateNetworkRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.CreateNetworkRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + CreateNetworkRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.CreateNetworkRequest"; + }; + + return CreateNetworkRequest; + })(); + + v1.DeleteNetworkRequest = (function() { + + /** + * Properties of a DeleteNetworkRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IDeleteNetworkRequest + * @property {string|null} [name] DeleteNetworkRequest name + * @property {string|null} [requestId] DeleteNetworkRequest requestId + */ + + /** + * Constructs a new DeleteNetworkRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a DeleteNetworkRequest. + * @implements IDeleteNetworkRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IDeleteNetworkRequest=} [properties] Properties to set + */ + function DeleteNetworkRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * DeleteNetworkRequest name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.DeleteNetworkRequest + * @instance + */ + DeleteNetworkRequest.prototype.name = ""; + + /** + * DeleteNetworkRequest requestId. + * @member {string} requestId + * @memberof google.cloud.edgenetwork.v1.DeleteNetworkRequest + * @instance + */ + DeleteNetworkRequest.prototype.requestId = ""; + + /** + * Creates a new DeleteNetworkRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.DeleteNetworkRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDeleteNetworkRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.DeleteNetworkRequest} DeleteNetworkRequest instance + */ + DeleteNetworkRequest.create = function create(properties) { + return new DeleteNetworkRequest(properties); + }; + + /** + * Encodes the specified DeleteNetworkRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.DeleteNetworkRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.DeleteNetworkRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDeleteNetworkRequest} message DeleteNetworkRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DeleteNetworkRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.requestId != null && Object.hasOwnProperty.call(message, "requestId")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.requestId); + return writer; + }; + + /** + * Encodes the specified DeleteNetworkRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DeleteNetworkRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.DeleteNetworkRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDeleteNetworkRequest} message DeleteNetworkRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DeleteNetworkRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a DeleteNetworkRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.DeleteNetworkRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.DeleteNetworkRequest} DeleteNetworkRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DeleteNetworkRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.DeleteNetworkRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.requestId = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a DeleteNetworkRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.DeleteNetworkRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.DeleteNetworkRequest} DeleteNetworkRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DeleteNetworkRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a DeleteNetworkRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.DeleteNetworkRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + DeleteNetworkRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.requestId != null && message.hasOwnProperty("requestId")) + if (!$util.isString(message.requestId)) + return "requestId: string expected"; + return null; + }; + + /** + * Creates a DeleteNetworkRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.DeleteNetworkRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.DeleteNetworkRequest} DeleteNetworkRequest + */ + DeleteNetworkRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.DeleteNetworkRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.DeleteNetworkRequest(); + if (object.name != null) + message.name = String(object.name); + if (object.requestId != null) + message.requestId = String(object.requestId); + return message; + }; + + /** + * Creates a plain object from a DeleteNetworkRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.DeleteNetworkRequest + * @static + * @param {google.cloud.edgenetwork.v1.DeleteNetworkRequest} message DeleteNetworkRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + DeleteNetworkRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.name = ""; + object.requestId = ""; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.requestId != null && message.hasOwnProperty("requestId")) + object.requestId = message.requestId; + return object; + }; + + /** + * Converts this DeleteNetworkRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.DeleteNetworkRequest + * @instance + * @returns {Object.} JSON object + */ + DeleteNetworkRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for DeleteNetworkRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.DeleteNetworkRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + DeleteNetworkRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.DeleteNetworkRequest"; + }; + + return DeleteNetworkRequest; + })(); + + v1.ListSubnetsRequest = (function() { + + /** + * Properties of a ListSubnetsRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IListSubnetsRequest + * @property {string|null} [parent] ListSubnetsRequest parent + * @property {number|null} [pageSize] ListSubnetsRequest pageSize + * @property {string|null} [pageToken] ListSubnetsRequest pageToken + * @property {string|null} [filter] ListSubnetsRequest filter + * @property {string|null} [orderBy] ListSubnetsRequest orderBy + */ + + /** + * Constructs a new ListSubnetsRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a ListSubnetsRequest. + * @implements IListSubnetsRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IListSubnetsRequest=} [properties] Properties to set + */ + function ListSubnetsRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ListSubnetsRequest parent. + * @member {string} parent + * @memberof google.cloud.edgenetwork.v1.ListSubnetsRequest + * @instance + */ + ListSubnetsRequest.prototype.parent = ""; + + /** + * ListSubnetsRequest pageSize. + * @member {number} pageSize + * @memberof google.cloud.edgenetwork.v1.ListSubnetsRequest + * @instance + */ + ListSubnetsRequest.prototype.pageSize = 0; + + /** + * ListSubnetsRequest pageToken. + * @member {string} pageToken + * @memberof google.cloud.edgenetwork.v1.ListSubnetsRequest + * @instance + */ + ListSubnetsRequest.prototype.pageToken = ""; + + /** + * ListSubnetsRequest filter. + * @member {string} filter + * @memberof google.cloud.edgenetwork.v1.ListSubnetsRequest + * @instance + */ + ListSubnetsRequest.prototype.filter = ""; + + /** + * ListSubnetsRequest orderBy. + * @member {string} orderBy + * @memberof google.cloud.edgenetwork.v1.ListSubnetsRequest + * @instance + */ + ListSubnetsRequest.prototype.orderBy = ""; + + /** + * Creates a new ListSubnetsRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.ListSubnetsRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListSubnetsRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.ListSubnetsRequest} ListSubnetsRequest instance + */ + ListSubnetsRequest.create = function create(properties) { + return new ListSubnetsRequest(properties); + }; + + /** + * Encodes the specified ListSubnetsRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListSubnetsRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.ListSubnetsRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListSubnetsRequest} message ListSubnetsRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListSubnetsRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.parent != null && Object.hasOwnProperty.call(message, "parent")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.parent); + if (message.pageSize != null && Object.hasOwnProperty.call(message, "pageSize")) + writer.uint32(/* id 2, wireType 0 =*/16).int32(message.pageSize); + if (message.pageToken != null && Object.hasOwnProperty.call(message, "pageToken")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.pageToken); + if (message.filter != null && Object.hasOwnProperty.call(message, "filter")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.filter); + if (message.orderBy != null && Object.hasOwnProperty.call(message, "orderBy")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.orderBy); + return writer; + }; + + /** + * Encodes the specified ListSubnetsRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListSubnetsRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListSubnetsRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListSubnetsRequest} message ListSubnetsRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListSubnetsRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ListSubnetsRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.ListSubnetsRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.ListSubnetsRequest} ListSubnetsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListSubnetsRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.ListSubnetsRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.parent = reader.string(); + break; + } + case 2: { + message.pageSize = reader.int32(); + break; + } + case 3: { + message.pageToken = reader.string(); + break; + } + case 4: { + message.filter = reader.string(); + break; + } + case 5: { + message.orderBy = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ListSubnetsRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListSubnetsRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.ListSubnetsRequest} ListSubnetsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListSubnetsRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ListSubnetsRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.ListSubnetsRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ListSubnetsRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.parent != null && message.hasOwnProperty("parent")) + if (!$util.isString(message.parent)) + return "parent: string expected"; + if (message.pageSize != null && message.hasOwnProperty("pageSize")) + if (!$util.isInteger(message.pageSize)) + return "pageSize: integer expected"; + if (message.pageToken != null && message.hasOwnProperty("pageToken")) + if (!$util.isString(message.pageToken)) + return "pageToken: string expected"; + if (message.filter != null && message.hasOwnProperty("filter")) + if (!$util.isString(message.filter)) + return "filter: string expected"; + if (message.orderBy != null && message.hasOwnProperty("orderBy")) + if (!$util.isString(message.orderBy)) + return "orderBy: string expected"; + return null; + }; + + /** + * Creates a ListSubnetsRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.ListSubnetsRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.ListSubnetsRequest} ListSubnetsRequest + */ + ListSubnetsRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.ListSubnetsRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.ListSubnetsRequest(); + if (object.parent != null) + message.parent = String(object.parent); + if (object.pageSize != null) + message.pageSize = object.pageSize | 0; + if (object.pageToken != null) + message.pageToken = String(object.pageToken); + if (object.filter != null) + message.filter = String(object.filter); + if (object.orderBy != null) + message.orderBy = String(object.orderBy); + return message; + }; + + /** + * Creates a plain object from a ListSubnetsRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.ListSubnetsRequest + * @static + * @param {google.cloud.edgenetwork.v1.ListSubnetsRequest} message ListSubnetsRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ListSubnetsRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.parent = ""; + object.pageSize = 0; + object.pageToken = ""; + object.filter = ""; + object.orderBy = ""; + } + if (message.parent != null && message.hasOwnProperty("parent")) + object.parent = message.parent; + if (message.pageSize != null && message.hasOwnProperty("pageSize")) + object.pageSize = message.pageSize; + if (message.pageToken != null && message.hasOwnProperty("pageToken")) + object.pageToken = message.pageToken; + if (message.filter != null && message.hasOwnProperty("filter")) + object.filter = message.filter; + if (message.orderBy != null && message.hasOwnProperty("orderBy")) + object.orderBy = message.orderBy; + return object; + }; + + /** + * Converts this ListSubnetsRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.ListSubnetsRequest + * @instance + * @returns {Object.} JSON object + */ + ListSubnetsRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ListSubnetsRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.ListSubnetsRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ListSubnetsRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.ListSubnetsRequest"; + }; + + return ListSubnetsRequest; + })(); + + v1.ListSubnetsResponse = (function() { + + /** + * Properties of a ListSubnetsResponse. + * @memberof google.cloud.edgenetwork.v1 + * @interface IListSubnetsResponse + * @property {Array.|null} [subnets] ListSubnetsResponse subnets + * @property {string|null} [nextPageToken] ListSubnetsResponse nextPageToken + * @property {Array.|null} [unreachable] ListSubnetsResponse unreachable + */ + + /** + * Constructs a new ListSubnetsResponse. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a ListSubnetsResponse. + * @implements IListSubnetsResponse + * @constructor + * @param {google.cloud.edgenetwork.v1.IListSubnetsResponse=} [properties] Properties to set + */ + function ListSubnetsResponse(properties) { + this.subnets = []; + this.unreachable = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ListSubnetsResponse subnets. + * @member {Array.} subnets + * @memberof google.cloud.edgenetwork.v1.ListSubnetsResponse + * @instance + */ + ListSubnetsResponse.prototype.subnets = $util.emptyArray; + + /** + * ListSubnetsResponse nextPageToken. + * @member {string} nextPageToken + * @memberof google.cloud.edgenetwork.v1.ListSubnetsResponse + * @instance + */ + ListSubnetsResponse.prototype.nextPageToken = ""; + + /** + * ListSubnetsResponse unreachable. + * @member {Array.} unreachable + * @memberof google.cloud.edgenetwork.v1.ListSubnetsResponse + * @instance + */ + ListSubnetsResponse.prototype.unreachable = $util.emptyArray; + + /** + * Creates a new ListSubnetsResponse instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.ListSubnetsResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListSubnetsResponse=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.ListSubnetsResponse} ListSubnetsResponse instance + */ + ListSubnetsResponse.create = function create(properties) { + return new ListSubnetsResponse(properties); + }; + + /** + * Encodes the specified ListSubnetsResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListSubnetsResponse.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.ListSubnetsResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListSubnetsResponse} message ListSubnetsResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListSubnetsResponse.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.subnets != null && message.subnets.length) + for (var i = 0; i < message.subnets.length; ++i) + $root.google.cloud.edgenetwork.v1.Subnet.encode(message.subnets[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.nextPageToken != null && Object.hasOwnProperty.call(message, "nextPageToken")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.nextPageToken); + if (message.unreachable != null && message.unreachable.length) + for (var i = 0; i < message.unreachable.length; ++i) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.unreachable[i]); + return writer; + }; + + /** + * Encodes the specified ListSubnetsResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListSubnetsResponse.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListSubnetsResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListSubnetsResponse} message ListSubnetsResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListSubnetsResponse.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ListSubnetsResponse message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.ListSubnetsResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.ListSubnetsResponse} ListSubnetsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListSubnetsResponse.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.ListSubnetsResponse(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + if (!(message.subnets && message.subnets.length)) + message.subnets = []; + message.subnets.push($root.google.cloud.edgenetwork.v1.Subnet.decode(reader, reader.uint32())); + break; + } + case 2: { + message.nextPageToken = reader.string(); + break; + } + case 3: { + if (!(message.unreachable && message.unreachable.length)) + message.unreachable = []; + message.unreachable.push(reader.string()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ListSubnetsResponse message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListSubnetsResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.ListSubnetsResponse} ListSubnetsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListSubnetsResponse.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ListSubnetsResponse message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.ListSubnetsResponse + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ListSubnetsResponse.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.subnets != null && message.hasOwnProperty("subnets")) { + if (!Array.isArray(message.subnets)) + return "subnets: array expected"; + for (var i = 0; i < message.subnets.length; ++i) { + var error = $root.google.cloud.edgenetwork.v1.Subnet.verify(message.subnets[i]); + if (error) + return "subnets." + error; + } + } + if (message.nextPageToken != null && message.hasOwnProperty("nextPageToken")) + if (!$util.isString(message.nextPageToken)) + return "nextPageToken: string expected"; + if (message.unreachable != null && message.hasOwnProperty("unreachable")) { + if (!Array.isArray(message.unreachable)) + return "unreachable: array expected"; + for (var i = 0; i < message.unreachable.length; ++i) + if (!$util.isString(message.unreachable[i])) + return "unreachable: string[] expected"; + } + return null; + }; + + /** + * Creates a ListSubnetsResponse message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.ListSubnetsResponse + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.ListSubnetsResponse} ListSubnetsResponse + */ + ListSubnetsResponse.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.ListSubnetsResponse) + return object; + var message = new $root.google.cloud.edgenetwork.v1.ListSubnetsResponse(); + if (object.subnets) { + if (!Array.isArray(object.subnets)) + throw TypeError(".google.cloud.edgenetwork.v1.ListSubnetsResponse.subnets: array expected"); + message.subnets = []; + for (var i = 0; i < object.subnets.length; ++i) { + if (typeof object.subnets[i] !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.ListSubnetsResponse.subnets: object expected"); + message.subnets[i] = $root.google.cloud.edgenetwork.v1.Subnet.fromObject(object.subnets[i]); + } + } + if (object.nextPageToken != null) + message.nextPageToken = String(object.nextPageToken); + if (object.unreachable) { + if (!Array.isArray(object.unreachable)) + throw TypeError(".google.cloud.edgenetwork.v1.ListSubnetsResponse.unreachable: array expected"); + message.unreachable = []; + for (var i = 0; i < object.unreachable.length; ++i) + message.unreachable[i] = String(object.unreachable[i]); + } + return message; + }; + + /** + * Creates a plain object from a ListSubnetsResponse message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.ListSubnetsResponse + * @static + * @param {google.cloud.edgenetwork.v1.ListSubnetsResponse} message ListSubnetsResponse + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ListSubnetsResponse.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.subnets = []; + object.unreachable = []; + } + if (options.defaults) + object.nextPageToken = ""; + if (message.subnets && message.subnets.length) { + object.subnets = []; + for (var j = 0; j < message.subnets.length; ++j) + object.subnets[j] = $root.google.cloud.edgenetwork.v1.Subnet.toObject(message.subnets[j], options); + } + if (message.nextPageToken != null && message.hasOwnProperty("nextPageToken")) + object.nextPageToken = message.nextPageToken; + if (message.unreachable && message.unreachable.length) { + object.unreachable = []; + for (var j = 0; j < message.unreachable.length; ++j) + object.unreachable[j] = message.unreachable[j]; + } + return object; + }; + + /** + * Converts this ListSubnetsResponse to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.ListSubnetsResponse + * @instance + * @returns {Object.} JSON object + */ + ListSubnetsResponse.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ListSubnetsResponse + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.ListSubnetsResponse + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ListSubnetsResponse.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.ListSubnetsResponse"; + }; + + return ListSubnetsResponse; + })(); + + v1.GetSubnetRequest = (function() { + + /** + * Properties of a GetSubnetRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IGetSubnetRequest + * @property {string|null} [name] GetSubnetRequest name + */ + + /** + * Constructs a new GetSubnetRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a GetSubnetRequest. + * @implements IGetSubnetRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IGetSubnetRequest=} [properties] Properties to set + */ + function GetSubnetRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * GetSubnetRequest name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.GetSubnetRequest + * @instance + */ + GetSubnetRequest.prototype.name = ""; + + /** + * Creates a new GetSubnetRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.GetSubnetRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetSubnetRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.GetSubnetRequest} GetSubnetRequest instance + */ + GetSubnetRequest.create = function create(properties) { + return new GetSubnetRequest(properties); + }; + + /** + * Encodes the specified GetSubnetRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.GetSubnetRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.GetSubnetRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetSubnetRequest} message GetSubnetRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GetSubnetRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + return writer; + }; + + /** + * Encodes the specified GetSubnetRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.GetSubnetRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.GetSubnetRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetSubnetRequest} message GetSubnetRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GetSubnetRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a GetSubnetRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.GetSubnetRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.GetSubnetRequest} GetSubnetRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GetSubnetRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.GetSubnetRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a GetSubnetRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.GetSubnetRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.GetSubnetRequest} GetSubnetRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GetSubnetRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a GetSubnetRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.GetSubnetRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + GetSubnetRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + return null; + }; + + /** + * Creates a GetSubnetRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.GetSubnetRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.GetSubnetRequest} GetSubnetRequest + */ + GetSubnetRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.GetSubnetRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.GetSubnetRequest(); + if (object.name != null) + message.name = String(object.name); + return message; + }; + + /** + * Creates a plain object from a GetSubnetRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.GetSubnetRequest + * @static + * @param {google.cloud.edgenetwork.v1.GetSubnetRequest} message GetSubnetRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + GetSubnetRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.name = ""; + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + return object; + }; + + /** + * Converts this GetSubnetRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.GetSubnetRequest + * @instance + * @returns {Object.} JSON object + */ + GetSubnetRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for GetSubnetRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.GetSubnetRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + GetSubnetRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.GetSubnetRequest"; + }; + + return GetSubnetRequest; + })(); + + v1.CreateSubnetRequest = (function() { + + /** + * Properties of a CreateSubnetRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface ICreateSubnetRequest + * @property {string|null} [parent] CreateSubnetRequest parent + * @property {string|null} [subnetId] CreateSubnetRequest subnetId + * @property {google.cloud.edgenetwork.v1.ISubnet|null} [subnet] CreateSubnetRequest subnet + * @property {string|null} [requestId] CreateSubnetRequest requestId + */ + + /** + * Constructs a new CreateSubnetRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a CreateSubnetRequest. + * @implements ICreateSubnetRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.ICreateSubnetRequest=} [properties] Properties to set + */ + function CreateSubnetRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * CreateSubnetRequest parent. + * @member {string} parent + * @memberof google.cloud.edgenetwork.v1.CreateSubnetRequest + * @instance + */ + CreateSubnetRequest.prototype.parent = ""; + + /** + * CreateSubnetRequest subnetId. + * @member {string} subnetId + * @memberof google.cloud.edgenetwork.v1.CreateSubnetRequest + * @instance + */ + CreateSubnetRequest.prototype.subnetId = ""; + + /** + * CreateSubnetRequest subnet. + * @member {google.cloud.edgenetwork.v1.ISubnet|null|undefined} subnet + * @memberof google.cloud.edgenetwork.v1.CreateSubnetRequest + * @instance + */ + CreateSubnetRequest.prototype.subnet = null; + + /** + * CreateSubnetRequest requestId. + * @member {string} requestId + * @memberof google.cloud.edgenetwork.v1.CreateSubnetRequest + * @instance + */ + CreateSubnetRequest.prototype.requestId = ""; + + /** + * Creates a new CreateSubnetRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.CreateSubnetRequest + * @static + * @param {google.cloud.edgenetwork.v1.ICreateSubnetRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.CreateSubnetRequest} CreateSubnetRequest instance + */ + CreateSubnetRequest.create = function create(properties) { + return new CreateSubnetRequest(properties); + }; + + /** + * Encodes the specified CreateSubnetRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.CreateSubnetRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.CreateSubnetRequest + * @static + * @param {google.cloud.edgenetwork.v1.ICreateSubnetRequest} message CreateSubnetRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + CreateSubnetRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.parent != null && Object.hasOwnProperty.call(message, "parent")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.parent); + if (message.subnetId != null && Object.hasOwnProperty.call(message, "subnetId")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.subnetId); + if (message.subnet != null && Object.hasOwnProperty.call(message, "subnet")) + $root.google.cloud.edgenetwork.v1.Subnet.encode(message.subnet, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + if (message.requestId != null && Object.hasOwnProperty.call(message, "requestId")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.requestId); + return writer; + }; + + /** + * Encodes the specified CreateSubnetRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.CreateSubnetRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.CreateSubnetRequest + * @static + * @param {google.cloud.edgenetwork.v1.ICreateSubnetRequest} message CreateSubnetRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + CreateSubnetRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a CreateSubnetRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.CreateSubnetRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.CreateSubnetRequest} CreateSubnetRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + CreateSubnetRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.CreateSubnetRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.parent = reader.string(); + break; + } + case 2: { + message.subnetId = reader.string(); + break; + } + case 3: { + message.subnet = $root.google.cloud.edgenetwork.v1.Subnet.decode(reader, reader.uint32()); + break; + } + case 4: { + message.requestId = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a CreateSubnetRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.CreateSubnetRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.CreateSubnetRequest} CreateSubnetRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + CreateSubnetRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a CreateSubnetRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.CreateSubnetRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + CreateSubnetRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.parent != null && message.hasOwnProperty("parent")) + if (!$util.isString(message.parent)) + return "parent: string expected"; + if (message.subnetId != null && message.hasOwnProperty("subnetId")) + if (!$util.isString(message.subnetId)) + return "subnetId: string expected"; + if (message.subnet != null && message.hasOwnProperty("subnet")) { + var error = $root.google.cloud.edgenetwork.v1.Subnet.verify(message.subnet); + if (error) + return "subnet." + error; + } + if (message.requestId != null && message.hasOwnProperty("requestId")) + if (!$util.isString(message.requestId)) + return "requestId: string expected"; + return null; + }; + + /** + * Creates a CreateSubnetRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.CreateSubnetRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.CreateSubnetRequest} CreateSubnetRequest + */ + CreateSubnetRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.CreateSubnetRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.CreateSubnetRequest(); + if (object.parent != null) + message.parent = String(object.parent); + if (object.subnetId != null) + message.subnetId = String(object.subnetId); + if (object.subnet != null) { + if (typeof object.subnet !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.CreateSubnetRequest.subnet: object expected"); + message.subnet = $root.google.cloud.edgenetwork.v1.Subnet.fromObject(object.subnet); + } + if (object.requestId != null) + message.requestId = String(object.requestId); + return message; + }; + + /** + * Creates a plain object from a CreateSubnetRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.CreateSubnetRequest + * @static + * @param {google.cloud.edgenetwork.v1.CreateSubnetRequest} message CreateSubnetRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + CreateSubnetRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.parent = ""; + object.subnetId = ""; + object.subnet = null; + object.requestId = ""; + } + if (message.parent != null && message.hasOwnProperty("parent")) + object.parent = message.parent; + if (message.subnetId != null && message.hasOwnProperty("subnetId")) + object.subnetId = message.subnetId; + if (message.subnet != null && message.hasOwnProperty("subnet")) + object.subnet = $root.google.cloud.edgenetwork.v1.Subnet.toObject(message.subnet, options); + if (message.requestId != null && message.hasOwnProperty("requestId")) + object.requestId = message.requestId; + return object; + }; + + /** + * Converts this CreateSubnetRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.CreateSubnetRequest + * @instance + * @returns {Object.} JSON object + */ + CreateSubnetRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for CreateSubnetRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.CreateSubnetRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + CreateSubnetRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.CreateSubnetRequest"; + }; + + return CreateSubnetRequest; + })(); + + v1.UpdateSubnetRequest = (function() { + + /** + * Properties of an UpdateSubnetRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IUpdateSubnetRequest + * @property {google.protobuf.IFieldMask|null} [updateMask] UpdateSubnetRequest updateMask + * @property {google.cloud.edgenetwork.v1.ISubnet|null} [subnet] UpdateSubnetRequest subnet + * @property {string|null} [requestId] UpdateSubnetRequest requestId + */ + + /** + * Constructs a new UpdateSubnetRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents an UpdateSubnetRequest. + * @implements IUpdateSubnetRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IUpdateSubnetRequest=} [properties] Properties to set + */ + function UpdateSubnetRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * UpdateSubnetRequest updateMask. + * @member {google.protobuf.IFieldMask|null|undefined} updateMask + * @memberof google.cloud.edgenetwork.v1.UpdateSubnetRequest + * @instance + */ + UpdateSubnetRequest.prototype.updateMask = null; + + /** + * UpdateSubnetRequest subnet. + * @member {google.cloud.edgenetwork.v1.ISubnet|null|undefined} subnet + * @memberof google.cloud.edgenetwork.v1.UpdateSubnetRequest + * @instance + */ + UpdateSubnetRequest.prototype.subnet = null; + + /** + * UpdateSubnetRequest requestId. + * @member {string} requestId + * @memberof google.cloud.edgenetwork.v1.UpdateSubnetRequest + * @instance + */ + UpdateSubnetRequest.prototype.requestId = ""; + + /** + * Creates a new UpdateSubnetRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.UpdateSubnetRequest + * @static + * @param {google.cloud.edgenetwork.v1.IUpdateSubnetRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.UpdateSubnetRequest} UpdateSubnetRequest instance + */ + UpdateSubnetRequest.create = function create(properties) { + return new UpdateSubnetRequest(properties); + }; + + /** + * Encodes the specified UpdateSubnetRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.UpdateSubnetRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.UpdateSubnetRequest + * @static + * @param {google.cloud.edgenetwork.v1.IUpdateSubnetRequest} message UpdateSubnetRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + UpdateSubnetRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.updateMask != null && Object.hasOwnProperty.call(message, "updateMask")) + $root.google.protobuf.FieldMask.encode(message.updateMask, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.subnet != null && Object.hasOwnProperty.call(message, "subnet")) + $root.google.cloud.edgenetwork.v1.Subnet.encode(message.subnet, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.requestId != null && Object.hasOwnProperty.call(message, "requestId")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.requestId); + return writer; + }; + + /** + * Encodes the specified UpdateSubnetRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.UpdateSubnetRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.UpdateSubnetRequest + * @static + * @param {google.cloud.edgenetwork.v1.IUpdateSubnetRequest} message UpdateSubnetRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + UpdateSubnetRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an UpdateSubnetRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.UpdateSubnetRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.UpdateSubnetRequest} UpdateSubnetRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + UpdateSubnetRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.UpdateSubnetRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.updateMask = $root.google.protobuf.FieldMask.decode(reader, reader.uint32()); + break; + } + case 2: { + message.subnet = $root.google.cloud.edgenetwork.v1.Subnet.decode(reader, reader.uint32()); + break; + } + case 3: { + message.requestId = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an UpdateSubnetRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.UpdateSubnetRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.UpdateSubnetRequest} UpdateSubnetRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + UpdateSubnetRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an UpdateSubnetRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.UpdateSubnetRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + UpdateSubnetRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.updateMask != null && message.hasOwnProperty("updateMask")) { + var error = $root.google.protobuf.FieldMask.verify(message.updateMask); + if (error) + return "updateMask." + error; + } + if (message.subnet != null && message.hasOwnProperty("subnet")) { + var error = $root.google.cloud.edgenetwork.v1.Subnet.verify(message.subnet); + if (error) + return "subnet." + error; + } + if (message.requestId != null && message.hasOwnProperty("requestId")) + if (!$util.isString(message.requestId)) + return "requestId: string expected"; + return null; + }; + + /** + * Creates an UpdateSubnetRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.UpdateSubnetRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.UpdateSubnetRequest} UpdateSubnetRequest + */ + UpdateSubnetRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.UpdateSubnetRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.UpdateSubnetRequest(); + if (object.updateMask != null) { + if (typeof object.updateMask !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.UpdateSubnetRequest.updateMask: object expected"); + message.updateMask = $root.google.protobuf.FieldMask.fromObject(object.updateMask); + } + if (object.subnet != null) { + if (typeof object.subnet !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.UpdateSubnetRequest.subnet: object expected"); + message.subnet = $root.google.cloud.edgenetwork.v1.Subnet.fromObject(object.subnet); + } + if (object.requestId != null) + message.requestId = String(object.requestId); + return message; + }; + + /** + * Creates a plain object from an UpdateSubnetRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.UpdateSubnetRequest + * @static + * @param {google.cloud.edgenetwork.v1.UpdateSubnetRequest} message UpdateSubnetRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + UpdateSubnetRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.updateMask = null; + object.subnet = null; + object.requestId = ""; + } + if (message.updateMask != null && message.hasOwnProperty("updateMask")) + object.updateMask = $root.google.protobuf.FieldMask.toObject(message.updateMask, options); + if (message.subnet != null && message.hasOwnProperty("subnet")) + object.subnet = $root.google.cloud.edgenetwork.v1.Subnet.toObject(message.subnet, options); + if (message.requestId != null && message.hasOwnProperty("requestId")) + object.requestId = message.requestId; + return object; + }; + + /** + * Converts this UpdateSubnetRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.UpdateSubnetRequest + * @instance + * @returns {Object.} JSON object + */ + UpdateSubnetRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for UpdateSubnetRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.UpdateSubnetRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + UpdateSubnetRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.UpdateSubnetRequest"; + }; + + return UpdateSubnetRequest; + })(); + + v1.DeleteSubnetRequest = (function() { + + /** + * Properties of a DeleteSubnetRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IDeleteSubnetRequest + * @property {string|null} [name] DeleteSubnetRequest name + * @property {string|null} [requestId] DeleteSubnetRequest requestId + */ + + /** + * Constructs a new DeleteSubnetRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a DeleteSubnetRequest. + * @implements IDeleteSubnetRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IDeleteSubnetRequest=} [properties] Properties to set + */ + function DeleteSubnetRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * DeleteSubnetRequest name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.DeleteSubnetRequest + * @instance + */ + DeleteSubnetRequest.prototype.name = ""; + + /** + * DeleteSubnetRequest requestId. + * @member {string} requestId + * @memberof google.cloud.edgenetwork.v1.DeleteSubnetRequest + * @instance + */ + DeleteSubnetRequest.prototype.requestId = ""; + + /** + * Creates a new DeleteSubnetRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.DeleteSubnetRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDeleteSubnetRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.DeleteSubnetRequest} DeleteSubnetRequest instance + */ + DeleteSubnetRequest.create = function create(properties) { + return new DeleteSubnetRequest(properties); + }; + + /** + * Encodes the specified DeleteSubnetRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.DeleteSubnetRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.DeleteSubnetRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDeleteSubnetRequest} message DeleteSubnetRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DeleteSubnetRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.requestId != null && Object.hasOwnProperty.call(message, "requestId")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.requestId); + return writer; + }; + + /** + * Encodes the specified DeleteSubnetRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DeleteSubnetRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.DeleteSubnetRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDeleteSubnetRequest} message DeleteSubnetRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DeleteSubnetRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a DeleteSubnetRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.DeleteSubnetRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.DeleteSubnetRequest} DeleteSubnetRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DeleteSubnetRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.DeleteSubnetRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.requestId = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a DeleteSubnetRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.DeleteSubnetRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.DeleteSubnetRequest} DeleteSubnetRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DeleteSubnetRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a DeleteSubnetRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.DeleteSubnetRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + DeleteSubnetRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.requestId != null && message.hasOwnProperty("requestId")) + if (!$util.isString(message.requestId)) + return "requestId: string expected"; + return null; + }; + + /** + * Creates a DeleteSubnetRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.DeleteSubnetRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.DeleteSubnetRequest} DeleteSubnetRequest + */ + DeleteSubnetRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.DeleteSubnetRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.DeleteSubnetRequest(); + if (object.name != null) + message.name = String(object.name); + if (object.requestId != null) + message.requestId = String(object.requestId); + return message; + }; + + /** + * Creates a plain object from a DeleteSubnetRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.DeleteSubnetRequest + * @static + * @param {google.cloud.edgenetwork.v1.DeleteSubnetRequest} message DeleteSubnetRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + DeleteSubnetRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.name = ""; + object.requestId = ""; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.requestId != null && message.hasOwnProperty("requestId")) + object.requestId = message.requestId; + return object; + }; + + /** + * Converts this DeleteSubnetRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.DeleteSubnetRequest + * @instance + * @returns {Object.} JSON object + */ + DeleteSubnetRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for DeleteSubnetRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.DeleteSubnetRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + DeleteSubnetRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.DeleteSubnetRequest"; + }; + + return DeleteSubnetRequest; + })(); + + v1.ListInterconnectsRequest = (function() { + + /** + * Properties of a ListInterconnectsRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IListInterconnectsRequest + * @property {string|null} [parent] ListInterconnectsRequest parent + * @property {number|null} [pageSize] ListInterconnectsRequest pageSize + * @property {string|null} [pageToken] ListInterconnectsRequest pageToken + * @property {string|null} [filter] ListInterconnectsRequest filter + * @property {string|null} [orderBy] ListInterconnectsRequest orderBy + */ + + /** + * Constructs a new ListInterconnectsRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a ListInterconnectsRequest. + * @implements IListInterconnectsRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IListInterconnectsRequest=} [properties] Properties to set + */ + function ListInterconnectsRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ListInterconnectsRequest parent. + * @member {string} parent + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsRequest + * @instance + */ + ListInterconnectsRequest.prototype.parent = ""; + + /** + * ListInterconnectsRequest pageSize. + * @member {number} pageSize + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsRequest + * @instance + */ + ListInterconnectsRequest.prototype.pageSize = 0; + + /** + * ListInterconnectsRequest pageToken. + * @member {string} pageToken + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsRequest + * @instance + */ + ListInterconnectsRequest.prototype.pageToken = ""; + + /** + * ListInterconnectsRequest filter. + * @member {string} filter + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsRequest + * @instance + */ + ListInterconnectsRequest.prototype.filter = ""; + + /** + * ListInterconnectsRequest orderBy. + * @member {string} orderBy + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsRequest + * @instance + */ + ListInterconnectsRequest.prototype.orderBy = ""; + + /** + * Creates a new ListInterconnectsRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListInterconnectsRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.ListInterconnectsRequest} ListInterconnectsRequest instance + */ + ListInterconnectsRequest.create = function create(properties) { + return new ListInterconnectsRequest(properties); + }; + + /** + * Encodes the specified ListInterconnectsRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListInterconnectsRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListInterconnectsRequest} message ListInterconnectsRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListInterconnectsRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.parent != null && Object.hasOwnProperty.call(message, "parent")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.parent); + if (message.pageSize != null && Object.hasOwnProperty.call(message, "pageSize")) + writer.uint32(/* id 2, wireType 0 =*/16).int32(message.pageSize); + if (message.pageToken != null && Object.hasOwnProperty.call(message, "pageToken")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.pageToken); + if (message.filter != null && Object.hasOwnProperty.call(message, "filter")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.filter); + if (message.orderBy != null && Object.hasOwnProperty.call(message, "orderBy")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.orderBy); + return writer; + }; + + /** + * Encodes the specified ListInterconnectsRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListInterconnectsRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListInterconnectsRequest} message ListInterconnectsRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListInterconnectsRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ListInterconnectsRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.ListInterconnectsRequest} ListInterconnectsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListInterconnectsRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.ListInterconnectsRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.parent = reader.string(); + break; + } + case 2: { + message.pageSize = reader.int32(); + break; + } + case 3: { + message.pageToken = reader.string(); + break; + } + case 4: { + message.filter = reader.string(); + break; + } + case 5: { + message.orderBy = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ListInterconnectsRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.ListInterconnectsRequest} ListInterconnectsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListInterconnectsRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ListInterconnectsRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ListInterconnectsRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.parent != null && message.hasOwnProperty("parent")) + if (!$util.isString(message.parent)) + return "parent: string expected"; + if (message.pageSize != null && message.hasOwnProperty("pageSize")) + if (!$util.isInteger(message.pageSize)) + return "pageSize: integer expected"; + if (message.pageToken != null && message.hasOwnProperty("pageToken")) + if (!$util.isString(message.pageToken)) + return "pageToken: string expected"; + if (message.filter != null && message.hasOwnProperty("filter")) + if (!$util.isString(message.filter)) + return "filter: string expected"; + if (message.orderBy != null && message.hasOwnProperty("orderBy")) + if (!$util.isString(message.orderBy)) + return "orderBy: string expected"; + return null; + }; + + /** + * Creates a ListInterconnectsRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.ListInterconnectsRequest} ListInterconnectsRequest + */ + ListInterconnectsRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.ListInterconnectsRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.ListInterconnectsRequest(); + if (object.parent != null) + message.parent = String(object.parent); + if (object.pageSize != null) + message.pageSize = object.pageSize | 0; + if (object.pageToken != null) + message.pageToken = String(object.pageToken); + if (object.filter != null) + message.filter = String(object.filter); + if (object.orderBy != null) + message.orderBy = String(object.orderBy); + return message; + }; + + /** + * Creates a plain object from a ListInterconnectsRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsRequest + * @static + * @param {google.cloud.edgenetwork.v1.ListInterconnectsRequest} message ListInterconnectsRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ListInterconnectsRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.parent = ""; + object.pageSize = 0; + object.pageToken = ""; + object.filter = ""; + object.orderBy = ""; + } + if (message.parent != null && message.hasOwnProperty("parent")) + object.parent = message.parent; + if (message.pageSize != null && message.hasOwnProperty("pageSize")) + object.pageSize = message.pageSize; + if (message.pageToken != null && message.hasOwnProperty("pageToken")) + object.pageToken = message.pageToken; + if (message.filter != null && message.hasOwnProperty("filter")) + object.filter = message.filter; + if (message.orderBy != null && message.hasOwnProperty("orderBy")) + object.orderBy = message.orderBy; + return object; + }; + + /** + * Converts this ListInterconnectsRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsRequest + * @instance + * @returns {Object.} JSON object + */ + ListInterconnectsRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ListInterconnectsRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ListInterconnectsRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.ListInterconnectsRequest"; + }; + + return ListInterconnectsRequest; + })(); + + v1.ListInterconnectsResponse = (function() { + + /** + * Properties of a ListInterconnectsResponse. + * @memberof google.cloud.edgenetwork.v1 + * @interface IListInterconnectsResponse + * @property {Array.|null} [interconnects] ListInterconnectsResponse interconnects + * @property {string|null} [nextPageToken] ListInterconnectsResponse nextPageToken + * @property {Array.|null} [unreachable] ListInterconnectsResponse unreachable + */ + + /** + * Constructs a new ListInterconnectsResponse. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a ListInterconnectsResponse. + * @implements IListInterconnectsResponse + * @constructor + * @param {google.cloud.edgenetwork.v1.IListInterconnectsResponse=} [properties] Properties to set + */ + function ListInterconnectsResponse(properties) { + this.interconnects = []; + this.unreachable = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ListInterconnectsResponse interconnects. + * @member {Array.} interconnects + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsResponse + * @instance + */ + ListInterconnectsResponse.prototype.interconnects = $util.emptyArray; + + /** + * ListInterconnectsResponse nextPageToken. + * @member {string} nextPageToken + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsResponse + * @instance + */ + ListInterconnectsResponse.prototype.nextPageToken = ""; + + /** + * ListInterconnectsResponse unreachable. + * @member {Array.} unreachable + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsResponse + * @instance + */ + ListInterconnectsResponse.prototype.unreachable = $util.emptyArray; + + /** + * Creates a new ListInterconnectsResponse instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListInterconnectsResponse=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.ListInterconnectsResponse} ListInterconnectsResponse instance + */ + ListInterconnectsResponse.create = function create(properties) { + return new ListInterconnectsResponse(properties); + }; + + /** + * Encodes the specified ListInterconnectsResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListInterconnectsResponse.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListInterconnectsResponse} message ListInterconnectsResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListInterconnectsResponse.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.interconnects != null && message.interconnects.length) + for (var i = 0; i < message.interconnects.length; ++i) + $root.google.cloud.edgenetwork.v1.Interconnect.encode(message.interconnects[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.nextPageToken != null && Object.hasOwnProperty.call(message, "nextPageToken")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.nextPageToken); + if (message.unreachable != null && message.unreachable.length) + for (var i = 0; i < message.unreachable.length; ++i) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.unreachable[i]); + return writer; + }; + + /** + * Encodes the specified ListInterconnectsResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListInterconnectsResponse.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListInterconnectsResponse} message ListInterconnectsResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListInterconnectsResponse.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ListInterconnectsResponse message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.ListInterconnectsResponse} ListInterconnectsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListInterconnectsResponse.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.ListInterconnectsResponse(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + if (!(message.interconnects && message.interconnects.length)) + message.interconnects = []; + message.interconnects.push($root.google.cloud.edgenetwork.v1.Interconnect.decode(reader, reader.uint32())); + break; + } + case 2: { + message.nextPageToken = reader.string(); + break; + } + case 3: { + if (!(message.unreachable && message.unreachable.length)) + message.unreachable = []; + message.unreachable.push(reader.string()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ListInterconnectsResponse message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.ListInterconnectsResponse} ListInterconnectsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListInterconnectsResponse.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ListInterconnectsResponse message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsResponse + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ListInterconnectsResponse.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.interconnects != null && message.hasOwnProperty("interconnects")) { + if (!Array.isArray(message.interconnects)) + return "interconnects: array expected"; + for (var i = 0; i < message.interconnects.length; ++i) { + var error = $root.google.cloud.edgenetwork.v1.Interconnect.verify(message.interconnects[i]); + if (error) + return "interconnects." + error; + } + } + if (message.nextPageToken != null && message.hasOwnProperty("nextPageToken")) + if (!$util.isString(message.nextPageToken)) + return "nextPageToken: string expected"; + if (message.unreachable != null && message.hasOwnProperty("unreachable")) { + if (!Array.isArray(message.unreachable)) + return "unreachable: array expected"; + for (var i = 0; i < message.unreachable.length; ++i) + if (!$util.isString(message.unreachable[i])) + return "unreachable: string[] expected"; + } + return null; + }; + + /** + * Creates a ListInterconnectsResponse message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsResponse + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.ListInterconnectsResponse} ListInterconnectsResponse + */ + ListInterconnectsResponse.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.ListInterconnectsResponse) + return object; + var message = new $root.google.cloud.edgenetwork.v1.ListInterconnectsResponse(); + if (object.interconnects) { + if (!Array.isArray(object.interconnects)) + throw TypeError(".google.cloud.edgenetwork.v1.ListInterconnectsResponse.interconnects: array expected"); + message.interconnects = []; + for (var i = 0; i < object.interconnects.length; ++i) { + if (typeof object.interconnects[i] !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.ListInterconnectsResponse.interconnects: object expected"); + message.interconnects[i] = $root.google.cloud.edgenetwork.v1.Interconnect.fromObject(object.interconnects[i]); + } + } + if (object.nextPageToken != null) + message.nextPageToken = String(object.nextPageToken); + if (object.unreachable) { + if (!Array.isArray(object.unreachable)) + throw TypeError(".google.cloud.edgenetwork.v1.ListInterconnectsResponse.unreachable: array expected"); + message.unreachable = []; + for (var i = 0; i < object.unreachable.length; ++i) + message.unreachable[i] = String(object.unreachable[i]); + } + return message; + }; + + /** + * Creates a plain object from a ListInterconnectsResponse message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsResponse + * @static + * @param {google.cloud.edgenetwork.v1.ListInterconnectsResponse} message ListInterconnectsResponse + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ListInterconnectsResponse.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.interconnects = []; + object.unreachable = []; + } + if (options.defaults) + object.nextPageToken = ""; + if (message.interconnects && message.interconnects.length) { + object.interconnects = []; + for (var j = 0; j < message.interconnects.length; ++j) + object.interconnects[j] = $root.google.cloud.edgenetwork.v1.Interconnect.toObject(message.interconnects[j], options); + } + if (message.nextPageToken != null && message.hasOwnProperty("nextPageToken")) + object.nextPageToken = message.nextPageToken; + if (message.unreachable && message.unreachable.length) { + object.unreachable = []; + for (var j = 0; j < message.unreachable.length; ++j) + object.unreachable[j] = message.unreachable[j]; + } + return object; + }; + + /** + * Converts this ListInterconnectsResponse to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsResponse + * @instance + * @returns {Object.} JSON object + */ + ListInterconnectsResponse.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ListInterconnectsResponse + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.ListInterconnectsResponse + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ListInterconnectsResponse.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.ListInterconnectsResponse"; + }; + + return ListInterconnectsResponse; + })(); + + v1.GetInterconnectRequest = (function() { + + /** + * Properties of a GetInterconnectRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IGetInterconnectRequest + * @property {string|null} [name] GetInterconnectRequest name + */ + + /** + * Constructs a new GetInterconnectRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a GetInterconnectRequest. + * @implements IGetInterconnectRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IGetInterconnectRequest=} [properties] Properties to set + */ + function GetInterconnectRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * GetInterconnectRequest name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.GetInterconnectRequest + * @instance + */ + GetInterconnectRequest.prototype.name = ""; + + /** + * Creates a new GetInterconnectRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.GetInterconnectRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetInterconnectRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.GetInterconnectRequest} GetInterconnectRequest instance + */ + GetInterconnectRequest.create = function create(properties) { + return new GetInterconnectRequest(properties); + }; + + /** + * Encodes the specified GetInterconnectRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.GetInterconnectRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.GetInterconnectRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetInterconnectRequest} message GetInterconnectRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GetInterconnectRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + return writer; + }; + + /** + * Encodes the specified GetInterconnectRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.GetInterconnectRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.GetInterconnectRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetInterconnectRequest} message GetInterconnectRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GetInterconnectRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a GetInterconnectRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.GetInterconnectRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.GetInterconnectRequest} GetInterconnectRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GetInterconnectRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.GetInterconnectRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a GetInterconnectRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.GetInterconnectRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.GetInterconnectRequest} GetInterconnectRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GetInterconnectRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a GetInterconnectRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.GetInterconnectRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + GetInterconnectRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + return null; + }; + + /** + * Creates a GetInterconnectRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.GetInterconnectRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.GetInterconnectRequest} GetInterconnectRequest + */ + GetInterconnectRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.GetInterconnectRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.GetInterconnectRequest(); + if (object.name != null) + message.name = String(object.name); + return message; + }; + + /** + * Creates a plain object from a GetInterconnectRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.GetInterconnectRequest + * @static + * @param {google.cloud.edgenetwork.v1.GetInterconnectRequest} message GetInterconnectRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + GetInterconnectRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.name = ""; + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + return object; + }; + + /** + * Converts this GetInterconnectRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.GetInterconnectRequest + * @instance + * @returns {Object.} JSON object + */ + GetInterconnectRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for GetInterconnectRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.GetInterconnectRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + GetInterconnectRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.GetInterconnectRequest"; + }; + + return GetInterconnectRequest; + })(); + + v1.ListInterconnectAttachmentsRequest = (function() { + + /** + * Properties of a ListInterconnectAttachmentsRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IListInterconnectAttachmentsRequest + * @property {string|null} [parent] ListInterconnectAttachmentsRequest parent + * @property {number|null} [pageSize] ListInterconnectAttachmentsRequest pageSize + * @property {string|null} [pageToken] ListInterconnectAttachmentsRequest pageToken + * @property {string|null} [filter] ListInterconnectAttachmentsRequest filter + * @property {string|null} [orderBy] ListInterconnectAttachmentsRequest orderBy + */ + + /** + * Constructs a new ListInterconnectAttachmentsRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a ListInterconnectAttachmentsRequest. + * @implements IListInterconnectAttachmentsRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest=} [properties] Properties to set + */ + function ListInterconnectAttachmentsRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ListInterconnectAttachmentsRequest parent. + * @member {string} parent + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest + * @instance + */ + ListInterconnectAttachmentsRequest.prototype.parent = ""; + + /** + * ListInterconnectAttachmentsRequest pageSize. + * @member {number} pageSize + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest + * @instance + */ + ListInterconnectAttachmentsRequest.prototype.pageSize = 0; + + /** + * ListInterconnectAttachmentsRequest pageToken. + * @member {string} pageToken + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest + * @instance + */ + ListInterconnectAttachmentsRequest.prototype.pageToken = ""; + + /** + * ListInterconnectAttachmentsRequest filter. + * @member {string} filter + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest + * @instance + */ + ListInterconnectAttachmentsRequest.prototype.filter = ""; + + /** + * ListInterconnectAttachmentsRequest orderBy. + * @member {string} orderBy + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest + * @instance + */ + ListInterconnectAttachmentsRequest.prototype.orderBy = ""; + + /** + * Creates a new ListInterconnectAttachmentsRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest} ListInterconnectAttachmentsRequest instance + */ + ListInterconnectAttachmentsRequest.create = function create(properties) { + return new ListInterconnectAttachmentsRequest(properties); + }; + + /** + * Encodes the specified ListInterconnectAttachmentsRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest} message ListInterconnectAttachmentsRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListInterconnectAttachmentsRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.parent != null && Object.hasOwnProperty.call(message, "parent")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.parent); + if (message.pageSize != null && Object.hasOwnProperty.call(message, "pageSize")) + writer.uint32(/* id 2, wireType 0 =*/16).int32(message.pageSize); + if (message.pageToken != null && Object.hasOwnProperty.call(message, "pageToken")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.pageToken); + if (message.filter != null && Object.hasOwnProperty.call(message, "filter")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.filter); + if (message.orderBy != null && Object.hasOwnProperty.call(message, "orderBy")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.orderBy); + return writer; + }; + + /** + * Encodes the specified ListInterconnectAttachmentsRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest} message ListInterconnectAttachmentsRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListInterconnectAttachmentsRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ListInterconnectAttachmentsRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest} ListInterconnectAttachmentsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListInterconnectAttachmentsRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.parent = reader.string(); + break; + } + case 2: { + message.pageSize = reader.int32(); + break; + } + case 3: { + message.pageToken = reader.string(); + break; + } + case 4: { + message.filter = reader.string(); + break; + } + case 5: { + message.orderBy = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ListInterconnectAttachmentsRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest} ListInterconnectAttachmentsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListInterconnectAttachmentsRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ListInterconnectAttachmentsRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ListInterconnectAttachmentsRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.parent != null && message.hasOwnProperty("parent")) + if (!$util.isString(message.parent)) + return "parent: string expected"; + if (message.pageSize != null && message.hasOwnProperty("pageSize")) + if (!$util.isInteger(message.pageSize)) + return "pageSize: integer expected"; + if (message.pageToken != null && message.hasOwnProperty("pageToken")) + if (!$util.isString(message.pageToken)) + return "pageToken: string expected"; + if (message.filter != null && message.hasOwnProperty("filter")) + if (!$util.isString(message.filter)) + return "filter: string expected"; + if (message.orderBy != null && message.hasOwnProperty("orderBy")) + if (!$util.isString(message.orderBy)) + return "orderBy: string expected"; + return null; + }; + + /** + * Creates a ListInterconnectAttachmentsRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest} ListInterconnectAttachmentsRequest + */ + ListInterconnectAttachmentsRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest(); + if (object.parent != null) + message.parent = String(object.parent); + if (object.pageSize != null) + message.pageSize = object.pageSize | 0; + if (object.pageToken != null) + message.pageToken = String(object.pageToken); + if (object.filter != null) + message.filter = String(object.filter); + if (object.orderBy != null) + message.orderBy = String(object.orderBy); + return message; + }; + + /** + * Creates a plain object from a ListInterconnectAttachmentsRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest + * @static + * @param {google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest} message ListInterconnectAttachmentsRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ListInterconnectAttachmentsRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.parent = ""; + object.pageSize = 0; + object.pageToken = ""; + object.filter = ""; + object.orderBy = ""; + } + if (message.parent != null && message.hasOwnProperty("parent")) + object.parent = message.parent; + if (message.pageSize != null && message.hasOwnProperty("pageSize")) + object.pageSize = message.pageSize; + if (message.pageToken != null && message.hasOwnProperty("pageToken")) + object.pageToken = message.pageToken; + if (message.filter != null && message.hasOwnProperty("filter")) + object.filter = message.filter; + if (message.orderBy != null && message.hasOwnProperty("orderBy")) + object.orderBy = message.orderBy; + return object; + }; + + /** + * Converts this ListInterconnectAttachmentsRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest + * @instance + * @returns {Object.} JSON object + */ + ListInterconnectAttachmentsRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ListInterconnectAttachmentsRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ListInterconnectAttachmentsRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest"; + }; + + return ListInterconnectAttachmentsRequest; + })(); + + v1.ListInterconnectAttachmentsResponse = (function() { + + /** + * Properties of a ListInterconnectAttachmentsResponse. + * @memberof google.cloud.edgenetwork.v1 + * @interface IListInterconnectAttachmentsResponse + * @property {Array.|null} [interconnectAttachments] ListInterconnectAttachmentsResponse interconnectAttachments + * @property {string|null} [nextPageToken] ListInterconnectAttachmentsResponse nextPageToken + * @property {Array.|null} [unreachable] ListInterconnectAttachmentsResponse unreachable + */ + + /** + * Constructs a new ListInterconnectAttachmentsResponse. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a ListInterconnectAttachmentsResponse. + * @implements IListInterconnectAttachmentsResponse + * @constructor + * @param {google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse=} [properties] Properties to set + */ + function ListInterconnectAttachmentsResponse(properties) { + this.interconnectAttachments = []; + this.unreachable = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ListInterconnectAttachmentsResponse interconnectAttachments. + * @member {Array.} interconnectAttachments + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse + * @instance + */ + ListInterconnectAttachmentsResponse.prototype.interconnectAttachments = $util.emptyArray; + + /** + * ListInterconnectAttachmentsResponse nextPageToken. + * @member {string} nextPageToken + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse + * @instance + */ + ListInterconnectAttachmentsResponse.prototype.nextPageToken = ""; + + /** + * ListInterconnectAttachmentsResponse unreachable. + * @member {Array.} unreachable + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse + * @instance + */ + ListInterconnectAttachmentsResponse.prototype.unreachable = $util.emptyArray; + + /** + * Creates a new ListInterconnectAttachmentsResponse instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse} ListInterconnectAttachmentsResponse instance + */ + ListInterconnectAttachmentsResponse.create = function create(properties) { + return new ListInterconnectAttachmentsResponse(properties); + }; + + /** + * Encodes the specified ListInterconnectAttachmentsResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse} message ListInterconnectAttachmentsResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListInterconnectAttachmentsResponse.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.interconnectAttachments != null && message.interconnectAttachments.length) + for (var i = 0; i < message.interconnectAttachments.length; ++i) + $root.google.cloud.edgenetwork.v1.InterconnectAttachment.encode(message.interconnectAttachments[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.nextPageToken != null && Object.hasOwnProperty.call(message, "nextPageToken")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.nextPageToken); + if (message.unreachable != null && message.unreachable.length) + for (var i = 0; i < message.unreachable.length; ++i) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.unreachable[i]); + return writer; + }; + + /** + * Encodes the specified ListInterconnectAttachmentsResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse} message ListInterconnectAttachmentsResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListInterconnectAttachmentsResponse.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ListInterconnectAttachmentsResponse message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse} ListInterconnectAttachmentsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListInterconnectAttachmentsResponse.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + if (!(message.interconnectAttachments && message.interconnectAttachments.length)) + message.interconnectAttachments = []; + message.interconnectAttachments.push($root.google.cloud.edgenetwork.v1.InterconnectAttachment.decode(reader, reader.uint32())); + break; + } + case 2: { + message.nextPageToken = reader.string(); + break; + } + case 3: { + if (!(message.unreachable && message.unreachable.length)) + message.unreachable = []; + message.unreachable.push(reader.string()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ListInterconnectAttachmentsResponse message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse} ListInterconnectAttachmentsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListInterconnectAttachmentsResponse.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ListInterconnectAttachmentsResponse message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ListInterconnectAttachmentsResponse.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.interconnectAttachments != null && message.hasOwnProperty("interconnectAttachments")) { + if (!Array.isArray(message.interconnectAttachments)) + return "interconnectAttachments: array expected"; + for (var i = 0; i < message.interconnectAttachments.length; ++i) { + var error = $root.google.cloud.edgenetwork.v1.InterconnectAttachment.verify(message.interconnectAttachments[i]); + if (error) + return "interconnectAttachments." + error; + } + } + if (message.nextPageToken != null && message.hasOwnProperty("nextPageToken")) + if (!$util.isString(message.nextPageToken)) + return "nextPageToken: string expected"; + if (message.unreachable != null && message.hasOwnProperty("unreachable")) { + if (!Array.isArray(message.unreachable)) + return "unreachable: array expected"; + for (var i = 0; i < message.unreachable.length; ++i) + if (!$util.isString(message.unreachable[i])) + return "unreachable: string[] expected"; + } + return null; + }; + + /** + * Creates a ListInterconnectAttachmentsResponse message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse} ListInterconnectAttachmentsResponse + */ + ListInterconnectAttachmentsResponse.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse) + return object; + var message = new $root.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse(); + if (object.interconnectAttachments) { + if (!Array.isArray(object.interconnectAttachments)) + throw TypeError(".google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse.interconnectAttachments: array expected"); + message.interconnectAttachments = []; + for (var i = 0; i < object.interconnectAttachments.length; ++i) { + if (typeof object.interconnectAttachments[i] !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse.interconnectAttachments: object expected"); + message.interconnectAttachments[i] = $root.google.cloud.edgenetwork.v1.InterconnectAttachment.fromObject(object.interconnectAttachments[i]); + } + } + if (object.nextPageToken != null) + message.nextPageToken = String(object.nextPageToken); + if (object.unreachable) { + if (!Array.isArray(object.unreachable)) + throw TypeError(".google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse.unreachable: array expected"); + message.unreachable = []; + for (var i = 0; i < object.unreachable.length; ++i) + message.unreachable[i] = String(object.unreachable[i]); + } + return message; + }; + + /** + * Creates a plain object from a ListInterconnectAttachmentsResponse message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse + * @static + * @param {google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse} message ListInterconnectAttachmentsResponse + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ListInterconnectAttachmentsResponse.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.interconnectAttachments = []; + object.unreachable = []; + } + if (options.defaults) + object.nextPageToken = ""; + if (message.interconnectAttachments && message.interconnectAttachments.length) { + object.interconnectAttachments = []; + for (var j = 0; j < message.interconnectAttachments.length; ++j) + object.interconnectAttachments[j] = $root.google.cloud.edgenetwork.v1.InterconnectAttachment.toObject(message.interconnectAttachments[j], options); + } + if (message.nextPageToken != null && message.hasOwnProperty("nextPageToken")) + object.nextPageToken = message.nextPageToken; + if (message.unreachable && message.unreachable.length) { + object.unreachable = []; + for (var j = 0; j < message.unreachable.length; ++j) + object.unreachable[j] = message.unreachable[j]; + } + return object; + }; + + /** + * Converts this ListInterconnectAttachmentsResponse to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse + * @instance + * @returns {Object.} JSON object + */ + ListInterconnectAttachmentsResponse.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ListInterconnectAttachmentsResponse + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ListInterconnectAttachmentsResponse.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse"; + }; + + return ListInterconnectAttachmentsResponse; + })(); + + v1.GetInterconnectAttachmentRequest = (function() { + + /** + * Properties of a GetInterconnectAttachmentRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IGetInterconnectAttachmentRequest + * @property {string|null} [name] GetInterconnectAttachmentRequest name + */ + + /** + * Constructs a new GetInterconnectAttachmentRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a GetInterconnectAttachmentRequest. + * @implements IGetInterconnectAttachmentRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest=} [properties] Properties to set + */ + function GetInterconnectAttachmentRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * GetInterconnectAttachmentRequest name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest + * @instance + */ + GetInterconnectAttachmentRequest.prototype.name = ""; + + /** + * Creates a new GetInterconnectAttachmentRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest} GetInterconnectAttachmentRequest instance + */ + GetInterconnectAttachmentRequest.create = function create(properties) { + return new GetInterconnectAttachmentRequest(properties); + }; + + /** + * Encodes the specified GetInterconnectAttachmentRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest} message GetInterconnectAttachmentRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GetInterconnectAttachmentRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + return writer; + }; + + /** + * Encodes the specified GetInterconnectAttachmentRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest} message GetInterconnectAttachmentRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GetInterconnectAttachmentRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a GetInterconnectAttachmentRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest} GetInterconnectAttachmentRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GetInterconnectAttachmentRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a GetInterconnectAttachmentRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest} GetInterconnectAttachmentRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GetInterconnectAttachmentRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a GetInterconnectAttachmentRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + GetInterconnectAttachmentRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + return null; + }; + + /** + * Creates a GetInterconnectAttachmentRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest} GetInterconnectAttachmentRequest + */ + GetInterconnectAttachmentRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest(); + if (object.name != null) + message.name = String(object.name); + return message; + }; + + /** + * Creates a plain object from a GetInterconnectAttachmentRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest + * @static + * @param {google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest} message GetInterconnectAttachmentRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + GetInterconnectAttachmentRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.name = ""; + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + return object; + }; + + /** + * Converts this GetInterconnectAttachmentRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest + * @instance + * @returns {Object.} JSON object + */ + GetInterconnectAttachmentRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for GetInterconnectAttachmentRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + GetInterconnectAttachmentRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest"; + }; + + return GetInterconnectAttachmentRequest; + })(); + + v1.CreateInterconnectAttachmentRequest = (function() { + + /** + * Properties of a CreateInterconnectAttachmentRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface ICreateInterconnectAttachmentRequest + * @property {string|null} [parent] CreateInterconnectAttachmentRequest parent + * @property {string|null} [interconnectAttachmentId] CreateInterconnectAttachmentRequest interconnectAttachmentId + * @property {google.cloud.edgenetwork.v1.IInterconnectAttachment|null} [interconnectAttachment] CreateInterconnectAttachmentRequest interconnectAttachment + * @property {string|null} [requestId] CreateInterconnectAttachmentRequest requestId + */ + + /** + * Constructs a new CreateInterconnectAttachmentRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a CreateInterconnectAttachmentRequest. + * @implements ICreateInterconnectAttachmentRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest=} [properties] Properties to set + */ + function CreateInterconnectAttachmentRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * CreateInterconnectAttachmentRequest parent. + * @member {string} parent + * @memberof google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest + * @instance + */ + CreateInterconnectAttachmentRequest.prototype.parent = ""; + + /** + * CreateInterconnectAttachmentRequest interconnectAttachmentId. + * @member {string} interconnectAttachmentId + * @memberof google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest + * @instance + */ + CreateInterconnectAttachmentRequest.prototype.interconnectAttachmentId = ""; + + /** + * CreateInterconnectAttachmentRequest interconnectAttachment. + * @member {google.cloud.edgenetwork.v1.IInterconnectAttachment|null|undefined} interconnectAttachment + * @memberof google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest + * @instance + */ + CreateInterconnectAttachmentRequest.prototype.interconnectAttachment = null; + + /** + * CreateInterconnectAttachmentRequest requestId. + * @member {string} requestId + * @memberof google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest + * @instance + */ + CreateInterconnectAttachmentRequest.prototype.requestId = ""; + + /** + * Creates a new CreateInterconnectAttachmentRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest + * @static + * @param {google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest} CreateInterconnectAttachmentRequest instance + */ + CreateInterconnectAttachmentRequest.create = function create(properties) { + return new CreateInterconnectAttachmentRequest(properties); + }; + + /** + * Encodes the specified CreateInterconnectAttachmentRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest + * @static + * @param {google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest} message CreateInterconnectAttachmentRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + CreateInterconnectAttachmentRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.parent != null && Object.hasOwnProperty.call(message, "parent")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.parent); + if (message.interconnectAttachmentId != null && Object.hasOwnProperty.call(message, "interconnectAttachmentId")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.interconnectAttachmentId); + if (message.interconnectAttachment != null && Object.hasOwnProperty.call(message, "interconnectAttachment")) + $root.google.cloud.edgenetwork.v1.InterconnectAttachment.encode(message.interconnectAttachment, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + if (message.requestId != null && Object.hasOwnProperty.call(message, "requestId")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.requestId); + return writer; + }; + + /** + * Encodes the specified CreateInterconnectAttachmentRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest + * @static + * @param {google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest} message CreateInterconnectAttachmentRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + CreateInterconnectAttachmentRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a CreateInterconnectAttachmentRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest} CreateInterconnectAttachmentRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + CreateInterconnectAttachmentRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.parent = reader.string(); + break; + } + case 2: { + message.interconnectAttachmentId = reader.string(); + break; + } + case 3: { + message.interconnectAttachment = $root.google.cloud.edgenetwork.v1.InterconnectAttachment.decode(reader, reader.uint32()); + break; + } + case 4: { + message.requestId = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a CreateInterconnectAttachmentRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest} CreateInterconnectAttachmentRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + CreateInterconnectAttachmentRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a CreateInterconnectAttachmentRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + CreateInterconnectAttachmentRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.parent != null && message.hasOwnProperty("parent")) + if (!$util.isString(message.parent)) + return "parent: string expected"; + if (message.interconnectAttachmentId != null && message.hasOwnProperty("interconnectAttachmentId")) + if (!$util.isString(message.interconnectAttachmentId)) + return "interconnectAttachmentId: string expected"; + if (message.interconnectAttachment != null && message.hasOwnProperty("interconnectAttachment")) { + var error = $root.google.cloud.edgenetwork.v1.InterconnectAttachment.verify(message.interconnectAttachment); + if (error) + return "interconnectAttachment." + error; + } + if (message.requestId != null && message.hasOwnProperty("requestId")) + if (!$util.isString(message.requestId)) + return "requestId: string expected"; + return null; + }; + + /** + * Creates a CreateInterconnectAttachmentRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest} CreateInterconnectAttachmentRequest + */ + CreateInterconnectAttachmentRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest(); + if (object.parent != null) + message.parent = String(object.parent); + if (object.interconnectAttachmentId != null) + message.interconnectAttachmentId = String(object.interconnectAttachmentId); + if (object.interconnectAttachment != null) { + if (typeof object.interconnectAttachment !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest.interconnectAttachment: object expected"); + message.interconnectAttachment = $root.google.cloud.edgenetwork.v1.InterconnectAttachment.fromObject(object.interconnectAttachment); + } + if (object.requestId != null) + message.requestId = String(object.requestId); + return message; + }; + + /** + * Creates a plain object from a CreateInterconnectAttachmentRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest + * @static + * @param {google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest} message CreateInterconnectAttachmentRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + CreateInterconnectAttachmentRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.parent = ""; + object.interconnectAttachmentId = ""; + object.interconnectAttachment = null; + object.requestId = ""; + } + if (message.parent != null && message.hasOwnProperty("parent")) + object.parent = message.parent; + if (message.interconnectAttachmentId != null && message.hasOwnProperty("interconnectAttachmentId")) + object.interconnectAttachmentId = message.interconnectAttachmentId; + if (message.interconnectAttachment != null && message.hasOwnProperty("interconnectAttachment")) + object.interconnectAttachment = $root.google.cloud.edgenetwork.v1.InterconnectAttachment.toObject(message.interconnectAttachment, options); + if (message.requestId != null && message.hasOwnProperty("requestId")) + object.requestId = message.requestId; + return object; + }; + + /** + * Converts this CreateInterconnectAttachmentRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest + * @instance + * @returns {Object.} JSON object + */ + CreateInterconnectAttachmentRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for CreateInterconnectAttachmentRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + CreateInterconnectAttachmentRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest"; + }; + + return CreateInterconnectAttachmentRequest; + })(); + + v1.DeleteInterconnectAttachmentRequest = (function() { + + /** + * Properties of a DeleteInterconnectAttachmentRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IDeleteInterconnectAttachmentRequest + * @property {string|null} [name] DeleteInterconnectAttachmentRequest name + * @property {string|null} [requestId] DeleteInterconnectAttachmentRequest requestId + */ + + /** + * Constructs a new DeleteInterconnectAttachmentRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a DeleteInterconnectAttachmentRequest. + * @implements IDeleteInterconnectAttachmentRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest=} [properties] Properties to set + */ + function DeleteInterconnectAttachmentRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * DeleteInterconnectAttachmentRequest name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest + * @instance + */ + DeleteInterconnectAttachmentRequest.prototype.name = ""; + + /** + * DeleteInterconnectAttachmentRequest requestId. + * @member {string} requestId + * @memberof google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest + * @instance + */ + DeleteInterconnectAttachmentRequest.prototype.requestId = ""; + + /** + * Creates a new DeleteInterconnectAttachmentRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest} DeleteInterconnectAttachmentRequest instance + */ + DeleteInterconnectAttachmentRequest.create = function create(properties) { + return new DeleteInterconnectAttachmentRequest(properties); + }; + + /** + * Encodes the specified DeleteInterconnectAttachmentRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest} message DeleteInterconnectAttachmentRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DeleteInterconnectAttachmentRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.requestId != null && Object.hasOwnProperty.call(message, "requestId")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.requestId); + return writer; + }; + + /** + * Encodes the specified DeleteInterconnectAttachmentRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest} message DeleteInterconnectAttachmentRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DeleteInterconnectAttachmentRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a DeleteInterconnectAttachmentRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest} DeleteInterconnectAttachmentRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DeleteInterconnectAttachmentRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.requestId = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a DeleteInterconnectAttachmentRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest} DeleteInterconnectAttachmentRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DeleteInterconnectAttachmentRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a DeleteInterconnectAttachmentRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + DeleteInterconnectAttachmentRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.requestId != null && message.hasOwnProperty("requestId")) + if (!$util.isString(message.requestId)) + return "requestId: string expected"; + return null; + }; + + /** + * Creates a DeleteInterconnectAttachmentRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest} DeleteInterconnectAttachmentRequest + */ + DeleteInterconnectAttachmentRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest(); + if (object.name != null) + message.name = String(object.name); + if (object.requestId != null) + message.requestId = String(object.requestId); + return message; + }; + + /** + * Creates a plain object from a DeleteInterconnectAttachmentRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest + * @static + * @param {google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest} message DeleteInterconnectAttachmentRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + DeleteInterconnectAttachmentRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.name = ""; + object.requestId = ""; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.requestId != null && message.hasOwnProperty("requestId")) + object.requestId = message.requestId; + return object; + }; + + /** + * Converts this DeleteInterconnectAttachmentRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest + * @instance + * @returns {Object.} JSON object + */ + DeleteInterconnectAttachmentRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for DeleteInterconnectAttachmentRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + DeleteInterconnectAttachmentRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest"; + }; + + return DeleteInterconnectAttachmentRequest; + })(); + + v1.ListRoutersRequest = (function() { + + /** + * Properties of a ListRoutersRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IListRoutersRequest + * @property {string|null} [parent] ListRoutersRequest parent + * @property {number|null} [pageSize] ListRoutersRequest pageSize + * @property {string|null} [pageToken] ListRoutersRequest pageToken + * @property {string|null} [filter] ListRoutersRequest filter + * @property {string|null} [orderBy] ListRoutersRequest orderBy + */ + + /** + * Constructs a new ListRoutersRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a ListRoutersRequest. + * @implements IListRoutersRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IListRoutersRequest=} [properties] Properties to set + */ + function ListRoutersRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ListRoutersRequest parent. + * @member {string} parent + * @memberof google.cloud.edgenetwork.v1.ListRoutersRequest + * @instance + */ + ListRoutersRequest.prototype.parent = ""; + + /** + * ListRoutersRequest pageSize. + * @member {number} pageSize + * @memberof google.cloud.edgenetwork.v1.ListRoutersRequest + * @instance + */ + ListRoutersRequest.prototype.pageSize = 0; + + /** + * ListRoutersRequest pageToken. + * @member {string} pageToken + * @memberof google.cloud.edgenetwork.v1.ListRoutersRequest + * @instance + */ + ListRoutersRequest.prototype.pageToken = ""; + + /** + * ListRoutersRequest filter. + * @member {string} filter + * @memberof google.cloud.edgenetwork.v1.ListRoutersRequest + * @instance + */ + ListRoutersRequest.prototype.filter = ""; + + /** + * ListRoutersRequest orderBy. + * @member {string} orderBy + * @memberof google.cloud.edgenetwork.v1.ListRoutersRequest + * @instance + */ + ListRoutersRequest.prototype.orderBy = ""; + + /** + * Creates a new ListRoutersRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.ListRoutersRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListRoutersRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.ListRoutersRequest} ListRoutersRequest instance + */ + ListRoutersRequest.create = function create(properties) { + return new ListRoutersRequest(properties); + }; + + /** + * Encodes the specified ListRoutersRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListRoutersRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.ListRoutersRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListRoutersRequest} message ListRoutersRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListRoutersRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.parent != null && Object.hasOwnProperty.call(message, "parent")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.parent); + if (message.pageSize != null && Object.hasOwnProperty.call(message, "pageSize")) + writer.uint32(/* id 2, wireType 0 =*/16).int32(message.pageSize); + if (message.pageToken != null && Object.hasOwnProperty.call(message, "pageToken")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.pageToken); + if (message.filter != null && Object.hasOwnProperty.call(message, "filter")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.filter); + if (message.orderBy != null && Object.hasOwnProperty.call(message, "orderBy")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.orderBy); + return writer; + }; + + /** + * Encodes the specified ListRoutersRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListRoutersRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListRoutersRequest + * @static + * @param {google.cloud.edgenetwork.v1.IListRoutersRequest} message ListRoutersRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListRoutersRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ListRoutersRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.ListRoutersRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.ListRoutersRequest} ListRoutersRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListRoutersRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.ListRoutersRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.parent = reader.string(); + break; + } + case 2: { + message.pageSize = reader.int32(); + break; + } + case 3: { + message.pageToken = reader.string(); + break; + } + case 4: { + message.filter = reader.string(); + break; + } + case 5: { + message.orderBy = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ListRoutersRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListRoutersRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.ListRoutersRequest} ListRoutersRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListRoutersRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ListRoutersRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.ListRoutersRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ListRoutersRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.parent != null && message.hasOwnProperty("parent")) + if (!$util.isString(message.parent)) + return "parent: string expected"; + if (message.pageSize != null && message.hasOwnProperty("pageSize")) + if (!$util.isInteger(message.pageSize)) + return "pageSize: integer expected"; + if (message.pageToken != null && message.hasOwnProperty("pageToken")) + if (!$util.isString(message.pageToken)) + return "pageToken: string expected"; + if (message.filter != null && message.hasOwnProperty("filter")) + if (!$util.isString(message.filter)) + return "filter: string expected"; + if (message.orderBy != null && message.hasOwnProperty("orderBy")) + if (!$util.isString(message.orderBy)) + return "orderBy: string expected"; + return null; + }; + + /** + * Creates a ListRoutersRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.ListRoutersRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.ListRoutersRequest} ListRoutersRequest + */ + ListRoutersRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.ListRoutersRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.ListRoutersRequest(); + if (object.parent != null) + message.parent = String(object.parent); + if (object.pageSize != null) + message.pageSize = object.pageSize | 0; + if (object.pageToken != null) + message.pageToken = String(object.pageToken); + if (object.filter != null) + message.filter = String(object.filter); + if (object.orderBy != null) + message.orderBy = String(object.orderBy); + return message; + }; + + /** + * Creates a plain object from a ListRoutersRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.ListRoutersRequest + * @static + * @param {google.cloud.edgenetwork.v1.ListRoutersRequest} message ListRoutersRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ListRoutersRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.parent = ""; + object.pageSize = 0; + object.pageToken = ""; + object.filter = ""; + object.orderBy = ""; + } + if (message.parent != null && message.hasOwnProperty("parent")) + object.parent = message.parent; + if (message.pageSize != null && message.hasOwnProperty("pageSize")) + object.pageSize = message.pageSize; + if (message.pageToken != null && message.hasOwnProperty("pageToken")) + object.pageToken = message.pageToken; + if (message.filter != null && message.hasOwnProperty("filter")) + object.filter = message.filter; + if (message.orderBy != null && message.hasOwnProperty("orderBy")) + object.orderBy = message.orderBy; + return object; + }; + + /** + * Converts this ListRoutersRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.ListRoutersRequest + * @instance + * @returns {Object.} JSON object + */ + ListRoutersRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ListRoutersRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.ListRoutersRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ListRoutersRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.ListRoutersRequest"; + }; + + return ListRoutersRequest; + })(); + + v1.ListRoutersResponse = (function() { + + /** + * Properties of a ListRoutersResponse. + * @memberof google.cloud.edgenetwork.v1 + * @interface IListRoutersResponse + * @property {Array.|null} [routers] ListRoutersResponse routers + * @property {string|null} [nextPageToken] ListRoutersResponse nextPageToken + * @property {Array.|null} [unreachable] ListRoutersResponse unreachable + */ + + /** + * Constructs a new ListRoutersResponse. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a ListRoutersResponse. + * @implements IListRoutersResponse + * @constructor + * @param {google.cloud.edgenetwork.v1.IListRoutersResponse=} [properties] Properties to set + */ + function ListRoutersResponse(properties) { + this.routers = []; + this.unreachable = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ListRoutersResponse routers. + * @member {Array.} routers + * @memberof google.cloud.edgenetwork.v1.ListRoutersResponse + * @instance + */ + ListRoutersResponse.prototype.routers = $util.emptyArray; + + /** + * ListRoutersResponse nextPageToken. + * @member {string} nextPageToken + * @memberof google.cloud.edgenetwork.v1.ListRoutersResponse + * @instance + */ + ListRoutersResponse.prototype.nextPageToken = ""; + + /** + * ListRoutersResponse unreachable. + * @member {Array.} unreachable + * @memberof google.cloud.edgenetwork.v1.ListRoutersResponse + * @instance + */ + ListRoutersResponse.prototype.unreachable = $util.emptyArray; + + /** + * Creates a new ListRoutersResponse instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.ListRoutersResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListRoutersResponse=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.ListRoutersResponse} ListRoutersResponse instance + */ + ListRoutersResponse.create = function create(properties) { + return new ListRoutersResponse(properties); + }; + + /** + * Encodes the specified ListRoutersResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.ListRoutersResponse.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.ListRoutersResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListRoutersResponse} message ListRoutersResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListRoutersResponse.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.routers != null && message.routers.length) + for (var i = 0; i < message.routers.length; ++i) + $root.google.cloud.edgenetwork.v1.Router.encode(message.routers[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.nextPageToken != null && Object.hasOwnProperty.call(message, "nextPageToken")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.nextPageToken); + if (message.unreachable != null && message.unreachable.length) + for (var i = 0; i < message.unreachable.length; ++i) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.unreachable[i]); + return writer; + }; + + /** + * Encodes the specified ListRoutersResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.ListRoutersResponse.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListRoutersResponse + * @static + * @param {google.cloud.edgenetwork.v1.IListRoutersResponse} message ListRoutersResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListRoutersResponse.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ListRoutersResponse message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.ListRoutersResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.ListRoutersResponse} ListRoutersResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListRoutersResponse.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.ListRoutersResponse(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + if (!(message.routers && message.routers.length)) + message.routers = []; + message.routers.push($root.google.cloud.edgenetwork.v1.Router.decode(reader, reader.uint32())); + break; + } + case 2: { + message.nextPageToken = reader.string(); + break; + } + case 3: { + if (!(message.unreachable && message.unreachable.length)) + message.unreachable = []; + message.unreachable.push(reader.string()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ListRoutersResponse message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.ListRoutersResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.ListRoutersResponse} ListRoutersResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListRoutersResponse.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ListRoutersResponse message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.ListRoutersResponse + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ListRoutersResponse.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.routers != null && message.hasOwnProperty("routers")) { + if (!Array.isArray(message.routers)) + return "routers: array expected"; + for (var i = 0; i < message.routers.length; ++i) { + var error = $root.google.cloud.edgenetwork.v1.Router.verify(message.routers[i]); + if (error) + return "routers." + error; + } + } + if (message.nextPageToken != null && message.hasOwnProperty("nextPageToken")) + if (!$util.isString(message.nextPageToken)) + return "nextPageToken: string expected"; + if (message.unreachable != null && message.hasOwnProperty("unreachable")) { + if (!Array.isArray(message.unreachable)) + return "unreachable: array expected"; + for (var i = 0; i < message.unreachable.length; ++i) + if (!$util.isString(message.unreachable[i])) + return "unreachable: string[] expected"; + } + return null; + }; + + /** + * Creates a ListRoutersResponse message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.ListRoutersResponse + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.ListRoutersResponse} ListRoutersResponse + */ + ListRoutersResponse.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.ListRoutersResponse) + return object; + var message = new $root.google.cloud.edgenetwork.v1.ListRoutersResponse(); + if (object.routers) { + if (!Array.isArray(object.routers)) + throw TypeError(".google.cloud.edgenetwork.v1.ListRoutersResponse.routers: array expected"); + message.routers = []; + for (var i = 0; i < object.routers.length; ++i) { + if (typeof object.routers[i] !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.ListRoutersResponse.routers: object expected"); + message.routers[i] = $root.google.cloud.edgenetwork.v1.Router.fromObject(object.routers[i]); + } + } + if (object.nextPageToken != null) + message.nextPageToken = String(object.nextPageToken); + if (object.unreachable) { + if (!Array.isArray(object.unreachable)) + throw TypeError(".google.cloud.edgenetwork.v1.ListRoutersResponse.unreachable: array expected"); + message.unreachable = []; + for (var i = 0; i < object.unreachable.length; ++i) + message.unreachable[i] = String(object.unreachable[i]); + } + return message; + }; + + /** + * Creates a plain object from a ListRoutersResponse message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.ListRoutersResponse + * @static + * @param {google.cloud.edgenetwork.v1.ListRoutersResponse} message ListRoutersResponse + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ListRoutersResponse.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.routers = []; + object.unreachable = []; + } + if (options.defaults) + object.nextPageToken = ""; + if (message.routers && message.routers.length) { + object.routers = []; + for (var j = 0; j < message.routers.length; ++j) + object.routers[j] = $root.google.cloud.edgenetwork.v1.Router.toObject(message.routers[j], options); + } + if (message.nextPageToken != null && message.hasOwnProperty("nextPageToken")) + object.nextPageToken = message.nextPageToken; + if (message.unreachable && message.unreachable.length) { + object.unreachable = []; + for (var j = 0; j < message.unreachable.length; ++j) + object.unreachable[j] = message.unreachable[j]; + } + return object; + }; + + /** + * Converts this ListRoutersResponse to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.ListRoutersResponse + * @instance + * @returns {Object.} JSON object + */ + ListRoutersResponse.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ListRoutersResponse + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.ListRoutersResponse + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ListRoutersResponse.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.ListRoutersResponse"; + }; + + return ListRoutersResponse; + })(); + + v1.GetRouterRequest = (function() { + + /** + * Properties of a GetRouterRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IGetRouterRequest + * @property {string|null} [name] GetRouterRequest name + */ + + /** + * Constructs a new GetRouterRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a GetRouterRequest. + * @implements IGetRouterRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IGetRouterRequest=} [properties] Properties to set + */ + function GetRouterRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * GetRouterRequest name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.GetRouterRequest + * @instance + */ + GetRouterRequest.prototype.name = ""; + + /** + * Creates a new GetRouterRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.GetRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetRouterRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.GetRouterRequest} GetRouterRequest instance + */ + GetRouterRequest.create = function create(properties) { + return new GetRouterRequest(properties); + }; + + /** + * Encodes the specified GetRouterRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.GetRouterRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.GetRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetRouterRequest} message GetRouterRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GetRouterRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + return writer; + }; + + /** + * Encodes the specified GetRouterRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.GetRouterRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.GetRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.IGetRouterRequest} message GetRouterRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GetRouterRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a GetRouterRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.GetRouterRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.GetRouterRequest} GetRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GetRouterRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.GetRouterRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a GetRouterRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.GetRouterRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.GetRouterRequest} GetRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GetRouterRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a GetRouterRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.GetRouterRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + GetRouterRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + return null; + }; + + /** + * Creates a GetRouterRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.GetRouterRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.GetRouterRequest} GetRouterRequest + */ + GetRouterRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.GetRouterRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.GetRouterRequest(); + if (object.name != null) + message.name = String(object.name); + return message; + }; + + /** + * Creates a plain object from a GetRouterRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.GetRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.GetRouterRequest} message GetRouterRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + GetRouterRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.name = ""; + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + return object; + }; + + /** + * Converts this GetRouterRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.GetRouterRequest + * @instance + * @returns {Object.} JSON object + */ + GetRouterRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for GetRouterRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.GetRouterRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + GetRouterRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.GetRouterRequest"; + }; + + return GetRouterRequest; + })(); + + v1.CreateRouterRequest = (function() { + + /** + * Properties of a CreateRouterRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface ICreateRouterRequest + * @property {string|null} [parent] CreateRouterRequest parent + * @property {string|null} [routerId] CreateRouterRequest routerId + * @property {google.cloud.edgenetwork.v1.IRouter|null} [router] CreateRouterRequest router + * @property {string|null} [requestId] CreateRouterRequest requestId + */ + + /** + * Constructs a new CreateRouterRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a CreateRouterRequest. + * @implements ICreateRouterRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.ICreateRouterRequest=} [properties] Properties to set + */ + function CreateRouterRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * CreateRouterRequest parent. + * @member {string} parent + * @memberof google.cloud.edgenetwork.v1.CreateRouterRequest + * @instance + */ + CreateRouterRequest.prototype.parent = ""; + + /** + * CreateRouterRequest routerId. + * @member {string} routerId + * @memberof google.cloud.edgenetwork.v1.CreateRouterRequest + * @instance + */ + CreateRouterRequest.prototype.routerId = ""; + + /** + * CreateRouterRequest router. + * @member {google.cloud.edgenetwork.v1.IRouter|null|undefined} router + * @memberof google.cloud.edgenetwork.v1.CreateRouterRequest + * @instance + */ + CreateRouterRequest.prototype.router = null; + + /** + * CreateRouterRequest requestId. + * @member {string} requestId + * @memberof google.cloud.edgenetwork.v1.CreateRouterRequest + * @instance + */ + CreateRouterRequest.prototype.requestId = ""; + + /** + * Creates a new CreateRouterRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.CreateRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.ICreateRouterRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.CreateRouterRequest} CreateRouterRequest instance + */ + CreateRouterRequest.create = function create(properties) { + return new CreateRouterRequest(properties); + }; + + /** + * Encodes the specified CreateRouterRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.CreateRouterRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.CreateRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.ICreateRouterRequest} message CreateRouterRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + CreateRouterRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.parent != null && Object.hasOwnProperty.call(message, "parent")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.parent); + if (message.routerId != null && Object.hasOwnProperty.call(message, "routerId")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.routerId); + if (message.router != null && Object.hasOwnProperty.call(message, "router")) + $root.google.cloud.edgenetwork.v1.Router.encode(message.router, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + if (message.requestId != null && Object.hasOwnProperty.call(message, "requestId")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.requestId); + return writer; + }; + + /** + * Encodes the specified CreateRouterRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.CreateRouterRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.CreateRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.ICreateRouterRequest} message CreateRouterRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + CreateRouterRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a CreateRouterRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.CreateRouterRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.CreateRouterRequest} CreateRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + CreateRouterRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.CreateRouterRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.parent = reader.string(); + break; + } + case 2: { + message.routerId = reader.string(); + break; + } + case 3: { + message.router = $root.google.cloud.edgenetwork.v1.Router.decode(reader, reader.uint32()); + break; + } + case 4: { + message.requestId = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a CreateRouterRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.CreateRouterRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.CreateRouterRequest} CreateRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + CreateRouterRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a CreateRouterRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.CreateRouterRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + CreateRouterRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.parent != null && message.hasOwnProperty("parent")) + if (!$util.isString(message.parent)) + return "parent: string expected"; + if (message.routerId != null && message.hasOwnProperty("routerId")) + if (!$util.isString(message.routerId)) + return "routerId: string expected"; + if (message.router != null && message.hasOwnProperty("router")) { + var error = $root.google.cloud.edgenetwork.v1.Router.verify(message.router); + if (error) + return "router." + error; + } + if (message.requestId != null && message.hasOwnProperty("requestId")) + if (!$util.isString(message.requestId)) + return "requestId: string expected"; + return null; + }; + + /** + * Creates a CreateRouterRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.CreateRouterRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.CreateRouterRequest} CreateRouterRequest + */ + CreateRouterRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.CreateRouterRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.CreateRouterRequest(); + if (object.parent != null) + message.parent = String(object.parent); + if (object.routerId != null) + message.routerId = String(object.routerId); + if (object.router != null) { + if (typeof object.router !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.CreateRouterRequest.router: object expected"); + message.router = $root.google.cloud.edgenetwork.v1.Router.fromObject(object.router); + } + if (object.requestId != null) + message.requestId = String(object.requestId); + return message; + }; + + /** + * Creates a plain object from a CreateRouterRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.CreateRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.CreateRouterRequest} message CreateRouterRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + CreateRouterRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.parent = ""; + object.routerId = ""; + object.router = null; + object.requestId = ""; + } + if (message.parent != null && message.hasOwnProperty("parent")) + object.parent = message.parent; + if (message.routerId != null && message.hasOwnProperty("routerId")) + object.routerId = message.routerId; + if (message.router != null && message.hasOwnProperty("router")) + object.router = $root.google.cloud.edgenetwork.v1.Router.toObject(message.router, options); + if (message.requestId != null && message.hasOwnProperty("requestId")) + object.requestId = message.requestId; + return object; + }; + + /** + * Converts this CreateRouterRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.CreateRouterRequest + * @instance + * @returns {Object.} JSON object + */ + CreateRouterRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for CreateRouterRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.CreateRouterRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + CreateRouterRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.CreateRouterRequest"; + }; + + return CreateRouterRequest; + })(); + + v1.UpdateRouterRequest = (function() { + + /** + * Properties of an UpdateRouterRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IUpdateRouterRequest + * @property {google.protobuf.IFieldMask|null} [updateMask] UpdateRouterRequest updateMask + * @property {google.cloud.edgenetwork.v1.IRouter|null} [router] UpdateRouterRequest router + * @property {string|null} [requestId] UpdateRouterRequest requestId + */ + + /** + * Constructs a new UpdateRouterRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents an UpdateRouterRequest. + * @implements IUpdateRouterRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IUpdateRouterRequest=} [properties] Properties to set + */ + function UpdateRouterRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * UpdateRouterRequest updateMask. + * @member {google.protobuf.IFieldMask|null|undefined} updateMask + * @memberof google.cloud.edgenetwork.v1.UpdateRouterRequest + * @instance + */ + UpdateRouterRequest.prototype.updateMask = null; + + /** + * UpdateRouterRequest router. + * @member {google.cloud.edgenetwork.v1.IRouter|null|undefined} router + * @memberof google.cloud.edgenetwork.v1.UpdateRouterRequest + * @instance + */ + UpdateRouterRequest.prototype.router = null; + + /** + * UpdateRouterRequest requestId. + * @member {string} requestId + * @memberof google.cloud.edgenetwork.v1.UpdateRouterRequest + * @instance + */ + UpdateRouterRequest.prototype.requestId = ""; + + /** + * Creates a new UpdateRouterRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.UpdateRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.IUpdateRouterRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.UpdateRouterRequest} UpdateRouterRequest instance + */ + UpdateRouterRequest.create = function create(properties) { + return new UpdateRouterRequest(properties); + }; + + /** + * Encodes the specified UpdateRouterRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.UpdateRouterRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.UpdateRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.IUpdateRouterRequest} message UpdateRouterRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + UpdateRouterRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.updateMask != null && Object.hasOwnProperty.call(message, "updateMask")) + $root.google.protobuf.FieldMask.encode(message.updateMask, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.router != null && Object.hasOwnProperty.call(message, "router")) + $root.google.cloud.edgenetwork.v1.Router.encode(message.router, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.requestId != null && Object.hasOwnProperty.call(message, "requestId")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.requestId); + return writer; + }; + + /** + * Encodes the specified UpdateRouterRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.UpdateRouterRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.UpdateRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.IUpdateRouterRequest} message UpdateRouterRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + UpdateRouterRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an UpdateRouterRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.UpdateRouterRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.UpdateRouterRequest} UpdateRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + UpdateRouterRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.UpdateRouterRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.updateMask = $root.google.protobuf.FieldMask.decode(reader, reader.uint32()); + break; + } + case 2: { + message.router = $root.google.cloud.edgenetwork.v1.Router.decode(reader, reader.uint32()); + break; + } + case 3: { + message.requestId = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an UpdateRouterRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.UpdateRouterRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.UpdateRouterRequest} UpdateRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + UpdateRouterRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an UpdateRouterRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.UpdateRouterRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + UpdateRouterRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.updateMask != null && message.hasOwnProperty("updateMask")) { + var error = $root.google.protobuf.FieldMask.verify(message.updateMask); + if (error) + return "updateMask." + error; + } + if (message.router != null && message.hasOwnProperty("router")) { + var error = $root.google.cloud.edgenetwork.v1.Router.verify(message.router); + if (error) + return "router." + error; + } + if (message.requestId != null && message.hasOwnProperty("requestId")) + if (!$util.isString(message.requestId)) + return "requestId: string expected"; + return null; + }; + + /** + * Creates an UpdateRouterRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.UpdateRouterRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.UpdateRouterRequest} UpdateRouterRequest + */ + UpdateRouterRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.UpdateRouterRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.UpdateRouterRequest(); + if (object.updateMask != null) { + if (typeof object.updateMask !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.UpdateRouterRequest.updateMask: object expected"); + message.updateMask = $root.google.protobuf.FieldMask.fromObject(object.updateMask); + } + if (object.router != null) { + if (typeof object.router !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.UpdateRouterRequest.router: object expected"); + message.router = $root.google.cloud.edgenetwork.v1.Router.fromObject(object.router); + } + if (object.requestId != null) + message.requestId = String(object.requestId); + return message; + }; + + /** + * Creates a plain object from an UpdateRouterRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.UpdateRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.UpdateRouterRequest} message UpdateRouterRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + UpdateRouterRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.updateMask = null; + object.router = null; + object.requestId = ""; + } + if (message.updateMask != null && message.hasOwnProperty("updateMask")) + object.updateMask = $root.google.protobuf.FieldMask.toObject(message.updateMask, options); + if (message.router != null && message.hasOwnProperty("router")) + object.router = $root.google.cloud.edgenetwork.v1.Router.toObject(message.router, options); + if (message.requestId != null && message.hasOwnProperty("requestId")) + object.requestId = message.requestId; + return object; + }; + + /** + * Converts this UpdateRouterRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.UpdateRouterRequest + * @instance + * @returns {Object.} JSON object + */ + UpdateRouterRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for UpdateRouterRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.UpdateRouterRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + UpdateRouterRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.UpdateRouterRequest"; + }; + + return UpdateRouterRequest; + })(); + + v1.DeleteRouterRequest = (function() { + + /** + * Properties of a DeleteRouterRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IDeleteRouterRequest + * @property {string|null} [name] DeleteRouterRequest name + * @property {string|null} [requestId] DeleteRouterRequest requestId + */ + + /** + * Constructs a new DeleteRouterRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a DeleteRouterRequest. + * @implements IDeleteRouterRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IDeleteRouterRequest=} [properties] Properties to set + */ + function DeleteRouterRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * DeleteRouterRequest name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.DeleteRouterRequest + * @instance + */ + DeleteRouterRequest.prototype.name = ""; + + /** + * DeleteRouterRequest requestId. + * @member {string} requestId + * @memberof google.cloud.edgenetwork.v1.DeleteRouterRequest + * @instance + */ + DeleteRouterRequest.prototype.requestId = ""; + + /** + * Creates a new DeleteRouterRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.DeleteRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDeleteRouterRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.DeleteRouterRequest} DeleteRouterRequest instance + */ + DeleteRouterRequest.create = function create(properties) { + return new DeleteRouterRequest(properties); + }; + + /** + * Encodes the specified DeleteRouterRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.DeleteRouterRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.DeleteRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDeleteRouterRequest} message DeleteRouterRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DeleteRouterRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.requestId != null && Object.hasOwnProperty.call(message, "requestId")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.requestId); + return writer; + }; + + /** + * Encodes the specified DeleteRouterRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DeleteRouterRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.DeleteRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDeleteRouterRequest} message DeleteRouterRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DeleteRouterRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a DeleteRouterRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.DeleteRouterRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.DeleteRouterRequest} DeleteRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DeleteRouterRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.DeleteRouterRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.requestId = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a DeleteRouterRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.DeleteRouterRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.DeleteRouterRequest} DeleteRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DeleteRouterRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a DeleteRouterRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.DeleteRouterRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + DeleteRouterRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.requestId != null && message.hasOwnProperty("requestId")) + if (!$util.isString(message.requestId)) + return "requestId: string expected"; + return null; + }; + + /** + * Creates a DeleteRouterRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.DeleteRouterRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.DeleteRouterRequest} DeleteRouterRequest + */ + DeleteRouterRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.DeleteRouterRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.DeleteRouterRequest(); + if (object.name != null) + message.name = String(object.name); + if (object.requestId != null) + message.requestId = String(object.requestId); + return message; + }; + + /** + * Creates a plain object from a DeleteRouterRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.DeleteRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.DeleteRouterRequest} message DeleteRouterRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + DeleteRouterRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.name = ""; + object.requestId = ""; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.requestId != null && message.hasOwnProperty("requestId")) + object.requestId = message.requestId; + return object; + }; + + /** + * Converts this DeleteRouterRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.DeleteRouterRequest + * @instance + * @returns {Object.} JSON object + */ + DeleteRouterRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for DeleteRouterRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.DeleteRouterRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + DeleteRouterRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.DeleteRouterRequest"; + }; + + return DeleteRouterRequest; + })(); + + v1.OperationMetadata = (function() { + + /** + * Properties of an OperationMetadata. + * @memberof google.cloud.edgenetwork.v1 + * @interface IOperationMetadata + * @property {google.protobuf.ITimestamp|null} [createTime] OperationMetadata createTime + * @property {google.protobuf.ITimestamp|null} [endTime] OperationMetadata endTime + * @property {string|null} [target] OperationMetadata target + * @property {string|null} [verb] OperationMetadata verb + * @property {string|null} [statusMessage] OperationMetadata statusMessage + * @property {boolean|null} [requestedCancellation] OperationMetadata requestedCancellation + * @property {string|null} [apiVersion] OperationMetadata apiVersion + */ + + /** + * Constructs a new OperationMetadata. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents an OperationMetadata. + * @implements IOperationMetadata + * @constructor + * @param {google.cloud.edgenetwork.v1.IOperationMetadata=} [properties] Properties to set + */ + function OperationMetadata(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * OperationMetadata createTime. + * @member {google.protobuf.ITimestamp|null|undefined} createTime + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @instance + */ + OperationMetadata.prototype.createTime = null; + + /** + * OperationMetadata endTime. + * @member {google.protobuf.ITimestamp|null|undefined} endTime + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @instance + */ + OperationMetadata.prototype.endTime = null; + + /** + * OperationMetadata target. + * @member {string} target + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @instance + */ + OperationMetadata.prototype.target = ""; + + /** + * OperationMetadata verb. + * @member {string} verb + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @instance + */ + OperationMetadata.prototype.verb = ""; + + /** + * OperationMetadata statusMessage. + * @member {string} statusMessage + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @instance + */ + OperationMetadata.prototype.statusMessage = ""; + + /** + * OperationMetadata requestedCancellation. + * @member {boolean} requestedCancellation + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @instance + */ + OperationMetadata.prototype.requestedCancellation = false; + + /** + * OperationMetadata apiVersion. + * @member {string} apiVersion + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @instance + */ + OperationMetadata.prototype.apiVersion = ""; + + /** + * Creates a new OperationMetadata instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @static + * @param {google.cloud.edgenetwork.v1.IOperationMetadata=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.OperationMetadata} OperationMetadata instance + */ + OperationMetadata.create = function create(properties) { + return new OperationMetadata(properties); + }; + + /** + * Encodes the specified OperationMetadata message. Does not implicitly {@link google.cloud.edgenetwork.v1.OperationMetadata.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @static + * @param {google.cloud.edgenetwork.v1.IOperationMetadata} message OperationMetadata message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + OperationMetadata.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.createTime != null && Object.hasOwnProperty.call(message, "createTime")) + $root.google.protobuf.Timestamp.encode(message.createTime, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.endTime != null && Object.hasOwnProperty.call(message, "endTime")) + $root.google.protobuf.Timestamp.encode(message.endTime, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.target != null && Object.hasOwnProperty.call(message, "target")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.target); + if (message.verb != null && Object.hasOwnProperty.call(message, "verb")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.verb); + if (message.statusMessage != null && Object.hasOwnProperty.call(message, "statusMessage")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.statusMessage); + if (message.requestedCancellation != null && Object.hasOwnProperty.call(message, "requestedCancellation")) + writer.uint32(/* id 6, wireType 0 =*/48).bool(message.requestedCancellation); + if (message.apiVersion != null && Object.hasOwnProperty.call(message, "apiVersion")) + writer.uint32(/* id 7, wireType 2 =*/58).string(message.apiVersion); + return writer; + }; + + /** + * Encodes the specified OperationMetadata message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.OperationMetadata.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @static + * @param {google.cloud.edgenetwork.v1.IOperationMetadata} message OperationMetadata message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + OperationMetadata.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an OperationMetadata message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.OperationMetadata} OperationMetadata + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + OperationMetadata.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.OperationMetadata(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.createTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 2: { + message.endTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 3: { + message.target = reader.string(); + break; + } + case 4: { + message.verb = reader.string(); + break; + } + case 5: { + message.statusMessage = reader.string(); + break; + } + case 6: { + message.requestedCancellation = reader.bool(); + break; + } + case 7: { + message.apiVersion = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an OperationMetadata message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.OperationMetadata} OperationMetadata + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + OperationMetadata.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an OperationMetadata message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + OperationMetadata.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.createTime != null && message.hasOwnProperty("createTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.createTime); + if (error) + return "createTime." + error; + } + if (message.endTime != null && message.hasOwnProperty("endTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.endTime); + if (error) + return "endTime." + error; + } + if (message.target != null && message.hasOwnProperty("target")) + if (!$util.isString(message.target)) + return "target: string expected"; + if (message.verb != null && message.hasOwnProperty("verb")) + if (!$util.isString(message.verb)) + return "verb: string expected"; + if (message.statusMessage != null && message.hasOwnProperty("statusMessage")) + if (!$util.isString(message.statusMessage)) + return "statusMessage: string expected"; + if (message.requestedCancellation != null && message.hasOwnProperty("requestedCancellation")) + if (typeof message.requestedCancellation !== "boolean") + return "requestedCancellation: boolean expected"; + if (message.apiVersion != null && message.hasOwnProperty("apiVersion")) + if (!$util.isString(message.apiVersion)) + return "apiVersion: string expected"; + return null; + }; + + /** + * Creates an OperationMetadata message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.OperationMetadata} OperationMetadata + */ + OperationMetadata.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.OperationMetadata) + return object; + var message = new $root.google.cloud.edgenetwork.v1.OperationMetadata(); + if (object.createTime != null) { + if (typeof object.createTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.OperationMetadata.createTime: object expected"); + message.createTime = $root.google.protobuf.Timestamp.fromObject(object.createTime); + } + if (object.endTime != null) { + if (typeof object.endTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.OperationMetadata.endTime: object expected"); + message.endTime = $root.google.protobuf.Timestamp.fromObject(object.endTime); + } + if (object.target != null) + message.target = String(object.target); + if (object.verb != null) + message.verb = String(object.verb); + if (object.statusMessage != null) + message.statusMessage = String(object.statusMessage); + if (object.requestedCancellation != null) + message.requestedCancellation = Boolean(object.requestedCancellation); + if (object.apiVersion != null) + message.apiVersion = String(object.apiVersion); + return message; + }; + + /** + * Creates a plain object from an OperationMetadata message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @static + * @param {google.cloud.edgenetwork.v1.OperationMetadata} message OperationMetadata + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + OperationMetadata.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.createTime = null; + object.endTime = null; + object.target = ""; + object.verb = ""; + object.statusMessage = ""; + object.requestedCancellation = false; + object.apiVersion = ""; + } + if (message.createTime != null && message.hasOwnProperty("createTime")) + object.createTime = $root.google.protobuf.Timestamp.toObject(message.createTime, options); + if (message.endTime != null && message.hasOwnProperty("endTime")) + object.endTime = $root.google.protobuf.Timestamp.toObject(message.endTime, options); + if (message.target != null && message.hasOwnProperty("target")) + object.target = message.target; + if (message.verb != null && message.hasOwnProperty("verb")) + object.verb = message.verb; + if (message.statusMessage != null && message.hasOwnProperty("statusMessage")) + object.statusMessage = message.statusMessage; + if (message.requestedCancellation != null && message.hasOwnProperty("requestedCancellation")) + object.requestedCancellation = message.requestedCancellation; + if (message.apiVersion != null && message.hasOwnProperty("apiVersion")) + object.apiVersion = message.apiVersion; + return object; + }; + + /** + * Converts this OperationMetadata to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @instance + * @returns {Object.} JSON object + */ + OperationMetadata.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for OperationMetadata + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.OperationMetadata + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + OperationMetadata.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.OperationMetadata"; + }; + + return OperationMetadata; + })(); + + v1.DiagnoseNetworkRequest = (function() { + + /** + * Properties of a DiagnoseNetworkRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IDiagnoseNetworkRequest + * @property {string|null} [name] DiagnoseNetworkRequest name + */ + + /** + * Constructs a new DiagnoseNetworkRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a DiagnoseNetworkRequest. + * @implements IDiagnoseNetworkRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest=} [properties] Properties to set + */ + function DiagnoseNetworkRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * DiagnoseNetworkRequest name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkRequest + * @instance + */ + DiagnoseNetworkRequest.prototype.name = ""; + + /** + * Creates a new DiagnoseNetworkRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.DiagnoseNetworkRequest} DiagnoseNetworkRequest instance + */ + DiagnoseNetworkRequest.create = function create(properties) { + return new DiagnoseNetworkRequest(properties); + }; + + /** + * Encodes the specified DiagnoseNetworkRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseNetworkRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest} message DiagnoseNetworkRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DiagnoseNetworkRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + return writer; + }; + + /** + * Encodes the specified DiagnoseNetworkRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseNetworkRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest} message DiagnoseNetworkRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DiagnoseNetworkRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a DiagnoseNetworkRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.DiagnoseNetworkRequest} DiagnoseNetworkRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DiagnoseNetworkRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a DiagnoseNetworkRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.DiagnoseNetworkRequest} DiagnoseNetworkRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DiagnoseNetworkRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a DiagnoseNetworkRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + DiagnoseNetworkRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + return null; + }; + + /** + * Creates a DiagnoseNetworkRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.DiagnoseNetworkRequest} DiagnoseNetworkRequest + */ + DiagnoseNetworkRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest(); + if (object.name != null) + message.name = String(object.name); + return message; + }; + + /** + * Creates a plain object from a DiagnoseNetworkRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkRequest + * @static + * @param {google.cloud.edgenetwork.v1.DiagnoseNetworkRequest} message DiagnoseNetworkRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + DiagnoseNetworkRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.name = ""; + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + return object; + }; + + /** + * Converts this DiagnoseNetworkRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkRequest + * @instance + * @returns {Object.} JSON object + */ + DiagnoseNetworkRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for DiagnoseNetworkRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + DiagnoseNetworkRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.DiagnoseNetworkRequest"; + }; + + return DiagnoseNetworkRequest; + })(); + + v1.DiagnoseNetworkResponse = (function() { + + /** + * Properties of a DiagnoseNetworkResponse. + * @memberof google.cloud.edgenetwork.v1 + * @interface IDiagnoseNetworkResponse + * @property {google.protobuf.ITimestamp|null} [updateTime] DiagnoseNetworkResponse updateTime + * @property {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.INetworkStatus|null} [result] DiagnoseNetworkResponse result + */ + + /** + * Constructs a new DiagnoseNetworkResponse. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a DiagnoseNetworkResponse. + * @implements IDiagnoseNetworkResponse + * @constructor + * @param {google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse=} [properties] Properties to set + */ + function DiagnoseNetworkResponse(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * DiagnoseNetworkResponse updateTime. + * @member {google.protobuf.ITimestamp|null|undefined} updateTime + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse + * @instance + */ + DiagnoseNetworkResponse.prototype.updateTime = null; + + /** + * DiagnoseNetworkResponse result. + * @member {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.INetworkStatus|null|undefined} result + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse + * @instance + */ + DiagnoseNetworkResponse.prototype.result = null; + + /** + * Creates a new DiagnoseNetworkResponse instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse} DiagnoseNetworkResponse instance + */ + DiagnoseNetworkResponse.create = function create(properties) { + return new DiagnoseNetworkResponse(properties); + }; + + /** + * Encodes the specified DiagnoseNetworkResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse} message DiagnoseNetworkResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DiagnoseNetworkResponse.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.updateTime != null && Object.hasOwnProperty.call(message, "updateTime")) + $root.google.protobuf.Timestamp.encode(message.updateTime, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.result != null && Object.hasOwnProperty.call(message, "result")) + $root.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus.encode(message.result, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified DiagnoseNetworkResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse} message DiagnoseNetworkResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DiagnoseNetworkResponse.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a DiagnoseNetworkResponse message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse} DiagnoseNetworkResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DiagnoseNetworkResponse.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.updateTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 2: { + message.result = $root.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a DiagnoseNetworkResponse message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse} DiagnoseNetworkResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DiagnoseNetworkResponse.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a DiagnoseNetworkResponse message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + DiagnoseNetworkResponse.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.updateTime != null && message.hasOwnProperty("updateTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.updateTime); + if (error) + return "updateTime." + error; + } + if (message.result != null && message.hasOwnProperty("result")) { + var error = $root.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus.verify(message.result); + if (error) + return "result." + error; + } + return null; + }; + + /** + * Creates a DiagnoseNetworkResponse message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse} DiagnoseNetworkResponse + */ + DiagnoseNetworkResponse.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse) + return object; + var message = new $root.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse(); + if (object.updateTime != null) { + if (typeof object.updateTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.updateTime: object expected"); + message.updateTime = $root.google.protobuf.Timestamp.fromObject(object.updateTime); + } + if (object.result != null) { + if (typeof object.result !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.result: object expected"); + message.result = $root.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus.fromObject(object.result); + } + return message; + }; + + /** + * Creates a plain object from a DiagnoseNetworkResponse message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse + * @static + * @param {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse} message DiagnoseNetworkResponse + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + DiagnoseNetworkResponse.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.updateTime = null; + object.result = null; + } + if (message.updateTime != null && message.hasOwnProperty("updateTime")) + object.updateTime = $root.google.protobuf.Timestamp.toObject(message.updateTime, options); + if (message.result != null && message.hasOwnProperty("result")) + object.result = $root.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus.toObject(message.result, options); + return object; + }; + + /** + * Converts this DiagnoseNetworkResponse to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse + * @instance + * @returns {Object.} JSON object + */ + DiagnoseNetworkResponse.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for DiagnoseNetworkResponse + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + DiagnoseNetworkResponse.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.DiagnoseNetworkResponse"; + }; + + DiagnoseNetworkResponse.NetworkStatus = (function() { + + /** + * Properties of a NetworkStatus. + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse + * @interface INetworkStatus + * @property {Array.|null} [subnetStatus] NetworkStatus subnetStatus + */ + + /** + * Constructs a new NetworkStatus. + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse + * @classdesc Represents a NetworkStatus. + * @implements INetworkStatus + * @constructor + * @param {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.INetworkStatus=} [properties] Properties to set + */ + function NetworkStatus(properties) { + this.subnetStatus = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * NetworkStatus subnetStatus. + * @member {Array.} subnetStatus + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus + * @instance + */ + NetworkStatus.prototype.subnetStatus = $util.emptyArray; + + /** + * Creates a new NetworkStatus instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus + * @static + * @param {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.INetworkStatus=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus} NetworkStatus instance + */ + NetworkStatus.create = function create(properties) { + return new NetworkStatus(properties); + }; + + /** + * Encodes the specified NetworkStatus message. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus + * @static + * @param {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.INetworkStatus} message NetworkStatus message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + NetworkStatus.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.subnetStatus != null && message.subnetStatus.length) + for (var i = 0; i < message.subnetStatus.length; ++i) + $root.google.cloud.edgenetwork.v1.SubnetStatus.encode(message.subnetStatus[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified NetworkStatus message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus + * @static + * @param {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.INetworkStatus} message NetworkStatus message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + NetworkStatus.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a NetworkStatus message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus} NetworkStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + NetworkStatus.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + if (!(message.subnetStatus && message.subnetStatus.length)) + message.subnetStatus = []; + message.subnetStatus.push($root.google.cloud.edgenetwork.v1.SubnetStatus.decode(reader, reader.uint32())); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a NetworkStatus message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus} NetworkStatus + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + NetworkStatus.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a NetworkStatus message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + NetworkStatus.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.subnetStatus != null && message.hasOwnProperty("subnetStatus")) { + if (!Array.isArray(message.subnetStatus)) + return "subnetStatus: array expected"; + for (var i = 0; i < message.subnetStatus.length; ++i) { + var error = $root.google.cloud.edgenetwork.v1.SubnetStatus.verify(message.subnetStatus[i]); + if (error) + return "subnetStatus." + error; + } + } + return null; + }; + + /** + * Creates a NetworkStatus message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus} NetworkStatus + */ + NetworkStatus.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus) + return object; + var message = new $root.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus(); + if (object.subnetStatus) { + if (!Array.isArray(object.subnetStatus)) + throw TypeError(".google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus.subnetStatus: array expected"); + message.subnetStatus = []; + for (var i = 0; i < object.subnetStatus.length; ++i) { + if (typeof object.subnetStatus[i] !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus.subnetStatus: object expected"); + message.subnetStatus[i] = $root.google.cloud.edgenetwork.v1.SubnetStatus.fromObject(object.subnetStatus[i]); + } + } + return message; + }; + + /** + * Creates a plain object from a NetworkStatus message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus + * @static + * @param {google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus} message NetworkStatus + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + NetworkStatus.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.subnetStatus = []; + if (message.subnetStatus && message.subnetStatus.length) { + object.subnetStatus = []; + for (var j = 0; j < message.subnetStatus.length; ++j) + object.subnetStatus[j] = $root.google.cloud.edgenetwork.v1.SubnetStatus.toObject(message.subnetStatus[j], options); + } + return object; + }; + + /** + * Converts this NetworkStatus to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus + * @instance + * @returns {Object.} JSON object + */ + NetworkStatus.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for NetworkStatus + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + NetworkStatus.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.DiagnoseNetworkResponse.NetworkStatus"; + }; + + return NetworkStatus; + })(); + + return DiagnoseNetworkResponse; + })(); + + v1.DiagnoseInterconnectRequest = (function() { + + /** + * Properties of a DiagnoseInterconnectRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IDiagnoseInterconnectRequest + * @property {string|null} [name] DiagnoseInterconnectRequest name + */ + + /** + * Constructs a new DiagnoseInterconnectRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a DiagnoseInterconnectRequest. + * @implements IDiagnoseInterconnectRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest=} [properties] Properties to set + */ + function DiagnoseInterconnectRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * DiagnoseInterconnectRequest name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest + * @instance + */ + DiagnoseInterconnectRequest.prototype.name = ""; + + /** + * Creates a new DiagnoseInterconnectRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest} DiagnoseInterconnectRequest instance + */ + DiagnoseInterconnectRequest.create = function create(properties) { + return new DiagnoseInterconnectRequest(properties); + }; + + /** + * Encodes the specified DiagnoseInterconnectRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest} message DiagnoseInterconnectRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DiagnoseInterconnectRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + return writer; + }; + + /** + * Encodes the specified DiagnoseInterconnectRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest} message DiagnoseInterconnectRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DiagnoseInterconnectRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a DiagnoseInterconnectRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest} DiagnoseInterconnectRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DiagnoseInterconnectRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a DiagnoseInterconnectRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest} DiagnoseInterconnectRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DiagnoseInterconnectRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a DiagnoseInterconnectRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + DiagnoseInterconnectRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + return null; + }; + + /** + * Creates a DiagnoseInterconnectRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest} DiagnoseInterconnectRequest + */ + DiagnoseInterconnectRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest(); + if (object.name != null) + message.name = String(object.name); + return message; + }; + + /** + * Creates a plain object from a DiagnoseInterconnectRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest + * @static + * @param {google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest} message DiagnoseInterconnectRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + DiagnoseInterconnectRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.name = ""; + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + return object; + }; + + /** + * Converts this DiagnoseInterconnectRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest + * @instance + * @returns {Object.} JSON object + */ + DiagnoseInterconnectRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for DiagnoseInterconnectRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + DiagnoseInterconnectRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest"; + }; + + return DiagnoseInterconnectRequest; + })(); + + v1.DiagnoseInterconnectResponse = (function() { + + /** + * Properties of a DiagnoseInterconnectResponse. + * @memberof google.cloud.edgenetwork.v1 + * @interface IDiagnoseInterconnectResponse + * @property {google.protobuf.ITimestamp|null} [updateTime] DiagnoseInterconnectResponse updateTime + * @property {google.cloud.edgenetwork.v1.IInterconnectDiagnostics|null} [result] DiagnoseInterconnectResponse result + */ + + /** + * Constructs a new DiagnoseInterconnectResponse. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a DiagnoseInterconnectResponse. + * @implements IDiagnoseInterconnectResponse + * @constructor + * @param {google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse=} [properties] Properties to set + */ + function DiagnoseInterconnectResponse(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * DiagnoseInterconnectResponse updateTime. + * @member {google.protobuf.ITimestamp|null|undefined} updateTime + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse + * @instance + */ + DiagnoseInterconnectResponse.prototype.updateTime = null; + + /** + * DiagnoseInterconnectResponse result. + * @member {google.cloud.edgenetwork.v1.IInterconnectDiagnostics|null|undefined} result + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse + * @instance + */ + DiagnoseInterconnectResponse.prototype.result = null; + + /** + * Creates a new DiagnoseInterconnectResponse instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse} DiagnoseInterconnectResponse instance + */ + DiagnoseInterconnectResponse.create = function create(properties) { + return new DiagnoseInterconnectResponse(properties); + }; + + /** + * Encodes the specified DiagnoseInterconnectResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse} message DiagnoseInterconnectResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DiagnoseInterconnectResponse.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.updateTime != null && Object.hasOwnProperty.call(message, "updateTime")) + $root.google.protobuf.Timestamp.encode(message.updateTime, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.result != null && Object.hasOwnProperty.call(message, "result")) + $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.encode(message.result, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified DiagnoseInterconnectResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse} message DiagnoseInterconnectResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DiagnoseInterconnectResponse.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a DiagnoseInterconnectResponse message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse} DiagnoseInterconnectResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DiagnoseInterconnectResponse.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.updateTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 2: { + message.result = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a DiagnoseInterconnectResponse message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse} DiagnoseInterconnectResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DiagnoseInterconnectResponse.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a DiagnoseInterconnectResponse message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + DiagnoseInterconnectResponse.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.updateTime != null && message.hasOwnProperty("updateTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.updateTime); + if (error) + return "updateTime." + error; + } + if (message.result != null && message.hasOwnProperty("result")) { + var error = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.verify(message.result); + if (error) + return "result." + error; + } + return null; + }; + + /** + * Creates a DiagnoseInterconnectResponse message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse} DiagnoseInterconnectResponse + */ + DiagnoseInterconnectResponse.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse) + return object; + var message = new $root.google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse(); + if (object.updateTime != null) { + if (typeof object.updateTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse.updateTime: object expected"); + message.updateTime = $root.google.protobuf.Timestamp.fromObject(object.updateTime); + } + if (object.result != null) { + if (typeof object.result !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse.result: object expected"); + message.result = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.fromObject(object.result); + } + return message; + }; + + /** + * Creates a plain object from a DiagnoseInterconnectResponse message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse + * @static + * @param {google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse} message DiagnoseInterconnectResponse + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + DiagnoseInterconnectResponse.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.updateTime = null; + object.result = null; + } + if (message.updateTime != null && message.hasOwnProperty("updateTime")) + object.updateTime = $root.google.protobuf.Timestamp.toObject(message.updateTime, options); + if (message.result != null && message.hasOwnProperty("result")) + object.result = $root.google.cloud.edgenetwork.v1.InterconnectDiagnostics.toObject(message.result, options); + return object; + }; + + /** + * Converts this DiagnoseInterconnectResponse to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse + * @instance + * @returns {Object.} JSON object + */ + DiagnoseInterconnectResponse.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for DiagnoseInterconnectResponse + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + DiagnoseInterconnectResponse.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse"; + }; + + return DiagnoseInterconnectResponse; + })(); + + v1.DiagnoseRouterRequest = (function() { + + /** + * Properties of a DiagnoseRouterRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IDiagnoseRouterRequest + * @property {string|null} [name] DiagnoseRouterRequest name + */ + + /** + * Constructs a new DiagnoseRouterRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a DiagnoseRouterRequest. + * @implements IDiagnoseRouterRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IDiagnoseRouterRequest=} [properties] Properties to set + */ + function DiagnoseRouterRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * DiagnoseRouterRequest name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterRequest + * @instance + */ + DiagnoseRouterRequest.prototype.name = ""; + + /** + * Creates a new DiagnoseRouterRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseRouterRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.DiagnoseRouterRequest} DiagnoseRouterRequest instance + */ + DiagnoseRouterRequest.create = function create(properties) { + return new DiagnoseRouterRequest(properties); + }; + + /** + * Encodes the specified DiagnoseRouterRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseRouterRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseRouterRequest} message DiagnoseRouterRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DiagnoseRouterRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + return writer; + }; + + /** + * Encodes the specified DiagnoseRouterRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseRouterRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseRouterRequest} message DiagnoseRouterRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DiagnoseRouterRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a DiagnoseRouterRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.DiagnoseRouterRequest} DiagnoseRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DiagnoseRouterRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.DiagnoseRouterRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a DiagnoseRouterRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.DiagnoseRouterRequest} DiagnoseRouterRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DiagnoseRouterRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a DiagnoseRouterRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + DiagnoseRouterRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + return null; + }; + + /** + * Creates a DiagnoseRouterRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.DiagnoseRouterRequest} DiagnoseRouterRequest + */ + DiagnoseRouterRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.DiagnoseRouterRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.DiagnoseRouterRequest(); + if (object.name != null) + message.name = String(object.name); + return message; + }; + + /** + * Creates a plain object from a DiagnoseRouterRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterRequest + * @static + * @param {google.cloud.edgenetwork.v1.DiagnoseRouterRequest} message DiagnoseRouterRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + DiagnoseRouterRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.name = ""; + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + return object; + }; + + /** + * Converts this DiagnoseRouterRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterRequest + * @instance + * @returns {Object.} JSON object + */ + DiagnoseRouterRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for DiagnoseRouterRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + DiagnoseRouterRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.DiagnoseRouterRequest"; + }; + + return DiagnoseRouterRequest; + })(); + + v1.DiagnoseRouterResponse = (function() { + + /** + * Properties of a DiagnoseRouterResponse. + * @memberof google.cloud.edgenetwork.v1 + * @interface IDiagnoseRouterResponse + * @property {google.protobuf.ITimestamp|null} [updateTime] DiagnoseRouterResponse updateTime + * @property {google.cloud.edgenetwork.v1.IRouterStatus|null} [result] DiagnoseRouterResponse result + */ + + /** + * Constructs a new DiagnoseRouterResponse. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents a DiagnoseRouterResponse. + * @implements IDiagnoseRouterResponse + * @constructor + * @param {google.cloud.edgenetwork.v1.IDiagnoseRouterResponse=} [properties] Properties to set + */ + function DiagnoseRouterResponse(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * DiagnoseRouterResponse updateTime. + * @member {google.protobuf.ITimestamp|null|undefined} updateTime + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterResponse + * @instance + */ + DiagnoseRouterResponse.prototype.updateTime = null; + + /** + * DiagnoseRouterResponse result. + * @member {google.cloud.edgenetwork.v1.IRouterStatus|null|undefined} result + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterResponse + * @instance + */ + DiagnoseRouterResponse.prototype.result = null; + + /** + * Creates a new DiagnoseRouterResponse instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterResponse + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseRouterResponse=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.DiagnoseRouterResponse} DiagnoseRouterResponse instance + */ + DiagnoseRouterResponse.create = function create(properties) { + return new DiagnoseRouterResponse(properties); + }; + + /** + * Encodes the specified DiagnoseRouterResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseRouterResponse.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterResponse + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseRouterResponse} message DiagnoseRouterResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DiagnoseRouterResponse.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.updateTime != null && Object.hasOwnProperty.call(message, "updateTime")) + $root.google.protobuf.Timestamp.encode(message.updateTime, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.result != null && Object.hasOwnProperty.call(message, "result")) + $root.google.cloud.edgenetwork.v1.RouterStatus.encode(message.result, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified DiagnoseRouterResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.DiagnoseRouterResponse.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterResponse + * @static + * @param {google.cloud.edgenetwork.v1.IDiagnoseRouterResponse} message DiagnoseRouterResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DiagnoseRouterResponse.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a DiagnoseRouterResponse message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.DiagnoseRouterResponse} DiagnoseRouterResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DiagnoseRouterResponse.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.DiagnoseRouterResponse(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.updateTime = $root.google.protobuf.Timestamp.decode(reader, reader.uint32()); + break; + } + case 2: { + message.result = $root.google.cloud.edgenetwork.v1.RouterStatus.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a DiagnoseRouterResponse message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.DiagnoseRouterResponse} DiagnoseRouterResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DiagnoseRouterResponse.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a DiagnoseRouterResponse message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterResponse + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + DiagnoseRouterResponse.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.updateTime != null && message.hasOwnProperty("updateTime")) { + var error = $root.google.protobuf.Timestamp.verify(message.updateTime); + if (error) + return "updateTime." + error; + } + if (message.result != null && message.hasOwnProperty("result")) { + var error = $root.google.cloud.edgenetwork.v1.RouterStatus.verify(message.result); + if (error) + return "result." + error; + } + return null; + }; + + /** + * Creates a DiagnoseRouterResponse message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterResponse + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.DiagnoseRouterResponse} DiagnoseRouterResponse + */ + DiagnoseRouterResponse.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.DiagnoseRouterResponse) + return object; + var message = new $root.google.cloud.edgenetwork.v1.DiagnoseRouterResponse(); + if (object.updateTime != null) { + if (typeof object.updateTime !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.DiagnoseRouterResponse.updateTime: object expected"); + message.updateTime = $root.google.protobuf.Timestamp.fromObject(object.updateTime); + } + if (object.result != null) { + if (typeof object.result !== "object") + throw TypeError(".google.cloud.edgenetwork.v1.DiagnoseRouterResponse.result: object expected"); + message.result = $root.google.cloud.edgenetwork.v1.RouterStatus.fromObject(object.result); + } + return message; + }; + + /** + * Creates a plain object from a DiagnoseRouterResponse message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterResponse + * @static + * @param {google.cloud.edgenetwork.v1.DiagnoseRouterResponse} message DiagnoseRouterResponse + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + DiagnoseRouterResponse.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.updateTime = null; + object.result = null; + } + if (message.updateTime != null && message.hasOwnProperty("updateTime")) + object.updateTime = $root.google.protobuf.Timestamp.toObject(message.updateTime, options); + if (message.result != null && message.hasOwnProperty("result")) + object.result = $root.google.cloud.edgenetwork.v1.RouterStatus.toObject(message.result, options); + return object; + }; + + /** + * Converts this DiagnoseRouterResponse to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterResponse + * @instance + * @returns {Object.} JSON object + */ + DiagnoseRouterResponse.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for DiagnoseRouterResponse + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.DiagnoseRouterResponse + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + DiagnoseRouterResponse.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.DiagnoseRouterResponse"; + }; + + return DiagnoseRouterResponse; + })(); + + v1.InitializeZoneRequest = (function() { + + /** + * Properties of an InitializeZoneRequest. + * @memberof google.cloud.edgenetwork.v1 + * @interface IInitializeZoneRequest + * @property {string|null} [name] InitializeZoneRequest name + */ + + /** + * Constructs a new InitializeZoneRequest. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents an InitializeZoneRequest. + * @implements IInitializeZoneRequest + * @constructor + * @param {google.cloud.edgenetwork.v1.IInitializeZoneRequest=} [properties] Properties to set + */ + function InitializeZoneRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * InitializeZoneRequest name. + * @member {string} name + * @memberof google.cloud.edgenetwork.v1.InitializeZoneRequest + * @instance + */ + InitializeZoneRequest.prototype.name = ""; + + /** + * Creates a new InitializeZoneRequest instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.InitializeZoneRequest + * @static + * @param {google.cloud.edgenetwork.v1.IInitializeZoneRequest=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.InitializeZoneRequest} InitializeZoneRequest instance + */ + InitializeZoneRequest.create = function create(properties) { + return new InitializeZoneRequest(properties); + }; + + /** + * Encodes the specified InitializeZoneRequest message. Does not implicitly {@link google.cloud.edgenetwork.v1.InitializeZoneRequest.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.InitializeZoneRequest + * @static + * @param {google.cloud.edgenetwork.v1.IInitializeZoneRequest} message InitializeZoneRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + InitializeZoneRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + return writer; + }; + + /** + * Encodes the specified InitializeZoneRequest message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.InitializeZoneRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.InitializeZoneRequest + * @static + * @param {google.cloud.edgenetwork.v1.IInitializeZoneRequest} message InitializeZoneRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + InitializeZoneRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an InitializeZoneRequest message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.InitializeZoneRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.InitializeZoneRequest} InitializeZoneRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + InitializeZoneRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.InitializeZoneRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an InitializeZoneRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.InitializeZoneRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.InitializeZoneRequest} InitializeZoneRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + InitializeZoneRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an InitializeZoneRequest message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.InitializeZoneRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + InitializeZoneRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + return null; + }; + + /** + * Creates an InitializeZoneRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.InitializeZoneRequest + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.InitializeZoneRequest} InitializeZoneRequest + */ + InitializeZoneRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.InitializeZoneRequest) + return object; + var message = new $root.google.cloud.edgenetwork.v1.InitializeZoneRequest(); + if (object.name != null) + message.name = String(object.name); + return message; + }; + + /** + * Creates a plain object from an InitializeZoneRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.InitializeZoneRequest + * @static + * @param {google.cloud.edgenetwork.v1.InitializeZoneRequest} message InitializeZoneRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + InitializeZoneRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.name = ""; + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + return object; + }; + + /** + * Converts this InitializeZoneRequest to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.InitializeZoneRequest + * @instance + * @returns {Object.} JSON object + */ + InitializeZoneRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for InitializeZoneRequest + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.InitializeZoneRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + InitializeZoneRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.InitializeZoneRequest"; + }; + + return InitializeZoneRequest; + })(); + + v1.InitializeZoneResponse = (function() { + + /** + * Properties of an InitializeZoneResponse. + * @memberof google.cloud.edgenetwork.v1 + * @interface IInitializeZoneResponse + */ + + /** + * Constructs a new InitializeZoneResponse. + * @memberof google.cloud.edgenetwork.v1 + * @classdesc Represents an InitializeZoneResponse. + * @implements IInitializeZoneResponse + * @constructor + * @param {google.cloud.edgenetwork.v1.IInitializeZoneResponse=} [properties] Properties to set + */ + function InitializeZoneResponse(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Creates a new InitializeZoneResponse instance using the specified properties. + * @function create + * @memberof google.cloud.edgenetwork.v1.InitializeZoneResponse + * @static + * @param {google.cloud.edgenetwork.v1.IInitializeZoneResponse=} [properties] Properties to set + * @returns {google.cloud.edgenetwork.v1.InitializeZoneResponse} InitializeZoneResponse instance + */ + InitializeZoneResponse.create = function create(properties) { + return new InitializeZoneResponse(properties); + }; + + /** + * Encodes the specified InitializeZoneResponse message. Does not implicitly {@link google.cloud.edgenetwork.v1.InitializeZoneResponse.verify|verify} messages. + * @function encode + * @memberof google.cloud.edgenetwork.v1.InitializeZoneResponse + * @static + * @param {google.cloud.edgenetwork.v1.IInitializeZoneResponse} message InitializeZoneResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + InitializeZoneResponse.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + return writer; + }; + + /** + * Encodes the specified InitializeZoneResponse message, length delimited. Does not implicitly {@link google.cloud.edgenetwork.v1.InitializeZoneResponse.verify|verify} messages. + * @function encodeDelimited + * @memberof google.cloud.edgenetwork.v1.InitializeZoneResponse + * @static + * @param {google.cloud.edgenetwork.v1.IInitializeZoneResponse} message InitializeZoneResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + InitializeZoneResponse.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an InitializeZoneResponse message from the specified reader or buffer. + * @function decode + * @memberof google.cloud.edgenetwork.v1.InitializeZoneResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.cloud.edgenetwork.v1.InitializeZoneResponse} InitializeZoneResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + InitializeZoneResponse.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.cloud.edgenetwork.v1.InitializeZoneResponse(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an InitializeZoneResponse message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.cloud.edgenetwork.v1.InitializeZoneResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.cloud.edgenetwork.v1.InitializeZoneResponse} InitializeZoneResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + InitializeZoneResponse.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an InitializeZoneResponse message. + * @function verify + * @memberof google.cloud.edgenetwork.v1.InitializeZoneResponse + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + InitializeZoneResponse.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + return null; + }; + + /** + * Creates an InitializeZoneResponse message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.cloud.edgenetwork.v1.InitializeZoneResponse + * @static + * @param {Object.} object Plain object + * @returns {google.cloud.edgenetwork.v1.InitializeZoneResponse} InitializeZoneResponse + */ + InitializeZoneResponse.fromObject = function fromObject(object) { + if (object instanceof $root.google.cloud.edgenetwork.v1.InitializeZoneResponse) + return object; + return new $root.google.cloud.edgenetwork.v1.InitializeZoneResponse(); + }; + + /** + * Creates a plain object from an InitializeZoneResponse message. Also converts values to other types if specified. + * @function toObject + * @memberof google.cloud.edgenetwork.v1.InitializeZoneResponse + * @static + * @param {google.cloud.edgenetwork.v1.InitializeZoneResponse} message InitializeZoneResponse + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + InitializeZoneResponse.toObject = function toObject() { + return {}; + }; + + /** + * Converts this InitializeZoneResponse to JSON. + * @function toJSON + * @memberof google.cloud.edgenetwork.v1.InitializeZoneResponse + * @instance + * @returns {Object.} JSON object + */ + InitializeZoneResponse.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for InitializeZoneResponse + * @function getTypeUrl + * @memberof google.cloud.edgenetwork.v1.InitializeZoneResponse + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + InitializeZoneResponse.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.cloud.edgenetwork.v1.InitializeZoneResponse"; + }; + + return InitializeZoneResponse; + })(); + + return v1; + })(); + + return edgenetwork; + })(); + + return cloud; + })(); + + google.api = (function() { + + /** + * Namespace api. + * @memberof google + * @namespace + */ + var api = {}; + + /** + * FieldBehavior enum. + * @name google.api.FieldBehavior + * @enum {number} + * @property {number} FIELD_BEHAVIOR_UNSPECIFIED=0 FIELD_BEHAVIOR_UNSPECIFIED value + * @property {number} OPTIONAL=1 OPTIONAL value + * @property {number} REQUIRED=2 REQUIRED value + * @property {number} OUTPUT_ONLY=3 OUTPUT_ONLY value + * @property {number} INPUT_ONLY=4 INPUT_ONLY value + * @property {number} IMMUTABLE=5 IMMUTABLE value + * @property {number} UNORDERED_LIST=6 UNORDERED_LIST value + * @property {number} NON_EMPTY_DEFAULT=7 NON_EMPTY_DEFAULT value + */ + api.FieldBehavior = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "FIELD_BEHAVIOR_UNSPECIFIED"] = 0; + values[valuesById[1] = "OPTIONAL"] = 1; + values[valuesById[2] = "REQUIRED"] = 2; + values[valuesById[3] = "OUTPUT_ONLY"] = 3; + values[valuesById[4] = "INPUT_ONLY"] = 4; + values[valuesById[5] = "IMMUTABLE"] = 5; + values[valuesById[6] = "UNORDERED_LIST"] = 6; + values[valuesById[7] = "NON_EMPTY_DEFAULT"] = 7; + return values; + })(); + + api.ResourceDescriptor = (function() { + + /** + * Properties of a ResourceDescriptor. + * @memberof google.api + * @interface IResourceDescriptor + * @property {string|null} [type] ResourceDescriptor type + * @property {Array.|null} [pattern] ResourceDescriptor pattern + * @property {string|null} [nameField] ResourceDescriptor nameField + * @property {google.api.ResourceDescriptor.History|null} [history] ResourceDescriptor history + * @property {string|null} [plural] ResourceDescriptor plural + * @property {string|null} [singular] ResourceDescriptor singular + * @property {Array.|null} [style] ResourceDescriptor style + */ + + /** + * Constructs a new ResourceDescriptor. + * @memberof google.api + * @classdesc Represents a ResourceDescriptor. + * @implements IResourceDescriptor + * @constructor + * @param {google.api.IResourceDescriptor=} [properties] Properties to set + */ + function ResourceDescriptor(properties) { + this.pattern = []; + this.style = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ResourceDescriptor type. + * @member {string} type + * @memberof google.api.ResourceDescriptor + * @instance + */ + ResourceDescriptor.prototype.type = ""; + + /** + * ResourceDescriptor pattern. + * @member {Array.} pattern + * @memberof google.api.ResourceDescriptor + * @instance + */ + ResourceDescriptor.prototype.pattern = $util.emptyArray; + + /** + * ResourceDescriptor nameField. + * @member {string} nameField + * @memberof google.api.ResourceDescriptor + * @instance + */ + ResourceDescriptor.prototype.nameField = ""; + + /** + * ResourceDescriptor history. + * @member {google.api.ResourceDescriptor.History} history + * @memberof google.api.ResourceDescriptor + * @instance + */ + ResourceDescriptor.prototype.history = 0; + + /** + * ResourceDescriptor plural. + * @member {string} plural + * @memberof google.api.ResourceDescriptor + * @instance + */ + ResourceDescriptor.prototype.plural = ""; + + /** + * ResourceDescriptor singular. + * @member {string} singular + * @memberof google.api.ResourceDescriptor + * @instance + */ + ResourceDescriptor.prototype.singular = ""; + + /** + * ResourceDescriptor style. + * @member {Array.} style + * @memberof google.api.ResourceDescriptor + * @instance + */ + ResourceDescriptor.prototype.style = $util.emptyArray; + + /** + * Creates a new ResourceDescriptor instance using the specified properties. + * @function create + * @memberof google.api.ResourceDescriptor + * @static + * @param {google.api.IResourceDescriptor=} [properties] Properties to set + * @returns {google.api.ResourceDescriptor} ResourceDescriptor instance + */ + ResourceDescriptor.create = function create(properties) { + return new ResourceDescriptor(properties); + }; + + /** + * Encodes the specified ResourceDescriptor message. Does not implicitly {@link google.api.ResourceDescriptor.verify|verify} messages. + * @function encode + * @memberof google.api.ResourceDescriptor + * @static + * @param {google.api.IResourceDescriptor} message ResourceDescriptor message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ResourceDescriptor.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.type != null && Object.hasOwnProperty.call(message, "type")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.type); + if (message.pattern != null && message.pattern.length) + for (var i = 0; i < message.pattern.length; ++i) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.pattern[i]); + if (message.nameField != null && Object.hasOwnProperty.call(message, "nameField")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.nameField); + if (message.history != null && Object.hasOwnProperty.call(message, "history")) + writer.uint32(/* id 4, wireType 0 =*/32).int32(message.history); + if (message.plural != null && Object.hasOwnProperty.call(message, "plural")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.plural); + if (message.singular != null && Object.hasOwnProperty.call(message, "singular")) + writer.uint32(/* id 6, wireType 2 =*/50).string(message.singular); + if (message.style != null && message.style.length) { + writer.uint32(/* id 10, wireType 2 =*/82).fork(); + for (var i = 0; i < message.style.length; ++i) + writer.int32(message.style[i]); + writer.ldelim(); + } + return writer; + }; + + /** + * Encodes the specified ResourceDescriptor message, length delimited. Does not implicitly {@link google.api.ResourceDescriptor.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.ResourceDescriptor + * @static + * @param {google.api.IResourceDescriptor} message ResourceDescriptor message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ResourceDescriptor.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ResourceDescriptor message from the specified reader or buffer. + * @function decode + * @memberof google.api.ResourceDescriptor + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.ResourceDescriptor} ResourceDescriptor + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ResourceDescriptor.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.ResourceDescriptor(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.type = reader.string(); + break; + } + case 2: { + if (!(message.pattern && message.pattern.length)) + message.pattern = []; + message.pattern.push(reader.string()); + break; + } + case 3: { + message.nameField = reader.string(); + break; + } + case 4: { + message.history = reader.int32(); + break; + } + case 5: { + message.plural = reader.string(); + break; + } + case 6: { + message.singular = reader.string(); + break; + } + case 10: { + if (!(message.style && message.style.length)) + message.style = []; + if ((tag & 7) === 2) { + var end2 = reader.uint32() + reader.pos; + while (reader.pos < end2) + message.style.push(reader.int32()); + } else + message.style.push(reader.int32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ResourceDescriptor message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.ResourceDescriptor + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.ResourceDescriptor} ResourceDescriptor + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ResourceDescriptor.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ResourceDescriptor message. + * @function verify + * @memberof google.api.ResourceDescriptor + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ResourceDescriptor.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.type != null && message.hasOwnProperty("type")) + if (!$util.isString(message.type)) + return "type: string expected"; + if (message.pattern != null && message.hasOwnProperty("pattern")) { + if (!Array.isArray(message.pattern)) + return "pattern: array expected"; + for (var i = 0; i < message.pattern.length; ++i) + if (!$util.isString(message.pattern[i])) + return "pattern: string[] expected"; + } + if (message.nameField != null && message.hasOwnProperty("nameField")) + if (!$util.isString(message.nameField)) + return "nameField: string expected"; + if (message.history != null && message.hasOwnProperty("history")) + switch (message.history) { + default: + return "history: enum value expected"; + case 0: + case 1: + case 2: + break; + } + if (message.plural != null && message.hasOwnProperty("plural")) + if (!$util.isString(message.plural)) + return "plural: string expected"; + if (message.singular != null && message.hasOwnProperty("singular")) + if (!$util.isString(message.singular)) + return "singular: string expected"; + if (message.style != null && message.hasOwnProperty("style")) { + if (!Array.isArray(message.style)) + return "style: array expected"; + for (var i = 0; i < message.style.length; ++i) + switch (message.style[i]) { + default: + return "style: enum value[] expected"; + case 0: + case 1: + break; + } + } + return null; + }; + + /** + * Creates a ResourceDescriptor message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.ResourceDescriptor + * @static + * @param {Object.} object Plain object + * @returns {google.api.ResourceDescriptor} ResourceDescriptor + */ + ResourceDescriptor.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.ResourceDescriptor) + return object; + var message = new $root.google.api.ResourceDescriptor(); + if (object.type != null) + message.type = String(object.type); + if (object.pattern) { + if (!Array.isArray(object.pattern)) + throw TypeError(".google.api.ResourceDescriptor.pattern: array expected"); + message.pattern = []; + for (var i = 0; i < object.pattern.length; ++i) + message.pattern[i] = String(object.pattern[i]); + } + if (object.nameField != null) + message.nameField = String(object.nameField); + switch (object.history) { + default: + if (typeof object.history === "number") { + message.history = object.history; + break; + } + break; + case "HISTORY_UNSPECIFIED": + case 0: + message.history = 0; + break; + case "ORIGINALLY_SINGLE_PATTERN": + case 1: + message.history = 1; + break; + case "FUTURE_MULTI_PATTERN": + case 2: + message.history = 2; + break; + } + if (object.plural != null) + message.plural = String(object.plural); + if (object.singular != null) + message.singular = String(object.singular); + if (object.style) { + if (!Array.isArray(object.style)) + throw TypeError(".google.api.ResourceDescriptor.style: array expected"); + message.style = []; + for (var i = 0; i < object.style.length; ++i) + switch (object.style[i]) { + default: + if (typeof object.style[i] === "number") { + message.style[i] = object.style[i]; + break; + } + case "STYLE_UNSPECIFIED": + case 0: + message.style[i] = 0; + break; + case "DECLARATIVE_FRIENDLY": + case 1: + message.style[i] = 1; + break; + } + } + return message; + }; + + /** + * Creates a plain object from a ResourceDescriptor message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.ResourceDescriptor + * @static + * @param {google.api.ResourceDescriptor} message ResourceDescriptor + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ResourceDescriptor.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.pattern = []; + object.style = []; + } + if (options.defaults) { + object.type = ""; + object.nameField = ""; + object.history = options.enums === String ? "HISTORY_UNSPECIFIED" : 0; + object.plural = ""; + object.singular = ""; + } + if (message.type != null && message.hasOwnProperty("type")) + object.type = message.type; + if (message.pattern && message.pattern.length) { + object.pattern = []; + for (var j = 0; j < message.pattern.length; ++j) + object.pattern[j] = message.pattern[j]; + } + if (message.nameField != null && message.hasOwnProperty("nameField")) + object.nameField = message.nameField; + if (message.history != null && message.hasOwnProperty("history")) + object.history = options.enums === String ? $root.google.api.ResourceDescriptor.History[message.history] === undefined ? message.history : $root.google.api.ResourceDescriptor.History[message.history] : message.history; + if (message.plural != null && message.hasOwnProperty("plural")) + object.plural = message.plural; + if (message.singular != null && message.hasOwnProperty("singular")) + object.singular = message.singular; + if (message.style && message.style.length) { + object.style = []; + for (var j = 0; j < message.style.length; ++j) + object.style[j] = options.enums === String ? $root.google.api.ResourceDescriptor.Style[message.style[j]] === undefined ? message.style[j] : $root.google.api.ResourceDescriptor.Style[message.style[j]] : message.style[j]; + } + return object; + }; + + /** + * Converts this ResourceDescriptor to JSON. + * @function toJSON + * @memberof google.api.ResourceDescriptor + * @instance + * @returns {Object.} JSON object + */ + ResourceDescriptor.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ResourceDescriptor + * @function getTypeUrl + * @memberof google.api.ResourceDescriptor + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ResourceDescriptor.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.ResourceDescriptor"; + }; + + /** + * History enum. + * @name google.api.ResourceDescriptor.History + * @enum {number} + * @property {number} HISTORY_UNSPECIFIED=0 HISTORY_UNSPECIFIED value + * @property {number} ORIGINALLY_SINGLE_PATTERN=1 ORIGINALLY_SINGLE_PATTERN value + * @property {number} FUTURE_MULTI_PATTERN=2 FUTURE_MULTI_PATTERN value + */ + ResourceDescriptor.History = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "HISTORY_UNSPECIFIED"] = 0; + values[valuesById[1] = "ORIGINALLY_SINGLE_PATTERN"] = 1; + values[valuesById[2] = "FUTURE_MULTI_PATTERN"] = 2; + return values; + })(); + + /** + * Style enum. + * @name google.api.ResourceDescriptor.Style + * @enum {number} + * @property {number} STYLE_UNSPECIFIED=0 STYLE_UNSPECIFIED value + * @property {number} DECLARATIVE_FRIENDLY=1 DECLARATIVE_FRIENDLY value + */ + ResourceDescriptor.Style = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "STYLE_UNSPECIFIED"] = 0; + values[valuesById[1] = "DECLARATIVE_FRIENDLY"] = 1; + return values; + })(); + + return ResourceDescriptor; + })(); + + api.ResourceReference = (function() { + + /** + * Properties of a ResourceReference. + * @memberof google.api + * @interface IResourceReference + * @property {string|null} [type] ResourceReference type + * @property {string|null} [childType] ResourceReference childType + */ + + /** + * Constructs a new ResourceReference. + * @memberof google.api + * @classdesc Represents a ResourceReference. + * @implements IResourceReference + * @constructor + * @param {google.api.IResourceReference=} [properties] Properties to set + */ + function ResourceReference(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ResourceReference type. + * @member {string} type + * @memberof google.api.ResourceReference + * @instance + */ + ResourceReference.prototype.type = ""; + + /** + * ResourceReference childType. + * @member {string} childType + * @memberof google.api.ResourceReference + * @instance + */ + ResourceReference.prototype.childType = ""; + + /** + * Creates a new ResourceReference instance using the specified properties. + * @function create + * @memberof google.api.ResourceReference + * @static + * @param {google.api.IResourceReference=} [properties] Properties to set + * @returns {google.api.ResourceReference} ResourceReference instance + */ + ResourceReference.create = function create(properties) { + return new ResourceReference(properties); + }; + + /** + * Encodes the specified ResourceReference message. Does not implicitly {@link google.api.ResourceReference.verify|verify} messages. + * @function encode + * @memberof google.api.ResourceReference + * @static + * @param {google.api.IResourceReference} message ResourceReference message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ResourceReference.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.type != null && Object.hasOwnProperty.call(message, "type")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.type); + if (message.childType != null && Object.hasOwnProperty.call(message, "childType")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.childType); + return writer; + }; + + /** + * Encodes the specified ResourceReference message, length delimited. Does not implicitly {@link google.api.ResourceReference.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.ResourceReference + * @static + * @param {google.api.IResourceReference} message ResourceReference message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ResourceReference.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ResourceReference message from the specified reader or buffer. + * @function decode + * @memberof google.api.ResourceReference + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.ResourceReference} ResourceReference + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ResourceReference.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.ResourceReference(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.type = reader.string(); + break; + } + case 2: { + message.childType = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ResourceReference message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.ResourceReference + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.ResourceReference} ResourceReference + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ResourceReference.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ResourceReference message. + * @function verify + * @memberof google.api.ResourceReference + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ResourceReference.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.type != null && message.hasOwnProperty("type")) + if (!$util.isString(message.type)) + return "type: string expected"; + if (message.childType != null && message.hasOwnProperty("childType")) + if (!$util.isString(message.childType)) + return "childType: string expected"; + return null; + }; + + /** + * Creates a ResourceReference message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.ResourceReference + * @static + * @param {Object.} object Plain object + * @returns {google.api.ResourceReference} ResourceReference + */ + ResourceReference.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.ResourceReference) + return object; + var message = new $root.google.api.ResourceReference(); + if (object.type != null) + message.type = String(object.type); + if (object.childType != null) + message.childType = String(object.childType); + return message; + }; + + /** + * Creates a plain object from a ResourceReference message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.ResourceReference + * @static + * @param {google.api.ResourceReference} message ResourceReference + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ResourceReference.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.type = ""; + object.childType = ""; + } + if (message.type != null && message.hasOwnProperty("type")) + object.type = message.type; + if (message.childType != null && message.hasOwnProperty("childType")) + object.childType = message.childType; + return object; + }; + + /** + * Converts this ResourceReference to JSON. + * @function toJSON + * @memberof google.api.ResourceReference + * @instance + * @returns {Object.} JSON object + */ + ResourceReference.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ResourceReference + * @function getTypeUrl + * @memberof google.api.ResourceReference + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ResourceReference.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.ResourceReference"; + }; + + return ResourceReference; + })(); + + api.Http = (function() { + + /** + * Properties of a Http. + * @memberof google.api + * @interface IHttp + * @property {Array.|null} [rules] Http rules + * @property {boolean|null} [fullyDecodeReservedExpansion] Http fullyDecodeReservedExpansion + */ + + /** + * Constructs a new Http. + * @memberof google.api + * @classdesc Represents a Http. + * @implements IHttp + * @constructor + * @param {google.api.IHttp=} [properties] Properties to set + */ + function Http(properties) { + this.rules = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Http rules. + * @member {Array.} rules + * @memberof google.api.Http + * @instance + */ + Http.prototype.rules = $util.emptyArray; + + /** + * Http fullyDecodeReservedExpansion. + * @member {boolean} fullyDecodeReservedExpansion + * @memberof google.api.Http + * @instance + */ + Http.prototype.fullyDecodeReservedExpansion = false; + + /** + * Creates a new Http instance using the specified properties. + * @function create + * @memberof google.api.Http + * @static + * @param {google.api.IHttp=} [properties] Properties to set + * @returns {google.api.Http} Http instance + */ + Http.create = function create(properties) { + return new Http(properties); + }; + + /** + * Encodes the specified Http message. Does not implicitly {@link google.api.Http.verify|verify} messages. + * @function encode + * @memberof google.api.Http + * @static + * @param {google.api.IHttp} message Http message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Http.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.rules != null && message.rules.length) + for (var i = 0; i < message.rules.length; ++i) + $root.google.api.HttpRule.encode(message.rules[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.fullyDecodeReservedExpansion != null && Object.hasOwnProperty.call(message, "fullyDecodeReservedExpansion")) + writer.uint32(/* id 2, wireType 0 =*/16).bool(message.fullyDecodeReservedExpansion); + return writer; + }; + + /** + * Encodes the specified Http message, length delimited. Does not implicitly {@link google.api.Http.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.Http + * @static + * @param {google.api.IHttp} message Http message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Http.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a Http message from the specified reader or buffer. + * @function decode + * @memberof google.api.Http + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.Http} Http + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Http.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.Http(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + if (!(message.rules && message.rules.length)) + message.rules = []; + message.rules.push($root.google.api.HttpRule.decode(reader, reader.uint32())); + break; + } + case 2: { + message.fullyDecodeReservedExpansion = reader.bool(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a Http message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.Http + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.Http} Http + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Http.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a Http message. + * @function verify + * @memberof google.api.Http + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Http.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.rules != null && message.hasOwnProperty("rules")) { + if (!Array.isArray(message.rules)) + return "rules: array expected"; + for (var i = 0; i < message.rules.length; ++i) { + var error = $root.google.api.HttpRule.verify(message.rules[i]); + if (error) + return "rules." + error; + } + } + if (message.fullyDecodeReservedExpansion != null && message.hasOwnProperty("fullyDecodeReservedExpansion")) + if (typeof message.fullyDecodeReservedExpansion !== "boolean") + return "fullyDecodeReservedExpansion: boolean expected"; + return null; + }; + + /** + * Creates a Http message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.Http + * @static + * @param {Object.} object Plain object + * @returns {google.api.Http} Http + */ + Http.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.Http) + return object; + var message = new $root.google.api.Http(); + if (object.rules) { + if (!Array.isArray(object.rules)) + throw TypeError(".google.api.Http.rules: array expected"); + message.rules = []; + for (var i = 0; i < object.rules.length; ++i) { + if (typeof object.rules[i] !== "object") + throw TypeError(".google.api.Http.rules: object expected"); + message.rules[i] = $root.google.api.HttpRule.fromObject(object.rules[i]); + } + } + if (object.fullyDecodeReservedExpansion != null) + message.fullyDecodeReservedExpansion = Boolean(object.fullyDecodeReservedExpansion); + return message; + }; + + /** + * Creates a plain object from a Http message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.Http + * @static + * @param {google.api.Http} message Http + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Http.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.rules = []; + if (options.defaults) + object.fullyDecodeReservedExpansion = false; + if (message.rules && message.rules.length) { + object.rules = []; + for (var j = 0; j < message.rules.length; ++j) + object.rules[j] = $root.google.api.HttpRule.toObject(message.rules[j], options); + } + if (message.fullyDecodeReservedExpansion != null && message.hasOwnProperty("fullyDecodeReservedExpansion")) + object.fullyDecodeReservedExpansion = message.fullyDecodeReservedExpansion; + return object; + }; + + /** + * Converts this Http to JSON. + * @function toJSON + * @memberof google.api.Http + * @instance + * @returns {Object.} JSON object + */ + Http.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Http + * @function getTypeUrl + * @memberof google.api.Http + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Http.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.Http"; + }; + + return Http; + })(); + + api.HttpRule = (function() { + + /** + * Properties of a HttpRule. + * @memberof google.api + * @interface IHttpRule + * @property {string|null} [selector] HttpRule selector + * @property {string|null} [get] HttpRule get + * @property {string|null} [put] HttpRule put + * @property {string|null} [post] HttpRule post + * @property {string|null} ["delete"] HttpRule delete + * @property {string|null} [patch] HttpRule patch + * @property {google.api.ICustomHttpPattern|null} [custom] HttpRule custom + * @property {string|null} [body] HttpRule body + * @property {string|null} [responseBody] HttpRule responseBody + * @property {Array.|null} [additionalBindings] HttpRule additionalBindings + */ + + /** + * Constructs a new HttpRule. + * @memberof google.api + * @classdesc Represents a HttpRule. + * @implements IHttpRule + * @constructor + * @param {google.api.IHttpRule=} [properties] Properties to set + */ + function HttpRule(properties) { + this.additionalBindings = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * HttpRule selector. + * @member {string} selector + * @memberof google.api.HttpRule + * @instance + */ + HttpRule.prototype.selector = ""; + + /** + * HttpRule get. + * @member {string|null|undefined} get + * @memberof google.api.HttpRule + * @instance + */ + HttpRule.prototype.get = null; + + /** + * HttpRule put. + * @member {string|null|undefined} put + * @memberof google.api.HttpRule + * @instance + */ + HttpRule.prototype.put = null; + + /** + * HttpRule post. + * @member {string|null|undefined} post + * @memberof google.api.HttpRule + * @instance + */ + HttpRule.prototype.post = null; + + /** + * HttpRule delete. + * @member {string|null|undefined} delete + * @memberof google.api.HttpRule + * @instance + */ + HttpRule.prototype["delete"] = null; + + /** + * HttpRule patch. + * @member {string|null|undefined} patch + * @memberof google.api.HttpRule + * @instance + */ + HttpRule.prototype.patch = null; + + /** + * HttpRule custom. + * @member {google.api.ICustomHttpPattern|null|undefined} custom + * @memberof google.api.HttpRule + * @instance + */ + HttpRule.prototype.custom = null; + + /** + * HttpRule body. + * @member {string} body + * @memberof google.api.HttpRule + * @instance + */ + HttpRule.prototype.body = ""; + + /** + * HttpRule responseBody. + * @member {string} responseBody + * @memberof google.api.HttpRule + * @instance + */ + HttpRule.prototype.responseBody = ""; + + /** + * HttpRule additionalBindings. + * @member {Array.} additionalBindings + * @memberof google.api.HttpRule + * @instance + */ + HttpRule.prototype.additionalBindings = $util.emptyArray; + + // OneOf field names bound to virtual getters and setters + var $oneOfFields; + + /** + * HttpRule pattern. + * @member {"get"|"put"|"post"|"delete"|"patch"|"custom"|undefined} pattern + * @memberof google.api.HttpRule + * @instance + */ + Object.defineProperty(HttpRule.prototype, "pattern", { + get: $util.oneOfGetter($oneOfFields = ["get", "put", "post", "delete", "patch", "custom"]), + set: $util.oneOfSetter($oneOfFields) + }); + + /** + * Creates a new HttpRule instance using the specified properties. + * @function create + * @memberof google.api.HttpRule + * @static + * @param {google.api.IHttpRule=} [properties] Properties to set + * @returns {google.api.HttpRule} HttpRule instance + */ + HttpRule.create = function create(properties) { + return new HttpRule(properties); + }; + + /** + * Encodes the specified HttpRule message. Does not implicitly {@link google.api.HttpRule.verify|verify} messages. + * @function encode + * @memberof google.api.HttpRule + * @static + * @param {google.api.IHttpRule} message HttpRule message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + HttpRule.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.selector != null && Object.hasOwnProperty.call(message, "selector")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.selector); + if (message.get != null && Object.hasOwnProperty.call(message, "get")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.get); + if (message.put != null && Object.hasOwnProperty.call(message, "put")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.put); + if (message.post != null && Object.hasOwnProperty.call(message, "post")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.post); + if (message["delete"] != null && Object.hasOwnProperty.call(message, "delete")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message["delete"]); + if (message.patch != null && Object.hasOwnProperty.call(message, "patch")) + writer.uint32(/* id 6, wireType 2 =*/50).string(message.patch); + if (message.body != null && Object.hasOwnProperty.call(message, "body")) + writer.uint32(/* id 7, wireType 2 =*/58).string(message.body); + if (message.custom != null && Object.hasOwnProperty.call(message, "custom")) + $root.google.api.CustomHttpPattern.encode(message.custom, writer.uint32(/* id 8, wireType 2 =*/66).fork()).ldelim(); + if (message.additionalBindings != null && message.additionalBindings.length) + for (var i = 0; i < message.additionalBindings.length; ++i) + $root.google.api.HttpRule.encode(message.additionalBindings[i], writer.uint32(/* id 11, wireType 2 =*/90).fork()).ldelim(); + if (message.responseBody != null && Object.hasOwnProperty.call(message, "responseBody")) + writer.uint32(/* id 12, wireType 2 =*/98).string(message.responseBody); + return writer; + }; + + /** + * Encodes the specified HttpRule message, length delimited. Does not implicitly {@link google.api.HttpRule.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.HttpRule + * @static + * @param {google.api.IHttpRule} message HttpRule message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + HttpRule.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a HttpRule message from the specified reader or buffer. + * @function decode + * @memberof google.api.HttpRule + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.HttpRule} HttpRule + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + HttpRule.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.HttpRule(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.selector = reader.string(); + break; + } + case 2: { + message.get = reader.string(); + break; + } + case 3: { + message.put = reader.string(); + break; + } + case 4: { + message.post = reader.string(); + break; + } + case 5: { + message["delete"] = reader.string(); + break; + } + case 6: { + message.patch = reader.string(); + break; + } + case 8: { + message.custom = $root.google.api.CustomHttpPattern.decode(reader, reader.uint32()); + break; + } + case 7: { + message.body = reader.string(); + break; + } + case 12: { + message.responseBody = reader.string(); + break; + } + case 11: { + if (!(message.additionalBindings && message.additionalBindings.length)) + message.additionalBindings = []; + message.additionalBindings.push($root.google.api.HttpRule.decode(reader, reader.uint32())); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a HttpRule message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.HttpRule + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.HttpRule} HttpRule + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + HttpRule.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a HttpRule message. + * @function verify + * @memberof google.api.HttpRule + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + HttpRule.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + var properties = {}; + if (message.selector != null && message.hasOwnProperty("selector")) + if (!$util.isString(message.selector)) + return "selector: string expected"; + if (message.get != null && message.hasOwnProperty("get")) { + properties.pattern = 1; + if (!$util.isString(message.get)) + return "get: string expected"; + } + if (message.put != null && message.hasOwnProperty("put")) { + if (properties.pattern === 1) + return "pattern: multiple values"; + properties.pattern = 1; + if (!$util.isString(message.put)) + return "put: string expected"; + } + if (message.post != null && message.hasOwnProperty("post")) { + if (properties.pattern === 1) + return "pattern: multiple values"; + properties.pattern = 1; + if (!$util.isString(message.post)) + return "post: string expected"; + } + if (message["delete"] != null && message.hasOwnProperty("delete")) { + if (properties.pattern === 1) + return "pattern: multiple values"; + properties.pattern = 1; + if (!$util.isString(message["delete"])) + return "delete: string expected"; + } + if (message.patch != null && message.hasOwnProperty("patch")) { + if (properties.pattern === 1) + return "pattern: multiple values"; + properties.pattern = 1; + if (!$util.isString(message.patch)) + return "patch: string expected"; + } + if (message.custom != null && message.hasOwnProperty("custom")) { + if (properties.pattern === 1) + return "pattern: multiple values"; + properties.pattern = 1; + { + var error = $root.google.api.CustomHttpPattern.verify(message.custom); + if (error) + return "custom." + error; + } + } + if (message.body != null && message.hasOwnProperty("body")) + if (!$util.isString(message.body)) + return "body: string expected"; + if (message.responseBody != null && message.hasOwnProperty("responseBody")) + if (!$util.isString(message.responseBody)) + return "responseBody: string expected"; + if (message.additionalBindings != null && message.hasOwnProperty("additionalBindings")) { + if (!Array.isArray(message.additionalBindings)) + return "additionalBindings: array expected"; + for (var i = 0; i < message.additionalBindings.length; ++i) { + var error = $root.google.api.HttpRule.verify(message.additionalBindings[i]); + if (error) + return "additionalBindings." + error; + } + } + return null; + }; + + /** + * Creates a HttpRule message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.HttpRule + * @static + * @param {Object.} object Plain object + * @returns {google.api.HttpRule} HttpRule + */ + HttpRule.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.HttpRule) + return object; + var message = new $root.google.api.HttpRule(); + if (object.selector != null) + message.selector = String(object.selector); + if (object.get != null) + message.get = String(object.get); + if (object.put != null) + message.put = String(object.put); + if (object.post != null) + message.post = String(object.post); + if (object["delete"] != null) + message["delete"] = String(object["delete"]); + if (object.patch != null) + message.patch = String(object.patch); + if (object.custom != null) { + if (typeof object.custom !== "object") + throw TypeError(".google.api.HttpRule.custom: object expected"); + message.custom = $root.google.api.CustomHttpPattern.fromObject(object.custom); + } + if (object.body != null) + message.body = String(object.body); + if (object.responseBody != null) + message.responseBody = String(object.responseBody); + if (object.additionalBindings) { + if (!Array.isArray(object.additionalBindings)) + throw TypeError(".google.api.HttpRule.additionalBindings: array expected"); + message.additionalBindings = []; + for (var i = 0; i < object.additionalBindings.length; ++i) { + if (typeof object.additionalBindings[i] !== "object") + throw TypeError(".google.api.HttpRule.additionalBindings: object expected"); + message.additionalBindings[i] = $root.google.api.HttpRule.fromObject(object.additionalBindings[i]); + } + } + return message; + }; + + /** + * Creates a plain object from a HttpRule message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.HttpRule + * @static + * @param {google.api.HttpRule} message HttpRule + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + HttpRule.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.additionalBindings = []; + if (options.defaults) { + object.selector = ""; + object.body = ""; + object.responseBody = ""; + } + if (message.selector != null && message.hasOwnProperty("selector")) + object.selector = message.selector; + if (message.get != null && message.hasOwnProperty("get")) { + object.get = message.get; + if (options.oneofs) + object.pattern = "get"; + } + if (message.put != null && message.hasOwnProperty("put")) { + object.put = message.put; + if (options.oneofs) + object.pattern = "put"; + } + if (message.post != null && message.hasOwnProperty("post")) { + object.post = message.post; + if (options.oneofs) + object.pattern = "post"; + } + if (message["delete"] != null && message.hasOwnProperty("delete")) { + object["delete"] = message["delete"]; + if (options.oneofs) + object.pattern = "delete"; + } + if (message.patch != null && message.hasOwnProperty("patch")) { + object.patch = message.patch; + if (options.oneofs) + object.pattern = "patch"; + } + if (message.body != null && message.hasOwnProperty("body")) + object.body = message.body; + if (message.custom != null && message.hasOwnProperty("custom")) { + object.custom = $root.google.api.CustomHttpPattern.toObject(message.custom, options); + if (options.oneofs) + object.pattern = "custom"; + } + if (message.additionalBindings && message.additionalBindings.length) { + object.additionalBindings = []; + for (var j = 0; j < message.additionalBindings.length; ++j) + object.additionalBindings[j] = $root.google.api.HttpRule.toObject(message.additionalBindings[j], options); + } + if (message.responseBody != null && message.hasOwnProperty("responseBody")) + object.responseBody = message.responseBody; + return object; + }; + + /** + * Converts this HttpRule to JSON. + * @function toJSON + * @memberof google.api.HttpRule + * @instance + * @returns {Object.} JSON object + */ + HttpRule.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for HttpRule + * @function getTypeUrl + * @memberof google.api.HttpRule + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + HttpRule.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.HttpRule"; + }; + + return HttpRule; + })(); + + api.CustomHttpPattern = (function() { + + /** + * Properties of a CustomHttpPattern. + * @memberof google.api + * @interface ICustomHttpPattern + * @property {string|null} [kind] CustomHttpPattern kind + * @property {string|null} [path] CustomHttpPattern path + */ + + /** + * Constructs a new CustomHttpPattern. + * @memberof google.api + * @classdesc Represents a CustomHttpPattern. + * @implements ICustomHttpPattern + * @constructor + * @param {google.api.ICustomHttpPattern=} [properties] Properties to set + */ + function CustomHttpPattern(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * CustomHttpPattern kind. + * @member {string} kind + * @memberof google.api.CustomHttpPattern + * @instance + */ + CustomHttpPattern.prototype.kind = ""; + + /** + * CustomHttpPattern path. + * @member {string} path + * @memberof google.api.CustomHttpPattern + * @instance + */ + CustomHttpPattern.prototype.path = ""; + + /** + * Creates a new CustomHttpPattern instance using the specified properties. + * @function create + * @memberof google.api.CustomHttpPattern + * @static + * @param {google.api.ICustomHttpPattern=} [properties] Properties to set + * @returns {google.api.CustomHttpPattern} CustomHttpPattern instance + */ + CustomHttpPattern.create = function create(properties) { + return new CustomHttpPattern(properties); + }; + + /** + * Encodes the specified CustomHttpPattern message. Does not implicitly {@link google.api.CustomHttpPattern.verify|verify} messages. + * @function encode + * @memberof google.api.CustomHttpPattern + * @static + * @param {google.api.ICustomHttpPattern} message CustomHttpPattern message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + CustomHttpPattern.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.kind != null && Object.hasOwnProperty.call(message, "kind")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.kind); + if (message.path != null && Object.hasOwnProperty.call(message, "path")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.path); + return writer; + }; + + /** + * Encodes the specified CustomHttpPattern message, length delimited. Does not implicitly {@link google.api.CustomHttpPattern.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.CustomHttpPattern + * @static + * @param {google.api.ICustomHttpPattern} message CustomHttpPattern message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + CustomHttpPattern.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a CustomHttpPattern message from the specified reader or buffer. + * @function decode + * @memberof google.api.CustomHttpPattern + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.CustomHttpPattern} CustomHttpPattern + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + CustomHttpPattern.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.CustomHttpPattern(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.kind = reader.string(); + break; + } + case 2: { + message.path = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a CustomHttpPattern message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.CustomHttpPattern + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.CustomHttpPattern} CustomHttpPattern + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + CustomHttpPattern.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a CustomHttpPattern message. + * @function verify + * @memberof google.api.CustomHttpPattern + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + CustomHttpPattern.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.kind != null && message.hasOwnProperty("kind")) + if (!$util.isString(message.kind)) + return "kind: string expected"; + if (message.path != null && message.hasOwnProperty("path")) + if (!$util.isString(message.path)) + return "path: string expected"; + return null; + }; + + /** + * Creates a CustomHttpPattern message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.CustomHttpPattern + * @static + * @param {Object.} object Plain object + * @returns {google.api.CustomHttpPattern} CustomHttpPattern + */ + CustomHttpPattern.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.CustomHttpPattern) + return object; + var message = new $root.google.api.CustomHttpPattern(); + if (object.kind != null) + message.kind = String(object.kind); + if (object.path != null) + message.path = String(object.path); + return message; + }; + + /** + * Creates a plain object from a CustomHttpPattern message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.CustomHttpPattern + * @static + * @param {google.api.CustomHttpPattern} message CustomHttpPattern + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + CustomHttpPattern.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.kind = ""; + object.path = ""; + } + if (message.kind != null && message.hasOwnProperty("kind")) + object.kind = message.kind; + if (message.path != null && message.hasOwnProperty("path")) + object.path = message.path; + return object; + }; + + /** + * Converts this CustomHttpPattern to JSON. + * @function toJSON + * @memberof google.api.CustomHttpPattern + * @instance + * @returns {Object.} JSON object + */ + CustomHttpPattern.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for CustomHttpPattern + * @function getTypeUrl + * @memberof google.api.CustomHttpPattern + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + CustomHttpPattern.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.CustomHttpPattern"; + }; + + return CustomHttpPattern; + })(); + + api.CommonLanguageSettings = (function() { + + /** + * Properties of a CommonLanguageSettings. + * @memberof google.api + * @interface ICommonLanguageSettings + * @property {string|null} [referenceDocsUri] CommonLanguageSettings referenceDocsUri + * @property {Array.|null} [destinations] CommonLanguageSettings destinations + */ + + /** + * Constructs a new CommonLanguageSettings. + * @memberof google.api + * @classdesc Represents a CommonLanguageSettings. + * @implements ICommonLanguageSettings + * @constructor + * @param {google.api.ICommonLanguageSettings=} [properties] Properties to set + */ + function CommonLanguageSettings(properties) { + this.destinations = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * CommonLanguageSettings referenceDocsUri. + * @member {string} referenceDocsUri + * @memberof google.api.CommonLanguageSettings + * @instance + */ + CommonLanguageSettings.prototype.referenceDocsUri = ""; + + /** + * CommonLanguageSettings destinations. + * @member {Array.} destinations + * @memberof google.api.CommonLanguageSettings + * @instance + */ + CommonLanguageSettings.prototype.destinations = $util.emptyArray; + + /** + * Creates a new CommonLanguageSettings instance using the specified properties. + * @function create + * @memberof google.api.CommonLanguageSettings + * @static + * @param {google.api.ICommonLanguageSettings=} [properties] Properties to set + * @returns {google.api.CommonLanguageSettings} CommonLanguageSettings instance + */ + CommonLanguageSettings.create = function create(properties) { + return new CommonLanguageSettings(properties); + }; + + /** + * Encodes the specified CommonLanguageSettings message. Does not implicitly {@link google.api.CommonLanguageSettings.verify|verify} messages. + * @function encode + * @memberof google.api.CommonLanguageSettings + * @static + * @param {google.api.ICommonLanguageSettings} message CommonLanguageSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + CommonLanguageSettings.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.referenceDocsUri != null && Object.hasOwnProperty.call(message, "referenceDocsUri")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.referenceDocsUri); + if (message.destinations != null && message.destinations.length) { + writer.uint32(/* id 2, wireType 2 =*/18).fork(); + for (var i = 0; i < message.destinations.length; ++i) + writer.int32(message.destinations[i]); + writer.ldelim(); + } + return writer; + }; + + /** + * Encodes the specified CommonLanguageSettings message, length delimited. Does not implicitly {@link google.api.CommonLanguageSettings.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.CommonLanguageSettings + * @static + * @param {google.api.ICommonLanguageSettings} message CommonLanguageSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + CommonLanguageSettings.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a CommonLanguageSettings message from the specified reader or buffer. + * @function decode + * @memberof google.api.CommonLanguageSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.CommonLanguageSettings} CommonLanguageSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + CommonLanguageSettings.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.CommonLanguageSettings(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.referenceDocsUri = reader.string(); + break; + } + case 2: { + if (!(message.destinations && message.destinations.length)) + message.destinations = []; + if ((tag & 7) === 2) { + var end2 = reader.uint32() + reader.pos; + while (reader.pos < end2) + message.destinations.push(reader.int32()); + } else + message.destinations.push(reader.int32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a CommonLanguageSettings message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.CommonLanguageSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.CommonLanguageSettings} CommonLanguageSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + CommonLanguageSettings.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a CommonLanguageSettings message. + * @function verify + * @memberof google.api.CommonLanguageSettings + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + CommonLanguageSettings.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.referenceDocsUri != null && message.hasOwnProperty("referenceDocsUri")) + if (!$util.isString(message.referenceDocsUri)) + return "referenceDocsUri: string expected"; + if (message.destinations != null && message.hasOwnProperty("destinations")) { + if (!Array.isArray(message.destinations)) + return "destinations: array expected"; + for (var i = 0; i < message.destinations.length; ++i) + switch (message.destinations[i]) { + default: + return "destinations: enum value[] expected"; + case 0: + case 10: + case 20: + break; + } + } + return null; + }; + + /** + * Creates a CommonLanguageSettings message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.CommonLanguageSettings + * @static + * @param {Object.} object Plain object + * @returns {google.api.CommonLanguageSettings} CommonLanguageSettings + */ + CommonLanguageSettings.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.CommonLanguageSettings) + return object; + var message = new $root.google.api.CommonLanguageSettings(); + if (object.referenceDocsUri != null) + message.referenceDocsUri = String(object.referenceDocsUri); + if (object.destinations) { + if (!Array.isArray(object.destinations)) + throw TypeError(".google.api.CommonLanguageSettings.destinations: array expected"); + message.destinations = []; + for (var i = 0; i < object.destinations.length; ++i) + switch (object.destinations[i]) { + default: + if (typeof object.destinations[i] === "number") { + message.destinations[i] = object.destinations[i]; + break; + } + case "CLIENT_LIBRARY_DESTINATION_UNSPECIFIED": + case 0: + message.destinations[i] = 0; + break; + case "GITHUB": + case 10: + message.destinations[i] = 10; + break; + case "PACKAGE_MANAGER": + case 20: + message.destinations[i] = 20; + break; + } + } + return message; + }; + + /** + * Creates a plain object from a CommonLanguageSettings message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.CommonLanguageSettings + * @static + * @param {google.api.CommonLanguageSettings} message CommonLanguageSettings + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + CommonLanguageSettings.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.destinations = []; + if (options.defaults) + object.referenceDocsUri = ""; + if (message.referenceDocsUri != null && message.hasOwnProperty("referenceDocsUri")) + object.referenceDocsUri = message.referenceDocsUri; + if (message.destinations && message.destinations.length) { + object.destinations = []; + for (var j = 0; j < message.destinations.length; ++j) + object.destinations[j] = options.enums === String ? $root.google.api.ClientLibraryDestination[message.destinations[j]] === undefined ? message.destinations[j] : $root.google.api.ClientLibraryDestination[message.destinations[j]] : message.destinations[j]; + } + return object; + }; + + /** + * Converts this CommonLanguageSettings to JSON. + * @function toJSON + * @memberof google.api.CommonLanguageSettings + * @instance + * @returns {Object.} JSON object + */ + CommonLanguageSettings.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for CommonLanguageSettings + * @function getTypeUrl + * @memberof google.api.CommonLanguageSettings + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + CommonLanguageSettings.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.CommonLanguageSettings"; + }; + + return CommonLanguageSettings; + })(); + + api.ClientLibrarySettings = (function() { + + /** + * Properties of a ClientLibrarySettings. + * @memberof google.api + * @interface IClientLibrarySettings + * @property {string|null} [version] ClientLibrarySettings version + * @property {google.api.LaunchStage|null} [launchStage] ClientLibrarySettings launchStage + * @property {boolean|null} [restNumericEnums] ClientLibrarySettings restNumericEnums + * @property {google.api.IJavaSettings|null} [javaSettings] ClientLibrarySettings javaSettings + * @property {google.api.ICppSettings|null} [cppSettings] ClientLibrarySettings cppSettings + * @property {google.api.IPhpSettings|null} [phpSettings] ClientLibrarySettings phpSettings + * @property {google.api.IPythonSettings|null} [pythonSettings] ClientLibrarySettings pythonSettings + * @property {google.api.INodeSettings|null} [nodeSettings] ClientLibrarySettings nodeSettings + * @property {google.api.IDotnetSettings|null} [dotnetSettings] ClientLibrarySettings dotnetSettings + * @property {google.api.IRubySettings|null} [rubySettings] ClientLibrarySettings rubySettings + * @property {google.api.IGoSettings|null} [goSettings] ClientLibrarySettings goSettings + */ + + /** + * Constructs a new ClientLibrarySettings. + * @memberof google.api + * @classdesc Represents a ClientLibrarySettings. + * @implements IClientLibrarySettings + * @constructor + * @param {google.api.IClientLibrarySettings=} [properties] Properties to set + */ + function ClientLibrarySettings(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ClientLibrarySettings version. + * @member {string} version + * @memberof google.api.ClientLibrarySettings + * @instance + */ + ClientLibrarySettings.prototype.version = ""; + + /** + * ClientLibrarySettings launchStage. + * @member {google.api.LaunchStage} launchStage + * @memberof google.api.ClientLibrarySettings + * @instance + */ + ClientLibrarySettings.prototype.launchStage = 0; + + /** + * ClientLibrarySettings restNumericEnums. + * @member {boolean} restNumericEnums + * @memberof google.api.ClientLibrarySettings + * @instance + */ + ClientLibrarySettings.prototype.restNumericEnums = false; + + /** + * ClientLibrarySettings javaSettings. + * @member {google.api.IJavaSettings|null|undefined} javaSettings + * @memberof google.api.ClientLibrarySettings + * @instance + */ + ClientLibrarySettings.prototype.javaSettings = null; + + /** + * ClientLibrarySettings cppSettings. + * @member {google.api.ICppSettings|null|undefined} cppSettings + * @memberof google.api.ClientLibrarySettings + * @instance + */ + ClientLibrarySettings.prototype.cppSettings = null; + + /** + * ClientLibrarySettings phpSettings. + * @member {google.api.IPhpSettings|null|undefined} phpSettings + * @memberof google.api.ClientLibrarySettings + * @instance + */ + ClientLibrarySettings.prototype.phpSettings = null; + + /** + * ClientLibrarySettings pythonSettings. + * @member {google.api.IPythonSettings|null|undefined} pythonSettings + * @memberof google.api.ClientLibrarySettings + * @instance + */ + ClientLibrarySettings.prototype.pythonSettings = null; + + /** + * ClientLibrarySettings nodeSettings. + * @member {google.api.INodeSettings|null|undefined} nodeSettings + * @memberof google.api.ClientLibrarySettings + * @instance + */ + ClientLibrarySettings.prototype.nodeSettings = null; + + /** + * ClientLibrarySettings dotnetSettings. + * @member {google.api.IDotnetSettings|null|undefined} dotnetSettings + * @memberof google.api.ClientLibrarySettings + * @instance + */ + ClientLibrarySettings.prototype.dotnetSettings = null; + + /** + * ClientLibrarySettings rubySettings. + * @member {google.api.IRubySettings|null|undefined} rubySettings + * @memberof google.api.ClientLibrarySettings + * @instance + */ + ClientLibrarySettings.prototype.rubySettings = null; + + /** + * ClientLibrarySettings goSettings. + * @member {google.api.IGoSettings|null|undefined} goSettings + * @memberof google.api.ClientLibrarySettings + * @instance + */ + ClientLibrarySettings.prototype.goSettings = null; + + /** + * Creates a new ClientLibrarySettings instance using the specified properties. + * @function create + * @memberof google.api.ClientLibrarySettings + * @static + * @param {google.api.IClientLibrarySettings=} [properties] Properties to set + * @returns {google.api.ClientLibrarySettings} ClientLibrarySettings instance + */ + ClientLibrarySettings.create = function create(properties) { + return new ClientLibrarySettings(properties); + }; + + /** + * Encodes the specified ClientLibrarySettings message. Does not implicitly {@link google.api.ClientLibrarySettings.verify|verify} messages. + * @function encode + * @memberof google.api.ClientLibrarySettings + * @static + * @param {google.api.IClientLibrarySettings} message ClientLibrarySettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ClientLibrarySettings.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.version != null && Object.hasOwnProperty.call(message, "version")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.version); + if (message.launchStage != null && Object.hasOwnProperty.call(message, "launchStage")) + writer.uint32(/* id 2, wireType 0 =*/16).int32(message.launchStage); + if (message.restNumericEnums != null && Object.hasOwnProperty.call(message, "restNumericEnums")) + writer.uint32(/* id 3, wireType 0 =*/24).bool(message.restNumericEnums); + if (message.javaSettings != null && Object.hasOwnProperty.call(message, "javaSettings")) + $root.google.api.JavaSettings.encode(message.javaSettings, writer.uint32(/* id 21, wireType 2 =*/170).fork()).ldelim(); + if (message.cppSettings != null && Object.hasOwnProperty.call(message, "cppSettings")) + $root.google.api.CppSettings.encode(message.cppSettings, writer.uint32(/* id 22, wireType 2 =*/178).fork()).ldelim(); + if (message.phpSettings != null && Object.hasOwnProperty.call(message, "phpSettings")) + $root.google.api.PhpSettings.encode(message.phpSettings, writer.uint32(/* id 23, wireType 2 =*/186).fork()).ldelim(); + if (message.pythonSettings != null && Object.hasOwnProperty.call(message, "pythonSettings")) + $root.google.api.PythonSettings.encode(message.pythonSettings, writer.uint32(/* id 24, wireType 2 =*/194).fork()).ldelim(); + if (message.nodeSettings != null && Object.hasOwnProperty.call(message, "nodeSettings")) + $root.google.api.NodeSettings.encode(message.nodeSettings, writer.uint32(/* id 25, wireType 2 =*/202).fork()).ldelim(); + if (message.dotnetSettings != null && Object.hasOwnProperty.call(message, "dotnetSettings")) + $root.google.api.DotnetSettings.encode(message.dotnetSettings, writer.uint32(/* id 26, wireType 2 =*/210).fork()).ldelim(); + if (message.rubySettings != null && Object.hasOwnProperty.call(message, "rubySettings")) + $root.google.api.RubySettings.encode(message.rubySettings, writer.uint32(/* id 27, wireType 2 =*/218).fork()).ldelim(); + if (message.goSettings != null && Object.hasOwnProperty.call(message, "goSettings")) + $root.google.api.GoSettings.encode(message.goSettings, writer.uint32(/* id 28, wireType 2 =*/226).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified ClientLibrarySettings message, length delimited. Does not implicitly {@link google.api.ClientLibrarySettings.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.ClientLibrarySettings + * @static + * @param {google.api.IClientLibrarySettings} message ClientLibrarySettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ClientLibrarySettings.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ClientLibrarySettings message from the specified reader or buffer. + * @function decode + * @memberof google.api.ClientLibrarySettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.ClientLibrarySettings} ClientLibrarySettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ClientLibrarySettings.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.ClientLibrarySettings(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.version = reader.string(); + break; + } + case 2: { + message.launchStage = reader.int32(); + break; + } + case 3: { + message.restNumericEnums = reader.bool(); + break; + } + case 21: { + message.javaSettings = $root.google.api.JavaSettings.decode(reader, reader.uint32()); + break; + } + case 22: { + message.cppSettings = $root.google.api.CppSettings.decode(reader, reader.uint32()); + break; + } + case 23: { + message.phpSettings = $root.google.api.PhpSettings.decode(reader, reader.uint32()); + break; + } + case 24: { + message.pythonSettings = $root.google.api.PythonSettings.decode(reader, reader.uint32()); + break; + } + case 25: { + message.nodeSettings = $root.google.api.NodeSettings.decode(reader, reader.uint32()); + break; + } + case 26: { + message.dotnetSettings = $root.google.api.DotnetSettings.decode(reader, reader.uint32()); + break; + } + case 27: { + message.rubySettings = $root.google.api.RubySettings.decode(reader, reader.uint32()); + break; + } + case 28: { + message.goSettings = $root.google.api.GoSettings.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ClientLibrarySettings message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.ClientLibrarySettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.ClientLibrarySettings} ClientLibrarySettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ClientLibrarySettings.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ClientLibrarySettings message. + * @function verify + * @memberof google.api.ClientLibrarySettings + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ClientLibrarySettings.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.version != null && message.hasOwnProperty("version")) + if (!$util.isString(message.version)) + return "version: string expected"; + if (message.launchStage != null && message.hasOwnProperty("launchStage")) + switch (message.launchStage) { + default: + return "launchStage: enum value expected"; + case 0: + case 6: + case 7: + case 1: + case 2: + case 3: + case 4: + case 5: + break; + } + if (message.restNumericEnums != null && message.hasOwnProperty("restNumericEnums")) + if (typeof message.restNumericEnums !== "boolean") + return "restNumericEnums: boolean expected"; + if (message.javaSettings != null && message.hasOwnProperty("javaSettings")) { + var error = $root.google.api.JavaSettings.verify(message.javaSettings); + if (error) + return "javaSettings." + error; + } + if (message.cppSettings != null && message.hasOwnProperty("cppSettings")) { + var error = $root.google.api.CppSettings.verify(message.cppSettings); + if (error) + return "cppSettings." + error; + } + if (message.phpSettings != null && message.hasOwnProperty("phpSettings")) { + var error = $root.google.api.PhpSettings.verify(message.phpSettings); + if (error) + return "phpSettings." + error; + } + if (message.pythonSettings != null && message.hasOwnProperty("pythonSettings")) { + var error = $root.google.api.PythonSettings.verify(message.pythonSettings); + if (error) + return "pythonSettings." + error; + } + if (message.nodeSettings != null && message.hasOwnProperty("nodeSettings")) { + var error = $root.google.api.NodeSettings.verify(message.nodeSettings); + if (error) + return "nodeSettings." + error; + } + if (message.dotnetSettings != null && message.hasOwnProperty("dotnetSettings")) { + var error = $root.google.api.DotnetSettings.verify(message.dotnetSettings); + if (error) + return "dotnetSettings." + error; + } + if (message.rubySettings != null && message.hasOwnProperty("rubySettings")) { + var error = $root.google.api.RubySettings.verify(message.rubySettings); + if (error) + return "rubySettings." + error; + } + if (message.goSettings != null && message.hasOwnProperty("goSettings")) { + var error = $root.google.api.GoSettings.verify(message.goSettings); + if (error) + return "goSettings." + error; + } + return null; + }; + + /** + * Creates a ClientLibrarySettings message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.ClientLibrarySettings + * @static + * @param {Object.} object Plain object + * @returns {google.api.ClientLibrarySettings} ClientLibrarySettings + */ + ClientLibrarySettings.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.ClientLibrarySettings) + return object; + var message = new $root.google.api.ClientLibrarySettings(); + if (object.version != null) + message.version = String(object.version); + switch (object.launchStage) { + default: + if (typeof object.launchStage === "number") { + message.launchStage = object.launchStage; + break; + } + break; + case "LAUNCH_STAGE_UNSPECIFIED": + case 0: + message.launchStage = 0; + break; + case "UNIMPLEMENTED": + case 6: + message.launchStage = 6; + break; + case "PRELAUNCH": + case 7: + message.launchStage = 7; + break; + case "EARLY_ACCESS": + case 1: + message.launchStage = 1; + break; + case "ALPHA": + case 2: + message.launchStage = 2; + break; + case "BETA": + case 3: + message.launchStage = 3; + break; + case "GA": + case 4: + message.launchStage = 4; + break; + case "DEPRECATED": + case 5: + message.launchStage = 5; + break; + } + if (object.restNumericEnums != null) + message.restNumericEnums = Boolean(object.restNumericEnums); + if (object.javaSettings != null) { + if (typeof object.javaSettings !== "object") + throw TypeError(".google.api.ClientLibrarySettings.javaSettings: object expected"); + message.javaSettings = $root.google.api.JavaSettings.fromObject(object.javaSettings); + } + if (object.cppSettings != null) { + if (typeof object.cppSettings !== "object") + throw TypeError(".google.api.ClientLibrarySettings.cppSettings: object expected"); + message.cppSettings = $root.google.api.CppSettings.fromObject(object.cppSettings); + } + if (object.phpSettings != null) { + if (typeof object.phpSettings !== "object") + throw TypeError(".google.api.ClientLibrarySettings.phpSettings: object expected"); + message.phpSettings = $root.google.api.PhpSettings.fromObject(object.phpSettings); + } + if (object.pythonSettings != null) { + if (typeof object.pythonSettings !== "object") + throw TypeError(".google.api.ClientLibrarySettings.pythonSettings: object expected"); + message.pythonSettings = $root.google.api.PythonSettings.fromObject(object.pythonSettings); + } + if (object.nodeSettings != null) { + if (typeof object.nodeSettings !== "object") + throw TypeError(".google.api.ClientLibrarySettings.nodeSettings: object expected"); + message.nodeSettings = $root.google.api.NodeSettings.fromObject(object.nodeSettings); + } + if (object.dotnetSettings != null) { + if (typeof object.dotnetSettings !== "object") + throw TypeError(".google.api.ClientLibrarySettings.dotnetSettings: object expected"); + message.dotnetSettings = $root.google.api.DotnetSettings.fromObject(object.dotnetSettings); + } + if (object.rubySettings != null) { + if (typeof object.rubySettings !== "object") + throw TypeError(".google.api.ClientLibrarySettings.rubySettings: object expected"); + message.rubySettings = $root.google.api.RubySettings.fromObject(object.rubySettings); + } + if (object.goSettings != null) { + if (typeof object.goSettings !== "object") + throw TypeError(".google.api.ClientLibrarySettings.goSettings: object expected"); + message.goSettings = $root.google.api.GoSettings.fromObject(object.goSettings); + } + return message; + }; + + /** + * Creates a plain object from a ClientLibrarySettings message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.ClientLibrarySettings + * @static + * @param {google.api.ClientLibrarySettings} message ClientLibrarySettings + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ClientLibrarySettings.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.version = ""; + object.launchStage = options.enums === String ? "LAUNCH_STAGE_UNSPECIFIED" : 0; + object.restNumericEnums = false; + object.javaSettings = null; + object.cppSettings = null; + object.phpSettings = null; + object.pythonSettings = null; + object.nodeSettings = null; + object.dotnetSettings = null; + object.rubySettings = null; + object.goSettings = null; + } + if (message.version != null && message.hasOwnProperty("version")) + object.version = message.version; + if (message.launchStage != null && message.hasOwnProperty("launchStage")) + object.launchStage = options.enums === String ? $root.google.api.LaunchStage[message.launchStage] === undefined ? message.launchStage : $root.google.api.LaunchStage[message.launchStage] : message.launchStage; + if (message.restNumericEnums != null && message.hasOwnProperty("restNumericEnums")) + object.restNumericEnums = message.restNumericEnums; + if (message.javaSettings != null && message.hasOwnProperty("javaSettings")) + object.javaSettings = $root.google.api.JavaSettings.toObject(message.javaSettings, options); + if (message.cppSettings != null && message.hasOwnProperty("cppSettings")) + object.cppSettings = $root.google.api.CppSettings.toObject(message.cppSettings, options); + if (message.phpSettings != null && message.hasOwnProperty("phpSettings")) + object.phpSettings = $root.google.api.PhpSettings.toObject(message.phpSettings, options); + if (message.pythonSettings != null && message.hasOwnProperty("pythonSettings")) + object.pythonSettings = $root.google.api.PythonSettings.toObject(message.pythonSettings, options); + if (message.nodeSettings != null && message.hasOwnProperty("nodeSettings")) + object.nodeSettings = $root.google.api.NodeSettings.toObject(message.nodeSettings, options); + if (message.dotnetSettings != null && message.hasOwnProperty("dotnetSettings")) + object.dotnetSettings = $root.google.api.DotnetSettings.toObject(message.dotnetSettings, options); + if (message.rubySettings != null && message.hasOwnProperty("rubySettings")) + object.rubySettings = $root.google.api.RubySettings.toObject(message.rubySettings, options); + if (message.goSettings != null && message.hasOwnProperty("goSettings")) + object.goSettings = $root.google.api.GoSettings.toObject(message.goSettings, options); + return object; + }; + + /** + * Converts this ClientLibrarySettings to JSON. + * @function toJSON + * @memberof google.api.ClientLibrarySettings + * @instance + * @returns {Object.} JSON object + */ + ClientLibrarySettings.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ClientLibrarySettings + * @function getTypeUrl + * @memberof google.api.ClientLibrarySettings + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ClientLibrarySettings.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.ClientLibrarySettings"; + }; + + return ClientLibrarySettings; + })(); + + api.Publishing = (function() { + + /** + * Properties of a Publishing. + * @memberof google.api + * @interface IPublishing + * @property {Array.|null} [methodSettings] Publishing methodSettings + * @property {string|null} [newIssueUri] Publishing newIssueUri + * @property {string|null} [documentationUri] Publishing documentationUri + * @property {string|null} [apiShortName] Publishing apiShortName + * @property {string|null} [githubLabel] Publishing githubLabel + * @property {Array.|null} [codeownerGithubTeams] Publishing codeownerGithubTeams + * @property {string|null} [docTagPrefix] Publishing docTagPrefix + * @property {google.api.ClientLibraryOrganization|null} [organization] Publishing organization + * @property {Array.|null} [librarySettings] Publishing librarySettings + */ + + /** + * Constructs a new Publishing. + * @memberof google.api + * @classdesc Represents a Publishing. + * @implements IPublishing + * @constructor + * @param {google.api.IPublishing=} [properties] Properties to set + */ + function Publishing(properties) { + this.methodSettings = []; + this.codeownerGithubTeams = []; + this.librarySettings = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Publishing methodSettings. + * @member {Array.} methodSettings + * @memberof google.api.Publishing + * @instance + */ + Publishing.prototype.methodSettings = $util.emptyArray; + + /** + * Publishing newIssueUri. + * @member {string} newIssueUri + * @memberof google.api.Publishing + * @instance + */ + Publishing.prototype.newIssueUri = ""; + + /** + * Publishing documentationUri. + * @member {string} documentationUri + * @memberof google.api.Publishing + * @instance + */ + Publishing.prototype.documentationUri = ""; + + /** + * Publishing apiShortName. + * @member {string} apiShortName + * @memberof google.api.Publishing + * @instance + */ + Publishing.prototype.apiShortName = ""; + + /** + * Publishing githubLabel. + * @member {string} githubLabel + * @memberof google.api.Publishing + * @instance + */ + Publishing.prototype.githubLabel = ""; + + /** + * Publishing codeownerGithubTeams. + * @member {Array.} codeownerGithubTeams + * @memberof google.api.Publishing + * @instance + */ + Publishing.prototype.codeownerGithubTeams = $util.emptyArray; + + /** + * Publishing docTagPrefix. + * @member {string} docTagPrefix + * @memberof google.api.Publishing + * @instance + */ + Publishing.prototype.docTagPrefix = ""; + + /** + * Publishing organization. + * @member {google.api.ClientLibraryOrganization} organization + * @memberof google.api.Publishing + * @instance + */ + Publishing.prototype.organization = 0; + + /** + * Publishing librarySettings. + * @member {Array.} librarySettings + * @memberof google.api.Publishing + * @instance + */ + Publishing.prototype.librarySettings = $util.emptyArray; + + /** + * Creates a new Publishing instance using the specified properties. + * @function create + * @memberof google.api.Publishing + * @static + * @param {google.api.IPublishing=} [properties] Properties to set + * @returns {google.api.Publishing} Publishing instance + */ + Publishing.create = function create(properties) { + return new Publishing(properties); + }; + + /** + * Encodes the specified Publishing message. Does not implicitly {@link google.api.Publishing.verify|verify} messages. + * @function encode + * @memberof google.api.Publishing + * @static + * @param {google.api.IPublishing} message Publishing message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Publishing.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.methodSettings != null && message.methodSettings.length) + for (var i = 0; i < message.methodSettings.length; ++i) + $root.google.api.MethodSettings.encode(message.methodSettings[i], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.newIssueUri != null && Object.hasOwnProperty.call(message, "newIssueUri")) + writer.uint32(/* id 101, wireType 2 =*/810).string(message.newIssueUri); + if (message.documentationUri != null && Object.hasOwnProperty.call(message, "documentationUri")) + writer.uint32(/* id 102, wireType 2 =*/818).string(message.documentationUri); + if (message.apiShortName != null && Object.hasOwnProperty.call(message, "apiShortName")) + writer.uint32(/* id 103, wireType 2 =*/826).string(message.apiShortName); + if (message.githubLabel != null && Object.hasOwnProperty.call(message, "githubLabel")) + writer.uint32(/* id 104, wireType 2 =*/834).string(message.githubLabel); + if (message.codeownerGithubTeams != null && message.codeownerGithubTeams.length) + for (var i = 0; i < message.codeownerGithubTeams.length; ++i) + writer.uint32(/* id 105, wireType 2 =*/842).string(message.codeownerGithubTeams[i]); + if (message.docTagPrefix != null && Object.hasOwnProperty.call(message, "docTagPrefix")) + writer.uint32(/* id 106, wireType 2 =*/850).string(message.docTagPrefix); + if (message.organization != null && Object.hasOwnProperty.call(message, "organization")) + writer.uint32(/* id 107, wireType 0 =*/856).int32(message.organization); + if (message.librarySettings != null && message.librarySettings.length) + for (var i = 0; i < message.librarySettings.length; ++i) + $root.google.api.ClientLibrarySettings.encode(message.librarySettings[i], writer.uint32(/* id 109, wireType 2 =*/874).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified Publishing message, length delimited. Does not implicitly {@link google.api.Publishing.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.Publishing + * @static + * @param {google.api.IPublishing} message Publishing message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Publishing.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a Publishing message from the specified reader or buffer. + * @function decode + * @memberof google.api.Publishing + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.Publishing} Publishing + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Publishing.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.Publishing(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 2: { + if (!(message.methodSettings && message.methodSettings.length)) + message.methodSettings = []; + message.methodSettings.push($root.google.api.MethodSettings.decode(reader, reader.uint32())); + break; + } + case 101: { + message.newIssueUri = reader.string(); + break; + } + case 102: { + message.documentationUri = reader.string(); + break; + } + case 103: { + message.apiShortName = reader.string(); + break; + } + case 104: { + message.githubLabel = reader.string(); + break; + } + case 105: { + if (!(message.codeownerGithubTeams && message.codeownerGithubTeams.length)) + message.codeownerGithubTeams = []; + message.codeownerGithubTeams.push(reader.string()); + break; + } + case 106: { + message.docTagPrefix = reader.string(); + break; + } + case 107: { + message.organization = reader.int32(); + break; + } + case 109: { + if (!(message.librarySettings && message.librarySettings.length)) + message.librarySettings = []; + message.librarySettings.push($root.google.api.ClientLibrarySettings.decode(reader, reader.uint32())); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a Publishing message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.Publishing + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.Publishing} Publishing + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Publishing.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a Publishing message. + * @function verify + * @memberof google.api.Publishing + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Publishing.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.methodSettings != null && message.hasOwnProperty("methodSettings")) { + if (!Array.isArray(message.methodSettings)) + return "methodSettings: array expected"; + for (var i = 0; i < message.methodSettings.length; ++i) { + var error = $root.google.api.MethodSettings.verify(message.methodSettings[i]); + if (error) + return "methodSettings." + error; + } + } + if (message.newIssueUri != null && message.hasOwnProperty("newIssueUri")) + if (!$util.isString(message.newIssueUri)) + return "newIssueUri: string expected"; + if (message.documentationUri != null && message.hasOwnProperty("documentationUri")) + if (!$util.isString(message.documentationUri)) + return "documentationUri: string expected"; + if (message.apiShortName != null && message.hasOwnProperty("apiShortName")) + if (!$util.isString(message.apiShortName)) + return "apiShortName: string expected"; + if (message.githubLabel != null && message.hasOwnProperty("githubLabel")) + if (!$util.isString(message.githubLabel)) + return "githubLabel: string expected"; + if (message.codeownerGithubTeams != null && message.hasOwnProperty("codeownerGithubTeams")) { + if (!Array.isArray(message.codeownerGithubTeams)) + return "codeownerGithubTeams: array expected"; + for (var i = 0; i < message.codeownerGithubTeams.length; ++i) + if (!$util.isString(message.codeownerGithubTeams[i])) + return "codeownerGithubTeams: string[] expected"; + } + if (message.docTagPrefix != null && message.hasOwnProperty("docTagPrefix")) + if (!$util.isString(message.docTagPrefix)) + return "docTagPrefix: string expected"; + if (message.organization != null && message.hasOwnProperty("organization")) + switch (message.organization) { + default: + return "organization: enum value expected"; + case 0: + case 1: + case 2: + case 3: + case 4: + break; + } + if (message.librarySettings != null && message.hasOwnProperty("librarySettings")) { + if (!Array.isArray(message.librarySettings)) + return "librarySettings: array expected"; + for (var i = 0; i < message.librarySettings.length; ++i) { + var error = $root.google.api.ClientLibrarySettings.verify(message.librarySettings[i]); + if (error) + return "librarySettings." + error; + } + } + return null; + }; + + /** + * Creates a Publishing message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.Publishing + * @static + * @param {Object.} object Plain object + * @returns {google.api.Publishing} Publishing + */ + Publishing.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.Publishing) + return object; + var message = new $root.google.api.Publishing(); + if (object.methodSettings) { + if (!Array.isArray(object.methodSettings)) + throw TypeError(".google.api.Publishing.methodSettings: array expected"); + message.methodSettings = []; + for (var i = 0; i < object.methodSettings.length; ++i) { + if (typeof object.methodSettings[i] !== "object") + throw TypeError(".google.api.Publishing.methodSettings: object expected"); + message.methodSettings[i] = $root.google.api.MethodSettings.fromObject(object.methodSettings[i]); + } + } + if (object.newIssueUri != null) + message.newIssueUri = String(object.newIssueUri); + if (object.documentationUri != null) + message.documentationUri = String(object.documentationUri); + if (object.apiShortName != null) + message.apiShortName = String(object.apiShortName); + if (object.githubLabel != null) + message.githubLabel = String(object.githubLabel); + if (object.codeownerGithubTeams) { + if (!Array.isArray(object.codeownerGithubTeams)) + throw TypeError(".google.api.Publishing.codeownerGithubTeams: array expected"); + message.codeownerGithubTeams = []; + for (var i = 0; i < object.codeownerGithubTeams.length; ++i) + message.codeownerGithubTeams[i] = String(object.codeownerGithubTeams[i]); + } + if (object.docTagPrefix != null) + message.docTagPrefix = String(object.docTagPrefix); + switch (object.organization) { + default: + if (typeof object.organization === "number") { + message.organization = object.organization; + break; + } + break; + case "CLIENT_LIBRARY_ORGANIZATION_UNSPECIFIED": + case 0: + message.organization = 0; + break; + case "CLOUD": + case 1: + message.organization = 1; + break; + case "ADS": + case 2: + message.organization = 2; + break; + case "PHOTOS": + case 3: + message.organization = 3; + break; + case "STREET_VIEW": + case 4: + message.organization = 4; + break; + } + if (object.librarySettings) { + if (!Array.isArray(object.librarySettings)) + throw TypeError(".google.api.Publishing.librarySettings: array expected"); + message.librarySettings = []; + for (var i = 0; i < object.librarySettings.length; ++i) { + if (typeof object.librarySettings[i] !== "object") + throw TypeError(".google.api.Publishing.librarySettings: object expected"); + message.librarySettings[i] = $root.google.api.ClientLibrarySettings.fromObject(object.librarySettings[i]); + } + } + return message; + }; + + /** + * Creates a plain object from a Publishing message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.Publishing + * @static + * @param {google.api.Publishing} message Publishing + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Publishing.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.methodSettings = []; + object.codeownerGithubTeams = []; + object.librarySettings = []; + } + if (options.defaults) { + object.newIssueUri = ""; + object.documentationUri = ""; + object.apiShortName = ""; + object.githubLabel = ""; + object.docTagPrefix = ""; + object.organization = options.enums === String ? "CLIENT_LIBRARY_ORGANIZATION_UNSPECIFIED" : 0; + } + if (message.methodSettings && message.methodSettings.length) { + object.methodSettings = []; + for (var j = 0; j < message.methodSettings.length; ++j) + object.methodSettings[j] = $root.google.api.MethodSettings.toObject(message.methodSettings[j], options); + } + if (message.newIssueUri != null && message.hasOwnProperty("newIssueUri")) + object.newIssueUri = message.newIssueUri; + if (message.documentationUri != null && message.hasOwnProperty("documentationUri")) + object.documentationUri = message.documentationUri; + if (message.apiShortName != null && message.hasOwnProperty("apiShortName")) + object.apiShortName = message.apiShortName; + if (message.githubLabel != null && message.hasOwnProperty("githubLabel")) + object.githubLabel = message.githubLabel; + if (message.codeownerGithubTeams && message.codeownerGithubTeams.length) { + object.codeownerGithubTeams = []; + for (var j = 0; j < message.codeownerGithubTeams.length; ++j) + object.codeownerGithubTeams[j] = message.codeownerGithubTeams[j]; + } + if (message.docTagPrefix != null && message.hasOwnProperty("docTagPrefix")) + object.docTagPrefix = message.docTagPrefix; + if (message.organization != null && message.hasOwnProperty("organization")) + object.organization = options.enums === String ? $root.google.api.ClientLibraryOrganization[message.organization] === undefined ? message.organization : $root.google.api.ClientLibraryOrganization[message.organization] : message.organization; + if (message.librarySettings && message.librarySettings.length) { + object.librarySettings = []; + for (var j = 0; j < message.librarySettings.length; ++j) + object.librarySettings[j] = $root.google.api.ClientLibrarySettings.toObject(message.librarySettings[j], options); + } + return object; + }; + + /** + * Converts this Publishing to JSON. + * @function toJSON + * @memberof google.api.Publishing + * @instance + * @returns {Object.} JSON object + */ + Publishing.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Publishing + * @function getTypeUrl + * @memberof google.api.Publishing + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Publishing.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.Publishing"; + }; + + return Publishing; + })(); + + api.JavaSettings = (function() { + + /** + * Properties of a JavaSettings. + * @memberof google.api + * @interface IJavaSettings + * @property {string|null} [libraryPackage] JavaSettings libraryPackage + * @property {Object.|null} [serviceClassNames] JavaSettings serviceClassNames + * @property {google.api.ICommonLanguageSettings|null} [common] JavaSettings common + */ + + /** + * Constructs a new JavaSettings. + * @memberof google.api + * @classdesc Represents a JavaSettings. + * @implements IJavaSettings + * @constructor + * @param {google.api.IJavaSettings=} [properties] Properties to set + */ + function JavaSettings(properties) { + this.serviceClassNames = {}; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * JavaSettings libraryPackage. + * @member {string} libraryPackage + * @memberof google.api.JavaSettings + * @instance + */ + JavaSettings.prototype.libraryPackage = ""; + + /** + * JavaSettings serviceClassNames. + * @member {Object.} serviceClassNames + * @memberof google.api.JavaSettings + * @instance + */ + JavaSettings.prototype.serviceClassNames = $util.emptyObject; + + /** + * JavaSettings common. + * @member {google.api.ICommonLanguageSettings|null|undefined} common + * @memberof google.api.JavaSettings + * @instance + */ + JavaSettings.prototype.common = null; + + /** + * Creates a new JavaSettings instance using the specified properties. + * @function create + * @memberof google.api.JavaSettings + * @static + * @param {google.api.IJavaSettings=} [properties] Properties to set + * @returns {google.api.JavaSettings} JavaSettings instance + */ + JavaSettings.create = function create(properties) { + return new JavaSettings(properties); + }; + + /** + * Encodes the specified JavaSettings message. Does not implicitly {@link google.api.JavaSettings.verify|verify} messages. + * @function encode + * @memberof google.api.JavaSettings + * @static + * @param {google.api.IJavaSettings} message JavaSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + JavaSettings.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.libraryPackage != null && Object.hasOwnProperty.call(message, "libraryPackage")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.libraryPackage); + if (message.serviceClassNames != null && Object.hasOwnProperty.call(message, "serviceClassNames")) + for (var keys = Object.keys(message.serviceClassNames), i = 0; i < keys.length; ++i) + writer.uint32(/* id 2, wireType 2 =*/18).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]).uint32(/* id 2, wireType 2 =*/18).string(message.serviceClassNames[keys[i]]).ldelim(); + if (message.common != null && Object.hasOwnProperty.call(message, "common")) + $root.google.api.CommonLanguageSettings.encode(message.common, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified JavaSettings message, length delimited. Does not implicitly {@link google.api.JavaSettings.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.JavaSettings + * @static + * @param {google.api.IJavaSettings} message JavaSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + JavaSettings.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a JavaSettings message from the specified reader or buffer. + * @function decode + * @memberof google.api.JavaSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.JavaSettings} JavaSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + JavaSettings.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.JavaSettings(), key, value; + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.libraryPackage = reader.string(); + break; + } + case 2: { + if (message.serviceClassNames === $util.emptyObject) + message.serviceClassNames = {}; + var end2 = reader.uint32() + reader.pos; + key = ""; + value = ""; + while (reader.pos < end2) { + var tag2 = reader.uint32(); + switch (tag2 >>> 3) { + case 1: + key = reader.string(); + break; + case 2: + value = reader.string(); + break; + default: + reader.skipType(tag2 & 7); + break; + } + } + message.serviceClassNames[key] = value; + break; + } + case 3: { + message.common = $root.google.api.CommonLanguageSettings.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a JavaSettings message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.JavaSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.JavaSettings} JavaSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + JavaSettings.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a JavaSettings message. + * @function verify + * @memberof google.api.JavaSettings + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + JavaSettings.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.libraryPackage != null && message.hasOwnProperty("libraryPackage")) + if (!$util.isString(message.libraryPackage)) + return "libraryPackage: string expected"; + if (message.serviceClassNames != null && message.hasOwnProperty("serviceClassNames")) { + if (!$util.isObject(message.serviceClassNames)) + return "serviceClassNames: object expected"; + var key = Object.keys(message.serviceClassNames); + for (var i = 0; i < key.length; ++i) + if (!$util.isString(message.serviceClassNames[key[i]])) + return "serviceClassNames: string{k:string} expected"; + } + if (message.common != null && message.hasOwnProperty("common")) { + var error = $root.google.api.CommonLanguageSettings.verify(message.common); + if (error) + return "common." + error; + } + return null; + }; + + /** + * Creates a JavaSettings message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.JavaSettings + * @static + * @param {Object.} object Plain object + * @returns {google.api.JavaSettings} JavaSettings + */ + JavaSettings.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.JavaSettings) + return object; + var message = new $root.google.api.JavaSettings(); + if (object.libraryPackage != null) + message.libraryPackage = String(object.libraryPackage); + if (object.serviceClassNames) { + if (typeof object.serviceClassNames !== "object") + throw TypeError(".google.api.JavaSettings.serviceClassNames: object expected"); + message.serviceClassNames = {}; + for (var keys = Object.keys(object.serviceClassNames), i = 0; i < keys.length; ++i) + message.serviceClassNames[keys[i]] = String(object.serviceClassNames[keys[i]]); + } + if (object.common != null) { + if (typeof object.common !== "object") + throw TypeError(".google.api.JavaSettings.common: object expected"); + message.common = $root.google.api.CommonLanguageSettings.fromObject(object.common); + } + return message; + }; + + /** + * Creates a plain object from a JavaSettings message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.JavaSettings + * @static + * @param {google.api.JavaSettings} message JavaSettings + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + JavaSettings.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.objects || options.defaults) + object.serviceClassNames = {}; + if (options.defaults) { + object.libraryPackage = ""; + object.common = null; + } + if (message.libraryPackage != null && message.hasOwnProperty("libraryPackage")) + object.libraryPackage = message.libraryPackage; + var keys2; + if (message.serviceClassNames && (keys2 = Object.keys(message.serviceClassNames)).length) { + object.serviceClassNames = {}; + for (var j = 0; j < keys2.length; ++j) + object.serviceClassNames[keys2[j]] = message.serviceClassNames[keys2[j]]; + } + if (message.common != null && message.hasOwnProperty("common")) + object.common = $root.google.api.CommonLanguageSettings.toObject(message.common, options); + return object; + }; + + /** + * Converts this JavaSettings to JSON. + * @function toJSON + * @memberof google.api.JavaSettings + * @instance + * @returns {Object.} JSON object + */ + JavaSettings.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for JavaSettings + * @function getTypeUrl + * @memberof google.api.JavaSettings + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + JavaSettings.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.JavaSettings"; + }; + + return JavaSettings; + })(); + + api.CppSettings = (function() { + + /** + * Properties of a CppSettings. + * @memberof google.api + * @interface ICppSettings + * @property {google.api.ICommonLanguageSettings|null} [common] CppSettings common + */ + + /** + * Constructs a new CppSettings. + * @memberof google.api + * @classdesc Represents a CppSettings. + * @implements ICppSettings + * @constructor + * @param {google.api.ICppSettings=} [properties] Properties to set + */ + function CppSettings(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * CppSettings common. + * @member {google.api.ICommonLanguageSettings|null|undefined} common + * @memberof google.api.CppSettings + * @instance + */ + CppSettings.prototype.common = null; + + /** + * Creates a new CppSettings instance using the specified properties. + * @function create + * @memberof google.api.CppSettings + * @static + * @param {google.api.ICppSettings=} [properties] Properties to set + * @returns {google.api.CppSettings} CppSettings instance + */ + CppSettings.create = function create(properties) { + return new CppSettings(properties); + }; + + /** + * Encodes the specified CppSettings message. Does not implicitly {@link google.api.CppSettings.verify|verify} messages. + * @function encode + * @memberof google.api.CppSettings + * @static + * @param {google.api.ICppSettings} message CppSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + CppSettings.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.common != null && Object.hasOwnProperty.call(message, "common")) + $root.google.api.CommonLanguageSettings.encode(message.common, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified CppSettings message, length delimited. Does not implicitly {@link google.api.CppSettings.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.CppSettings + * @static + * @param {google.api.ICppSettings} message CppSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + CppSettings.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a CppSettings message from the specified reader or buffer. + * @function decode + * @memberof google.api.CppSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.CppSettings} CppSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + CppSettings.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.CppSettings(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.common = $root.google.api.CommonLanguageSettings.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a CppSettings message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.CppSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.CppSettings} CppSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + CppSettings.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a CppSettings message. + * @function verify + * @memberof google.api.CppSettings + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + CppSettings.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.common != null && message.hasOwnProperty("common")) { + var error = $root.google.api.CommonLanguageSettings.verify(message.common); + if (error) + return "common." + error; + } + return null; + }; + + /** + * Creates a CppSettings message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.CppSettings + * @static + * @param {Object.} object Plain object + * @returns {google.api.CppSettings} CppSettings + */ + CppSettings.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.CppSettings) + return object; + var message = new $root.google.api.CppSettings(); + if (object.common != null) { + if (typeof object.common !== "object") + throw TypeError(".google.api.CppSettings.common: object expected"); + message.common = $root.google.api.CommonLanguageSettings.fromObject(object.common); + } + return message; + }; + + /** + * Creates a plain object from a CppSettings message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.CppSettings + * @static + * @param {google.api.CppSettings} message CppSettings + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + CppSettings.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.common = null; + if (message.common != null && message.hasOwnProperty("common")) + object.common = $root.google.api.CommonLanguageSettings.toObject(message.common, options); + return object; + }; + + /** + * Converts this CppSettings to JSON. + * @function toJSON + * @memberof google.api.CppSettings + * @instance + * @returns {Object.} JSON object + */ + CppSettings.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for CppSettings + * @function getTypeUrl + * @memberof google.api.CppSettings + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + CppSettings.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.CppSettings"; + }; + + return CppSettings; + })(); + + api.PhpSettings = (function() { + + /** + * Properties of a PhpSettings. + * @memberof google.api + * @interface IPhpSettings + * @property {google.api.ICommonLanguageSettings|null} [common] PhpSettings common + */ + + /** + * Constructs a new PhpSettings. + * @memberof google.api + * @classdesc Represents a PhpSettings. + * @implements IPhpSettings + * @constructor + * @param {google.api.IPhpSettings=} [properties] Properties to set + */ + function PhpSettings(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * PhpSettings common. + * @member {google.api.ICommonLanguageSettings|null|undefined} common + * @memberof google.api.PhpSettings + * @instance + */ + PhpSettings.prototype.common = null; + + /** + * Creates a new PhpSettings instance using the specified properties. + * @function create + * @memberof google.api.PhpSettings + * @static + * @param {google.api.IPhpSettings=} [properties] Properties to set + * @returns {google.api.PhpSettings} PhpSettings instance + */ + PhpSettings.create = function create(properties) { + return new PhpSettings(properties); + }; + + /** + * Encodes the specified PhpSettings message. Does not implicitly {@link google.api.PhpSettings.verify|verify} messages. + * @function encode + * @memberof google.api.PhpSettings + * @static + * @param {google.api.IPhpSettings} message PhpSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + PhpSettings.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.common != null && Object.hasOwnProperty.call(message, "common")) + $root.google.api.CommonLanguageSettings.encode(message.common, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified PhpSettings message, length delimited. Does not implicitly {@link google.api.PhpSettings.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.PhpSettings + * @static + * @param {google.api.IPhpSettings} message PhpSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + PhpSettings.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a PhpSettings message from the specified reader or buffer. + * @function decode + * @memberof google.api.PhpSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.PhpSettings} PhpSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + PhpSettings.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.PhpSettings(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.common = $root.google.api.CommonLanguageSettings.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a PhpSettings message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.PhpSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.PhpSettings} PhpSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + PhpSettings.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a PhpSettings message. + * @function verify + * @memberof google.api.PhpSettings + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + PhpSettings.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.common != null && message.hasOwnProperty("common")) { + var error = $root.google.api.CommonLanguageSettings.verify(message.common); + if (error) + return "common." + error; + } + return null; + }; + + /** + * Creates a PhpSettings message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.PhpSettings + * @static + * @param {Object.} object Plain object + * @returns {google.api.PhpSettings} PhpSettings + */ + PhpSettings.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.PhpSettings) + return object; + var message = new $root.google.api.PhpSettings(); + if (object.common != null) { + if (typeof object.common !== "object") + throw TypeError(".google.api.PhpSettings.common: object expected"); + message.common = $root.google.api.CommonLanguageSettings.fromObject(object.common); + } + return message; + }; + + /** + * Creates a plain object from a PhpSettings message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.PhpSettings + * @static + * @param {google.api.PhpSettings} message PhpSettings + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + PhpSettings.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.common = null; + if (message.common != null && message.hasOwnProperty("common")) + object.common = $root.google.api.CommonLanguageSettings.toObject(message.common, options); + return object; + }; + + /** + * Converts this PhpSettings to JSON. + * @function toJSON + * @memberof google.api.PhpSettings + * @instance + * @returns {Object.} JSON object + */ + PhpSettings.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for PhpSettings + * @function getTypeUrl + * @memberof google.api.PhpSettings + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + PhpSettings.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.PhpSettings"; + }; + + return PhpSettings; + })(); + + api.PythonSettings = (function() { + + /** + * Properties of a PythonSettings. + * @memberof google.api + * @interface IPythonSettings + * @property {google.api.ICommonLanguageSettings|null} [common] PythonSettings common + */ + + /** + * Constructs a new PythonSettings. + * @memberof google.api + * @classdesc Represents a PythonSettings. + * @implements IPythonSettings + * @constructor + * @param {google.api.IPythonSettings=} [properties] Properties to set + */ + function PythonSettings(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * PythonSettings common. + * @member {google.api.ICommonLanguageSettings|null|undefined} common + * @memberof google.api.PythonSettings + * @instance + */ + PythonSettings.prototype.common = null; + + /** + * Creates a new PythonSettings instance using the specified properties. + * @function create + * @memberof google.api.PythonSettings + * @static + * @param {google.api.IPythonSettings=} [properties] Properties to set + * @returns {google.api.PythonSettings} PythonSettings instance + */ + PythonSettings.create = function create(properties) { + return new PythonSettings(properties); + }; + + /** + * Encodes the specified PythonSettings message. Does not implicitly {@link google.api.PythonSettings.verify|verify} messages. + * @function encode + * @memberof google.api.PythonSettings + * @static + * @param {google.api.IPythonSettings} message PythonSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + PythonSettings.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.common != null && Object.hasOwnProperty.call(message, "common")) + $root.google.api.CommonLanguageSettings.encode(message.common, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified PythonSettings message, length delimited. Does not implicitly {@link google.api.PythonSettings.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.PythonSettings + * @static + * @param {google.api.IPythonSettings} message PythonSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + PythonSettings.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a PythonSettings message from the specified reader or buffer. + * @function decode + * @memberof google.api.PythonSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.PythonSettings} PythonSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + PythonSettings.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.PythonSettings(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.common = $root.google.api.CommonLanguageSettings.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a PythonSettings message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.PythonSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.PythonSettings} PythonSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + PythonSettings.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a PythonSettings message. + * @function verify + * @memberof google.api.PythonSettings + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + PythonSettings.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.common != null && message.hasOwnProperty("common")) { + var error = $root.google.api.CommonLanguageSettings.verify(message.common); + if (error) + return "common." + error; + } + return null; + }; + + /** + * Creates a PythonSettings message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.PythonSettings + * @static + * @param {Object.} object Plain object + * @returns {google.api.PythonSettings} PythonSettings + */ + PythonSettings.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.PythonSettings) + return object; + var message = new $root.google.api.PythonSettings(); + if (object.common != null) { + if (typeof object.common !== "object") + throw TypeError(".google.api.PythonSettings.common: object expected"); + message.common = $root.google.api.CommonLanguageSettings.fromObject(object.common); + } + return message; + }; + + /** + * Creates a plain object from a PythonSettings message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.PythonSettings + * @static + * @param {google.api.PythonSettings} message PythonSettings + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + PythonSettings.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.common = null; + if (message.common != null && message.hasOwnProperty("common")) + object.common = $root.google.api.CommonLanguageSettings.toObject(message.common, options); + return object; + }; + + /** + * Converts this PythonSettings to JSON. + * @function toJSON + * @memberof google.api.PythonSettings + * @instance + * @returns {Object.} JSON object + */ + PythonSettings.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for PythonSettings + * @function getTypeUrl + * @memberof google.api.PythonSettings + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + PythonSettings.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.PythonSettings"; + }; + + return PythonSettings; + })(); + + api.NodeSettings = (function() { + + /** + * Properties of a NodeSettings. + * @memberof google.api + * @interface INodeSettings + * @property {google.api.ICommonLanguageSettings|null} [common] NodeSettings common + */ + + /** + * Constructs a new NodeSettings. + * @memberof google.api + * @classdesc Represents a NodeSettings. + * @implements INodeSettings + * @constructor + * @param {google.api.INodeSettings=} [properties] Properties to set + */ + function NodeSettings(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * NodeSettings common. + * @member {google.api.ICommonLanguageSettings|null|undefined} common + * @memberof google.api.NodeSettings + * @instance + */ + NodeSettings.prototype.common = null; + + /** + * Creates a new NodeSettings instance using the specified properties. + * @function create + * @memberof google.api.NodeSettings + * @static + * @param {google.api.INodeSettings=} [properties] Properties to set + * @returns {google.api.NodeSettings} NodeSettings instance + */ + NodeSettings.create = function create(properties) { + return new NodeSettings(properties); + }; + + /** + * Encodes the specified NodeSettings message. Does not implicitly {@link google.api.NodeSettings.verify|verify} messages. + * @function encode + * @memberof google.api.NodeSettings + * @static + * @param {google.api.INodeSettings} message NodeSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + NodeSettings.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.common != null && Object.hasOwnProperty.call(message, "common")) + $root.google.api.CommonLanguageSettings.encode(message.common, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified NodeSettings message, length delimited. Does not implicitly {@link google.api.NodeSettings.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.NodeSettings + * @static + * @param {google.api.INodeSettings} message NodeSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + NodeSettings.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a NodeSettings message from the specified reader or buffer. + * @function decode + * @memberof google.api.NodeSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.NodeSettings} NodeSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + NodeSettings.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.NodeSettings(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.common = $root.google.api.CommonLanguageSettings.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a NodeSettings message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.NodeSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.NodeSettings} NodeSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + NodeSettings.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a NodeSettings message. + * @function verify + * @memberof google.api.NodeSettings + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + NodeSettings.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.common != null && message.hasOwnProperty("common")) { + var error = $root.google.api.CommonLanguageSettings.verify(message.common); + if (error) + return "common." + error; + } + return null; + }; + + /** + * Creates a NodeSettings message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.NodeSettings + * @static + * @param {Object.} object Plain object + * @returns {google.api.NodeSettings} NodeSettings + */ + NodeSettings.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.NodeSettings) + return object; + var message = new $root.google.api.NodeSettings(); + if (object.common != null) { + if (typeof object.common !== "object") + throw TypeError(".google.api.NodeSettings.common: object expected"); + message.common = $root.google.api.CommonLanguageSettings.fromObject(object.common); + } + return message; + }; + + /** + * Creates a plain object from a NodeSettings message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.NodeSettings + * @static + * @param {google.api.NodeSettings} message NodeSettings + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + NodeSettings.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.common = null; + if (message.common != null && message.hasOwnProperty("common")) + object.common = $root.google.api.CommonLanguageSettings.toObject(message.common, options); + return object; + }; + + /** + * Converts this NodeSettings to JSON. + * @function toJSON + * @memberof google.api.NodeSettings + * @instance + * @returns {Object.} JSON object + */ + NodeSettings.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for NodeSettings + * @function getTypeUrl + * @memberof google.api.NodeSettings + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + NodeSettings.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.NodeSettings"; + }; + + return NodeSettings; + })(); + + api.DotnetSettings = (function() { + + /** + * Properties of a DotnetSettings. + * @memberof google.api + * @interface IDotnetSettings + * @property {google.api.ICommonLanguageSettings|null} [common] DotnetSettings common + */ + + /** + * Constructs a new DotnetSettings. + * @memberof google.api + * @classdesc Represents a DotnetSettings. + * @implements IDotnetSettings + * @constructor + * @param {google.api.IDotnetSettings=} [properties] Properties to set + */ + function DotnetSettings(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * DotnetSettings common. + * @member {google.api.ICommonLanguageSettings|null|undefined} common + * @memberof google.api.DotnetSettings + * @instance + */ + DotnetSettings.prototype.common = null; + + /** + * Creates a new DotnetSettings instance using the specified properties. + * @function create + * @memberof google.api.DotnetSettings + * @static + * @param {google.api.IDotnetSettings=} [properties] Properties to set + * @returns {google.api.DotnetSettings} DotnetSettings instance + */ + DotnetSettings.create = function create(properties) { + return new DotnetSettings(properties); + }; + + /** + * Encodes the specified DotnetSettings message. Does not implicitly {@link google.api.DotnetSettings.verify|verify} messages. + * @function encode + * @memberof google.api.DotnetSettings + * @static + * @param {google.api.IDotnetSettings} message DotnetSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DotnetSettings.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.common != null && Object.hasOwnProperty.call(message, "common")) + $root.google.api.CommonLanguageSettings.encode(message.common, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified DotnetSettings message, length delimited. Does not implicitly {@link google.api.DotnetSettings.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.DotnetSettings + * @static + * @param {google.api.IDotnetSettings} message DotnetSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DotnetSettings.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a DotnetSettings message from the specified reader or buffer. + * @function decode + * @memberof google.api.DotnetSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.DotnetSettings} DotnetSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DotnetSettings.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.DotnetSettings(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.common = $root.google.api.CommonLanguageSettings.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a DotnetSettings message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.DotnetSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.DotnetSettings} DotnetSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DotnetSettings.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a DotnetSettings message. + * @function verify + * @memberof google.api.DotnetSettings + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + DotnetSettings.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.common != null && message.hasOwnProperty("common")) { + var error = $root.google.api.CommonLanguageSettings.verify(message.common); + if (error) + return "common." + error; + } + return null; + }; + + /** + * Creates a DotnetSettings message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.DotnetSettings + * @static + * @param {Object.} object Plain object + * @returns {google.api.DotnetSettings} DotnetSettings + */ + DotnetSettings.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.DotnetSettings) + return object; + var message = new $root.google.api.DotnetSettings(); + if (object.common != null) { + if (typeof object.common !== "object") + throw TypeError(".google.api.DotnetSettings.common: object expected"); + message.common = $root.google.api.CommonLanguageSettings.fromObject(object.common); + } + return message; + }; + + /** + * Creates a plain object from a DotnetSettings message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.DotnetSettings + * @static + * @param {google.api.DotnetSettings} message DotnetSettings + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + DotnetSettings.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.common = null; + if (message.common != null && message.hasOwnProperty("common")) + object.common = $root.google.api.CommonLanguageSettings.toObject(message.common, options); + return object; + }; + + /** + * Converts this DotnetSettings to JSON. + * @function toJSON + * @memberof google.api.DotnetSettings + * @instance + * @returns {Object.} JSON object + */ + DotnetSettings.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for DotnetSettings + * @function getTypeUrl + * @memberof google.api.DotnetSettings + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + DotnetSettings.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.DotnetSettings"; + }; + + return DotnetSettings; + })(); + + api.RubySettings = (function() { + + /** + * Properties of a RubySettings. + * @memberof google.api + * @interface IRubySettings + * @property {google.api.ICommonLanguageSettings|null} [common] RubySettings common + */ + + /** + * Constructs a new RubySettings. + * @memberof google.api + * @classdesc Represents a RubySettings. + * @implements IRubySettings + * @constructor + * @param {google.api.IRubySettings=} [properties] Properties to set + */ + function RubySettings(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * RubySettings common. + * @member {google.api.ICommonLanguageSettings|null|undefined} common + * @memberof google.api.RubySettings + * @instance + */ + RubySettings.prototype.common = null; + + /** + * Creates a new RubySettings instance using the specified properties. + * @function create + * @memberof google.api.RubySettings + * @static + * @param {google.api.IRubySettings=} [properties] Properties to set + * @returns {google.api.RubySettings} RubySettings instance + */ + RubySettings.create = function create(properties) { + return new RubySettings(properties); + }; + + /** + * Encodes the specified RubySettings message. Does not implicitly {@link google.api.RubySettings.verify|verify} messages. + * @function encode + * @memberof google.api.RubySettings + * @static + * @param {google.api.IRubySettings} message RubySettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + RubySettings.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.common != null && Object.hasOwnProperty.call(message, "common")) + $root.google.api.CommonLanguageSettings.encode(message.common, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified RubySettings message, length delimited. Does not implicitly {@link google.api.RubySettings.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.RubySettings + * @static + * @param {google.api.IRubySettings} message RubySettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + RubySettings.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a RubySettings message from the specified reader or buffer. + * @function decode + * @memberof google.api.RubySettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.RubySettings} RubySettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + RubySettings.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.RubySettings(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.common = $root.google.api.CommonLanguageSettings.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a RubySettings message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.RubySettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.RubySettings} RubySettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + RubySettings.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a RubySettings message. + * @function verify + * @memberof google.api.RubySettings + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + RubySettings.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.common != null && message.hasOwnProperty("common")) { + var error = $root.google.api.CommonLanguageSettings.verify(message.common); + if (error) + return "common." + error; + } + return null; + }; + + /** + * Creates a RubySettings message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.RubySettings + * @static + * @param {Object.} object Plain object + * @returns {google.api.RubySettings} RubySettings + */ + RubySettings.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.RubySettings) + return object; + var message = new $root.google.api.RubySettings(); + if (object.common != null) { + if (typeof object.common !== "object") + throw TypeError(".google.api.RubySettings.common: object expected"); + message.common = $root.google.api.CommonLanguageSettings.fromObject(object.common); + } + return message; + }; + + /** + * Creates a plain object from a RubySettings message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.RubySettings + * @static + * @param {google.api.RubySettings} message RubySettings + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + RubySettings.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.common = null; + if (message.common != null && message.hasOwnProperty("common")) + object.common = $root.google.api.CommonLanguageSettings.toObject(message.common, options); + return object; + }; + + /** + * Converts this RubySettings to JSON. + * @function toJSON + * @memberof google.api.RubySettings + * @instance + * @returns {Object.} JSON object + */ + RubySettings.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for RubySettings + * @function getTypeUrl + * @memberof google.api.RubySettings + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + RubySettings.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.RubySettings"; + }; + + return RubySettings; + })(); + + api.GoSettings = (function() { + + /** + * Properties of a GoSettings. + * @memberof google.api + * @interface IGoSettings + * @property {google.api.ICommonLanguageSettings|null} [common] GoSettings common + */ + + /** + * Constructs a new GoSettings. + * @memberof google.api + * @classdesc Represents a GoSettings. + * @implements IGoSettings + * @constructor + * @param {google.api.IGoSettings=} [properties] Properties to set + */ + function GoSettings(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * GoSettings common. + * @member {google.api.ICommonLanguageSettings|null|undefined} common + * @memberof google.api.GoSettings + * @instance + */ + GoSettings.prototype.common = null; + + /** + * Creates a new GoSettings instance using the specified properties. + * @function create + * @memberof google.api.GoSettings + * @static + * @param {google.api.IGoSettings=} [properties] Properties to set + * @returns {google.api.GoSettings} GoSettings instance + */ + GoSettings.create = function create(properties) { + return new GoSettings(properties); + }; + + /** + * Encodes the specified GoSettings message. Does not implicitly {@link google.api.GoSettings.verify|verify} messages. + * @function encode + * @memberof google.api.GoSettings + * @static + * @param {google.api.IGoSettings} message GoSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GoSettings.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.common != null && Object.hasOwnProperty.call(message, "common")) + $root.google.api.CommonLanguageSettings.encode(message.common, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified GoSettings message, length delimited. Does not implicitly {@link google.api.GoSettings.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.GoSettings + * @static + * @param {google.api.IGoSettings} message GoSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GoSettings.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a GoSettings message from the specified reader or buffer. + * @function decode + * @memberof google.api.GoSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.GoSettings} GoSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GoSettings.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.GoSettings(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.common = $root.google.api.CommonLanguageSettings.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a GoSettings message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.GoSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.GoSettings} GoSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GoSettings.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a GoSettings message. + * @function verify + * @memberof google.api.GoSettings + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + GoSettings.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.common != null && message.hasOwnProperty("common")) { + var error = $root.google.api.CommonLanguageSettings.verify(message.common); + if (error) + return "common." + error; + } + return null; + }; + + /** + * Creates a GoSettings message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.GoSettings + * @static + * @param {Object.} object Plain object + * @returns {google.api.GoSettings} GoSettings + */ + GoSettings.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.GoSettings) + return object; + var message = new $root.google.api.GoSettings(); + if (object.common != null) { + if (typeof object.common !== "object") + throw TypeError(".google.api.GoSettings.common: object expected"); + message.common = $root.google.api.CommonLanguageSettings.fromObject(object.common); + } + return message; + }; + + /** + * Creates a plain object from a GoSettings message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.GoSettings + * @static + * @param {google.api.GoSettings} message GoSettings + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + GoSettings.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.common = null; + if (message.common != null && message.hasOwnProperty("common")) + object.common = $root.google.api.CommonLanguageSettings.toObject(message.common, options); + return object; + }; + + /** + * Converts this GoSettings to JSON. + * @function toJSON + * @memberof google.api.GoSettings + * @instance + * @returns {Object.} JSON object + */ + GoSettings.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for GoSettings + * @function getTypeUrl + * @memberof google.api.GoSettings + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + GoSettings.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.GoSettings"; + }; + + return GoSettings; + })(); + + api.MethodSettings = (function() { + + /** + * Properties of a MethodSettings. + * @memberof google.api + * @interface IMethodSettings + * @property {string|null} [selector] MethodSettings selector + * @property {google.api.MethodSettings.ILongRunning|null} [longRunning] MethodSettings longRunning + */ + + /** + * Constructs a new MethodSettings. + * @memberof google.api + * @classdesc Represents a MethodSettings. + * @implements IMethodSettings + * @constructor + * @param {google.api.IMethodSettings=} [properties] Properties to set + */ + function MethodSettings(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * MethodSettings selector. + * @member {string} selector + * @memberof google.api.MethodSettings + * @instance + */ + MethodSettings.prototype.selector = ""; + + /** + * MethodSettings longRunning. + * @member {google.api.MethodSettings.ILongRunning|null|undefined} longRunning + * @memberof google.api.MethodSettings + * @instance + */ + MethodSettings.prototype.longRunning = null; + + /** + * Creates a new MethodSettings instance using the specified properties. + * @function create + * @memberof google.api.MethodSettings + * @static + * @param {google.api.IMethodSettings=} [properties] Properties to set + * @returns {google.api.MethodSettings} MethodSettings instance + */ + MethodSettings.create = function create(properties) { + return new MethodSettings(properties); + }; + + /** + * Encodes the specified MethodSettings message. Does not implicitly {@link google.api.MethodSettings.verify|verify} messages. + * @function encode + * @memberof google.api.MethodSettings + * @static + * @param {google.api.IMethodSettings} message MethodSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + MethodSettings.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.selector != null && Object.hasOwnProperty.call(message, "selector")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.selector); + if (message.longRunning != null && Object.hasOwnProperty.call(message, "longRunning")) + $root.google.api.MethodSettings.LongRunning.encode(message.longRunning, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified MethodSettings message, length delimited. Does not implicitly {@link google.api.MethodSettings.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.MethodSettings + * @static + * @param {google.api.IMethodSettings} message MethodSettings message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + MethodSettings.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a MethodSettings message from the specified reader or buffer. + * @function decode + * @memberof google.api.MethodSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.MethodSettings} MethodSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + MethodSettings.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.MethodSettings(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.selector = reader.string(); + break; + } + case 2: { + message.longRunning = $root.google.api.MethodSettings.LongRunning.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a MethodSettings message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.MethodSettings + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.MethodSettings} MethodSettings + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + MethodSettings.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a MethodSettings message. + * @function verify + * @memberof google.api.MethodSettings + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + MethodSettings.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.selector != null && message.hasOwnProperty("selector")) + if (!$util.isString(message.selector)) + return "selector: string expected"; + if (message.longRunning != null && message.hasOwnProperty("longRunning")) { + var error = $root.google.api.MethodSettings.LongRunning.verify(message.longRunning); + if (error) + return "longRunning." + error; + } + return null; + }; + + /** + * Creates a MethodSettings message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.MethodSettings + * @static + * @param {Object.} object Plain object + * @returns {google.api.MethodSettings} MethodSettings + */ + MethodSettings.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.MethodSettings) + return object; + var message = new $root.google.api.MethodSettings(); + if (object.selector != null) + message.selector = String(object.selector); + if (object.longRunning != null) { + if (typeof object.longRunning !== "object") + throw TypeError(".google.api.MethodSettings.longRunning: object expected"); + message.longRunning = $root.google.api.MethodSettings.LongRunning.fromObject(object.longRunning); + } + return message; + }; + + /** + * Creates a plain object from a MethodSettings message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.MethodSettings + * @static + * @param {google.api.MethodSettings} message MethodSettings + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + MethodSettings.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.selector = ""; + object.longRunning = null; + } + if (message.selector != null && message.hasOwnProperty("selector")) + object.selector = message.selector; + if (message.longRunning != null && message.hasOwnProperty("longRunning")) + object.longRunning = $root.google.api.MethodSettings.LongRunning.toObject(message.longRunning, options); + return object; + }; + + /** + * Converts this MethodSettings to JSON. + * @function toJSON + * @memberof google.api.MethodSettings + * @instance + * @returns {Object.} JSON object + */ + MethodSettings.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for MethodSettings + * @function getTypeUrl + * @memberof google.api.MethodSettings + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + MethodSettings.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.MethodSettings"; + }; + + MethodSettings.LongRunning = (function() { + + /** + * Properties of a LongRunning. + * @memberof google.api.MethodSettings + * @interface ILongRunning + * @property {google.protobuf.IDuration|null} [initialPollDelay] LongRunning initialPollDelay + * @property {number|null} [pollDelayMultiplier] LongRunning pollDelayMultiplier + * @property {google.protobuf.IDuration|null} [maxPollDelay] LongRunning maxPollDelay + * @property {google.protobuf.IDuration|null} [totalPollTimeout] LongRunning totalPollTimeout + */ + + /** + * Constructs a new LongRunning. + * @memberof google.api.MethodSettings + * @classdesc Represents a LongRunning. + * @implements ILongRunning + * @constructor + * @param {google.api.MethodSettings.ILongRunning=} [properties] Properties to set + */ + function LongRunning(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * LongRunning initialPollDelay. + * @member {google.protobuf.IDuration|null|undefined} initialPollDelay + * @memberof google.api.MethodSettings.LongRunning + * @instance + */ + LongRunning.prototype.initialPollDelay = null; + + /** + * LongRunning pollDelayMultiplier. + * @member {number} pollDelayMultiplier + * @memberof google.api.MethodSettings.LongRunning + * @instance + */ + LongRunning.prototype.pollDelayMultiplier = 0; + + /** + * LongRunning maxPollDelay. + * @member {google.protobuf.IDuration|null|undefined} maxPollDelay + * @memberof google.api.MethodSettings.LongRunning + * @instance + */ + LongRunning.prototype.maxPollDelay = null; + + /** + * LongRunning totalPollTimeout. + * @member {google.protobuf.IDuration|null|undefined} totalPollTimeout + * @memberof google.api.MethodSettings.LongRunning + * @instance + */ + LongRunning.prototype.totalPollTimeout = null; + + /** + * Creates a new LongRunning instance using the specified properties. + * @function create + * @memberof google.api.MethodSettings.LongRunning + * @static + * @param {google.api.MethodSettings.ILongRunning=} [properties] Properties to set + * @returns {google.api.MethodSettings.LongRunning} LongRunning instance + */ + LongRunning.create = function create(properties) { + return new LongRunning(properties); + }; + + /** + * Encodes the specified LongRunning message. Does not implicitly {@link google.api.MethodSettings.LongRunning.verify|verify} messages. + * @function encode + * @memberof google.api.MethodSettings.LongRunning + * @static + * @param {google.api.MethodSettings.ILongRunning} message LongRunning message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + LongRunning.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.initialPollDelay != null && Object.hasOwnProperty.call(message, "initialPollDelay")) + $root.google.protobuf.Duration.encode(message.initialPollDelay, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.pollDelayMultiplier != null && Object.hasOwnProperty.call(message, "pollDelayMultiplier")) + writer.uint32(/* id 2, wireType 5 =*/21).float(message.pollDelayMultiplier); + if (message.maxPollDelay != null && Object.hasOwnProperty.call(message, "maxPollDelay")) + $root.google.protobuf.Duration.encode(message.maxPollDelay, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + if (message.totalPollTimeout != null && Object.hasOwnProperty.call(message, "totalPollTimeout")) + $root.google.protobuf.Duration.encode(message.totalPollTimeout, writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified LongRunning message, length delimited. Does not implicitly {@link google.api.MethodSettings.LongRunning.verify|verify} messages. + * @function encodeDelimited + * @memberof google.api.MethodSettings.LongRunning + * @static + * @param {google.api.MethodSettings.ILongRunning} message LongRunning message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + LongRunning.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a LongRunning message from the specified reader or buffer. + * @function decode + * @memberof google.api.MethodSettings.LongRunning + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.api.MethodSettings.LongRunning} LongRunning + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + LongRunning.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.MethodSettings.LongRunning(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.initialPollDelay = $root.google.protobuf.Duration.decode(reader, reader.uint32()); + break; + } + case 2: { + message.pollDelayMultiplier = reader.float(); + break; + } + case 3: { + message.maxPollDelay = $root.google.protobuf.Duration.decode(reader, reader.uint32()); + break; + } + case 4: { + message.totalPollTimeout = $root.google.protobuf.Duration.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a LongRunning message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.api.MethodSettings.LongRunning + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.api.MethodSettings.LongRunning} LongRunning + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + LongRunning.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a LongRunning message. + * @function verify + * @memberof google.api.MethodSettings.LongRunning + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + LongRunning.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.initialPollDelay != null && message.hasOwnProperty("initialPollDelay")) { + var error = $root.google.protobuf.Duration.verify(message.initialPollDelay); + if (error) + return "initialPollDelay." + error; + } + if (message.pollDelayMultiplier != null && message.hasOwnProperty("pollDelayMultiplier")) + if (typeof message.pollDelayMultiplier !== "number") + return "pollDelayMultiplier: number expected"; + if (message.maxPollDelay != null && message.hasOwnProperty("maxPollDelay")) { + var error = $root.google.protobuf.Duration.verify(message.maxPollDelay); + if (error) + return "maxPollDelay." + error; + } + if (message.totalPollTimeout != null && message.hasOwnProperty("totalPollTimeout")) { + var error = $root.google.protobuf.Duration.verify(message.totalPollTimeout); + if (error) + return "totalPollTimeout." + error; + } + return null; + }; + + /** + * Creates a LongRunning message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.api.MethodSettings.LongRunning + * @static + * @param {Object.} object Plain object + * @returns {google.api.MethodSettings.LongRunning} LongRunning + */ + LongRunning.fromObject = function fromObject(object) { + if (object instanceof $root.google.api.MethodSettings.LongRunning) + return object; + var message = new $root.google.api.MethodSettings.LongRunning(); + if (object.initialPollDelay != null) { + if (typeof object.initialPollDelay !== "object") + throw TypeError(".google.api.MethodSettings.LongRunning.initialPollDelay: object expected"); + message.initialPollDelay = $root.google.protobuf.Duration.fromObject(object.initialPollDelay); + } + if (object.pollDelayMultiplier != null) + message.pollDelayMultiplier = Number(object.pollDelayMultiplier); + if (object.maxPollDelay != null) { + if (typeof object.maxPollDelay !== "object") + throw TypeError(".google.api.MethodSettings.LongRunning.maxPollDelay: object expected"); + message.maxPollDelay = $root.google.protobuf.Duration.fromObject(object.maxPollDelay); + } + if (object.totalPollTimeout != null) { + if (typeof object.totalPollTimeout !== "object") + throw TypeError(".google.api.MethodSettings.LongRunning.totalPollTimeout: object expected"); + message.totalPollTimeout = $root.google.protobuf.Duration.fromObject(object.totalPollTimeout); + } + return message; + }; + + /** + * Creates a plain object from a LongRunning message. Also converts values to other types if specified. + * @function toObject + * @memberof google.api.MethodSettings.LongRunning + * @static + * @param {google.api.MethodSettings.LongRunning} message LongRunning + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + LongRunning.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.initialPollDelay = null; + object.pollDelayMultiplier = 0; + object.maxPollDelay = null; + object.totalPollTimeout = null; + } + if (message.initialPollDelay != null && message.hasOwnProperty("initialPollDelay")) + object.initialPollDelay = $root.google.protobuf.Duration.toObject(message.initialPollDelay, options); + if (message.pollDelayMultiplier != null && message.hasOwnProperty("pollDelayMultiplier")) + object.pollDelayMultiplier = options.json && !isFinite(message.pollDelayMultiplier) ? String(message.pollDelayMultiplier) : message.pollDelayMultiplier; + if (message.maxPollDelay != null && message.hasOwnProperty("maxPollDelay")) + object.maxPollDelay = $root.google.protobuf.Duration.toObject(message.maxPollDelay, options); + if (message.totalPollTimeout != null && message.hasOwnProperty("totalPollTimeout")) + object.totalPollTimeout = $root.google.protobuf.Duration.toObject(message.totalPollTimeout, options); + return object; + }; + + /** + * Converts this LongRunning to JSON. + * @function toJSON + * @memberof google.api.MethodSettings.LongRunning + * @instance + * @returns {Object.} JSON object + */ + LongRunning.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for LongRunning + * @function getTypeUrl + * @memberof google.api.MethodSettings.LongRunning + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + LongRunning.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.api.MethodSettings.LongRunning"; + }; + + return LongRunning; + })(); + + return MethodSettings; + })(); + + /** + * ClientLibraryOrganization enum. + * @name google.api.ClientLibraryOrganization + * @enum {number} + * @property {number} CLIENT_LIBRARY_ORGANIZATION_UNSPECIFIED=0 CLIENT_LIBRARY_ORGANIZATION_UNSPECIFIED value + * @property {number} CLOUD=1 CLOUD value + * @property {number} ADS=2 ADS value + * @property {number} PHOTOS=3 PHOTOS value + * @property {number} STREET_VIEW=4 STREET_VIEW value + */ + api.ClientLibraryOrganization = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "CLIENT_LIBRARY_ORGANIZATION_UNSPECIFIED"] = 0; + values[valuesById[1] = "CLOUD"] = 1; + values[valuesById[2] = "ADS"] = 2; + values[valuesById[3] = "PHOTOS"] = 3; + values[valuesById[4] = "STREET_VIEW"] = 4; + return values; + })(); + + /** + * ClientLibraryDestination enum. + * @name google.api.ClientLibraryDestination + * @enum {number} + * @property {number} CLIENT_LIBRARY_DESTINATION_UNSPECIFIED=0 CLIENT_LIBRARY_DESTINATION_UNSPECIFIED value + * @property {number} GITHUB=10 GITHUB value + * @property {number} PACKAGE_MANAGER=20 PACKAGE_MANAGER value + */ + api.ClientLibraryDestination = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "CLIENT_LIBRARY_DESTINATION_UNSPECIFIED"] = 0; + values[valuesById[10] = "GITHUB"] = 10; + values[valuesById[20] = "PACKAGE_MANAGER"] = 20; + return values; + })(); + + /** + * LaunchStage enum. + * @name google.api.LaunchStage + * @enum {number} + * @property {number} LAUNCH_STAGE_UNSPECIFIED=0 LAUNCH_STAGE_UNSPECIFIED value + * @property {number} UNIMPLEMENTED=6 UNIMPLEMENTED value + * @property {number} PRELAUNCH=7 PRELAUNCH value + * @property {number} EARLY_ACCESS=1 EARLY_ACCESS value + * @property {number} ALPHA=2 ALPHA value + * @property {number} BETA=3 BETA value + * @property {number} GA=4 GA value + * @property {number} DEPRECATED=5 DEPRECATED value + */ + api.LaunchStage = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "LAUNCH_STAGE_UNSPECIFIED"] = 0; + values[valuesById[6] = "UNIMPLEMENTED"] = 6; + values[valuesById[7] = "PRELAUNCH"] = 7; + values[valuesById[1] = "EARLY_ACCESS"] = 1; + values[valuesById[2] = "ALPHA"] = 2; + values[valuesById[3] = "BETA"] = 3; + values[valuesById[4] = "GA"] = 4; + values[valuesById[5] = "DEPRECATED"] = 5; + return values; + })(); + + return api; + })(); + + google.protobuf = (function() { + + /** + * Namespace protobuf. + * @memberof google + * @namespace + */ + var protobuf = {}; + + protobuf.FileDescriptorSet = (function() { + + /** + * Properties of a FileDescriptorSet. + * @memberof google.protobuf + * @interface IFileDescriptorSet + * @property {Array.|null} [file] FileDescriptorSet file + */ + + /** + * Constructs a new FileDescriptorSet. + * @memberof google.protobuf + * @classdesc Represents a FileDescriptorSet. + * @implements IFileDescriptorSet + * @constructor + * @param {google.protobuf.IFileDescriptorSet=} [properties] Properties to set + */ + function FileDescriptorSet(properties) { + this.file = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * FileDescriptorSet file. + * @member {Array.} file + * @memberof google.protobuf.FileDescriptorSet + * @instance + */ + FileDescriptorSet.prototype.file = $util.emptyArray; + + /** + * Creates a new FileDescriptorSet instance using the specified properties. + * @function create + * @memberof google.protobuf.FileDescriptorSet + * @static + * @param {google.protobuf.IFileDescriptorSet=} [properties] Properties to set + * @returns {google.protobuf.FileDescriptorSet} FileDescriptorSet instance + */ + FileDescriptorSet.create = function create(properties) { + return new FileDescriptorSet(properties); + }; + + /** + * Encodes the specified FileDescriptorSet message. Does not implicitly {@link google.protobuf.FileDescriptorSet.verify|verify} messages. + * @function encode + * @memberof google.protobuf.FileDescriptorSet + * @static + * @param {google.protobuf.IFileDescriptorSet} message FileDescriptorSet message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + FileDescriptorSet.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.file != null && message.file.length) + for (var i = 0; i < message.file.length; ++i) + $root.google.protobuf.FileDescriptorProto.encode(message.file[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified FileDescriptorSet message, length delimited. Does not implicitly {@link google.protobuf.FileDescriptorSet.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.FileDescriptorSet + * @static + * @param {google.protobuf.IFileDescriptorSet} message FileDescriptorSet message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + FileDescriptorSet.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a FileDescriptorSet message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.FileDescriptorSet + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.FileDescriptorSet} FileDescriptorSet + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + FileDescriptorSet.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.FileDescriptorSet(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + if (!(message.file && message.file.length)) + message.file = []; + message.file.push($root.google.protobuf.FileDescriptorProto.decode(reader, reader.uint32())); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a FileDescriptorSet message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.FileDescriptorSet + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.FileDescriptorSet} FileDescriptorSet + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + FileDescriptorSet.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a FileDescriptorSet message. + * @function verify + * @memberof google.protobuf.FileDescriptorSet + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + FileDescriptorSet.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.file != null && message.hasOwnProperty("file")) { + if (!Array.isArray(message.file)) + return "file: array expected"; + for (var i = 0; i < message.file.length; ++i) { + var error = $root.google.protobuf.FileDescriptorProto.verify(message.file[i]); + if (error) + return "file." + error; + } + } + return null; + }; + + /** + * Creates a FileDescriptorSet message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.FileDescriptorSet + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.FileDescriptorSet} FileDescriptorSet + */ + FileDescriptorSet.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.FileDescriptorSet) + return object; + var message = new $root.google.protobuf.FileDescriptorSet(); + if (object.file) { + if (!Array.isArray(object.file)) + throw TypeError(".google.protobuf.FileDescriptorSet.file: array expected"); + message.file = []; + for (var i = 0; i < object.file.length; ++i) { + if (typeof object.file[i] !== "object") + throw TypeError(".google.protobuf.FileDescriptorSet.file: object expected"); + message.file[i] = $root.google.protobuf.FileDescriptorProto.fromObject(object.file[i]); + } + } + return message; + }; + + /** + * Creates a plain object from a FileDescriptorSet message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.FileDescriptorSet + * @static + * @param {google.protobuf.FileDescriptorSet} message FileDescriptorSet + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + FileDescriptorSet.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.file = []; + if (message.file && message.file.length) { + object.file = []; + for (var j = 0; j < message.file.length; ++j) + object.file[j] = $root.google.protobuf.FileDescriptorProto.toObject(message.file[j], options); + } + return object; + }; + + /** + * Converts this FileDescriptorSet to JSON. + * @function toJSON + * @memberof google.protobuf.FileDescriptorSet + * @instance + * @returns {Object.} JSON object + */ + FileDescriptorSet.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for FileDescriptorSet + * @function getTypeUrl + * @memberof google.protobuf.FileDescriptorSet + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + FileDescriptorSet.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.FileDescriptorSet"; + }; + + return FileDescriptorSet; + })(); + + protobuf.FileDescriptorProto = (function() { + + /** + * Properties of a FileDescriptorProto. + * @memberof google.protobuf + * @interface IFileDescriptorProto + * @property {string|null} [name] FileDescriptorProto name + * @property {string|null} ["package"] FileDescriptorProto package + * @property {Array.|null} [dependency] FileDescriptorProto dependency + * @property {Array.|null} [publicDependency] FileDescriptorProto publicDependency + * @property {Array.|null} [weakDependency] FileDescriptorProto weakDependency + * @property {Array.|null} [messageType] FileDescriptorProto messageType + * @property {Array.|null} [enumType] FileDescriptorProto enumType + * @property {Array.|null} [service] FileDescriptorProto service + * @property {Array.|null} [extension] FileDescriptorProto extension + * @property {google.protobuf.IFileOptions|null} [options] FileDescriptorProto options + * @property {google.protobuf.ISourceCodeInfo|null} [sourceCodeInfo] FileDescriptorProto sourceCodeInfo + * @property {string|null} [syntax] FileDescriptorProto syntax + * @property {string|null} [edition] FileDescriptorProto edition + */ + + /** + * Constructs a new FileDescriptorProto. + * @memberof google.protobuf + * @classdesc Represents a FileDescriptorProto. + * @implements IFileDescriptorProto + * @constructor + * @param {google.protobuf.IFileDescriptorProto=} [properties] Properties to set + */ + function FileDescriptorProto(properties) { + this.dependency = []; + this.publicDependency = []; + this.weakDependency = []; + this.messageType = []; + this.enumType = []; + this.service = []; + this.extension = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * FileDescriptorProto name. + * @member {string} name + * @memberof google.protobuf.FileDescriptorProto + * @instance + */ + FileDescriptorProto.prototype.name = ""; + + /** + * FileDescriptorProto package. + * @member {string} package + * @memberof google.protobuf.FileDescriptorProto + * @instance + */ + FileDescriptorProto.prototype["package"] = ""; + + /** + * FileDescriptorProto dependency. + * @member {Array.} dependency + * @memberof google.protobuf.FileDescriptorProto + * @instance + */ + FileDescriptorProto.prototype.dependency = $util.emptyArray; + + /** + * FileDescriptorProto publicDependency. + * @member {Array.} publicDependency + * @memberof google.protobuf.FileDescriptorProto + * @instance + */ + FileDescriptorProto.prototype.publicDependency = $util.emptyArray; + + /** + * FileDescriptorProto weakDependency. + * @member {Array.} weakDependency + * @memberof google.protobuf.FileDescriptorProto + * @instance + */ + FileDescriptorProto.prototype.weakDependency = $util.emptyArray; + + /** + * FileDescriptorProto messageType. + * @member {Array.} messageType + * @memberof google.protobuf.FileDescriptorProto + * @instance + */ + FileDescriptorProto.prototype.messageType = $util.emptyArray; + + /** + * FileDescriptorProto enumType. + * @member {Array.} enumType + * @memberof google.protobuf.FileDescriptorProto + * @instance + */ + FileDescriptorProto.prototype.enumType = $util.emptyArray; + + /** + * FileDescriptorProto service. + * @member {Array.} service + * @memberof google.protobuf.FileDescriptorProto + * @instance + */ + FileDescriptorProto.prototype.service = $util.emptyArray; + + /** + * FileDescriptorProto extension. + * @member {Array.} extension + * @memberof google.protobuf.FileDescriptorProto + * @instance + */ + FileDescriptorProto.prototype.extension = $util.emptyArray; + + /** + * FileDescriptorProto options. + * @member {google.protobuf.IFileOptions|null|undefined} options + * @memberof google.protobuf.FileDescriptorProto + * @instance + */ + FileDescriptorProto.prototype.options = null; + + /** + * FileDescriptorProto sourceCodeInfo. + * @member {google.protobuf.ISourceCodeInfo|null|undefined} sourceCodeInfo + * @memberof google.protobuf.FileDescriptorProto + * @instance + */ + FileDescriptorProto.prototype.sourceCodeInfo = null; + + /** + * FileDescriptorProto syntax. + * @member {string} syntax + * @memberof google.protobuf.FileDescriptorProto + * @instance + */ + FileDescriptorProto.prototype.syntax = ""; + + /** + * FileDescriptorProto edition. + * @member {string} edition + * @memberof google.protobuf.FileDescriptorProto + * @instance + */ + FileDescriptorProto.prototype.edition = ""; + + /** + * Creates a new FileDescriptorProto instance using the specified properties. + * @function create + * @memberof google.protobuf.FileDescriptorProto + * @static + * @param {google.protobuf.IFileDescriptorProto=} [properties] Properties to set + * @returns {google.protobuf.FileDescriptorProto} FileDescriptorProto instance + */ + FileDescriptorProto.create = function create(properties) { + return new FileDescriptorProto(properties); + }; + + /** + * Encodes the specified FileDescriptorProto message. Does not implicitly {@link google.protobuf.FileDescriptorProto.verify|verify} messages. + * @function encode + * @memberof google.protobuf.FileDescriptorProto + * @static + * @param {google.protobuf.IFileDescriptorProto} message FileDescriptorProto message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + FileDescriptorProto.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message["package"] != null && Object.hasOwnProperty.call(message, "package")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message["package"]); + if (message.dependency != null && message.dependency.length) + for (var i = 0; i < message.dependency.length; ++i) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.dependency[i]); + if (message.messageType != null && message.messageType.length) + for (var i = 0; i < message.messageType.length; ++i) + $root.google.protobuf.DescriptorProto.encode(message.messageType[i], writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); + if (message.enumType != null && message.enumType.length) + for (var i = 0; i < message.enumType.length; ++i) + $root.google.protobuf.EnumDescriptorProto.encode(message.enumType[i], writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim(); + if (message.service != null && message.service.length) + for (var i = 0; i < message.service.length; ++i) + $root.google.protobuf.ServiceDescriptorProto.encode(message.service[i], writer.uint32(/* id 6, wireType 2 =*/50).fork()).ldelim(); + if (message.extension != null && message.extension.length) + for (var i = 0; i < message.extension.length; ++i) + $root.google.protobuf.FieldDescriptorProto.encode(message.extension[i], writer.uint32(/* id 7, wireType 2 =*/58).fork()).ldelim(); + if (message.options != null && Object.hasOwnProperty.call(message, "options")) + $root.google.protobuf.FileOptions.encode(message.options, writer.uint32(/* id 8, wireType 2 =*/66).fork()).ldelim(); + if (message.sourceCodeInfo != null && Object.hasOwnProperty.call(message, "sourceCodeInfo")) + $root.google.protobuf.SourceCodeInfo.encode(message.sourceCodeInfo, writer.uint32(/* id 9, wireType 2 =*/74).fork()).ldelim(); + if (message.publicDependency != null && message.publicDependency.length) + for (var i = 0; i < message.publicDependency.length; ++i) + writer.uint32(/* id 10, wireType 0 =*/80).int32(message.publicDependency[i]); + if (message.weakDependency != null && message.weakDependency.length) + for (var i = 0; i < message.weakDependency.length; ++i) + writer.uint32(/* id 11, wireType 0 =*/88).int32(message.weakDependency[i]); + if (message.syntax != null && Object.hasOwnProperty.call(message, "syntax")) + writer.uint32(/* id 12, wireType 2 =*/98).string(message.syntax); + if (message.edition != null && Object.hasOwnProperty.call(message, "edition")) + writer.uint32(/* id 13, wireType 2 =*/106).string(message.edition); + return writer; + }; + + /** + * Encodes the specified FileDescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.FileDescriptorProto.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.FileDescriptorProto + * @static + * @param {google.protobuf.IFileDescriptorProto} message FileDescriptorProto message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + FileDescriptorProto.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a FileDescriptorProto message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.FileDescriptorProto + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.FileDescriptorProto} FileDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + FileDescriptorProto.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.FileDescriptorProto(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message["package"] = reader.string(); + break; + } + case 3: { + if (!(message.dependency && message.dependency.length)) + message.dependency = []; + message.dependency.push(reader.string()); + break; + } + case 10: { + if (!(message.publicDependency && message.publicDependency.length)) + message.publicDependency = []; + if ((tag & 7) === 2) { + var end2 = reader.uint32() + reader.pos; + while (reader.pos < end2) + message.publicDependency.push(reader.int32()); + } else + message.publicDependency.push(reader.int32()); + break; + } + case 11: { + if (!(message.weakDependency && message.weakDependency.length)) + message.weakDependency = []; + if ((tag & 7) === 2) { + var end2 = reader.uint32() + reader.pos; + while (reader.pos < end2) + message.weakDependency.push(reader.int32()); + } else + message.weakDependency.push(reader.int32()); + break; + } + case 4: { + if (!(message.messageType && message.messageType.length)) + message.messageType = []; + message.messageType.push($root.google.protobuf.DescriptorProto.decode(reader, reader.uint32())); + break; + } + case 5: { + if (!(message.enumType && message.enumType.length)) + message.enumType = []; + message.enumType.push($root.google.protobuf.EnumDescriptorProto.decode(reader, reader.uint32())); + break; + } + case 6: { + if (!(message.service && message.service.length)) + message.service = []; + message.service.push($root.google.protobuf.ServiceDescriptorProto.decode(reader, reader.uint32())); + break; + } + case 7: { + if (!(message.extension && message.extension.length)) + message.extension = []; + message.extension.push($root.google.protobuf.FieldDescriptorProto.decode(reader, reader.uint32())); + break; + } + case 8: { + message.options = $root.google.protobuf.FileOptions.decode(reader, reader.uint32()); + break; + } + case 9: { + message.sourceCodeInfo = $root.google.protobuf.SourceCodeInfo.decode(reader, reader.uint32()); + break; + } + case 12: { + message.syntax = reader.string(); + break; + } + case 13: { + message.edition = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a FileDescriptorProto message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.FileDescriptorProto + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.FileDescriptorProto} FileDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + FileDescriptorProto.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a FileDescriptorProto message. + * @function verify + * @memberof google.protobuf.FileDescriptorProto + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + FileDescriptorProto.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message["package"] != null && message.hasOwnProperty("package")) + if (!$util.isString(message["package"])) + return "package: string expected"; + if (message.dependency != null && message.hasOwnProperty("dependency")) { + if (!Array.isArray(message.dependency)) + return "dependency: array expected"; + for (var i = 0; i < message.dependency.length; ++i) + if (!$util.isString(message.dependency[i])) + return "dependency: string[] expected"; + } + if (message.publicDependency != null && message.hasOwnProperty("publicDependency")) { + if (!Array.isArray(message.publicDependency)) + return "publicDependency: array expected"; + for (var i = 0; i < message.publicDependency.length; ++i) + if (!$util.isInteger(message.publicDependency[i])) + return "publicDependency: integer[] expected"; + } + if (message.weakDependency != null && message.hasOwnProperty("weakDependency")) { + if (!Array.isArray(message.weakDependency)) + return "weakDependency: array expected"; + for (var i = 0; i < message.weakDependency.length; ++i) + if (!$util.isInteger(message.weakDependency[i])) + return "weakDependency: integer[] expected"; + } + if (message.messageType != null && message.hasOwnProperty("messageType")) { + if (!Array.isArray(message.messageType)) + return "messageType: array expected"; + for (var i = 0; i < message.messageType.length; ++i) { + var error = $root.google.protobuf.DescriptorProto.verify(message.messageType[i]); + if (error) + return "messageType." + error; + } + } + if (message.enumType != null && message.hasOwnProperty("enumType")) { + if (!Array.isArray(message.enumType)) + return "enumType: array expected"; + for (var i = 0; i < message.enumType.length; ++i) { + var error = $root.google.protobuf.EnumDescriptorProto.verify(message.enumType[i]); + if (error) + return "enumType." + error; + } + } + if (message.service != null && message.hasOwnProperty("service")) { + if (!Array.isArray(message.service)) + return "service: array expected"; + for (var i = 0; i < message.service.length; ++i) { + var error = $root.google.protobuf.ServiceDescriptorProto.verify(message.service[i]); + if (error) + return "service." + error; + } + } + if (message.extension != null && message.hasOwnProperty("extension")) { + if (!Array.isArray(message.extension)) + return "extension: array expected"; + for (var i = 0; i < message.extension.length; ++i) { + var error = $root.google.protobuf.FieldDescriptorProto.verify(message.extension[i]); + if (error) + return "extension." + error; + } + } + if (message.options != null && message.hasOwnProperty("options")) { + var error = $root.google.protobuf.FileOptions.verify(message.options); + if (error) + return "options." + error; + } + if (message.sourceCodeInfo != null && message.hasOwnProperty("sourceCodeInfo")) { + var error = $root.google.protobuf.SourceCodeInfo.verify(message.sourceCodeInfo); + if (error) + return "sourceCodeInfo." + error; + } + if (message.syntax != null && message.hasOwnProperty("syntax")) + if (!$util.isString(message.syntax)) + return "syntax: string expected"; + if (message.edition != null && message.hasOwnProperty("edition")) + if (!$util.isString(message.edition)) + return "edition: string expected"; + return null; + }; + + /** + * Creates a FileDescriptorProto message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.FileDescriptorProto + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.FileDescriptorProto} FileDescriptorProto + */ + FileDescriptorProto.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.FileDescriptorProto) + return object; + var message = new $root.google.protobuf.FileDescriptorProto(); + if (object.name != null) + message.name = String(object.name); + if (object["package"] != null) + message["package"] = String(object["package"]); + if (object.dependency) { + if (!Array.isArray(object.dependency)) + throw TypeError(".google.protobuf.FileDescriptorProto.dependency: array expected"); + message.dependency = []; + for (var i = 0; i < object.dependency.length; ++i) + message.dependency[i] = String(object.dependency[i]); + } + if (object.publicDependency) { + if (!Array.isArray(object.publicDependency)) + throw TypeError(".google.protobuf.FileDescriptorProto.publicDependency: array expected"); + message.publicDependency = []; + for (var i = 0; i < object.publicDependency.length; ++i) + message.publicDependency[i] = object.publicDependency[i] | 0; + } + if (object.weakDependency) { + if (!Array.isArray(object.weakDependency)) + throw TypeError(".google.protobuf.FileDescriptorProto.weakDependency: array expected"); + message.weakDependency = []; + for (var i = 0; i < object.weakDependency.length; ++i) + message.weakDependency[i] = object.weakDependency[i] | 0; + } + if (object.messageType) { + if (!Array.isArray(object.messageType)) + throw TypeError(".google.protobuf.FileDescriptorProto.messageType: array expected"); + message.messageType = []; + for (var i = 0; i < object.messageType.length; ++i) { + if (typeof object.messageType[i] !== "object") + throw TypeError(".google.protobuf.FileDescriptorProto.messageType: object expected"); + message.messageType[i] = $root.google.protobuf.DescriptorProto.fromObject(object.messageType[i]); + } + } + if (object.enumType) { + if (!Array.isArray(object.enumType)) + throw TypeError(".google.protobuf.FileDescriptorProto.enumType: array expected"); + message.enumType = []; + for (var i = 0; i < object.enumType.length; ++i) { + if (typeof object.enumType[i] !== "object") + throw TypeError(".google.protobuf.FileDescriptorProto.enumType: object expected"); + message.enumType[i] = $root.google.protobuf.EnumDescriptorProto.fromObject(object.enumType[i]); + } + } + if (object.service) { + if (!Array.isArray(object.service)) + throw TypeError(".google.protobuf.FileDescriptorProto.service: array expected"); + message.service = []; + for (var i = 0; i < object.service.length; ++i) { + if (typeof object.service[i] !== "object") + throw TypeError(".google.protobuf.FileDescriptorProto.service: object expected"); + message.service[i] = $root.google.protobuf.ServiceDescriptorProto.fromObject(object.service[i]); + } + } + if (object.extension) { + if (!Array.isArray(object.extension)) + throw TypeError(".google.protobuf.FileDescriptorProto.extension: array expected"); + message.extension = []; + for (var i = 0; i < object.extension.length; ++i) { + if (typeof object.extension[i] !== "object") + throw TypeError(".google.protobuf.FileDescriptorProto.extension: object expected"); + message.extension[i] = $root.google.protobuf.FieldDescriptorProto.fromObject(object.extension[i]); + } + } + if (object.options != null) { + if (typeof object.options !== "object") + throw TypeError(".google.protobuf.FileDescriptorProto.options: object expected"); + message.options = $root.google.protobuf.FileOptions.fromObject(object.options); + } + if (object.sourceCodeInfo != null) { + if (typeof object.sourceCodeInfo !== "object") + throw TypeError(".google.protobuf.FileDescriptorProto.sourceCodeInfo: object expected"); + message.sourceCodeInfo = $root.google.protobuf.SourceCodeInfo.fromObject(object.sourceCodeInfo); + } + if (object.syntax != null) + message.syntax = String(object.syntax); + if (object.edition != null) + message.edition = String(object.edition); + return message; + }; + + /** + * Creates a plain object from a FileDescriptorProto message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.FileDescriptorProto + * @static + * @param {google.protobuf.FileDescriptorProto} message FileDescriptorProto + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + FileDescriptorProto.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.dependency = []; + object.messageType = []; + object.enumType = []; + object.service = []; + object.extension = []; + object.publicDependency = []; + object.weakDependency = []; + } + if (options.defaults) { + object.name = ""; + object["package"] = ""; + object.options = null; + object.sourceCodeInfo = null; + object.syntax = ""; + object.edition = ""; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message["package"] != null && message.hasOwnProperty("package")) + object["package"] = message["package"]; + if (message.dependency && message.dependency.length) { + object.dependency = []; + for (var j = 0; j < message.dependency.length; ++j) + object.dependency[j] = message.dependency[j]; + } + if (message.messageType && message.messageType.length) { + object.messageType = []; + for (var j = 0; j < message.messageType.length; ++j) + object.messageType[j] = $root.google.protobuf.DescriptorProto.toObject(message.messageType[j], options); + } + if (message.enumType && message.enumType.length) { + object.enumType = []; + for (var j = 0; j < message.enumType.length; ++j) + object.enumType[j] = $root.google.protobuf.EnumDescriptorProto.toObject(message.enumType[j], options); + } + if (message.service && message.service.length) { + object.service = []; + for (var j = 0; j < message.service.length; ++j) + object.service[j] = $root.google.protobuf.ServiceDescriptorProto.toObject(message.service[j], options); + } + if (message.extension && message.extension.length) { + object.extension = []; + for (var j = 0; j < message.extension.length; ++j) + object.extension[j] = $root.google.protobuf.FieldDescriptorProto.toObject(message.extension[j], options); + } + if (message.options != null && message.hasOwnProperty("options")) + object.options = $root.google.protobuf.FileOptions.toObject(message.options, options); + if (message.sourceCodeInfo != null && message.hasOwnProperty("sourceCodeInfo")) + object.sourceCodeInfo = $root.google.protobuf.SourceCodeInfo.toObject(message.sourceCodeInfo, options); + if (message.publicDependency && message.publicDependency.length) { + object.publicDependency = []; + for (var j = 0; j < message.publicDependency.length; ++j) + object.publicDependency[j] = message.publicDependency[j]; + } + if (message.weakDependency && message.weakDependency.length) { + object.weakDependency = []; + for (var j = 0; j < message.weakDependency.length; ++j) + object.weakDependency[j] = message.weakDependency[j]; + } + if (message.syntax != null && message.hasOwnProperty("syntax")) + object.syntax = message.syntax; + if (message.edition != null && message.hasOwnProperty("edition")) + object.edition = message.edition; + return object; + }; + + /** + * Converts this FileDescriptorProto to JSON. + * @function toJSON + * @memberof google.protobuf.FileDescriptorProto + * @instance + * @returns {Object.} JSON object + */ + FileDescriptorProto.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for FileDescriptorProto + * @function getTypeUrl + * @memberof google.protobuf.FileDescriptorProto + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + FileDescriptorProto.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.FileDescriptorProto"; + }; + + return FileDescriptorProto; + })(); + + protobuf.DescriptorProto = (function() { + + /** + * Properties of a DescriptorProto. + * @memberof google.protobuf + * @interface IDescriptorProto + * @property {string|null} [name] DescriptorProto name + * @property {Array.|null} [field] DescriptorProto field + * @property {Array.|null} [extension] DescriptorProto extension + * @property {Array.|null} [nestedType] DescriptorProto nestedType + * @property {Array.|null} [enumType] DescriptorProto enumType + * @property {Array.|null} [extensionRange] DescriptorProto extensionRange + * @property {Array.|null} [oneofDecl] DescriptorProto oneofDecl + * @property {google.protobuf.IMessageOptions|null} [options] DescriptorProto options + * @property {Array.|null} [reservedRange] DescriptorProto reservedRange + * @property {Array.|null} [reservedName] DescriptorProto reservedName + */ + + /** + * Constructs a new DescriptorProto. + * @memberof google.protobuf + * @classdesc Represents a DescriptorProto. + * @implements IDescriptorProto + * @constructor + * @param {google.protobuf.IDescriptorProto=} [properties] Properties to set + */ + function DescriptorProto(properties) { + this.field = []; + this.extension = []; + this.nestedType = []; + this.enumType = []; + this.extensionRange = []; + this.oneofDecl = []; + this.reservedRange = []; + this.reservedName = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * DescriptorProto name. + * @member {string} name + * @memberof google.protobuf.DescriptorProto + * @instance + */ + DescriptorProto.prototype.name = ""; + + /** + * DescriptorProto field. + * @member {Array.} field + * @memberof google.protobuf.DescriptorProto + * @instance + */ + DescriptorProto.prototype.field = $util.emptyArray; + + /** + * DescriptorProto extension. + * @member {Array.} extension + * @memberof google.protobuf.DescriptorProto + * @instance + */ + DescriptorProto.prototype.extension = $util.emptyArray; + + /** + * DescriptorProto nestedType. + * @member {Array.} nestedType + * @memberof google.protobuf.DescriptorProto + * @instance + */ + DescriptorProto.prototype.nestedType = $util.emptyArray; + + /** + * DescriptorProto enumType. + * @member {Array.} enumType + * @memberof google.protobuf.DescriptorProto + * @instance + */ + DescriptorProto.prototype.enumType = $util.emptyArray; + + /** + * DescriptorProto extensionRange. + * @member {Array.} extensionRange + * @memberof google.protobuf.DescriptorProto + * @instance + */ + DescriptorProto.prototype.extensionRange = $util.emptyArray; + + /** + * DescriptorProto oneofDecl. + * @member {Array.} oneofDecl + * @memberof google.protobuf.DescriptorProto + * @instance + */ + DescriptorProto.prototype.oneofDecl = $util.emptyArray; + + /** + * DescriptorProto options. + * @member {google.protobuf.IMessageOptions|null|undefined} options + * @memberof google.protobuf.DescriptorProto + * @instance + */ + DescriptorProto.prototype.options = null; + + /** + * DescriptorProto reservedRange. + * @member {Array.} reservedRange + * @memberof google.protobuf.DescriptorProto + * @instance + */ + DescriptorProto.prototype.reservedRange = $util.emptyArray; + + /** + * DescriptorProto reservedName. + * @member {Array.} reservedName + * @memberof google.protobuf.DescriptorProto + * @instance + */ + DescriptorProto.prototype.reservedName = $util.emptyArray; + + /** + * Creates a new DescriptorProto instance using the specified properties. + * @function create + * @memberof google.protobuf.DescriptorProto + * @static + * @param {google.protobuf.IDescriptorProto=} [properties] Properties to set + * @returns {google.protobuf.DescriptorProto} DescriptorProto instance + */ + DescriptorProto.create = function create(properties) { + return new DescriptorProto(properties); + }; + + /** + * Encodes the specified DescriptorProto message. Does not implicitly {@link google.protobuf.DescriptorProto.verify|verify} messages. + * @function encode + * @memberof google.protobuf.DescriptorProto + * @static + * @param {google.protobuf.IDescriptorProto} message DescriptorProto message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DescriptorProto.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.field != null && message.field.length) + for (var i = 0; i < message.field.length; ++i) + $root.google.protobuf.FieldDescriptorProto.encode(message.field[i], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.nestedType != null && message.nestedType.length) + for (var i = 0; i < message.nestedType.length; ++i) + $root.google.protobuf.DescriptorProto.encode(message.nestedType[i], writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + if (message.enumType != null && message.enumType.length) + for (var i = 0; i < message.enumType.length; ++i) + $root.google.protobuf.EnumDescriptorProto.encode(message.enumType[i], writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); + if (message.extensionRange != null && message.extensionRange.length) + for (var i = 0; i < message.extensionRange.length; ++i) + $root.google.protobuf.DescriptorProto.ExtensionRange.encode(message.extensionRange[i], writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim(); + if (message.extension != null && message.extension.length) + for (var i = 0; i < message.extension.length; ++i) + $root.google.protobuf.FieldDescriptorProto.encode(message.extension[i], writer.uint32(/* id 6, wireType 2 =*/50).fork()).ldelim(); + if (message.options != null && Object.hasOwnProperty.call(message, "options")) + $root.google.protobuf.MessageOptions.encode(message.options, writer.uint32(/* id 7, wireType 2 =*/58).fork()).ldelim(); + if (message.oneofDecl != null && message.oneofDecl.length) + for (var i = 0; i < message.oneofDecl.length; ++i) + $root.google.protobuf.OneofDescriptorProto.encode(message.oneofDecl[i], writer.uint32(/* id 8, wireType 2 =*/66).fork()).ldelim(); + if (message.reservedRange != null && message.reservedRange.length) + for (var i = 0; i < message.reservedRange.length; ++i) + $root.google.protobuf.DescriptorProto.ReservedRange.encode(message.reservedRange[i], writer.uint32(/* id 9, wireType 2 =*/74).fork()).ldelim(); + if (message.reservedName != null && message.reservedName.length) + for (var i = 0; i < message.reservedName.length; ++i) + writer.uint32(/* id 10, wireType 2 =*/82).string(message.reservedName[i]); + return writer; + }; + + /** + * Encodes the specified DescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.DescriptorProto.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.DescriptorProto + * @static + * @param {google.protobuf.IDescriptorProto} message DescriptorProto message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DescriptorProto.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a DescriptorProto message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.DescriptorProto + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.DescriptorProto} DescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DescriptorProto.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.DescriptorProto(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + if (!(message.field && message.field.length)) + message.field = []; + message.field.push($root.google.protobuf.FieldDescriptorProto.decode(reader, reader.uint32())); + break; + } + case 6: { + if (!(message.extension && message.extension.length)) + message.extension = []; + message.extension.push($root.google.protobuf.FieldDescriptorProto.decode(reader, reader.uint32())); + break; + } + case 3: { + if (!(message.nestedType && message.nestedType.length)) + message.nestedType = []; + message.nestedType.push($root.google.protobuf.DescriptorProto.decode(reader, reader.uint32())); + break; + } + case 4: { + if (!(message.enumType && message.enumType.length)) + message.enumType = []; + message.enumType.push($root.google.protobuf.EnumDescriptorProto.decode(reader, reader.uint32())); + break; + } + case 5: { + if (!(message.extensionRange && message.extensionRange.length)) + message.extensionRange = []; + message.extensionRange.push($root.google.protobuf.DescriptorProto.ExtensionRange.decode(reader, reader.uint32())); + break; + } + case 8: { + if (!(message.oneofDecl && message.oneofDecl.length)) + message.oneofDecl = []; + message.oneofDecl.push($root.google.protobuf.OneofDescriptorProto.decode(reader, reader.uint32())); + break; + } + case 7: { + message.options = $root.google.protobuf.MessageOptions.decode(reader, reader.uint32()); + break; + } + case 9: { + if (!(message.reservedRange && message.reservedRange.length)) + message.reservedRange = []; + message.reservedRange.push($root.google.protobuf.DescriptorProto.ReservedRange.decode(reader, reader.uint32())); + break; + } + case 10: { + if (!(message.reservedName && message.reservedName.length)) + message.reservedName = []; + message.reservedName.push(reader.string()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a DescriptorProto message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.DescriptorProto + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.DescriptorProto} DescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DescriptorProto.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a DescriptorProto message. + * @function verify + * @memberof google.protobuf.DescriptorProto + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + DescriptorProto.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.field != null && message.hasOwnProperty("field")) { + if (!Array.isArray(message.field)) + return "field: array expected"; + for (var i = 0; i < message.field.length; ++i) { + var error = $root.google.protobuf.FieldDescriptorProto.verify(message.field[i]); + if (error) + return "field." + error; + } + } + if (message.extension != null && message.hasOwnProperty("extension")) { + if (!Array.isArray(message.extension)) + return "extension: array expected"; + for (var i = 0; i < message.extension.length; ++i) { + var error = $root.google.protobuf.FieldDescriptorProto.verify(message.extension[i]); + if (error) + return "extension." + error; + } + } + if (message.nestedType != null && message.hasOwnProperty("nestedType")) { + if (!Array.isArray(message.nestedType)) + return "nestedType: array expected"; + for (var i = 0; i < message.nestedType.length; ++i) { + var error = $root.google.protobuf.DescriptorProto.verify(message.nestedType[i]); + if (error) + return "nestedType." + error; + } + } + if (message.enumType != null && message.hasOwnProperty("enumType")) { + if (!Array.isArray(message.enumType)) + return "enumType: array expected"; + for (var i = 0; i < message.enumType.length; ++i) { + var error = $root.google.protobuf.EnumDescriptorProto.verify(message.enumType[i]); + if (error) + return "enumType." + error; + } + } + if (message.extensionRange != null && message.hasOwnProperty("extensionRange")) { + if (!Array.isArray(message.extensionRange)) + return "extensionRange: array expected"; + for (var i = 0; i < message.extensionRange.length; ++i) { + var error = $root.google.protobuf.DescriptorProto.ExtensionRange.verify(message.extensionRange[i]); + if (error) + return "extensionRange." + error; + } + } + if (message.oneofDecl != null && message.hasOwnProperty("oneofDecl")) { + if (!Array.isArray(message.oneofDecl)) + return "oneofDecl: array expected"; + for (var i = 0; i < message.oneofDecl.length; ++i) { + var error = $root.google.protobuf.OneofDescriptorProto.verify(message.oneofDecl[i]); + if (error) + return "oneofDecl." + error; + } + } + if (message.options != null && message.hasOwnProperty("options")) { + var error = $root.google.protobuf.MessageOptions.verify(message.options); + if (error) + return "options." + error; + } + if (message.reservedRange != null && message.hasOwnProperty("reservedRange")) { + if (!Array.isArray(message.reservedRange)) + return "reservedRange: array expected"; + for (var i = 0; i < message.reservedRange.length; ++i) { + var error = $root.google.protobuf.DescriptorProto.ReservedRange.verify(message.reservedRange[i]); + if (error) + return "reservedRange." + error; + } + } + if (message.reservedName != null && message.hasOwnProperty("reservedName")) { + if (!Array.isArray(message.reservedName)) + return "reservedName: array expected"; + for (var i = 0; i < message.reservedName.length; ++i) + if (!$util.isString(message.reservedName[i])) + return "reservedName: string[] expected"; + } + return null; + }; + + /** + * Creates a DescriptorProto message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.DescriptorProto + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.DescriptorProto} DescriptorProto + */ + DescriptorProto.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.DescriptorProto) + return object; + var message = new $root.google.protobuf.DescriptorProto(); + if (object.name != null) + message.name = String(object.name); + if (object.field) { + if (!Array.isArray(object.field)) + throw TypeError(".google.protobuf.DescriptorProto.field: array expected"); + message.field = []; + for (var i = 0; i < object.field.length; ++i) { + if (typeof object.field[i] !== "object") + throw TypeError(".google.protobuf.DescriptorProto.field: object expected"); + message.field[i] = $root.google.protobuf.FieldDescriptorProto.fromObject(object.field[i]); + } + } + if (object.extension) { + if (!Array.isArray(object.extension)) + throw TypeError(".google.protobuf.DescriptorProto.extension: array expected"); + message.extension = []; + for (var i = 0; i < object.extension.length; ++i) { + if (typeof object.extension[i] !== "object") + throw TypeError(".google.protobuf.DescriptorProto.extension: object expected"); + message.extension[i] = $root.google.protobuf.FieldDescriptorProto.fromObject(object.extension[i]); + } + } + if (object.nestedType) { + if (!Array.isArray(object.nestedType)) + throw TypeError(".google.protobuf.DescriptorProto.nestedType: array expected"); + message.nestedType = []; + for (var i = 0; i < object.nestedType.length; ++i) { + if (typeof object.nestedType[i] !== "object") + throw TypeError(".google.protobuf.DescriptorProto.nestedType: object expected"); + message.nestedType[i] = $root.google.protobuf.DescriptorProto.fromObject(object.nestedType[i]); + } + } + if (object.enumType) { + if (!Array.isArray(object.enumType)) + throw TypeError(".google.protobuf.DescriptorProto.enumType: array expected"); + message.enumType = []; + for (var i = 0; i < object.enumType.length; ++i) { + if (typeof object.enumType[i] !== "object") + throw TypeError(".google.protobuf.DescriptorProto.enumType: object expected"); + message.enumType[i] = $root.google.protobuf.EnumDescriptorProto.fromObject(object.enumType[i]); + } + } + if (object.extensionRange) { + if (!Array.isArray(object.extensionRange)) + throw TypeError(".google.protobuf.DescriptorProto.extensionRange: array expected"); + message.extensionRange = []; + for (var i = 0; i < object.extensionRange.length; ++i) { + if (typeof object.extensionRange[i] !== "object") + throw TypeError(".google.protobuf.DescriptorProto.extensionRange: object expected"); + message.extensionRange[i] = $root.google.protobuf.DescriptorProto.ExtensionRange.fromObject(object.extensionRange[i]); + } + } + if (object.oneofDecl) { + if (!Array.isArray(object.oneofDecl)) + throw TypeError(".google.protobuf.DescriptorProto.oneofDecl: array expected"); + message.oneofDecl = []; + for (var i = 0; i < object.oneofDecl.length; ++i) { + if (typeof object.oneofDecl[i] !== "object") + throw TypeError(".google.protobuf.DescriptorProto.oneofDecl: object expected"); + message.oneofDecl[i] = $root.google.protobuf.OneofDescriptorProto.fromObject(object.oneofDecl[i]); + } + } + if (object.options != null) { + if (typeof object.options !== "object") + throw TypeError(".google.protobuf.DescriptorProto.options: object expected"); + message.options = $root.google.protobuf.MessageOptions.fromObject(object.options); + } + if (object.reservedRange) { + if (!Array.isArray(object.reservedRange)) + throw TypeError(".google.protobuf.DescriptorProto.reservedRange: array expected"); + message.reservedRange = []; + for (var i = 0; i < object.reservedRange.length; ++i) { + if (typeof object.reservedRange[i] !== "object") + throw TypeError(".google.protobuf.DescriptorProto.reservedRange: object expected"); + message.reservedRange[i] = $root.google.protobuf.DescriptorProto.ReservedRange.fromObject(object.reservedRange[i]); + } + } + if (object.reservedName) { + if (!Array.isArray(object.reservedName)) + throw TypeError(".google.protobuf.DescriptorProto.reservedName: array expected"); + message.reservedName = []; + for (var i = 0; i < object.reservedName.length; ++i) + message.reservedName[i] = String(object.reservedName[i]); + } + return message; + }; + + /** + * Creates a plain object from a DescriptorProto message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.DescriptorProto + * @static + * @param {google.protobuf.DescriptorProto} message DescriptorProto + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + DescriptorProto.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.field = []; + object.nestedType = []; + object.enumType = []; + object.extensionRange = []; + object.extension = []; + object.oneofDecl = []; + object.reservedRange = []; + object.reservedName = []; + } + if (options.defaults) { + object.name = ""; + object.options = null; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.field && message.field.length) { + object.field = []; + for (var j = 0; j < message.field.length; ++j) + object.field[j] = $root.google.protobuf.FieldDescriptorProto.toObject(message.field[j], options); + } + if (message.nestedType && message.nestedType.length) { + object.nestedType = []; + for (var j = 0; j < message.nestedType.length; ++j) + object.nestedType[j] = $root.google.protobuf.DescriptorProto.toObject(message.nestedType[j], options); + } + if (message.enumType && message.enumType.length) { + object.enumType = []; + for (var j = 0; j < message.enumType.length; ++j) + object.enumType[j] = $root.google.protobuf.EnumDescriptorProto.toObject(message.enumType[j], options); + } + if (message.extensionRange && message.extensionRange.length) { + object.extensionRange = []; + for (var j = 0; j < message.extensionRange.length; ++j) + object.extensionRange[j] = $root.google.protobuf.DescriptorProto.ExtensionRange.toObject(message.extensionRange[j], options); + } + if (message.extension && message.extension.length) { + object.extension = []; + for (var j = 0; j < message.extension.length; ++j) + object.extension[j] = $root.google.protobuf.FieldDescriptorProto.toObject(message.extension[j], options); + } + if (message.options != null && message.hasOwnProperty("options")) + object.options = $root.google.protobuf.MessageOptions.toObject(message.options, options); + if (message.oneofDecl && message.oneofDecl.length) { + object.oneofDecl = []; + for (var j = 0; j < message.oneofDecl.length; ++j) + object.oneofDecl[j] = $root.google.protobuf.OneofDescriptorProto.toObject(message.oneofDecl[j], options); + } + if (message.reservedRange && message.reservedRange.length) { + object.reservedRange = []; + for (var j = 0; j < message.reservedRange.length; ++j) + object.reservedRange[j] = $root.google.protobuf.DescriptorProto.ReservedRange.toObject(message.reservedRange[j], options); + } + if (message.reservedName && message.reservedName.length) { + object.reservedName = []; + for (var j = 0; j < message.reservedName.length; ++j) + object.reservedName[j] = message.reservedName[j]; + } + return object; + }; + + /** + * Converts this DescriptorProto to JSON. + * @function toJSON + * @memberof google.protobuf.DescriptorProto + * @instance + * @returns {Object.} JSON object + */ + DescriptorProto.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for DescriptorProto + * @function getTypeUrl + * @memberof google.protobuf.DescriptorProto + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + DescriptorProto.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.DescriptorProto"; + }; + + DescriptorProto.ExtensionRange = (function() { + + /** + * Properties of an ExtensionRange. + * @memberof google.protobuf.DescriptorProto + * @interface IExtensionRange + * @property {number|null} [start] ExtensionRange start + * @property {number|null} [end] ExtensionRange end + * @property {google.protobuf.IExtensionRangeOptions|null} [options] ExtensionRange options + */ + + /** + * Constructs a new ExtensionRange. + * @memberof google.protobuf.DescriptorProto + * @classdesc Represents an ExtensionRange. + * @implements IExtensionRange + * @constructor + * @param {google.protobuf.DescriptorProto.IExtensionRange=} [properties] Properties to set + */ + function ExtensionRange(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ExtensionRange start. + * @member {number} start + * @memberof google.protobuf.DescriptorProto.ExtensionRange + * @instance + */ + ExtensionRange.prototype.start = 0; + + /** + * ExtensionRange end. + * @member {number} end + * @memberof google.protobuf.DescriptorProto.ExtensionRange + * @instance + */ + ExtensionRange.prototype.end = 0; + + /** + * ExtensionRange options. + * @member {google.protobuf.IExtensionRangeOptions|null|undefined} options + * @memberof google.protobuf.DescriptorProto.ExtensionRange + * @instance + */ + ExtensionRange.prototype.options = null; + + /** + * Creates a new ExtensionRange instance using the specified properties. + * @function create + * @memberof google.protobuf.DescriptorProto.ExtensionRange + * @static + * @param {google.protobuf.DescriptorProto.IExtensionRange=} [properties] Properties to set + * @returns {google.protobuf.DescriptorProto.ExtensionRange} ExtensionRange instance + */ + ExtensionRange.create = function create(properties) { + return new ExtensionRange(properties); + }; + + /** + * Encodes the specified ExtensionRange message. Does not implicitly {@link google.protobuf.DescriptorProto.ExtensionRange.verify|verify} messages. + * @function encode + * @memberof google.protobuf.DescriptorProto.ExtensionRange + * @static + * @param {google.protobuf.DescriptorProto.IExtensionRange} message ExtensionRange message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ExtensionRange.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.start != null && Object.hasOwnProperty.call(message, "start")) + writer.uint32(/* id 1, wireType 0 =*/8).int32(message.start); + if (message.end != null && Object.hasOwnProperty.call(message, "end")) + writer.uint32(/* id 2, wireType 0 =*/16).int32(message.end); + if (message.options != null && Object.hasOwnProperty.call(message, "options")) + $root.google.protobuf.ExtensionRangeOptions.encode(message.options, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified ExtensionRange message, length delimited. Does not implicitly {@link google.protobuf.DescriptorProto.ExtensionRange.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.DescriptorProto.ExtensionRange + * @static + * @param {google.protobuf.DescriptorProto.IExtensionRange} message ExtensionRange message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ExtensionRange.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an ExtensionRange message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.DescriptorProto.ExtensionRange + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.DescriptorProto.ExtensionRange} ExtensionRange + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ExtensionRange.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.DescriptorProto.ExtensionRange(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.start = reader.int32(); + break; + } + case 2: { + message.end = reader.int32(); + break; + } + case 3: { + message.options = $root.google.protobuf.ExtensionRangeOptions.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an ExtensionRange message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.DescriptorProto.ExtensionRange + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.DescriptorProto.ExtensionRange} ExtensionRange + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ExtensionRange.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an ExtensionRange message. + * @function verify + * @memberof google.protobuf.DescriptorProto.ExtensionRange + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ExtensionRange.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.start != null && message.hasOwnProperty("start")) + if (!$util.isInteger(message.start)) + return "start: integer expected"; + if (message.end != null && message.hasOwnProperty("end")) + if (!$util.isInteger(message.end)) + return "end: integer expected"; + if (message.options != null && message.hasOwnProperty("options")) { + var error = $root.google.protobuf.ExtensionRangeOptions.verify(message.options); + if (error) + return "options." + error; + } + return null; + }; + + /** + * Creates an ExtensionRange message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.DescriptorProto.ExtensionRange + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.DescriptorProto.ExtensionRange} ExtensionRange + */ + ExtensionRange.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.DescriptorProto.ExtensionRange) + return object; + var message = new $root.google.protobuf.DescriptorProto.ExtensionRange(); + if (object.start != null) + message.start = object.start | 0; + if (object.end != null) + message.end = object.end | 0; + if (object.options != null) { + if (typeof object.options !== "object") + throw TypeError(".google.protobuf.DescriptorProto.ExtensionRange.options: object expected"); + message.options = $root.google.protobuf.ExtensionRangeOptions.fromObject(object.options); + } + return message; + }; + + /** + * Creates a plain object from an ExtensionRange message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.DescriptorProto.ExtensionRange + * @static + * @param {google.protobuf.DescriptorProto.ExtensionRange} message ExtensionRange + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ExtensionRange.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.start = 0; + object.end = 0; + object.options = null; + } + if (message.start != null && message.hasOwnProperty("start")) + object.start = message.start; + if (message.end != null && message.hasOwnProperty("end")) + object.end = message.end; + if (message.options != null && message.hasOwnProperty("options")) + object.options = $root.google.protobuf.ExtensionRangeOptions.toObject(message.options, options); + return object; + }; + + /** + * Converts this ExtensionRange to JSON. + * @function toJSON + * @memberof google.protobuf.DescriptorProto.ExtensionRange + * @instance + * @returns {Object.} JSON object + */ + ExtensionRange.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ExtensionRange + * @function getTypeUrl + * @memberof google.protobuf.DescriptorProto.ExtensionRange + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ExtensionRange.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.DescriptorProto.ExtensionRange"; + }; + + return ExtensionRange; + })(); + + DescriptorProto.ReservedRange = (function() { + + /** + * Properties of a ReservedRange. + * @memberof google.protobuf.DescriptorProto + * @interface IReservedRange + * @property {number|null} [start] ReservedRange start + * @property {number|null} [end] ReservedRange end + */ + + /** + * Constructs a new ReservedRange. + * @memberof google.protobuf.DescriptorProto + * @classdesc Represents a ReservedRange. + * @implements IReservedRange + * @constructor + * @param {google.protobuf.DescriptorProto.IReservedRange=} [properties] Properties to set + */ + function ReservedRange(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ReservedRange start. + * @member {number} start + * @memberof google.protobuf.DescriptorProto.ReservedRange + * @instance + */ + ReservedRange.prototype.start = 0; + + /** + * ReservedRange end. + * @member {number} end + * @memberof google.protobuf.DescriptorProto.ReservedRange + * @instance + */ + ReservedRange.prototype.end = 0; + + /** + * Creates a new ReservedRange instance using the specified properties. + * @function create + * @memberof google.protobuf.DescriptorProto.ReservedRange + * @static + * @param {google.protobuf.DescriptorProto.IReservedRange=} [properties] Properties to set + * @returns {google.protobuf.DescriptorProto.ReservedRange} ReservedRange instance + */ + ReservedRange.create = function create(properties) { + return new ReservedRange(properties); + }; + + /** + * Encodes the specified ReservedRange message. Does not implicitly {@link google.protobuf.DescriptorProto.ReservedRange.verify|verify} messages. + * @function encode + * @memberof google.protobuf.DescriptorProto.ReservedRange + * @static + * @param {google.protobuf.DescriptorProto.IReservedRange} message ReservedRange message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ReservedRange.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.start != null && Object.hasOwnProperty.call(message, "start")) + writer.uint32(/* id 1, wireType 0 =*/8).int32(message.start); + if (message.end != null && Object.hasOwnProperty.call(message, "end")) + writer.uint32(/* id 2, wireType 0 =*/16).int32(message.end); + return writer; + }; + + /** + * Encodes the specified ReservedRange message, length delimited. Does not implicitly {@link google.protobuf.DescriptorProto.ReservedRange.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.DescriptorProto.ReservedRange + * @static + * @param {google.protobuf.DescriptorProto.IReservedRange} message ReservedRange message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ReservedRange.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ReservedRange message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.DescriptorProto.ReservedRange + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.DescriptorProto.ReservedRange} ReservedRange + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ReservedRange.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.DescriptorProto.ReservedRange(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.start = reader.int32(); + break; + } + case 2: { + message.end = reader.int32(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ReservedRange message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.DescriptorProto.ReservedRange + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.DescriptorProto.ReservedRange} ReservedRange + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ReservedRange.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ReservedRange message. + * @function verify + * @memberof google.protobuf.DescriptorProto.ReservedRange + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ReservedRange.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.start != null && message.hasOwnProperty("start")) + if (!$util.isInteger(message.start)) + return "start: integer expected"; + if (message.end != null && message.hasOwnProperty("end")) + if (!$util.isInteger(message.end)) + return "end: integer expected"; + return null; + }; + + /** + * Creates a ReservedRange message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.DescriptorProto.ReservedRange + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.DescriptorProto.ReservedRange} ReservedRange + */ + ReservedRange.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.DescriptorProto.ReservedRange) + return object; + var message = new $root.google.protobuf.DescriptorProto.ReservedRange(); + if (object.start != null) + message.start = object.start | 0; + if (object.end != null) + message.end = object.end | 0; + return message; + }; + + /** + * Creates a plain object from a ReservedRange message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.DescriptorProto.ReservedRange + * @static + * @param {google.protobuf.DescriptorProto.ReservedRange} message ReservedRange + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ReservedRange.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.start = 0; + object.end = 0; + } + if (message.start != null && message.hasOwnProperty("start")) + object.start = message.start; + if (message.end != null && message.hasOwnProperty("end")) + object.end = message.end; + return object; + }; + + /** + * Converts this ReservedRange to JSON. + * @function toJSON + * @memberof google.protobuf.DescriptorProto.ReservedRange + * @instance + * @returns {Object.} JSON object + */ + ReservedRange.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ReservedRange + * @function getTypeUrl + * @memberof google.protobuf.DescriptorProto.ReservedRange + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ReservedRange.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.DescriptorProto.ReservedRange"; + }; + + return ReservedRange; + })(); + + return DescriptorProto; + })(); + + protobuf.ExtensionRangeOptions = (function() { + + /** + * Properties of an ExtensionRangeOptions. + * @memberof google.protobuf + * @interface IExtensionRangeOptions + * @property {Array.|null} [uninterpretedOption] ExtensionRangeOptions uninterpretedOption + */ + + /** + * Constructs a new ExtensionRangeOptions. + * @memberof google.protobuf + * @classdesc Represents an ExtensionRangeOptions. + * @implements IExtensionRangeOptions + * @constructor + * @param {google.protobuf.IExtensionRangeOptions=} [properties] Properties to set + */ + function ExtensionRangeOptions(properties) { + this.uninterpretedOption = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ExtensionRangeOptions uninterpretedOption. + * @member {Array.} uninterpretedOption + * @memberof google.protobuf.ExtensionRangeOptions + * @instance + */ + ExtensionRangeOptions.prototype.uninterpretedOption = $util.emptyArray; + + /** + * Creates a new ExtensionRangeOptions instance using the specified properties. + * @function create + * @memberof google.protobuf.ExtensionRangeOptions + * @static + * @param {google.protobuf.IExtensionRangeOptions=} [properties] Properties to set + * @returns {google.protobuf.ExtensionRangeOptions} ExtensionRangeOptions instance + */ + ExtensionRangeOptions.create = function create(properties) { + return new ExtensionRangeOptions(properties); + }; + + /** + * Encodes the specified ExtensionRangeOptions message. Does not implicitly {@link google.protobuf.ExtensionRangeOptions.verify|verify} messages. + * @function encode + * @memberof google.protobuf.ExtensionRangeOptions + * @static + * @param {google.protobuf.IExtensionRangeOptions} message ExtensionRangeOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ExtensionRangeOptions.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.uninterpretedOption != null && message.uninterpretedOption.length) + for (var i = 0; i < message.uninterpretedOption.length; ++i) + $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified ExtensionRangeOptions message, length delimited. Does not implicitly {@link google.protobuf.ExtensionRangeOptions.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.ExtensionRangeOptions + * @static + * @param {google.protobuf.IExtensionRangeOptions} message ExtensionRangeOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ExtensionRangeOptions.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an ExtensionRangeOptions message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.ExtensionRangeOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.ExtensionRangeOptions} ExtensionRangeOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ExtensionRangeOptions.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.ExtensionRangeOptions(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 999: { + if (!(message.uninterpretedOption && message.uninterpretedOption.length)) + message.uninterpretedOption = []; + message.uninterpretedOption.push($root.google.protobuf.UninterpretedOption.decode(reader, reader.uint32())); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an ExtensionRangeOptions message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.ExtensionRangeOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.ExtensionRangeOptions} ExtensionRangeOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ExtensionRangeOptions.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an ExtensionRangeOptions message. + * @function verify + * @memberof google.protobuf.ExtensionRangeOptions + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ExtensionRangeOptions.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { + if (!Array.isArray(message.uninterpretedOption)) + return "uninterpretedOption: array expected"; + for (var i = 0; i < message.uninterpretedOption.length; ++i) { + var error = $root.google.protobuf.UninterpretedOption.verify(message.uninterpretedOption[i]); + if (error) + return "uninterpretedOption." + error; + } + } + return null; + }; + + /** + * Creates an ExtensionRangeOptions message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.ExtensionRangeOptions + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.ExtensionRangeOptions} ExtensionRangeOptions + */ + ExtensionRangeOptions.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.ExtensionRangeOptions) + return object; + var message = new $root.google.protobuf.ExtensionRangeOptions(); + if (object.uninterpretedOption) { + if (!Array.isArray(object.uninterpretedOption)) + throw TypeError(".google.protobuf.ExtensionRangeOptions.uninterpretedOption: array expected"); + message.uninterpretedOption = []; + for (var i = 0; i < object.uninterpretedOption.length; ++i) { + if (typeof object.uninterpretedOption[i] !== "object") + throw TypeError(".google.protobuf.ExtensionRangeOptions.uninterpretedOption: object expected"); + message.uninterpretedOption[i] = $root.google.protobuf.UninterpretedOption.fromObject(object.uninterpretedOption[i]); + } + } + return message; + }; + + /** + * Creates a plain object from an ExtensionRangeOptions message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.ExtensionRangeOptions + * @static + * @param {google.protobuf.ExtensionRangeOptions} message ExtensionRangeOptions + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ExtensionRangeOptions.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.uninterpretedOption = []; + if (message.uninterpretedOption && message.uninterpretedOption.length) { + object.uninterpretedOption = []; + for (var j = 0; j < message.uninterpretedOption.length; ++j) + object.uninterpretedOption[j] = $root.google.protobuf.UninterpretedOption.toObject(message.uninterpretedOption[j], options); + } + return object; + }; + + /** + * Converts this ExtensionRangeOptions to JSON. + * @function toJSON + * @memberof google.protobuf.ExtensionRangeOptions + * @instance + * @returns {Object.} JSON object + */ + ExtensionRangeOptions.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ExtensionRangeOptions + * @function getTypeUrl + * @memberof google.protobuf.ExtensionRangeOptions + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ExtensionRangeOptions.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.ExtensionRangeOptions"; + }; + + return ExtensionRangeOptions; + })(); + + protobuf.FieldDescriptorProto = (function() { + + /** + * Properties of a FieldDescriptorProto. + * @memberof google.protobuf + * @interface IFieldDescriptorProto + * @property {string|null} [name] FieldDescriptorProto name + * @property {number|null} [number] FieldDescriptorProto number + * @property {google.protobuf.FieldDescriptorProto.Label|null} [label] FieldDescriptorProto label + * @property {google.protobuf.FieldDescriptorProto.Type|null} [type] FieldDescriptorProto type + * @property {string|null} [typeName] FieldDescriptorProto typeName + * @property {string|null} [extendee] FieldDescriptorProto extendee + * @property {string|null} [defaultValue] FieldDescriptorProto defaultValue + * @property {number|null} [oneofIndex] FieldDescriptorProto oneofIndex + * @property {string|null} [jsonName] FieldDescriptorProto jsonName + * @property {google.protobuf.IFieldOptions|null} [options] FieldDescriptorProto options + * @property {boolean|null} [proto3Optional] FieldDescriptorProto proto3Optional + */ + + /** + * Constructs a new FieldDescriptorProto. + * @memberof google.protobuf + * @classdesc Represents a FieldDescriptorProto. + * @implements IFieldDescriptorProto + * @constructor + * @param {google.protobuf.IFieldDescriptorProto=} [properties] Properties to set + */ + function FieldDescriptorProto(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * FieldDescriptorProto name. + * @member {string} name + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.name = ""; + + /** + * FieldDescriptorProto number. + * @member {number} number + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.number = 0; + + /** + * FieldDescriptorProto label. + * @member {google.protobuf.FieldDescriptorProto.Label} label + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.label = 1; + + /** + * FieldDescriptorProto type. + * @member {google.protobuf.FieldDescriptorProto.Type} type + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.type = 1; + + /** + * FieldDescriptorProto typeName. + * @member {string} typeName + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.typeName = ""; + + /** + * FieldDescriptorProto extendee. + * @member {string} extendee + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.extendee = ""; + + /** + * FieldDescriptorProto defaultValue. + * @member {string} defaultValue + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.defaultValue = ""; + + /** + * FieldDescriptorProto oneofIndex. + * @member {number} oneofIndex + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.oneofIndex = 0; + + /** + * FieldDescriptorProto jsonName. + * @member {string} jsonName + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.jsonName = ""; + + /** + * FieldDescriptorProto options. + * @member {google.protobuf.IFieldOptions|null|undefined} options + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.options = null; + + /** + * FieldDescriptorProto proto3Optional. + * @member {boolean} proto3Optional + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.proto3Optional = false; + + /** + * Creates a new FieldDescriptorProto instance using the specified properties. + * @function create + * @memberof google.protobuf.FieldDescriptorProto + * @static + * @param {google.protobuf.IFieldDescriptorProto=} [properties] Properties to set + * @returns {google.protobuf.FieldDescriptorProto} FieldDescriptorProto instance + */ + FieldDescriptorProto.create = function create(properties) { + return new FieldDescriptorProto(properties); + }; + + /** + * Encodes the specified FieldDescriptorProto message. Does not implicitly {@link google.protobuf.FieldDescriptorProto.verify|verify} messages. + * @function encode + * @memberof google.protobuf.FieldDescriptorProto + * @static + * @param {google.protobuf.IFieldDescriptorProto} message FieldDescriptorProto message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + FieldDescriptorProto.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.extendee != null && Object.hasOwnProperty.call(message, "extendee")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.extendee); + if (message.number != null && Object.hasOwnProperty.call(message, "number")) + writer.uint32(/* id 3, wireType 0 =*/24).int32(message.number); + if (message.label != null && Object.hasOwnProperty.call(message, "label")) + writer.uint32(/* id 4, wireType 0 =*/32).int32(message.label); + if (message.type != null && Object.hasOwnProperty.call(message, "type")) + writer.uint32(/* id 5, wireType 0 =*/40).int32(message.type); + if (message.typeName != null && Object.hasOwnProperty.call(message, "typeName")) + writer.uint32(/* id 6, wireType 2 =*/50).string(message.typeName); + if (message.defaultValue != null && Object.hasOwnProperty.call(message, "defaultValue")) + writer.uint32(/* id 7, wireType 2 =*/58).string(message.defaultValue); + if (message.options != null && Object.hasOwnProperty.call(message, "options")) + $root.google.protobuf.FieldOptions.encode(message.options, writer.uint32(/* id 8, wireType 2 =*/66).fork()).ldelim(); + if (message.oneofIndex != null && Object.hasOwnProperty.call(message, "oneofIndex")) + writer.uint32(/* id 9, wireType 0 =*/72).int32(message.oneofIndex); + if (message.jsonName != null && Object.hasOwnProperty.call(message, "jsonName")) + writer.uint32(/* id 10, wireType 2 =*/82).string(message.jsonName); + if (message.proto3Optional != null && Object.hasOwnProperty.call(message, "proto3Optional")) + writer.uint32(/* id 17, wireType 0 =*/136).bool(message.proto3Optional); + return writer; + }; + + /** + * Encodes the specified FieldDescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.FieldDescriptorProto.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.FieldDescriptorProto + * @static + * @param {google.protobuf.IFieldDescriptorProto} message FieldDescriptorProto message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + FieldDescriptorProto.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a FieldDescriptorProto message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.FieldDescriptorProto + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.FieldDescriptorProto} FieldDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + FieldDescriptorProto.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.FieldDescriptorProto(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 3: { + message.number = reader.int32(); + break; + } + case 4: { + message.label = reader.int32(); + break; + } + case 5: { + message.type = reader.int32(); + break; + } + case 6: { + message.typeName = reader.string(); + break; + } + case 2: { + message.extendee = reader.string(); + break; + } + case 7: { + message.defaultValue = reader.string(); + break; + } + case 9: { + message.oneofIndex = reader.int32(); + break; + } + case 10: { + message.jsonName = reader.string(); + break; + } + case 8: { + message.options = $root.google.protobuf.FieldOptions.decode(reader, reader.uint32()); + break; + } + case 17: { + message.proto3Optional = reader.bool(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a FieldDescriptorProto message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.FieldDescriptorProto + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.FieldDescriptorProto} FieldDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + FieldDescriptorProto.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a FieldDescriptorProto message. + * @function verify + * @memberof google.protobuf.FieldDescriptorProto + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + FieldDescriptorProto.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.number != null && message.hasOwnProperty("number")) + if (!$util.isInteger(message.number)) + return "number: integer expected"; + if (message.label != null && message.hasOwnProperty("label")) + switch (message.label) { + default: + return "label: enum value expected"; + case 1: + case 2: + case 3: + break; + } + if (message.type != null && message.hasOwnProperty("type")) + switch (message.type) { + default: + return "type: enum value expected"; + case 1: + case 2: + case 3: + case 4: + case 5: + case 6: + case 7: + case 8: + case 9: + case 10: + case 11: + case 12: + case 13: + case 14: + case 15: + case 16: + case 17: + case 18: + break; + } + if (message.typeName != null && message.hasOwnProperty("typeName")) + if (!$util.isString(message.typeName)) + return "typeName: string expected"; + if (message.extendee != null && message.hasOwnProperty("extendee")) + if (!$util.isString(message.extendee)) + return "extendee: string expected"; + if (message.defaultValue != null && message.hasOwnProperty("defaultValue")) + if (!$util.isString(message.defaultValue)) + return "defaultValue: string expected"; + if (message.oneofIndex != null && message.hasOwnProperty("oneofIndex")) + if (!$util.isInteger(message.oneofIndex)) + return "oneofIndex: integer expected"; + if (message.jsonName != null && message.hasOwnProperty("jsonName")) + if (!$util.isString(message.jsonName)) + return "jsonName: string expected"; + if (message.options != null && message.hasOwnProperty("options")) { + var error = $root.google.protobuf.FieldOptions.verify(message.options); + if (error) + return "options." + error; + } + if (message.proto3Optional != null && message.hasOwnProperty("proto3Optional")) + if (typeof message.proto3Optional !== "boolean") + return "proto3Optional: boolean expected"; + return null; + }; + + /** + * Creates a FieldDescriptorProto message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.FieldDescriptorProto + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.FieldDescriptorProto} FieldDescriptorProto + */ + FieldDescriptorProto.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.FieldDescriptorProto) + return object; + var message = new $root.google.protobuf.FieldDescriptorProto(); + if (object.name != null) + message.name = String(object.name); + if (object.number != null) + message.number = object.number | 0; + switch (object.label) { + default: + if (typeof object.label === "number") { + message.label = object.label; + break; + } + break; + case "LABEL_OPTIONAL": + case 1: + message.label = 1; + break; + case "LABEL_REQUIRED": + case 2: + message.label = 2; + break; + case "LABEL_REPEATED": + case 3: + message.label = 3; + break; + } + switch (object.type) { + default: + if (typeof object.type === "number") { + message.type = object.type; + break; + } + break; + case "TYPE_DOUBLE": + case 1: + message.type = 1; + break; + case "TYPE_FLOAT": + case 2: + message.type = 2; + break; + case "TYPE_INT64": + case 3: + message.type = 3; + break; + case "TYPE_UINT64": + case 4: + message.type = 4; + break; + case "TYPE_INT32": + case 5: + message.type = 5; + break; + case "TYPE_FIXED64": + case 6: + message.type = 6; + break; + case "TYPE_FIXED32": + case 7: + message.type = 7; + break; + case "TYPE_BOOL": + case 8: + message.type = 8; + break; + case "TYPE_STRING": + case 9: + message.type = 9; + break; + case "TYPE_GROUP": + case 10: + message.type = 10; + break; + case "TYPE_MESSAGE": + case 11: + message.type = 11; + break; + case "TYPE_BYTES": + case 12: + message.type = 12; + break; + case "TYPE_UINT32": + case 13: + message.type = 13; + break; + case "TYPE_ENUM": + case 14: + message.type = 14; + break; + case "TYPE_SFIXED32": + case 15: + message.type = 15; + break; + case "TYPE_SFIXED64": + case 16: + message.type = 16; + break; + case "TYPE_SINT32": + case 17: + message.type = 17; + break; + case "TYPE_SINT64": + case 18: + message.type = 18; + break; + } + if (object.typeName != null) + message.typeName = String(object.typeName); + if (object.extendee != null) + message.extendee = String(object.extendee); + if (object.defaultValue != null) + message.defaultValue = String(object.defaultValue); + if (object.oneofIndex != null) + message.oneofIndex = object.oneofIndex | 0; + if (object.jsonName != null) + message.jsonName = String(object.jsonName); + if (object.options != null) { + if (typeof object.options !== "object") + throw TypeError(".google.protobuf.FieldDescriptorProto.options: object expected"); + message.options = $root.google.protobuf.FieldOptions.fromObject(object.options); + } + if (object.proto3Optional != null) + message.proto3Optional = Boolean(object.proto3Optional); + return message; + }; + + /** + * Creates a plain object from a FieldDescriptorProto message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.FieldDescriptorProto + * @static + * @param {google.protobuf.FieldDescriptorProto} message FieldDescriptorProto + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + FieldDescriptorProto.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.name = ""; + object.extendee = ""; + object.number = 0; + object.label = options.enums === String ? "LABEL_OPTIONAL" : 1; + object.type = options.enums === String ? "TYPE_DOUBLE" : 1; + object.typeName = ""; + object.defaultValue = ""; + object.options = null; + object.oneofIndex = 0; + object.jsonName = ""; + object.proto3Optional = false; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.extendee != null && message.hasOwnProperty("extendee")) + object.extendee = message.extendee; + if (message.number != null && message.hasOwnProperty("number")) + object.number = message.number; + if (message.label != null && message.hasOwnProperty("label")) + object.label = options.enums === String ? $root.google.protobuf.FieldDescriptorProto.Label[message.label] === undefined ? message.label : $root.google.protobuf.FieldDescriptorProto.Label[message.label] : message.label; + if (message.type != null && message.hasOwnProperty("type")) + object.type = options.enums === String ? $root.google.protobuf.FieldDescriptorProto.Type[message.type] === undefined ? message.type : $root.google.protobuf.FieldDescriptorProto.Type[message.type] : message.type; + if (message.typeName != null && message.hasOwnProperty("typeName")) + object.typeName = message.typeName; + if (message.defaultValue != null && message.hasOwnProperty("defaultValue")) + object.defaultValue = message.defaultValue; + if (message.options != null && message.hasOwnProperty("options")) + object.options = $root.google.protobuf.FieldOptions.toObject(message.options, options); + if (message.oneofIndex != null && message.hasOwnProperty("oneofIndex")) + object.oneofIndex = message.oneofIndex; + if (message.jsonName != null && message.hasOwnProperty("jsonName")) + object.jsonName = message.jsonName; + if (message.proto3Optional != null && message.hasOwnProperty("proto3Optional")) + object.proto3Optional = message.proto3Optional; + return object; + }; + + /** + * Converts this FieldDescriptorProto to JSON. + * @function toJSON + * @memberof google.protobuf.FieldDescriptorProto + * @instance + * @returns {Object.} JSON object + */ + FieldDescriptorProto.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for FieldDescriptorProto + * @function getTypeUrl + * @memberof google.protobuf.FieldDescriptorProto + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + FieldDescriptorProto.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.FieldDescriptorProto"; + }; + + /** + * Type enum. + * @name google.protobuf.FieldDescriptorProto.Type + * @enum {number} + * @property {number} TYPE_DOUBLE=1 TYPE_DOUBLE value + * @property {number} TYPE_FLOAT=2 TYPE_FLOAT value + * @property {number} TYPE_INT64=3 TYPE_INT64 value + * @property {number} TYPE_UINT64=4 TYPE_UINT64 value + * @property {number} TYPE_INT32=5 TYPE_INT32 value + * @property {number} TYPE_FIXED64=6 TYPE_FIXED64 value + * @property {number} TYPE_FIXED32=7 TYPE_FIXED32 value + * @property {number} TYPE_BOOL=8 TYPE_BOOL value + * @property {number} TYPE_STRING=9 TYPE_STRING value + * @property {number} TYPE_GROUP=10 TYPE_GROUP value + * @property {number} TYPE_MESSAGE=11 TYPE_MESSAGE value + * @property {number} TYPE_BYTES=12 TYPE_BYTES value + * @property {number} TYPE_UINT32=13 TYPE_UINT32 value + * @property {number} TYPE_ENUM=14 TYPE_ENUM value + * @property {number} TYPE_SFIXED32=15 TYPE_SFIXED32 value + * @property {number} TYPE_SFIXED64=16 TYPE_SFIXED64 value + * @property {number} TYPE_SINT32=17 TYPE_SINT32 value + * @property {number} TYPE_SINT64=18 TYPE_SINT64 value + */ + FieldDescriptorProto.Type = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[1] = "TYPE_DOUBLE"] = 1; + values[valuesById[2] = "TYPE_FLOAT"] = 2; + values[valuesById[3] = "TYPE_INT64"] = 3; + values[valuesById[4] = "TYPE_UINT64"] = 4; + values[valuesById[5] = "TYPE_INT32"] = 5; + values[valuesById[6] = "TYPE_FIXED64"] = 6; + values[valuesById[7] = "TYPE_FIXED32"] = 7; + values[valuesById[8] = "TYPE_BOOL"] = 8; + values[valuesById[9] = "TYPE_STRING"] = 9; + values[valuesById[10] = "TYPE_GROUP"] = 10; + values[valuesById[11] = "TYPE_MESSAGE"] = 11; + values[valuesById[12] = "TYPE_BYTES"] = 12; + values[valuesById[13] = "TYPE_UINT32"] = 13; + values[valuesById[14] = "TYPE_ENUM"] = 14; + values[valuesById[15] = "TYPE_SFIXED32"] = 15; + values[valuesById[16] = "TYPE_SFIXED64"] = 16; + values[valuesById[17] = "TYPE_SINT32"] = 17; + values[valuesById[18] = "TYPE_SINT64"] = 18; + return values; + })(); + + /** + * Label enum. + * @name google.protobuf.FieldDescriptorProto.Label + * @enum {number} + * @property {number} LABEL_OPTIONAL=1 LABEL_OPTIONAL value + * @property {number} LABEL_REQUIRED=2 LABEL_REQUIRED value + * @property {number} LABEL_REPEATED=3 LABEL_REPEATED value + */ + FieldDescriptorProto.Label = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[1] = "LABEL_OPTIONAL"] = 1; + values[valuesById[2] = "LABEL_REQUIRED"] = 2; + values[valuesById[3] = "LABEL_REPEATED"] = 3; + return values; + })(); + + return FieldDescriptorProto; + })(); + + protobuf.OneofDescriptorProto = (function() { + + /** + * Properties of an OneofDescriptorProto. + * @memberof google.protobuf + * @interface IOneofDescriptorProto + * @property {string|null} [name] OneofDescriptorProto name + * @property {google.protobuf.IOneofOptions|null} [options] OneofDescriptorProto options + */ + + /** + * Constructs a new OneofDescriptorProto. + * @memberof google.protobuf + * @classdesc Represents an OneofDescriptorProto. + * @implements IOneofDescriptorProto + * @constructor + * @param {google.protobuf.IOneofDescriptorProto=} [properties] Properties to set + */ + function OneofDescriptorProto(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * OneofDescriptorProto name. + * @member {string} name + * @memberof google.protobuf.OneofDescriptorProto + * @instance + */ + OneofDescriptorProto.prototype.name = ""; + + /** + * OneofDescriptorProto options. + * @member {google.protobuf.IOneofOptions|null|undefined} options + * @memberof google.protobuf.OneofDescriptorProto + * @instance + */ + OneofDescriptorProto.prototype.options = null; + + /** + * Creates a new OneofDescriptorProto instance using the specified properties. + * @function create + * @memberof google.protobuf.OneofDescriptorProto + * @static + * @param {google.protobuf.IOneofDescriptorProto=} [properties] Properties to set + * @returns {google.protobuf.OneofDescriptorProto} OneofDescriptorProto instance + */ + OneofDescriptorProto.create = function create(properties) { + return new OneofDescriptorProto(properties); + }; + + /** + * Encodes the specified OneofDescriptorProto message. Does not implicitly {@link google.protobuf.OneofDescriptorProto.verify|verify} messages. + * @function encode + * @memberof google.protobuf.OneofDescriptorProto + * @static + * @param {google.protobuf.IOneofDescriptorProto} message OneofDescriptorProto message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + OneofDescriptorProto.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.options != null && Object.hasOwnProperty.call(message, "options")) + $root.google.protobuf.OneofOptions.encode(message.options, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified OneofDescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.OneofDescriptorProto.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.OneofDescriptorProto + * @static + * @param {google.protobuf.IOneofDescriptorProto} message OneofDescriptorProto message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + OneofDescriptorProto.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an OneofDescriptorProto message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.OneofDescriptorProto + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.OneofDescriptorProto} OneofDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + OneofDescriptorProto.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.OneofDescriptorProto(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.options = $root.google.protobuf.OneofOptions.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an OneofDescriptorProto message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.OneofDescriptorProto + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.OneofDescriptorProto} OneofDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + OneofDescriptorProto.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an OneofDescriptorProto message. + * @function verify + * @memberof google.protobuf.OneofDescriptorProto + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + OneofDescriptorProto.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.options != null && message.hasOwnProperty("options")) { + var error = $root.google.protobuf.OneofOptions.verify(message.options); + if (error) + return "options." + error; + } + return null; + }; + + /** + * Creates an OneofDescriptorProto message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.OneofDescriptorProto + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.OneofDescriptorProto} OneofDescriptorProto + */ + OneofDescriptorProto.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.OneofDescriptorProto) + return object; + var message = new $root.google.protobuf.OneofDescriptorProto(); + if (object.name != null) + message.name = String(object.name); + if (object.options != null) { + if (typeof object.options !== "object") + throw TypeError(".google.protobuf.OneofDescriptorProto.options: object expected"); + message.options = $root.google.protobuf.OneofOptions.fromObject(object.options); + } + return message; + }; + + /** + * Creates a plain object from an OneofDescriptorProto message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.OneofDescriptorProto + * @static + * @param {google.protobuf.OneofDescriptorProto} message OneofDescriptorProto + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + OneofDescriptorProto.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.name = ""; + object.options = null; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.options != null && message.hasOwnProperty("options")) + object.options = $root.google.protobuf.OneofOptions.toObject(message.options, options); + return object; + }; + + /** + * Converts this OneofDescriptorProto to JSON. + * @function toJSON + * @memberof google.protobuf.OneofDescriptorProto + * @instance + * @returns {Object.} JSON object + */ + OneofDescriptorProto.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for OneofDescriptorProto + * @function getTypeUrl + * @memberof google.protobuf.OneofDescriptorProto + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + OneofDescriptorProto.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.OneofDescriptorProto"; + }; + + return OneofDescriptorProto; + })(); + + protobuf.EnumDescriptorProto = (function() { + + /** + * Properties of an EnumDescriptorProto. + * @memberof google.protobuf + * @interface IEnumDescriptorProto + * @property {string|null} [name] EnumDescriptorProto name + * @property {Array.|null} [value] EnumDescriptorProto value + * @property {google.protobuf.IEnumOptions|null} [options] EnumDescriptorProto options + * @property {Array.|null} [reservedRange] EnumDescriptorProto reservedRange + * @property {Array.|null} [reservedName] EnumDescriptorProto reservedName + */ + + /** + * Constructs a new EnumDescriptorProto. + * @memberof google.protobuf + * @classdesc Represents an EnumDescriptorProto. + * @implements IEnumDescriptorProto + * @constructor + * @param {google.protobuf.IEnumDescriptorProto=} [properties] Properties to set + */ + function EnumDescriptorProto(properties) { + this.value = []; + this.reservedRange = []; + this.reservedName = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * EnumDescriptorProto name. + * @member {string} name + * @memberof google.protobuf.EnumDescriptorProto + * @instance + */ + EnumDescriptorProto.prototype.name = ""; + + /** + * EnumDescriptorProto value. + * @member {Array.} value + * @memberof google.protobuf.EnumDescriptorProto + * @instance + */ + EnumDescriptorProto.prototype.value = $util.emptyArray; + + /** + * EnumDescriptorProto options. + * @member {google.protobuf.IEnumOptions|null|undefined} options + * @memberof google.protobuf.EnumDescriptorProto + * @instance + */ + EnumDescriptorProto.prototype.options = null; + + /** + * EnumDescriptorProto reservedRange. + * @member {Array.} reservedRange + * @memberof google.protobuf.EnumDescriptorProto + * @instance + */ + EnumDescriptorProto.prototype.reservedRange = $util.emptyArray; + + /** + * EnumDescriptorProto reservedName. + * @member {Array.} reservedName + * @memberof google.protobuf.EnumDescriptorProto + * @instance + */ + EnumDescriptorProto.prototype.reservedName = $util.emptyArray; + + /** + * Creates a new EnumDescriptorProto instance using the specified properties. + * @function create + * @memberof google.protobuf.EnumDescriptorProto + * @static + * @param {google.protobuf.IEnumDescriptorProto=} [properties] Properties to set + * @returns {google.protobuf.EnumDescriptorProto} EnumDescriptorProto instance + */ + EnumDescriptorProto.create = function create(properties) { + return new EnumDescriptorProto(properties); + }; + + /** + * Encodes the specified EnumDescriptorProto message. Does not implicitly {@link google.protobuf.EnumDescriptorProto.verify|verify} messages. + * @function encode + * @memberof google.protobuf.EnumDescriptorProto + * @static + * @param {google.protobuf.IEnumDescriptorProto} message EnumDescriptorProto message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + EnumDescriptorProto.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.value != null && message.value.length) + for (var i = 0; i < message.value.length; ++i) + $root.google.protobuf.EnumValueDescriptorProto.encode(message.value[i], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.options != null && Object.hasOwnProperty.call(message, "options")) + $root.google.protobuf.EnumOptions.encode(message.options, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + if (message.reservedRange != null && message.reservedRange.length) + for (var i = 0; i < message.reservedRange.length; ++i) + $root.google.protobuf.EnumDescriptorProto.EnumReservedRange.encode(message.reservedRange[i], writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); + if (message.reservedName != null && message.reservedName.length) + for (var i = 0; i < message.reservedName.length; ++i) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.reservedName[i]); + return writer; + }; + + /** + * Encodes the specified EnumDescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.EnumDescriptorProto.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.EnumDescriptorProto + * @static + * @param {google.protobuf.IEnumDescriptorProto} message EnumDescriptorProto message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + EnumDescriptorProto.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an EnumDescriptorProto message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.EnumDescriptorProto + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.EnumDescriptorProto} EnumDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + EnumDescriptorProto.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.EnumDescriptorProto(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + if (!(message.value && message.value.length)) + message.value = []; + message.value.push($root.google.protobuf.EnumValueDescriptorProto.decode(reader, reader.uint32())); + break; + } + case 3: { + message.options = $root.google.protobuf.EnumOptions.decode(reader, reader.uint32()); + break; + } + case 4: { + if (!(message.reservedRange && message.reservedRange.length)) + message.reservedRange = []; + message.reservedRange.push($root.google.protobuf.EnumDescriptorProto.EnumReservedRange.decode(reader, reader.uint32())); + break; + } + case 5: { + if (!(message.reservedName && message.reservedName.length)) + message.reservedName = []; + message.reservedName.push(reader.string()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an EnumDescriptorProto message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.EnumDescriptorProto + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.EnumDescriptorProto} EnumDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + EnumDescriptorProto.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an EnumDescriptorProto message. + * @function verify + * @memberof google.protobuf.EnumDescriptorProto + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + EnumDescriptorProto.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.value != null && message.hasOwnProperty("value")) { + if (!Array.isArray(message.value)) + return "value: array expected"; + for (var i = 0; i < message.value.length; ++i) { + var error = $root.google.protobuf.EnumValueDescriptorProto.verify(message.value[i]); + if (error) + return "value." + error; + } + } + if (message.options != null && message.hasOwnProperty("options")) { + var error = $root.google.protobuf.EnumOptions.verify(message.options); + if (error) + return "options." + error; + } + if (message.reservedRange != null && message.hasOwnProperty("reservedRange")) { + if (!Array.isArray(message.reservedRange)) + return "reservedRange: array expected"; + for (var i = 0; i < message.reservedRange.length; ++i) { + var error = $root.google.protobuf.EnumDescriptorProto.EnumReservedRange.verify(message.reservedRange[i]); + if (error) + return "reservedRange." + error; + } + } + if (message.reservedName != null && message.hasOwnProperty("reservedName")) { + if (!Array.isArray(message.reservedName)) + return "reservedName: array expected"; + for (var i = 0; i < message.reservedName.length; ++i) + if (!$util.isString(message.reservedName[i])) + return "reservedName: string[] expected"; + } + return null; + }; + + /** + * Creates an EnumDescriptorProto message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.EnumDescriptorProto + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.EnumDescriptorProto} EnumDescriptorProto + */ + EnumDescriptorProto.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.EnumDescriptorProto) + return object; + var message = new $root.google.protobuf.EnumDescriptorProto(); + if (object.name != null) + message.name = String(object.name); + if (object.value) { + if (!Array.isArray(object.value)) + throw TypeError(".google.protobuf.EnumDescriptorProto.value: array expected"); + message.value = []; + for (var i = 0; i < object.value.length; ++i) { + if (typeof object.value[i] !== "object") + throw TypeError(".google.protobuf.EnumDescriptorProto.value: object expected"); + message.value[i] = $root.google.protobuf.EnumValueDescriptorProto.fromObject(object.value[i]); + } + } + if (object.options != null) { + if (typeof object.options !== "object") + throw TypeError(".google.protobuf.EnumDescriptorProto.options: object expected"); + message.options = $root.google.protobuf.EnumOptions.fromObject(object.options); + } + if (object.reservedRange) { + if (!Array.isArray(object.reservedRange)) + throw TypeError(".google.protobuf.EnumDescriptorProto.reservedRange: array expected"); + message.reservedRange = []; + for (var i = 0; i < object.reservedRange.length; ++i) { + if (typeof object.reservedRange[i] !== "object") + throw TypeError(".google.protobuf.EnumDescriptorProto.reservedRange: object expected"); + message.reservedRange[i] = $root.google.protobuf.EnumDescriptorProto.EnumReservedRange.fromObject(object.reservedRange[i]); + } + } + if (object.reservedName) { + if (!Array.isArray(object.reservedName)) + throw TypeError(".google.protobuf.EnumDescriptorProto.reservedName: array expected"); + message.reservedName = []; + for (var i = 0; i < object.reservedName.length; ++i) + message.reservedName[i] = String(object.reservedName[i]); + } + return message; + }; + + /** + * Creates a plain object from an EnumDescriptorProto message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.EnumDescriptorProto + * @static + * @param {google.protobuf.EnumDescriptorProto} message EnumDescriptorProto + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + EnumDescriptorProto.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.value = []; + object.reservedRange = []; + object.reservedName = []; + } + if (options.defaults) { + object.name = ""; + object.options = null; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.value && message.value.length) { + object.value = []; + for (var j = 0; j < message.value.length; ++j) + object.value[j] = $root.google.protobuf.EnumValueDescriptorProto.toObject(message.value[j], options); + } + if (message.options != null && message.hasOwnProperty("options")) + object.options = $root.google.protobuf.EnumOptions.toObject(message.options, options); + if (message.reservedRange && message.reservedRange.length) { + object.reservedRange = []; + for (var j = 0; j < message.reservedRange.length; ++j) + object.reservedRange[j] = $root.google.protobuf.EnumDescriptorProto.EnumReservedRange.toObject(message.reservedRange[j], options); + } + if (message.reservedName && message.reservedName.length) { + object.reservedName = []; + for (var j = 0; j < message.reservedName.length; ++j) + object.reservedName[j] = message.reservedName[j]; + } + return object; + }; + + /** + * Converts this EnumDescriptorProto to JSON. + * @function toJSON + * @memberof google.protobuf.EnumDescriptorProto + * @instance + * @returns {Object.} JSON object + */ + EnumDescriptorProto.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for EnumDescriptorProto + * @function getTypeUrl + * @memberof google.protobuf.EnumDescriptorProto + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + EnumDescriptorProto.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.EnumDescriptorProto"; + }; + + EnumDescriptorProto.EnumReservedRange = (function() { + + /** + * Properties of an EnumReservedRange. + * @memberof google.protobuf.EnumDescriptorProto + * @interface IEnumReservedRange + * @property {number|null} [start] EnumReservedRange start + * @property {number|null} [end] EnumReservedRange end + */ + + /** + * Constructs a new EnumReservedRange. + * @memberof google.protobuf.EnumDescriptorProto + * @classdesc Represents an EnumReservedRange. + * @implements IEnumReservedRange + * @constructor + * @param {google.protobuf.EnumDescriptorProto.IEnumReservedRange=} [properties] Properties to set + */ + function EnumReservedRange(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * EnumReservedRange start. + * @member {number} start + * @memberof google.protobuf.EnumDescriptorProto.EnumReservedRange + * @instance + */ + EnumReservedRange.prototype.start = 0; + + /** + * EnumReservedRange end. + * @member {number} end + * @memberof google.protobuf.EnumDescriptorProto.EnumReservedRange + * @instance + */ + EnumReservedRange.prototype.end = 0; + + /** + * Creates a new EnumReservedRange instance using the specified properties. + * @function create + * @memberof google.protobuf.EnumDescriptorProto.EnumReservedRange + * @static + * @param {google.protobuf.EnumDescriptorProto.IEnumReservedRange=} [properties] Properties to set + * @returns {google.protobuf.EnumDescriptorProto.EnumReservedRange} EnumReservedRange instance + */ + EnumReservedRange.create = function create(properties) { + return new EnumReservedRange(properties); + }; + + /** + * Encodes the specified EnumReservedRange message. Does not implicitly {@link google.protobuf.EnumDescriptorProto.EnumReservedRange.verify|verify} messages. + * @function encode + * @memberof google.protobuf.EnumDescriptorProto.EnumReservedRange + * @static + * @param {google.protobuf.EnumDescriptorProto.IEnumReservedRange} message EnumReservedRange message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + EnumReservedRange.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.start != null && Object.hasOwnProperty.call(message, "start")) + writer.uint32(/* id 1, wireType 0 =*/8).int32(message.start); + if (message.end != null && Object.hasOwnProperty.call(message, "end")) + writer.uint32(/* id 2, wireType 0 =*/16).int32(message.end); + return writer; + }; + + /** + * Encodes the specified EnumReservedRange message, length delimited. Does not implicitly {@link google.protobuf.EnumDescriptorProto.EnumReservedRange.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.EnumDescriptorProto.EnumReservedRange + * @static + * @param {google.protobuf.EnumDescriptorProto.IEnumReservedRange} message EnumReservedRange message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + EnumReservedRange.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an EnumReservedRange message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.EnumDescriptorProto.EnumReservedRange + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.EnumDescriptorProto.EnumReservedRange} EnumReservedRange + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + EnumReservedRange.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.EnumDescriptorProto.EnumReservedRange(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.start = reader.int32(); + break; + } + case 2: { + message.end = reader.int32(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an EnumReservedRange message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.EnumDescriptorProto.EnumReservedRange + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.EnumDescriptorProto.EnumReservedRange} EnumReservedRange + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + EnumReservedRange.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an EnumReservedRange message. + * @function verify + * @memberof google.protobuf.EnumDescriptorProto.EnumReservedRange + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + EnumReservedRange.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.start != null && message.hasOwnProperty("start")) + if (!$util.isInteger(message.start)) + return "start: integer expected"; + if (message.end != null && message.hasOwnProperty("end")) + if (!$util.isInteger(message.end)) + return "end: integer expected"; + return null; + }; + + /** + * Creates an EnumReservedRange message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.EnumDescriptorProto.EnumReservedRange + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.EnumDescriptorProto.EnumReservedRange} EnumReservedRange + */ + EnumReservedRange.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.EnumDescriptorProto.EnumReservedRange) + return object; + var message = new $root.google.protobuf.EnumDescriptorProto.EnumReservedRange(); + if (object.start != null) + message.start = object.start | 0; + if (object.end != null) + message.end = object.end | 0; + return message; + }; + + /** + * Creates a plain object from an EnumReservedRange message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.EnumDescriptorProto.EnumReservedRange + * @static + * @param {google.protobuf.EnumDescriptorProto.EnumReservedRange} message EnumReservedRange + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + EnumReservedRange.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.start = 0; + object.end = 0; + } + if (message.start != null && message.hasOwnProperty("start")) + object.start = message.start; + if (message.end != null && message.hasOwnProperty("end")) + object.end = message.end; + return object; + }; + + /** + * Converts this EnumReservedRange to JSON. + * @function toJSON + * @memberof google.protobuf.EnumDescriptorProto.EnumReservedRange + * @instance + * @returns {Object.} JSON object + */ + EnumReservedRange.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for EnumReservedRange + * @function getTypeUrl + * @memberof google.protobuf.EnumDescriptorProto.EnumReservedRange + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + EnumReservedRange.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.EnumDescriptorProto.EnumReservedRange"; + }; + + return EnumReservedRange; + })(); + + return EnumDescriptorProto; + })(); + + protobuf.EnumValueDescriptorProto = (function() { + + /** + * Properties of an EnumValueDescriptorProto. + * @memberof google.protobuf + * @interface IEnumValueDescriptorProto + * @property {string|null} [name] EnumValueDescriptorProto name + * @property {number|null} [number] EnumValueDescriptorProto number + * @property {google.protobuf.IEnumValueOptions|null} [options] EnumValueDescriptorProto options + */ + + /** + * Constructs a new EnumValueDescriptorProto. + * @memberof google.protobuf + * @classdesc Represents an EnumValueDescriptorProto. + * @implements IEnumValueDescriptorProto + * @constructor + * @param {google.protobuf.IEnumValueDescriptorProto=} [properties] Properties to set + */ + function EnumValueDescriptorProto(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * EnumValueDescriptorProto name. + * @member {string} name + * @memberof google.protobuf.EnumValueDescriptorProto + * @instance + */ + EnumValueDescriptorProto.prototype.name = ""; + + /** + * EnumValueDescriptorProto number. + * @member {number} number + * @memberof google.protobuf.EnumValueDescriptorProto + * @instance + */ + EnumValueDescriptorProto.prototype.number = 0; + + /** + * EnumValueDescriptorProto options. + * @member {google.protobuf.IEnumValueOptions|null|undefined} options + * @memberof google.protobuf.EnumValueDescriptorProto + * @instance + */ + EnumValueDescriptorProto.prototype.options = null; + + /** + * Creates a new EnumValueDescriptorProto instance using the specified properties. + * @function create + * @memberof google.protobuf.EnumValueDescriptorProto + * @static + * @param {google.protobuf.IEnumValueDescriptorProto=} [properties] Properties to set + * @returns {google.protobuf.EnumValueDescriptorProto} EnumValueDescriptorProto instance + */ + EnumValueDescriptorProto.create = function create(properties) { + return new EnumValueDescriptorProto(properties); + }; + + /** + * Encodes the specified EnumValueDescriptorProto message. Does not implicitly {@link google.protobuf.EnumValueDescriptorProto.verify|verify} messages. + * @function encode + * @memberof google.protobuf.EnumValueDescriptorProto + * @static + * @param {google.protobuf.IEnumValueDescriptorProto} message EnumValueDescriptorProto message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + EnumValueDescriptorProto.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.number != null && Object.hasOwnProperty.call(message, "number")) + writer.uint32(/* id 2, wireType 0 =*/16).int32(message.number); + if (message.options != null && Object.hasOwnProperty.call(message, "options")) + $root.google.protobuf.EnumValueOptions.encode(message.options, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified EnumValueDescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.EnumValueDescriptorProto.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.EnumValueDescriptorProto + * @static + * @param {google.protobuf.IEnumValueDescriptorProto} message EnumValueDescriptorProto message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + EnumValueDescriptorProto.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an EnumValueDescriptorProto message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.EnumValueDescriptorProto + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.EnumValueDescriptorProto} EnumValueDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + EnumValueDescriptorProto.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.EnumValueDescriptorProto(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.number = reader.int32(); + break; + } + case 3: { + message.options = $root.google.protobuf.EnumValueOptions.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an EnumValueDescriptorProto message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.EnumValueDescriptorProto + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.EnumValueDescriptorProto} EnumValueDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + EnumValueDescriptorProto.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an EnumValueDescriptorProto message. + * @function verify + * @memberof google.protobuf.EnumValueDescriptorProto + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + EnumValueDescriptorProto.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.number != null && message.hasOwnProperty("number")) + if (!$util.isInteger(message.number)) + return "number: integer expected"; + if (message.options != null && message.hasOwnProperty("options")) { + var error = $root.google.protobuf.EnumValueOptions.verify(message.options); + if (error) + return "options." + error; + } + return null; + }; + + /** + * Creates an EnumValueDescriptorProto message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.EnumValueDescriptorProto + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.EnumValueDescriptorProto} EnumValueDescriptorProto + */ + EnumValueDescriptorProto.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.EnumValueDescriptorProto) + return object; + var message = new $root.google.protobuf.EnumValueDescriptorProto(); + if (object.name != null) + message.name = String(object.name); + if (object.number != null) + message.number = object.number | 0; + if (object.options != null) { + if (typeof object.options !== "object") + throw TypeError(".google.protobuf.EnumValueDescriptorProto.options: object expected"); + message.options = $root.google.protobuf.EnumValueOptions.fromObject(object.options); + } + return message; + }; + + /** + * Creates a plain object from an EnumValueDescriptorProto message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.EnumValueDescriptorProto + * @static + * @param {google.protobuf.EnumValueDescriptorProto} message EnumValueDescriptorProto + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + EnumValueDescriptorProto.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.name = ""; + object.number = 0; + object.options = null; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.number != null && message.hasOwnProperty("number")) + object.number = message.number; + if (message.options != null && message.hasOwnProperty("options")) + object.options = $root.google.protobuf.EnumValueOptions.toObject(message.options, options); + return object; + }; + + /** + * Converts this EnumValueDescriptorProto to JSON. + * @function toJSON + * @memberof google.protobuf.EnumValueDescriptorProto + * @instance + * @returns {Object.} JSON object + */ + EnumValueDescriptorProto.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for EnumValueDescriptorProto + * @function getTypeUrl + * @memberof google.protobuf.EnumValueDescriptorProto + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + EnumValueDescriptorProto.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.EnumValueDescriptorProto"; + }; + + return EnumValueDescriptorProto; + })(); + + protobuf.ServiceDescriptorProto = (function() { + + /** + * Properties of a ServiceDescriptorProto. + * @memberof google.protobuf + * @interface IServiceDescriptorProto + * @property {string|null} [name] ServiceDescriptorProto name + * @property {Array.|null} [method] ServiceDescriptorProto method + * @property {google.protobuf.IServiceOptions|null} [options] ServiceDescriptorProto options + */ + + /** + * Constructs a new ServiceDescriptorProto. + * @memberof google.protobuf + * @classdesc Represents a ServiceDescriptorProto. + * @implements IServiceDescriptorProto + * @constructor + * @param {google.protobuf.IServiceDescriptorProto=} [properties] Properties to set + */ + function ServiceDescriptorProto(properties) { + this.method = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ServiceDescriptorProto name. + * @member {string} name + * @memberof google.protobuf.ServiceDescriptorProto + * @instance + */ + ServiceDescriptorProto.prototype.name = ""; + + /** + * ServiceDescriptorProto method. + * @member {Array.} method + * @memberof google.protobuf.ServiceDescriptorProto + * @instance + */ + ServiceDescriptorProto.prototype.method = $util.emptyArray; + + /** + * ServiceDescriptorProto options. + * @member {google.protobuf.IServiceOptions|null|undefined} options + * @memberof google.protobuf.ServiceDescriptorProto + * @instance + */ + ServiceDescriptorProto.prototype.options = null; + + /** + * Creates a new ServiceDescriptorProto instance using the specified properties. + * @function create + * @memberof google.protobuf.ServiceDescriptorProto + * @static + * @param {google.protobuf.IServiceDescriptorProto=} [properties] Properties to set + * @returns {google.protobuf.ServiceDescriptorProto} ServiceDescriptorProto instance + */ + ServiceDescriptorProto.create = function create(properties) { + return new ServiceDescriptorProto(properties); + }; + + /** + * Encodes the specified ServiceDescriptorProto message. Does not implicitly {@link google.protobuf.ServiceDescriptorProto.verify|verify} messages. + * @function encode + * @memberof google.protobuf.ServiceDescriptorProto + * @static + * @param {google.protobuf.IServiceDescriptorProto} message ServiceDescriptorProto message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ServiceDescriptorProto.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.method != null && message.method.length) + for (var i = 0; i < message.method.length; ++i) + $root.google.protobuf.MethodDescriptorProto.encode(message.method[i], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.options != null && Object.hasOwnProperty.call(message, "options")) + $root.google.protobuf.ServiceOptions.encode(message.options, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified ServiceDescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.ServiceDescriptorProto.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.ServiceDescriptorProto + * @static + * @param {google.protobuf.IServiceDescriptorProto} message ServiceDescriptorProto message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ServiceDescriptorProto.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ServiceDescriptorProto message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.ServiceDescriptorProto + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.ServiceDescriptorProto} ServiceDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ServiceDescriptorProto.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.ServiceDescriptorProto(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + if (!(message.method && message.method.length)) + message.method = []; + message.method.push($root.google.protobuf.MethodDescriptorProto.decode(reader, reader.uint32())); + break; + } + case 3: { + message.options = $root.google.protobuf.ServiceOptions.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ServiceDescriptorProto message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.ServiceDescriptorProto + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.ServiceDescriptorProto} ServiceDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ServiceDescriptorProto.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ServiceDescriptorProto message. + * @function verify + * @memberof google.protobuf.ServiceDescriptorProto + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ServiceDescriptorProto.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.method != null && message.hasOwnProperty("method")) { + if (!Array.isArray(message.method)) + return "method: array expected"; + for (var i = 0; i < message.method.length; ++i) { + var error = $root.google.protobuf.MethodDescriptorProto.verify(message.method[i]); + if (error) + return "method." + error; + } + } + if (message.options != null && message.hasOwnProperty("options")) { + var error = $root.google.protobuf.ServiceOptions.verify(message.options); + if (error) + return "options." + error; + } + return null; + }; + + /** + * Creates a ServiceDescriptorProto message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.ServiceDescriptorProto + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.ServiceDescriptorProto} ServiceDescriptorProto + */ + ServiceDescriptorProto.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.ServiceDescriptorProto) + return object; + var message = new $root.google.protobuf.ServiceDescriptorProto(); + if (object.name != null) + message.name = String(object.name); + if (object.method) { + if (!Array.isArray(object.method)) + throw TypeError(".google.protobuf.ServiceDescriptorProto.method: array expected"); + message.method = []; + for (var i = 0; i < object.method.length; ++i) { + if (typeof object.method[i] !== "object") + throw TypeError(".google.protobuf.ServiceDescriptorProto.method: object expected"); + message.method[i] = $root.google.protobuf.MethodDescriptorProto.fromObject(object.method[i]); + } + } + if (object.options != null) { + if (typeof object.options !== "object") + throw TypeError(".google.protobuf.ServiceDescriptorProto.options: object expected"); + message.options = $root.google.protobuf.ServiceOptions.fromObject(object.options); + } + return message; + }; + + /** + * Creates a plain object from a ServiceDescriptorProto message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.ServiceDescriptorProto + * @static + * @param {google.protobuf.ServiceDescriptorProto} message ServiceDescriptorProto + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ServiceDescriptorProto.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.method = []; + if (options.defaults) { + object.name = ""; + object.options = null; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.method && message.method.length) { + object.method = []; + for (var j = 0; j < message.method.length; ++j) + object.method[j] = $root.google.protobuf.MethodDescriptorProto.toObject(message.method[j], options); + } + if (message.options != null && message.hasOwnProperty("options")) + object.options = $root.google.protobuf.ServiceOptions.toObject(message.options, options); + return object; + }; + + /** + * Converts this ServiceDescriptorProto to JSON. + * @function toJSON + * @memberof google.protobuf.ServiceDescriptorProto + * @instance + * @returns {Object.} JSON object + */ + ServiceDescriptorProto.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ServiceDescriptorProto + * @function getTypeUrl + * @memberof google.protobuf.ServiceDescriptorProto + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ServiceDescriptorProto.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.ServiceDescriptorProto"; + }; + + return ServiceDescriptorProto; + })(); + + protobuf.MethodDescriptorProto = (function() { + + /** + * Properties of a MethodDescriptorProto. + * @memberof google.protobuf + * @interface IMethodDescriptorProto + * @property {string|null} [name] MethodDescriptorProto name + * @property {string|null} [inputType] MethodDescriptorProto inputType + * @property {string|null} [outputType] MethodDescriptorProto outputType + * @property {google.protobuf.IMethodOptions|null} [options] MethodDescriptorProto options + * @property {boolean|null} [clientStreaming] MethodDescriptorProto clientStreaming + * @property {boolean|null} [serverStreaming] MethodDescriptorProto serverStreaming + */ + + /** + * Constructs a new MethodDescriptorProto. + * @memberof google.protobuf + * @classdesc Represents a MethodDescriptorProto. + * @implements IMethodDescriptorProto + * @constructor + * @param {google.protobuf.IMethodDescriptorProto=} [properties] Properties to set + */ + function MethodDescriptorProto(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * MethodDescriptorProto name. + * @member {string} name + * @memberof google.protobuf.MethodDescriptorProto + * @instance + */ + MethodDescriptorProto.prototype.name = ""; + + /** + * MethodDescriptorProto inputType. + * @member {string} inputType + * @memberof google.protobuf.MethodDescriptorProto + * @instance + */ + MethodDescriptorProto.prototype.inputType = ""; + + /** + * MethodDescriptorProto outputType. + * @member {string} outputType + * @memberof google.protobuf.MethodDescriptorProto + * @instance + */ + MethodDescriptorProto.prototype.outputType = ""; + + /** + * MethodDescriptorProto options. + * @member {google.protobuf.IMethodOptions|null|undefined} options + * @memberof google.protobuf.MethodDescriptorProto + * @instance + */ + MethodDescriptorProto.prototype.options = null; + + /** + * MethodDescriptorProto clientStreaming. + * @member {boolean} clientStreaming + * @memberof google.protobuf.MethodDescriptorProto + * @instance + */ + MethodDescriptorProto.prototype.clientStreaming = false; + + /** + * MethodDescriptorProto serverStreaming. + * @member {boolean} serverStreaming + * @memberof google.protobuf.MethodDescriptorProto + * @instance + */ + MethodDescriptorProto.prototype.serverStreaming = false; + + /** + * Creates a new MethodDescriptorProto instance using the specified properties. + * @function create + * @memberof google.protobuf.MethodDescriptorProto + * @static + * @param {google.protobuf.IMethodDescriptorProto=} [properties] Properties to set + * @returns {google.protobuf.MethodDescriptorProto} MethodDescriptorProto instance + */ + MethodDescriptorProto.create = function create(properties) { + return new MethodDescriptorProto(properties); + }; + + /** + * Encodes the specified MethodDescriptorProto message. Does not implicitly {@link google.protobuf.MethodDescriptorProto.verify|verify} messages. + * @function encode + * @memberof google.protobuf.MethodDescriptorProto + * @static + * @param {google.protobuf.IMethodDescriptorProto} message MethodDescriptorProto message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + MethodDescriptorProto.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.inputType != null && Object.hasOwnProperty.call(message, "inputType")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.inputType); + if (message.outputType != null && Object.hasOwnProperty.call(message, "outputType")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.outputType); + if (message.options != null && Object.hasOwnProperty.call(message, "options")) + $root.google.protobuf.MethodOptions.encode(message.options, writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); + if (message.clientStreaming != null && Object.hasOwnProperty.call(message, "clientStreaming")) + writer.uint32(/* id 5, wireType 0 =*/40).bool(message.clientStreaming); + if (message.serverStreaming != null && Object.hasOwnProperty.call(message, "serverStreaming")) + writer.uint32(/* id 6, wireType 0 =*/48).bool(message.serverStreaming); + return writer; + }; + + /** + * Encodes the specified MethodDescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.MethodDescriptorProto.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.MethodDescriptorProto + * @static + * @param {google.protobuf.IMethodDescriptorProto} message MethodDescriptorProto message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + MethodDescriptorProto.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a MethodDescriptorProto message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.MethodDescriptorProto + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.MethodDescriptorProto} MethodDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + MethodDescriptorProto.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.MethodDescriptorProto(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.inputType = reader.string(); + break; + } + case 3: { + message.outputType = reader.string(); + break; + } + case 4: { + message.options = $root.google.protobuf.MethodOptions.decode(reader, reader.uint32()); + break; + } + case 5: { + message.clientStreaming = reader.bool(); + break; + } + case 6: { + message.serverStreaming = reader.bool(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a MethodDescriptorProto message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.MethodDescriptorProto + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.MethodDescriptorProto} MethodDescriptorProto + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + MethodDescriptorProto.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a MethodDescriptorProto message. + * @function verify + * @memberof google.protobuf.MethodDescriptorProto + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + MethodDescriptorProto.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.inputType != null && message.hasOwnProperty("inputType")) + if (!$util.isString(message.inputType)) + return "inputType: string expected"; + if (message.outputType != null && message.hasOwnProperty("outputType")) + if (!$util.isString(message.outputType)) + return "outputType: string expected"; + if (message.options != null && message.hasOwnProperty("options")) { + var error = $root.google.protobuf.MethodOptions.verify(message.options); + if (error) + return "options." + error; + } + if (message.clientStreaming != null && message.hasOwnProperty("clientStreaming")) + if (typeof message.clientStreaming !== "boolean") + return "clientStreaming: boolean expected"; + if (message.serverStreaming != null && message.hasOwnProperty("serverStreaming")) + if (typeof message.serverStreaming !== "boolean") + return "serverStreaming: boolean expected"; + return null; + }; + + /** + * Creates a MethodDescriptorProto message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.MethodDescriptorProto + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.MethodDescriptorProto} MethodDescriptorProto + */ + MethodDescriptorProto.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.MethodDescriptorProto) + return object; + var message = new $root.google.protobuf.MethodDescriptorProto(); + if (object.name != null) + message.name = String(object.name); + if (object.inputType != null) + message.inputType = String(object.inputType); + if (object.outputType != null) + message.outputType = String(object.outputType); + if (object.options != null) { + if (typeof object.options !== "object") + throw TypeError(".google.protobuf.MethodDescriptorProto.options: object expected"); + message.options = $root.google.protobuf.MethodOptions.fromObject(object.options); + } + if (object.clientStreaming != null) + message.clientStreaming = Boolean(object.clientStreaming); + if (object.serverStreaming != null) + message.serverStreaming = Boolean(object.serverStreaming); + return message; + }; + + /** + * Creates a plain object from a MethodDescriptorProto message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.MethodDescriptorProto + * @static + * @param {google.protobuf.MethodDescriptorProto} message MethodDescriptorProto + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + MethodDescriptorProto.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.name = ""; + object.inputType = ""; + object.outputType = ""; + object.options = null; + object.clientStreaming = false; + object.serverStreaming = false; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.inputType != null && message.hasOwnProperty("inputType")) + object.inputType = message.inputType; + if (message.outputType != null && message.hasOwnProperty("outputType")) + object.outputType = message.outputType; + if (message.options != null && message.hasOwnProperty("options")) + object.options = $root.google.protobuf.MethodOptions.toObject(message.options, options); + if (message.clientStreaming != null && message.hasOwnProperty("clientStreaming")) + object.clientStreaming = message.clientStreaming; + if (message.serverStreaming != null && message.hasOwnProperty("serverStreaming")) + object.serverStreaming = message.serverStreaming; + return object; + }; + + /** + * Converts this MethodDescriptorProto to JSON. + * @function toJSON + * @memberof google.protobuf.MethodDescriptorProto + * @instance + * @returns {Object.} JSON object + */ + MethodDescriptorProto.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for MethodDescriptorProto + * @function getTypeUrl + * @memberof google.protobuf.MethodDescriptorProto + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + MethodDescriptorProto.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.MethodDescriptorProto"; + }; + + return MethodDescriptorProto; + })(); + + protobuf.FileOptions = (function() { + + /** + * Properties of a FileOptions. + * @memberof google.protobuf + * @interface IFileOptions + * @property {string|null} [javaPackage] FileOptions javaPackage + * @property {string|null} [javaOuterClassname] FileOptions javaOuterClassname + * @property {boolean|null} [javaMultipleFiles] FileOptions javaMultipleFiles + * @property {boolean|null} [javaGenerateEqualsAndHash] FileOptions javaGenerateEqualsAndHash + * @property {boolean|null} [javaStringCheckUtf8] FileOptions javaStringCheckUtf8 + * @property {google.protobuf.FileOptions.OptimizeMode|null} [optimizeFor] FileOptions optimizeFor + * @property {string|null} [goPackage] FileOptions goPackage + * @property {boolean|null} [ccGenericServices] FileOptions ccGenericServices + * @property {boolean|null} [javaGenericServices] FileOptions javaGenericServices + * @property {boolean|null} [pyGenericServices] FileOptions pyGenericServices + * @property {boolean|null} [phpGenericServices] FileOptions phpGenericServices + * @property {boolean|null} [deprecated] FileOptions deprecated + * @property {boolean|null} [ccEnableArenas] FileOptions ccEnableArenas + * @property {string|null} [objcClassPrefix] FileOptions objcClassPrefix + * @property {string|null} [csharpNamespace] FileOptions csharpNamespace + * @property {string|null} [swiftPrefix] FileOptions swiftPrefix + * @property {string|null} [phpClassPrefix] FileOptions phpClassPrefix + * @property {string|null} [phpNamespace] FileOptions phpNamespace + * @property {string|null} [phpMetadataNamespace] FileOptions phpMetadataNamespace + * @property {string|null} [rubyPackage] FileOptions rubyPackage + * @property {Array.|null} [uninterpretedOption] FileOptions uninterpretedOption + * @property {Array.|null} [".google.api.resourceDefinition"] FileOptions .google.api.resourceDefinition + */ + + /** + * Constructs a new FileOptions. + * @memberof google.protobuf + * @classdesc Represents a FileOptions. + * @implements IFileOptions + * @constructor + * @param {google.protobuf.IFileOptions=} [properties] Properties to set + */ + function FileOptions(properties) { + this.uninterpretedOption = []; + this[".google.api.resourceDefinition"] = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * FileOptions javaPackage. + * @member {string} javaPackage + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.javaPackage = ""; + + /** + * FileOptions javaOuterClassname. + * @member {string} javaOuterClassname + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.javaOuterClassname = ""; + + /** + * FileOptions javaMultipleFiles. + * @member {boolean} javaMultipleFiles + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.javaMultipleFiles = false; + + /** + * FileOptions javaGenerateEqualsAndHash. + * @member {boolean} javaGenerateEqualsAndHash + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.javaGenerateEqualsAndHash = false; + + /** + * FileOptions javaStringCheckUtf8. + * @member {boolean} javaStringCheckUtf8 + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.javaStringCheckUtf8 = false; + + /** + * FileOptions optimizeFor. + * @member {google.protobuf.FileOptions.OptimizeMode} optimizeFor + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.optimizeFor = 1; + + /** + * FileOptions goPackage. + * @member {string} goPackage + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.goPackage = ""; + + /** + * FileOptions ccGenericServices. + * @member {boolean} ccGenericServices + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.ccGenericServices = false; + + /** + * FileOptions javaGenericServices. + * @member {boolean} javaGenericServices + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.javaGenericServices = false; + + /** + * FileOptions pyGenericServices. + * @member {boolean} pyGenericServices + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.pyGenericServices = false; + + /** + * FileOptions phpGenericServices. + * @member {boolean} phpGenericServices + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.phpGenericServices = false; + + /** + * FileOptions deprecated. + * @member {boolean} deprecated + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.deprecated = false; + + /** + * FileOptions ccEnableArenas. + * @member {boolean} ccEnableArenas + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.ccEnableArenas = true; + + /** + * FileOptions objcClassPrefix. + * @member {string} objcClassPrefix + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.objcClassPrefix = ""; + + /** + * FileOptions csharpNamespace. + * @member {string} csharpNamespace + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.csharpNamespace = ""; + + /** + * FileOptions swiftPrefix. + * @member {string} swiftPrefix + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.swiftPrefix = ""; + + /** + * FileOptions phpClassPrefix. + * @member {string} phpClassPrefix + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.phpClassPrefix = ""; + + /** + * FileOptions phpNamespace. + * @member {string} phpNamespace + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.phpNamespace = ""; + + /** + * FileOptions phpMetadataNamespace. + * @member {string} phpMetadataNamespace + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.phpMetadataNamespace = ""; + + /** + * FileOptions rubyPackage. + * @member {string} rubyPackage + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.rubyPackage = ""; + + /** + * FileOptions uninterpretedOption. + * @member {Array.} uninterpretedOption + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.uninterpretedOption = $util.emptyArray; + + /** + * FileOptions .google.api.resourceDefinition. + * @member {Array.} .google.api.resourceDefinition + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype[".google.api.resourceDefinition"] = $util.emptyArray; + + /** + * Creates a new FileOptions instance using the specified properties. + * @function create + * @memberof google.protobuf.FileOptions + * @static + * @param {google.protobuf.IFileOptions=} [properties] Properties to set + * @returns {google.protobuf.FileOptions} FileOptions instance + */ + FileOptions.create = function create(properties) { + return new FileOptions(properties); + }; + + /** + * Encodes the specified FileOptions message. Does not implicitly {@link google.protobuf.FileOptions.verify|verify} messages. + * @function encode + * @memberof google.protobuf.FileOptions + * @static + * @param {google.protobuf.IFileOptions} message FileOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + FileOptions.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.javaPackage != null && Object.hasOwnProperty.call(message, "javaPackage")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.javaPackage); + if (message.javaOuterClassname != null && Object.hasOwnProperty.call(message, "javaOuterClassname")) + writer.uint32(/* id 8, wireType 2 =*/66).string(message.javaOuterClassname); + if (message.optimizeFor != null && Object.hasOwnProperty.call(message, "optimizeFor")) + writer.uint32(/* id 9, wireType 0 =*/72).int32(message.optimizeFor); + if (message.javaMultipleFiles != null && Object.hasOwnProperty.call(message, "javaMultipleFiles")) + writer.uint32(/* id 10, wireType 0 =*/80).bool(message.javaMultipleFiles); + if (message.goPackage != null && Object.hasOwnProperty.call(message, "goPackage")) + writer.uint32(/* id 11, wireType 2 =*/90).string(message.goPackage); + if (message.ccGenericServices != null && Object.hasOwnProperty.call(message, "ccGenericServices")) + writer.uint32(/* id 16, wireType 0 =*/128).bool(message.ccGenericServices); + if (message.javaGenericServices != null && Object.hasOwnProperty.call(message, "javaGenericServices")) + writer.uint32(/* id 17, wireType 0 =*/136).bool(message.javaGenericServices); + if (message.pyGenericServices != null && Object.hasOwnProperty.call(message, "pyGenericServices")) + writer.uint32(/* id 18, wireType 0 =*/144).bool(message.pyGenericServices); + if (message.javaGenerateEqualsAndHash != null && Object.hasOwnProperty.call(message, "javaGenerateEqualsAndHash")) + writer.uint32(/* id 20, wireType 0 =*/160).bool(message.javaGenerateEqualsAndHash); + if (message.deprecated != null && Object.hasOwnProperty.call(message, "deprecated")) + writer.uint32(/* id 23, wireType 0 =*/184).bool(message.deprecated); + if (message.javaStringCheckUtf8 != null && Object.hasOwnProperty.call(message, "javaStringCheckUtf8")) + writer.uint32(/* id 27, wireType 0 =*/216).bool(message.javaStringCheckUtf8); + if (message.ccEnableArenas != null && Object.hasOwnProperty.call(message, "ccEnableArenas")) + writer.uint32(/* id 31, wireType 0 =*/248).bool(message.ccEnableArenas); + if (message.objcClassPrefix != null && Object.hasOwnProperty.call(message, "objcClassPrefix")) + writer.uint32(/* id 36, wireType 2 =*/290).string(message.objcClassPrefix); + if (message.csharpNamespace != null && Object.hasOwnProperty.call(message, "csharpNamespace")) + writer.uint32(/* id 37, wireType 2 =*/298).string(message.csharpNamespace); + if (message.swiftPrefix != null && Object.hasOwnProperty.call(message, "swiftPrefix")) + writer.uint32(/* id 39, wireType 2 =*/314).string(message.swiftPrefix); + if (message.phpClassPrefix != null && Object.hasOwnProperty.call(message, "phpClassPrefix")) + writer.uint32(/* id 40, wireType 2 =*/322).string(message.phpClassPrefix); + if (message.phpNamespace != null && Object.hasOwnProperty.call(message, "phpNamespace")) + writer.uint32(/* id 41, wireType 2 =*/330).string(message.phpNamespace); + if (message.phpGenericServices != null && Object.hasOwnProperty.call(message, "phpGenericServices")) + writer.uint32(/* id 42, wireType 0 =*/336).bool(message.phpGenericServices); + if (message.phpMetadataNamespace != null && Object.hasOwnProperty.call(message, "phpMetadataNamespace")) + writer.uint32(/* id 44, wireType 2 =*/354).string(message.phpMetadataNamespace); + if (message.rubyPackage != null && Object.hasOwnProperty.call(message, "rubyPackage")) + writer.uint32(/* id 45, wireType 2 =*/362).string(message.rubyPackage); + if (message.uninterpretedOption != null && message.uninterpretedOption.length) + for (var i = 0; i < message.uninterpretedOption.length; ++i) + $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); + if (message[".google.api.resourceDefinition"] != null && message[".google.api.resourceDefinition"].length) + for (var i = 0; i < message[".google.api.resourceDefinition"].length; ++i) + $root.google.api.ResourceDescriptor.encode(message[".google.api.resourceDefinition"][i], writer.uint32(/* id 1053, wireType 2 =*/8426).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified FileOptions message, length delimited. Does not implicitly {@link google.protobuf.FileOptions.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.FileOptions + * @static + * @param {google.protobuf.IFileOptions} message FileOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + FileOptions.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a FileOptions message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.FileOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.FileOptions} FileOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + FileOptions.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.FileOptions(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.javaPackage = reader.string(); + break; + } + case 8: { + message.javaOuterClassname = reader.string(); + break; + } + case 10: { + message.javaMultipleFiles = reader.bool(); + break; + } + case 20: { + message.javaGenerateEqualsAndHash = reader.bool(); + break; + } + case 27: { + message.javaStringCheckUtf8 = reader.bool(); + break; + } + case 9: { + message.optimizeFor = reader.int32(); + break; + } + case 11: { + message.goPackage = reader.string(); + break; + } + case 16: { + message.ccGenericServices = reader.bool(); + break; + } + case 17: { + message.javaGenericServices = reader.bool(); + break; + } + case 18: { + message.pyGenericServices = reader.bool(); + break; + } + case 42: { + message.phpGenericServices = reader.bool(); + break; + } + case 23: { + message.deprecated = reader.bool(); + break; + } + case 31: { + message.ccEnableArenas = reader.bool(); + break; + } + case 36: { + message.objcClassPrefix = reader.string(); + break; + } + case 37: { + message.csharpNamespace = reader.string(); + break; + } + case 39: { + message.swiftPrefix = reader.string(); + break; + } + case 40: { + message.phpClassPrefix = reader.string(); + break; + } + case 41: { + message.phpNamespace = reader.string(); + break; + } + case 44: { + message.phpMetadataNamespace = reader.string(); + break; + } + case 45: { + message.rubyPackage = reader.string(); + break; + } + case 999: { + if (!(message.uninterpretedOption && message.uninterpretedOption.length)) + message.uninterpretedOption = []; + message.uninterpretedOption.push($root.google.protobuf.UninterpretedOption.decode(reader, reader.uint32())); + break; + } + case 1053: { + if (!(message[".google.api.resourceDefinition"] && message[".google.api.resourceDefinition"].length)) + message[".google.api.resourceDefinition"] = []; + message[".google.api.resourceDefinition"].push($root.google.api.ResourceDescriptor.decode(reader, reader.uint32())); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a FileOptions message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.FileOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.FileOptions} FileOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + FileOptions.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a FileOptions message. + * @function verify + * @memberof google.protobuf.FileOptions + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + FileOptions.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.javaPackage != null && message.hasOwnProperty("javaPackage")) + if (!$util.isString(message.javaPackage)) + return "javaPackage: string expected"; + if (message.javaOuterClassname != null && message.hasOwnProperty("javaOuterClassname")) + if (!$util.isString(message.javaOuterClassname)) + return "javaOuterClassname: string expected"; + if (message.javaMultipleFiles != null && message.hasOwnProperty("javaMultipleFiles")) + if (typeof message.javaMultipleFiles !== "boolean") + return "javaMultipleFiles: boolean expected"; + if (message.javaGenerateEqualsAndHash != null && message.hasOwnProperty("javaGenerateEqualsAndHash")) + if (typeof message.javaGenerateEqualsAndHash !== "boolean") + return "javaGenerateEqualsAndHash: boolean expected"; + if (message.javaStringCheckUtf8 != null && message.hasOwnProperty("javaStringCheckUtf8")) + if (typeof message.javaStringCheckUtf8 !== "boolean") + return "javaStringCheckUtf8: boolean expected"; + if (message.optimizeFor != null && message.hasOwnProperty("optimizeFor")) + switch (message.optimizeFor) { + default: + return "optimizeFor: enum value expected"; + case 1: + case 2: + case 3: + break; + } + if (message.goPackage != null && message.hasOwnProperty("goPackage")) + if (!$util.isString(message.goPackage)) + return "goPackage: string expected"; + if (message.ccGenericServices != null && message.hasOwnProperty("ccGenericServices")) + if (typeof message.ccGenericServices !== "boolean") + return "ccGenericServices: boolean expected"; + if (message.javaGenericServices != null && message.hasOwnProperty("javaGenericServices")) + if (typeof message.javaGenericServices !== "boolean") + return "javaGenericServices: boolean expected"; + if (message.pyGenericServices != null && message.hasOwnProperty("pyGenericServices")) + if (typeof message.pyGenericServices !== "boolean") + return "pyGenericServices: boolean expected"; + if (message.phpGenericServices != null && message.hasOwnProperty("phpGenericServices")) + if (typeof message.phpGenericServices !== "boolean") + return "phpGenericServices: boolean expected"; + if (message.deprecated != null && message.hasOwnProperty("deprecated")) + if (typeof message.deprecated !== "boolean") + return "deprecated: boolean expected"; + if (message.ccEnableArenas != null && message.hasOwnProperty("ccEnableArenas")) + if (typeof message.ccEnableArenas !== "boolean") + return "ccEnableArenas: boolean expected"; + if (message.objcClassPrefix != null && message.hasOwnProperty("objcClassPrefix")) + if (!$util.isString(message.objcClassPrefix)) + return "objcClassPrefix: string expected"; + if (message.csharpNamespace != null && message.hasOwnProperty("csharpNamespace")) + if (!$util.isString(message.csharpNamespace)) + return "csharpNamespace: string expected"; + if (message.swiftPrefix != null && message.hasOwnProperty("swiftPrefix")) + if (!$util.isString(message.swiftPrefix)) + return "swiftPrefix: string expected"; + if (message.phpClassPrefix != null && message.hasOwnProperty("phpClassPrefix")) + if (!$util.isString(message.phpClassPrefix)) + return "phpClassPrefix: string expected"; + if (message.phpNamespace != null && message.hasOwnProperty("phpNamespace")) + if (!$util.isString(message.phpNamespace)) + return "phpNamespace: string expected"; + if (message.phpMetadataNamespace != null && message.hasOwnProperty("phpMetadataNamespace")) + if (!$util.isString(message.phpMetadataNamespace)) + return "phpMetadataNamespace: string expected"; + if (message.rubyPackage != null && message.hasOwnProperty("rubyPackage")) + if (!$util.isString(message.rubyPackage)) + return "rubyPackage: string expected"; + if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { + if (!Array.isArray(message.uninterpretedOption)) + return "uninterpretedOption: array expected"; + for (var i = 0; i < message.uninterpretedOption.length; ++i) { + var error = $root.google.protobuf.UninterpretedOption.verify(message.uninterpretedOption[i]); + if (error) + return "uninterpretedOption." + error; + } + } + if (message[".google.api.resourceDefinition"] != null && message.hasOwnProperty(".google.api.resourceDefinition")) { + if (!Array.isArray(message[".google.api.resourceDefinition"])) + return ".google.api.resourceDefinition: array expected"; + for (var i = 0; i < message[".google.api.resourceDefinition"].length; ++i) { + var error = $root.google.api.ResourceDescriptor.verify(message[".google.api.resourceDefinition"][i]); + if (error) + return ".google.api.resourceDefinition." + error; + } + } + return null; + }; + + /** + * Creates a FileOptions message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.FileOptions + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.FileOptions} FileOptions + */ + FileOptions.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.FileOptions) + return object; + var message = new $root.google.protobuf.FileOptions(); + if (object.javaPackage != null) + message.javaPackage = String(object.javaPackage); + if (object.javaOuterClassname != null) + message.javaOuterClassname = String(object.javaOuterClassname); + if (object.javaMultipleFiles != null) + message.javaMultipleFiles = Boolean(object.javaMultipleFiles); + if (object.javaGenerateEqualsAndHash != null) + message.javaGenerateEqualsAndHash = Boolean(object.javaGenerateEqualsAndHash); + if (object.javaStringCheckUtf8 != null) + message.javaStringCheckUtf8 = Boolean(object.javaStringCheckUtf8); + switch (object.optimizeFor) { + default: + if (typeof object.optimizeFor === "number") { + message.optimizeFor = object.optimizeFor; + break; + } + break; + case "SPEED": + case 1: + message.optimizeFor = 1; + break; + case "CODE_SIZE": + case 2: + message.optimizeFor = 2; + break; + case "LITE_RUNTIME": + case 3: + message.optimizeFor = 3; + break; + } + if (object.goPackage != null) + message.goPackage = String(object.goPackage); + if (object.ccGenericServices != null) + message.ccGenericServices = Boolean(object.ccGenericServices); + if (object.javaGenericServices != null) + message.javaGenericServices = Boolean(object.javaGenericServices); + if (object.pyGenericServices != null) + message.pyGenericServices = Boolean(object.pyGenericServices); + if (object.phpGenericServices != null) + message.phpGenericServices = Boolean(object.phpGenericServices); + if (object.deprecated != null) + message.deprecated = Boolean(object.deprecated); + if (object.ccEnableArenas != null) + message.ccEnableArenas = Boolean(object.ccEnableArenas); + if (object.objcClassPrefix != null) + message.objcClassPrefix = String(object.objcClassPrefix); + if (object.csharpNamespace != null) + message.csharpNamespace = String(object.csharpNamespace); + if (object.swiftPrefix != null) + message.swiftPrefix = String(object.swiftPrefix); + if (object.phpClassPrefix != null) + message.phpClassPrefix = String(object.phpClassPrefix); + if (object.phpNamespace != null) + message.phpNamespace = String(object.phpNamespace); + if (object.phpMetadataNamespace != null) + message.phpMetadataNamespace = String(object.phpMetadataNamespace); + if (object.rubyPackage != null) + message.rubyPackage = String(object.rubyPackage); + if (object.uninterpretedOption) { + if (!Array.isArray(object.uninterpretedOption)) + throw TypeError(".google.protobuf.FileOptions.uninterpretedOption: array expected"); + message.uninterpretedOption = []; + for (var i = 0; i < object.uninterpretedOption.length; ++i) { + if (typeof object.uninterpretedOption[i] !== "object") + throw TypeError(".google.protobuf.FileOptions.uninterpretedOption: object expected"); + message.uninterpretedOption[i] = $root.google.protobuf.UninterpretedOption.fromObject(object.uninterpretedOption[i]); + } + } + if (object[".google.api.resourceDefinition"]) { + if (!Array.isArray(object[".google.api.resourceDefinition"])) + throw TypeError(".google.protobuf.FileOptions..google.api.resourceDefinition: array expected"); + message[".google.api.resourceDefinition"] = []; + for (var i = 0; i < object[".google.api.resourceDefinition"].length; ++i) { + if (typeof object[".google.api.resourceDefinition"][i] !== "object") + throw TypeError(".google.protobuf.FileOptions..google.api.resourceDefinition: object expected"); + message[".google.api.resourceDefinition"][i] = $root.google.api.ResourceDescriptor.fromObject(object[".google.api.resourceDefinition"][i]); + } + } + return message; + }; + + /** + * Creates a plain object from a FileOptions message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.FileOptions + * @static + * @param {google.protobuf.FileOptions} message FileOptions + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + FileOptions.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.uninterpretedOption = []; + object[".google.api.resourceDefinition"] = []; + } + if (options.defaults) { + object.javaPackage = ""; + object.javaOuterClassname = ""; + object.optimizeFor = options.enums === String ? "SPEED" : 1; + object.javaMultipleFiles = false; + object.goPackage = ""; + object.ccGenericServices = false; + object.javaGenericServices = false; + object.pyGenericServices = false; + object.javaGenerateEqualsAndHash = false; + object.deprecated = false; + object.javaStringCheckUtf8 = false; + object.ccEnableArenas = true; + object.objcClassPrefix = ""; + object.csharpNamespace = ""; + object.swiftPrefix = ""; + object.phpClassPrefix = ""; + object.phpNamespace = ""; + object.phpGenericServices = false; + object.phpMetadataNamespace = ""; + object.rubyPackage = ""; + } + if (message.javaPackage != null && message.hasOwnProperty("javaPackage")) + object.javaPackage = message.javaPackage; + if (message.javaOuterClassname != null && message.hasOwnProperty("javaOuterClassname")) + object.javaOuterClassname = message.javaOuterClassname; + if (message.optimizeFor != null && message.hasOwnProperty("optimizeFor")) + object.optimizeFor = options.enums === String ? $root.google.protobuf.FileOptions.OptimizeMode[message.optimizeFor] === undefined ? message.optimizeFor : $root.google.protobuf.FileOptions.OptimizeMode[message.optimizeFor] : message.optimizeFor; + if (message.javaMultipleFiles != null && message.hasOwnProperty("javaMultipleFiles")) + object.javaMultipleFiles = message.javaMultipleFiles; + if (message.goPackage != null && message.hasOwnProperty("goPackage")) + object.goPackage = message.goPackage; + if (message.ccGenericServices != null && message.hasOwnProperty("ccGenericServices")) + object.ccGenericServices = message.ccGenericServices; + if (message.javaGenericServices != null && message.hasOwnProperty("javaGenericServices")) + object.javaGenericServices = message.javaGenericServices; + if (message.pyGenericServices != null && message.hasOwnProperty("pyGenericServices")) + object.pyGenericServices = message.pyGenericServices; + if (message.javaGenerateEqualsAndHash != null && message.hasOwnProperty("javaGenerateEqualsAndHash")) + object.javaGenerateEqualsAndHash = message.javaGenerateEqualsAndHash; + if (message.deprecated != null && message.hasOwnProperty("deprecated")) + object.deprecated = message.deprecated; + if (message.javaStringCheckUtf8 != null && message.hasOwnProperty("javaStringCheckUtf8")) + object.javaStringCheckUtf8 = message.javaStringCheckUtf8; + if (message.ccEnableArenas != null && message.hasOwnProperty("ccEnableArenas")) + object.ccEnableArenas = message.ccEnableArenas; + if (message.objcClassPrefix != null && message.hasOwnProperty("objcClassPrefix")) + object.objcClassPrefix = message.objcClassPrefix; + if (message.csharpNamespace != null && message.hasOwnProperty("csharpNamespace")) + object.csharpNamespace = message.csharpNamespace; + if (message.swiftPrefix != null && message.hasOwnProperty("swiftPrefix")) + object.swiftPrefix = message.swiftPrefix; + if (message.phpClassPrefix != null && message.hasOwnProperty("phpClassPrefix")) + object.phpClassPrefix = message.phpClassPrefix; + if (message.phpNamespace != null && message.hasOwnProperty("phpNamespace")) + object.phpNamespace = message.phpNamespace; + if (message.phpGenericServices != null && message.hasOwnProperty("phpGenericServices")) + object.phpGenericServices = message.phpGenericServices; + if (message.phpMetadataNamespace != null && message.hasOwnProperty("phpMetadataNamespace")) + object.phpMetadataNamespace = message.phpMetadataNamespace; + if (message.rubyPackage != null && message.hasOwnProperty("rubyPackage")) + object.rubyPackage = message.rubyPackage; + if (message.uninterpretedOption && message.uninterpretedOption.length) { + object.uninterpretedOption = []; + for (var j = 0; j < message.uninterpretedOption.length; ++j) + object.uninterpretedOption[j] = $root.google.protobuf.UninterpretedOption.toObject(message.uninterpretedOption[j], options); + } + if (message[".google.api.resourceDefinition"] && message[".google.api.resourceDefinition"].length) { + object[".google.api.resourceDefinition"] = []; + for (var j = 0; j < message[".google.api.resourceDefinition"].length; ++j) + object[".google.api.resourceDefinition"][j] = $root.google.api.ResourceDescriptor.toObject(message[".google.api.resourceDefinition"][j], options); + } + return object; + }; + + /** + * Converts this FileOptions to JSON. + * @function toJSON + * @memberof google.protobuf.FileOptions + * @instance + * @returns {Object.} JSON object + */ + FileOptions.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for FileOptions + * @function getTypeUrl + * @memberof google.protobuf.FileOptions + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + FileOptions.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.FileOptions"; + }; + + /** + * OptimizeMode enum. + * @name google.protobuf.FileOptions.OptimizeMode + * @enum {number} + * @property {number} SPEED=1 SPEED value + * @property {number} CODE_SIZE=2 CODE_SIZE value + * @property {number} LITE_RUNTIME=3 LITE_RUNTIME value + */ + FileOptions.OptimizeMode = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[1] = "SPEED"] = 1; + values[valuesById[2] = "CODE_SIZE"] = 2; + values[valuesById[3] = "LITE_RUNTIME"] = 3; + return values; + })(); + + return FileOptions; + })(); + + protobuf.MessageOptions = (function() { + + /** + * Properties of a MessageOptions. + * @memberof google.protobuf + * @interface IMessageOptions + * @property {boolean|null} [messageSetWireFormat] MessageOptions messageSetWireFormat + * @property {boolean|null} [noStandardDescriptorAccessor] MessageOptions noStandardDescriptorAccessor + * @property {boolean|null} [deprecated] MessageOptions deprecated + * @property {boolean|null} [mapEntry] MessageOptions mapEntry + * @property {boolean|null} [deprecatedLegacyJsonFieldConflicts] MessageOptions deprecatedLegacyJsonFieldConflicts + * @property {Array.|null} [uninterpretedOption] MessageOptions uninterpretedOption + * @property {google.api.IResourceDescriptor|null} [".google.api.resource"] MessageOptions .google.api.resource + */ + + /** + * Constructs a new MessageOptions. + * @memberof google.protobuf + * @classdesc Represents a MessageOptions. + * @implements IMessageOptions + * @constructor + * @param {google.protobuf.IMessageOptions=} [properties] Properties to set + */ + function MessageOptions(properties) { + this.uninterpretedOption = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * MessageOptions messageSetWireFormat. + * @member {boolean} messageSetWireFormat + * @memberof google.protobuf.MessageOptions + * @instance + */ + MessageOptions.prototype.messageSetWireFormat = false; + + /** + * MessageOptions noStandardDescriptorAccessor. + * @member {boolean} noStandardDescriptorAccessor + * @memberof google.protobuf.MessageOptions + * @instance + */ + MessageOptions.prototype.noStandardDescriptorAccessor = false; + + /** + * MessageOptions deprecated. + * @member {boolean} deprecated + * @memberof google.protobuf.MessageOptions + * @instance + */ + MessageOptions.prototype.deprecated = false; + + /** + * MessageOptions mapEntry. + * @member {boolean} mapEntry + * @memberof google.protobuf.MessageOptions + * @instance + */ + MessageOptions.prototype.mapEntry = false; + + /** + * MessageOptions deprecatedLegacyJsonFieldConflicts. + * @member {boolean} deprecatedLegacyJsonFieldConflicts + * @memberof google.protobuf.MessageOptions + * @instance + */ + MessageOptions.prototype.deprecatedLegacyJsonFieldConflicts = false; + + /** + * MessageOptions uninterpretedOption. + * @member {Array.} uninterpretedOption + * @memberof google.protobuf.MessageOptions + * @instance + */ + MessageOptions.prototype.uninterpretedOption = $util.emptyArray; + + /** + * MessageOptions .google.api.resource. + * @member {google.api.IResourceDescriptor|null|undefined} .google.api.resource + * @memberof google.protobuf.MessageOptions + * @instance + */ + MessageOptions.prototype[".google.api.resource"] = null; + + /** + * Creates a new MessageOptions instance using the specified properties. + * @function create + * @memberof google.protobuf.MessageOptions + * @static + * @param {google.protobuf.IMessageOptions=} [properties] Properties to set + * @returns {google.protobuf.MessageOptions} MessageOptions instance + */ + MessageOptions.create = function create(properties) { + return new MessageOptions(properties); + }; + + /** + * Encodes the specified MessageOptions message. Does not implicitly {@link google.protobuf.MessageOptions.verify|verify} messages. + * @function encode + * @memberof google.protobuf.MessageOptions + * @static + * @param {google.protobuf.IMessageOptions} message MessageOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + MessageOptions.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.messageSetWireFormat != null && Object.hasOwnProperty.call(message, "messageSetWireFormat")) + writer.uint32(/* id 1, wireType 0 =*/8).bool(message.messageSetWireFormat); + if (message.noStandardDescriptorAccessor != null && Object.hasOwnProperty.call(message, "noStandardDescriptorAccessor")) + writer.uint32(/* id 2, wireType 0 =*/16).bool(message.noStandardDescriptorAccessor); + if (message.deprecated != null && Object.hasOwnProperty.call(message, "deprecated")) + writer.uint32(/* id 3, wireType 0 =*/24).bool(message.deprecated); + if (message.mapEntry != null && Object.hasOwnProperty.call(message, "mapEntry")) + writer.uint32(/* id 7, wireType 0 =*/56).bool(message.mapEntry); + if (message.deprecatedLegacyJsonFieldConflicts != null && Object.hasOwnProperty.call(message, "deprecatedLegacyJsonFieldConflicts")) + writer.uint32(/* id 11, wireType 0 =*/88).bool(message.deprecatedLegacyJsonFieldConflicts); + if (message.uninterpretedOption != null && message.uninterpretedOption.length) + for (var i = 0; i < message.uninterpretedOption.length; ++i) + $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); + if (message[".google.api.resource"] != null && Object.hasOwnProperty.call(message, ".google.api.resource")) + $root.google.api.ResourceDescriptor.encode(message[".google.api.resource"], writer.uint32(/* id 1053, wireType 2 =*/8426).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified MessageOptions message, length delimited. Does not implicitly {@link google.protobuf.MessageOptions.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.MessageOptions + * @static + * @param {google.protobuf.IMessageOptions} message MessageOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + MessageOptions.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a MessageOptions message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.MessageOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.MessageOptions} MessageOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + MessageOptions.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.MessageOptions(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.messageSetWireFormat = reader.bool(); + break; + } + case 2: { + message.noStandardDescriptorAccessor = reader.bool(); + break; + } + case 3: { + message.deprecated = reader.bool(); + break; + } + case 7: { + message.mapEntry = reader.bool(); + break; + } + case 11: { + message.deprecatedLegacyJsonFieldConflicts = reader.bool(); + break; + } + case 999: { + if (!(message.uninterpretedOption && message.uninterpretedOption.length)) + message.uninterpretedOption = []; + message.uninterpretedOption.push($root.google.protobuf.UninterpretedOption.decode(reader, reader.uint32())); + break; + } + case 1053: { + message[".google.api.resource"] = $root.google.api.ResourceDescriptor.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a MessageOptions message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.MessageOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.MessageOptions} MessageOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + MessageOptions.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a MessageOptions message. + * @function verify + * @memberof google.protobuf.MessageOptions + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + MessageOptions.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.messageSetWireFormat != null && message.hasOwnProperty("messageSetWireFormat")) + if (typeof message.messageSetWireFormat !== "boolean") + return "messageSetWireFormat: boolean expected"; + if (message.noStandardDescriptorAccessor != null && message.hasOwnProperty("noStandardDescriptorAccessor")) + if (typeof message.noStandardDescriptorAccessor !== "boolean") + return "noStandardDescriptorAccessor: boolean expected"; + if (message.deprecated != null && message.hasOwnProperty("deprecated")) + if (typeof message.deprecated !== "boolean") + return "deprecated: boolean expected"; + if (message.mapEntry != null && message.hasOwnProperty("mapEntry")) + if (typeof message.mapEntry !== "boolean") + return "mapEntry: boolean expected"; + if (message.deprecatedLegacyJsonFieldConflicts != null && message.hasOwnProperty("deprecatedLegacyJsonFieldConflicts")) + if (typeof message.deprecatedLegacyJsonFieldConflicts !== "boolean") + return "deprecatedLegacyJsonFieldConflicts: boolean expected"; + if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { + if (!Array.isArray(message.uninterpretedOption)) + return "uninterpretedOption: array expected"; + for (var i = 0; i < message.uninterpretedOption.length; ++i) { + var error = $root.google.protobuf.UninterpretedOption.verify(message.uninterpretedOption[i]); + if (error) + return "uninterpretedOption." + error; + } + } + if (message[".google.api.resource"] != null && message.hasOwnProperty(".google.api.resource")) { + var error = $root.google.api.ResourceDescriptor.verify(message[".google.api.resource"]); + if (error) + return ".google.api.resource." + error; + } + return null; + }; + + /** + * Creates a MessageOptions message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.MessageOptions + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.MessageOptions} MessageOptions + */ + MessageOptions.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.MessageOptions) + return object; + var message = new $root.google.protobuf.MessageOptions(); + if (object.messageSetWireFormat != null) + message.messageSetWireFormat = Boolean(object.messageSetWireFormat); + if (object.noStandardDescriptorAccessor != null) + message.noStandardDescriptorAccessor = Boolean(object.noStandardDescriptorAccessor); + if (object.deprecated != null) + message.deprecated = Boolean(object.deprecated); + if (object.mapEntry != null) + message.mapEntry = Boolean(object.mapEntry); + if (object.deprecatedLegacyJsonFieldConflicts != null) + message.deprecatedLegacyJsonFieldConflicts = Boolean(object.deprecatedLegacyJsonFieldConflicts); + if (object.uninterpretedOption) { + if (!Array.isArray(object.uninterpretedOption)) + throw TypeError(".google.protobuf.MessageOptions.uninterpretedOption: array expected"); + message.uninterpretedOption = []; + for (var i = 0; i < object.uninterpretedOption.length; ++i) { + if (typeof object.uninterpretedOption[i] !== "object") + throw TypeError(".google.protobuf.MessageOptions.uninterpretedOption: object expected"); + message.uninterpretedOption[i] = $root.google.protobuf.UninterpretedOption.fromObject(object.uninterpretedOption[i]); + } + } + if (object[".google.api.resource"] != null) { + if (typeof object[".google.api.resource"] !== "object") + throw TypeError(".google.protobuf.MessageOptions..google.api.resource: object expected"); + message[".google.api.resource"] = $root.google.api.ResourceDescriptor.fromObject(object[".google.api.resource"]); + } + return message; + }; + + /** + * Creates a plain object from a MessageOptions message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.MessageOptions + * @static + * @param {google.protobuf.MessageOptions} message MessageOptions + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + MessageOptions.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.uninterpretedOption = []; + if (options.defaults) { + object.messageSetWireFormat = false; + object.noStandardDescriptorAccessor = false; + object.deprecated = false; + object.mapEntry = false; + object.deprecatedLegacyJsonFieldConflicts = false; + object[".google.api.resource"] = null; + } + if (message.messageSetWireFormat != null && message.hasOwnProperty("messageSetWireFormat")) + object.messageSetWireFormat = message.messageSetWireFormat; + if (message.noStandardDescriptorAccessor != null && message.hasOwnProperty("noStandardDescriptorAccessor")) + object.noStandardDescriptorAccessor = message.noStandardDescriptorAccessor; + if (message.deprecated != null && message.hasOwnProperty("deprecated")) + object.deprecated = message.deprecated; + if (message.mapEntry != null && message.hasOwnProperty("mapEntry")) + object.mapEntry = message.mapEntry; + if (message.deprecatedLegacyJsonFieldConflicts != null && message.hasOwnProperty("deprecatedLegacyJsonFieldConflicts")) + object.deprecatedLegacyJsonFieldConflicts = message.deprecatedLegacyJsonFieldConflicts; + if (message.uninterpretedOption && message.uninterpretedOption.length) { + object.uninterpretedOption = []; + for (var j = 0; j < message.uninterpretedOption.length; ++j) + object.uninterpretedOption[j] = $root.google.protobuf.UninterpretedOption.toObject(message.uninterpretedOption[j], options); + } + if (message[".google.api.resource"] != null && message.hasOwnProperty(".google.api.resource")) + object[".google.api.resource"] = $root.google.api.ResourceDescriptor.toObject(message[".google.api.resource"], options); + return object; + }; + + /** + * Converts this MessageOptions to JSON. + * @function toJSON + * @memberof google.protobuf.MessageOptions + * @instance + * @returns {Object.} JSON object + */ + MessageOptions.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for MessageOptions + * @function getTypeUrl + * @memberof google.protobuf.MessageOptions + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + MessageOptions.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.MessageOptions"; + }; + + return MessageOptions; + })(); + + protobuf.FieldOptions = (function() { + + /** + * Properties of a FieldOptions. + * @memberof google.protobuf + * @interface IFieldOptions + * @property {google.protobuf.FieldOptions.CType|null} [ctype] FieldOptions ctype + * @property {boolean|null} [packed] FieldOptions packed + * @property {google.protobuf.FieldOptions.JSType|null} [jstype] FieldOptions jstype + * @property {boolean|null} [lazy] FieldOptions lazy + * @property {boolean|null} [unverifiedLazy] FieldOptions unverifiedLazy + * @property {boolean|null} [deprecated] FieldOptions deprecated + * @property {boolean|null} [weak] FieldOptions weak + * @property {boolean|null} [debugRedact] FieldOptions debugRedact + * @property {google.protobuf.FieldOptions.OptionRetention|null} [retention] FieldOptions retention + * @property {google.protobuf.FieldOptions.OptionTargetType|null} [target] FieldOptions target + * @property {Array.|null} [uninterpretedOption] FieldOptions uninterpretedOption + * @property {Array.|null} [".google.api.fieldBehavior"] FieldOptions .google.api.fieldBehavior + * @property {google.api.IResourceReference|null} [".google.api.resourceReference"] FieldOptions .google.api.resourceReference + */ + + /** + * Constructs a new FieldOptions. + * @memberof google.protobuf + * @classdesc Represents a FieldOptions. + * @implements IFieldOptions + * @constructor + * @param {google.protobuf.IFieldOptions=} [properties] Properties to set + */ + function FieldOptions(properties) { + this.uninterpretedOption = []; + this[".google.api.fieldBehavior"] = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * FieldOptions ctype. + * @member {google.protobuf.FieldOptions.CType} ctype + * @memberof google.protobuf.FieldOptions + * @instance + */ + FieldOptions.prototype.ctype = 0; + + /** + * FieldOptions packed. + * @member {boolean} packed + * @memberof google.protobuf.FieldOptions + * @instance + */ + FieldOptions.prototype.packed = false; + + /** + * FieldOptions jstype. + * @member {google.protobuf.FieldOptions.JSType} jstype + * @memberof google.protobuf.FieldOptions + * @instance + */ + FieldOptions.prototype.jstype = 0; + + /** + * FieldOptions lazy. + * @member {boolean} lazy + * @memberof google.protobuf.FieldOptions + * @instance + */ + FieldOptions.prototype.lazy = false; + + /** + * FieldOptions unverifiedLazy. + * @member {boolean} unverifiedLazy + * @memberof google.protobuf.FieldOptions + * @instance + */ + FieldOptions.prototype.unverifiedLazy = false; + + /** + * FieldOptions deprecated. + * @member {boolean} deprecated + * @memberof google.protobuf.FieldOptions + * @instance + */ + FieldOptions.prototype.deprecated = false; + + /** + * FieldOptions weak. + * @member {boolean} weak + * @memberof google.protobuf.FieldOptions + * @instance + */ + FieldOptions.prototype.weak = false; + + /** + * FieldOptions debugRedact. + * @member {boolean} debugRedact + * @memberof google.protobuf.FieldOptions + * @instance + */ + FieldOptions.prototype.debugRedact = false; + + /** + * FieldOptions retention. + * @member {google.protobuf.FieldOptions.OptionRetention} retention + * @memberof google.protobuf.FieldOptions + * @instance + */ + FieldOptions.prototype.retention = 0; + + /** + * FieldOptions target. + * @member {google.protobuf.FieldOptions.OptionTargetType} target + * @memberof google.protobuf.FieldOptions + * @instance + */ + FieldOptions.prototype.target = 0; + + /** + * FieldOptions uninterpretedOption. + * @member {Array.} uninterpretedOption + * @memberof google.protobuf.FieldOptions + * @instance + */ + FieldOptions.prototype.uninterpretedOption = $util.emptyArray; + + /** + * FieldOptions .google.api.fieldBehavior. + * @member {Array.} .google.api.fieldBehavior + * @memberof google.protobuf.FieldOptions + * @instance + */ + FieldOptions.prototype[".google.api.fieldBehavior"] = $util.emptyArray; + + /** + * FieldOptions .google.api.resourceReference. + * @member {google.api.IResourceReference|null|undefined} .google.api.resourceReference + * @memberof google.protobuf.FieldOptions + * @instance + */ + FieldOptions.prototype[".google.api.resourceReference"] = null; + + /** + * Creates a new FieldOptions instance using the specified properties. + * @function create + * @memberof google.protobuf.FieldOptions + * @static + * @param {google.protobuf.IFieldOptions=} [properties] Properties to set + * @returns {google.protobuf.FieldOptions} FieldOptions instance + */ + FieldOptions.create = function create(properties) { + return new FieldOptions(properties); + }; + + /** + * Encodes the specified FieldOptions message. Does not implicitly {@link google.protobuf.FieldOptions.verify|verify} messages. + * @function encode + * @memberof google.protobuf.FieldOptions + * @static + * @param {google.protobuf.IFieldOptions} message FieldOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + FieldOptions.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.ctype != null && Object.hasOwnProperty.call(message, "ctype")) + writer.uint32(/* id 1, wireType 0 =*/8).int32(message.ctype); + if (message.packed != null && Object.hasOwnProperty.call(message, "packed")) + writer.uint32(/* id 2, wireType 0 =*/16).bool(message.packed); + if (message.deprecated != null && Object.hasOwnProperty.call(message, "deprecated")) + writer.uint32(/* id 3, wireType 0 =*/24).bool(message.deprecated); + if (message.lazy != null && Object.hasOwnProperty.call(message, "lazy")) + writer.uint32(/* id 5, wireType 0 =*/40).bool(message.lazy); + if (message.jstype != null && Object.hasOwnProperty.call(message, "jstype")) + writer.uint32(/* id 6, wireType 0 =*/48).int32(message.jstype); + if (message.weak != null && Object.hasOwnProperty.call(message, "weak")) + writer.uint32(/* id 10, wireType 0 =*/80).bool(message.weak); + if (message.unverifiedLazy != null && Object.hasOwnProperty.call(message, "unverifiedLazy")) + writer.uint32(/* id 15, wireType 0 =*/120).bool(message.unverifiedLazy); + if (message.debugRedact != null && Object.hasOwnProperty.call(message, "debugRedact")) + writer.uint32(/* id 16, wireType 0 =*/128).bool(message.debugRedact); + if (message.retention != null && Object.hasOwnProperty.call(message, "retention")) + writer.uint32(/* id 17, wireType 0 =*/136).int32(message.retention); + if (message.target != null && Object.hasOwnProperty.call(message, "target")) + writer.uint32(/* id 18, wireType 0 =*/144).int32(message.target); + if (message.uninterpretedOption != null && message.uninterpretedOption.length) + for (var i = 0; i < message.uninterpretedOption.length; ++i) + $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); + if (message[".google.api.fieldBehavior"] != null && message[".google.api.fieldBehavior"].length) { + writer.uint32(/* id 1052, wireType 2 =*/8418).fork(); + for (var i = 0; i < message[".google.api.fieldBehavior"].length; ++i) + writer.int32(message[".google.api.fieldBehavior"][i]); + writer.ldelim(); + } + if (message[".google.api.resourceReference"] != null && Object.hasOwnProperty.call(message, ".google.api.resourceReference")) + $root.google.api.ResourceReference.encode(message[".google.api.resourceReference"], writer.uint32(/* id 1055, wireType 2 =*/8442).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified FieldOptions message, length delimited. Does not implicitly {@link google.protobuf.FieldOptions.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.FieldOptions + * @static + * @param {google.protobuf.IFieldOptions} message FieldOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + FieldOptions.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a FieldOptions message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.FieldOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.FieldOptions} FieldOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + FieldOptions.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.FieldOptions(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.ctype = reader.int32(); + break; + } + case 2: { + message.packed = reader.bool(); + break; + } + case 6: { + message.jstype = reader.int32(); + break; + } + case 5: { + message.lazy = reader.bool(); + break; + } + case 15: { + message.unverifiedLazy = reader.bool(); + break; + } + case 3: { + message.deprecated = reader.bool(); + break; + } + case 10: { + message.weak = reader.bool(); + break; + } + case 16: { + message.debugRedact = reader.bool(); + break; + } + case 17: { + message.retention = reader.int32(); + break; + } + case 18: { + message.target = reader.int32(); + break; + } + case 999: { + if (!(message.uninterpretedOption && message.uninterpretedOption.length)) + message.uninterpretedOption = []; + message.uninterpretedOption.push($root.google.protobuf.UninterpretedOption.decode(reader, reader.uint32())); + break; + } + case 1052: { + if (!(message[".google.api.fieldBehavior"] && message[".google.api.fieldBehavior"].length)) + message[".google.api.fieldBehavior"] = []; + if ((tag & 7) === 2) { + var end2 = reader.uint32() + reader.pos; + while (reader.pos < end2) + message[".google.api.fieldBehavior"].push(reader.int32()); + } else + message[".google.api.fieldBehavior"].push(reader.int32()); + break; + } + case 1055: { + message[".google.api.resourceReference"] = $root.google.api.ResourceReference.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a FieldOptions message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.FieldOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.FieldOptions} FieldOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + FieldOptions.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a FieldOptions message. + * @function verify + * @memberof google.protobuf.FieldOptions + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + FieldOptions.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.ctype != null && message.hasOwnProperty("ctype")) + switch (message.ctype) { + default: + return "ctype: enum value expected"; + case 0: + case 1: + case 2: + break; + } + if (message.packed != null && message.hasOwnProperty("packed")) + if (typeof message.packed !== "boolean") + return "packed: boolean expected"; + if (message.jstype != null && message.hasOwnProperty("jstype")) + switch (message.jstype) { + default: + return "jstype: enum value expected"; + case 0: + case 1: + case 2: + break; + } + if (message.lazy != null && message.hasOwnProperty("lazy")) + if (typeof message.lazy !== "boolean") + return "lazy: boolean expected"; + if (message.unverifiedLazy != null && message.hasOwnProperty("unverifiedLazy")) + if (typeof message.unverifiedLazy !== "boolean") + return "unverifiedLazy: boolean expected"; + if (message.deprecated != null && message.hasOwnProperty("deprecated")) + if (typeof message.deprecated !== "boolean") + return "deprecated: boolean expected"; + if (message.weak != null && message.hasOwnProperty("weak")) + if (typeof message.weak !== "boolean") + return "weak: boolean expected"; + if (message.debugRedact != null && message.hasOwnProperty("debugRedact")) + if (typeof message.debugRedact !== "boolean") + return "debugRedact: boolean expected"; + if (message.retention != null && message.hasOwnProperty("retention")) + switch (message.retention) { + default: + return "retention: enum value expected"; + case 0: + case 1: + case 2: + break; + } + if (message.target != null && message.hasOwnProperty("target")) + switch (message.target) { + default: + return "target: enum value expected"; + case 0: + case 1: + case 2: + case 3: + case 4: + case 5: + case 6: + case 7: + case 8: + case 9: + break; + } + if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { + if (!Array.isArray(message.uninterpretedOption)) + return "uninterpretedOption: array expected"; + for (var i = 0; i < message.uninterpretedOption.length; ++i) { + var error = $root.google.protobuf.UninterpretedOption.verify(message.uninterpretedOption[i]); + if (error) + return "uninterpretedOption." + error; + } + } + if (message[".google.api.fieldBehavior"] != null && message.hasOwnProperty(".google.api.fieldBehavior")) { + if (!Array.isArray(message[".google.api.fieldBehavior"])) + return ".google.api.fieldBehavior: array expected"; + for (var i = 0; i < message[".google.api.fieldBehavior"].length; ++i) + switch (message[".google.api.fieldBehavior"][i]) { + default: + return ".google.api.fieldBehavior: enum value[] expected"; + case 0: + case 1: + case 2: + case 3: + case 4: + case 5: + case 6: + case 7: + break; + } + } + if (message[".google.api.resourceReference"] != null && message.hasOwnProperty(".google.api.resourceReference")) { + var error = $root.google.api.ResourceReference.verify(message[".google.api.resourceReference"]); + if (error) + return ".google.api.resourceReference." + error; + } + return null; + }; + + /** + * Creates a FieldOptions message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.FieldOptions + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.FieldOptions} FieldOptions + */ + FieldOptions.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.FieldOptions) + return object; + var message = new $root.google.protobuf.FieldOptions(); + switch (object.ctype) { + default: + if (typeof object.ctype === "number") { + message.ctype = object.ctype; + break; + } + break; + case "STRING": + case 0: + message.ctype = 0; + break; + case "CORD": + case 1: + message.ctype = 1; + break; + case "STRING_PIECE": + case 2: + message.ctype = 2; + break; + } + if (object.packed != null) + message.packed = Boolean(object.packed); + switch (object.jstype) { + default: + if (typeof object.jstype === "number") { + message.jstype = object.jstype; + break; + } + break; + case "JS_NORMAL": + case 0: + message.jstype = 0; + break; + case "JS_STRING": + case 1: + message.jstype = 1; + break; + case "JS_NUMBER": + case 2: + message.jstype = 2; + break; + } + if (object.lazy != null) + message.lazy = Boolean(object.lazy); + if (object.unverifiedLazy != null) + message.unverifiedLazy = Boolean(object.unverifiedLazy); + if (object.deprecated != null) + message.deprecated = Boolean(object.deprecated); + if (object.weak != null) + message.weak = Boolean(object.weak); + if (object.debugRedact != null) + message.debugRedact = Boolean(object.debugRedact); + switch (object.retention) { + default: + if (typeof object.retention === "number") { + message.retention = object.retention; + break; + } + break; + case "RETENTION_UNKNOWN": + case 0: + message.retention = 0; + break; + case "RETENTION_RUNTIME": + case 1: + message.retention = 1; + break; + case "RETENTION_SOURCE": + case 2: + message.retention = 2; + break; + } + switch (object.target) { + default: + if (typeof object.target === "number") { + message.target = object.target; + break; + } + break; + case "TARGET_TYPE_UNKNOWN": + case 0: + message.target = 0; + break; + case "TARGET_TYPE_FILE": + case 1: + message.target = 1; + break; + case "TARGET_TYPE_EXTENSION_RANGE": + case 2: + message.target = 2; + break; + case "TARGET_TYPE_MESSAGE": + case 3: + message.target = 3; + break; + case "TARGET_TYPE_FIELD": + case 4: + message.target = 4; + break; + case "TARGET_TYPE_ONEOF": + case 5: + message.target = 5; + break; + case "TARGET_TYPE_ENUM": + case 6: + message.target = 6; + break; + case "TARGET_TYPE_ENUM_ENTRY": + case 7: + message.target = 7; + break; + case "TARGET_TYPE_SERVICE": + case 8: + message.target = 8; + break; + case "TARGET_TYPE_METHOD": + case 9: + message.target = 9; + break; + } + if (object.uninterpretedOption) { + if (!Array.isArray(object.uninterpretedOption)) + throw TypeError(".google.protobuf.FieldOptions.uninterpretedOption: array expected"); + message.uninterpretedOption = []; + for (var i = 0; i < object.uninterpretedOption.length; ++i) { + if (typeof object.uninterpretedOption[i] !== "object") + throw TypeError(".google.protobuf.FieldOptions.uninterpretedOption: object expected"); + message.uninterpretedOption[i] = $root.google.protobuf.UninterpretedOption.fromObject(object.uninterpretedOption[i]); + } + } + if (object[".google.api.fieldBehavior"]) { + if (!Array.isArray(object[".google.api.fieldBehavior"])) + throw TypeError(".google.protobuf.FieldOptions..google.api.fieldBehavior: array expected"); + message[".google.api.fieldBehavior"] = []; + for (var i = 0; i < object[".google.api.fieldBehavior"].length; ++i) + switch (object[".google.api.fieldBehavior"][i]) { + default: + if (typeof object[".google.api.fieldBehavior"][i] === "number") { + message[".google.api.fieldBehavior"][i] = object[".google.api.fieldBehavior"][i]; + break; + } + case "FIELD_BEHAVIOR_UNSPECIFIED": + case 0: + message[".google.api.fieldBehavior"][i] = 0; + break; + case "OPTIONAL": + case 1: + message[".google.api.fieldBehavior"][i] = 1; + break; + case "REQUIRED": + case 2: + message[".google.api.fieldBehavior"][i] = 2; + break; + case "OUTPUT_ONLY": + case 3: + message[".google.api.fieldBehavior"][i] = 3; + break; + case "INPUT_ONLY": + case 4: + message[".google.api.fieldBehavior"][i] = 4; + break; + case "IMMUTABLE": + case 5: + message[".google.api.fieldBehavior"][i] = 5; + break; + case "UNORDERED_LIST": + case 6: + message[".google.api.fieldBehavior"][i] = 6; + break; + case "NON_EMPTY_DEFAULT": + case 7: + message[".google.api.fieldBehavior"][i] = 7; + break; + } + } + if (object[".google.api.resourceReference"] != null) { + if (typeof object[".google.api.resourceReference"] !== "object") + throw TypeError(".google.protobuf.FieldOptions..google.api.resourceReference: object expected"); + message[".google.api.resourceReference"] = $root.google.api.ResourceReference.fromObject(object[".google.api.resourceReference"]); + } + return message; + }; + + /** + * Creates a plain object from a FieldOptions message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.FieldOptions + * @static + * @param {google.protobuf.FieldOptions} message FieldOptions + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + FieldOptions.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.uninterpretedOption = []; + object[".google.api.fieldBehavior"] = []; + } + if (options.defaults) { + object.ctype = options.enums === String ? "STRING" : 0; + object.packed = false; + object.deprecated = false; + object.lazy = false; + object.jstype = options.enums === String ? "JS_NORMAL" : 0; + object.weak = false; + object.unverifiedLazy = false; + object.debugRedact = false; + object.retention = options.enums === String ? "RETENTION_UNKNOWN" : 0; + object.target = options.enums === String ? "TARGET_TYPE_UNKNOWN" : 0; + object[".google.api.resourceReference"] = null; + } + if (message.ctype != null && message.hasOwnProperty("ctype")) + object.ctype = options.enums === String ? $root.google.protobuf.FieldOptions.CType[message.ctype] === undefined ? message.ctype : $root.google.protobuf.FieldOptions.CType[message.ctype] : message.ctype; + if (message.packed != null && message.hasOwnProperty("packed")) + object.packed = message.packed; + if (message.deprecated != null && message.hasOwnProperty("deprecated")) + object.deprecated = message.deprecated; + if (message.lazy != null && message.hasOwnProperty("lazy")) + object.lazy = message.lazy; + if (message.jstype != null && message.hasOwnProperty("jstype")) + object.jstype = options.enums === String ? $root.google.protobuf.FieldOptions.JSType[message.jstype] === undefined ? message.jstype : $root.google.protobuf.FieldOptions.JSType[message.jstype] : message.jstype; + if (message.weak != null && message.hasOwnProperty("weak")) + object.weak = message.weak; + if (message.unverifiedLazy != null && message.hasOwnProperty("unverifiedLazy")) + object.unverifiedLazy = message.unverifiedLazy; + if (message.debugRedact != null && message.hasOwnProperty("debugRedact")) + object.debugRedact = message.debugRedact; + if (message.retention != null && message.hasOwnProperty("retention")) + object.retention = options.enums === String ? $root.google.protobuf.FieldOptions.OptionRetention[message.retention] === undefined ? message.retention : $root.google.protobuf.FieldOptions.OptionRetention[message.retention] : message.retention; + if (message.target != null && message.hasOwnProperty("target")) + object.target = options.enums === String ? $root.google.protobuf.FieldOptions.OptionTargetType[message.target] === undefined ? message.target : $root.google.protobuf.FieldOptions.OptionTargetType[message.target] : message.target; + if (message.uninterpretedOption && message.uninterpretedOption.length) { + object.uninterpretedOption = []; + for (var j = 0; j < message.uninterpretedOption.length; ++j) + object.uninterpretedOption[j] = $root.google.protobuf.UninterpretedOption.toObject(message.uninterpretedOption[j], options); + } + if (message[".google.api.fieldBehavior"] && message[".google.api.fieldBehavior"].length) { + object[".google.api.fieldBehavior"] = []; + for (var j = 0; j < message[".google.api.fieldBehavior"].length; ++j) + object[".google.api.fieldBehavior"][j] = options.enums === String ? $root.google.api.FieldBehavior[message[".google.api.fieldBehavior"][j]] === undefined ? message[".google.api.fieldBehavior"][j] : $root.google.api.FieldBehavior[message[".google.api.fieldBehavior"][j]] : message[".google.api.fieldBehavior"][j]; + } + if (message[".google.api.resourceReference"] != null && message.hasOwnProperty(".google.api.resourceReference")) + object[".google.api.resourceReference"] = $root.google.api.ResourceReference.toObject(message[".google.api.resourceReference"], options); + return object; + }; + + /** + * Converts this FieldOptions to JSON. + * @function toJSON + * @memberof google.protobuf.FieldOptions + * @instance + * @returns {Object.} JSON object + */ + FieldOptions.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for FieldOptions + * @function getTypeUrl + * @memberof google.protobuf.FieldOptions + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + FieldOptions.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.FieldOptions"; + }; + + /** + * CType enum. + * @name google.protobuf.FieldOptions.CType + * @enum {number} + * @property {number} STRING=0 STRING value + * @property {number} CORD=1 CORD value + * @property {number} STRING_PIECE=2 STRING_PIECE value + */ + FieldOptions.CType = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "STRING"] = 0; + values[valuesById[1] = "CORD"] = 1; + values[valuesById[2] = "STRING_PIECE"] = 2; + return values; + })(); + + /** + * JSType enum. + * @name google.protobuf.FieldOptions.JSType + * @enum {number} + * @property {number} JS_NORMAL=0 JS_NORMAL value + * @property {number} JS_STRING=1 JS_STRING value + * @property {number} JS_NUMBER=2 JS_NUMBER value + */ + FieldOptions.JSType = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "JS_NORMAL"] = 0; + values[valuesById[1] = "JS_STRING"] = 1; + values[valuesById[2] = "JS_NUMBER"] = 2; + return values; + })(); + + /** + * OptionRetention enum. + * @name google.protobuf.FieldOptions.OptionRetention + * @enum {number} + * @property {number} RETENTION_UNKNOWN=0 RETENTION_UNKNOWN value + * @property {number} RETENTION_RUNTIME=1 RETENTION_RUNTIME value + * @property {number} RETENTION_SOURCE=2 RETENTION_SOURCE value + */ + FieldOptions.OptionRetention = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "RETENTION_UNKNOWN"] = 0; + values[valuesById[1] = "RETENTION_RUNTIME"] = 1; + values[valuesById[2] = "RETENTION_SOURCE"] = 2; + return values; + })(); + + /** + * OptionTargetType enum. + * @name google.protobuf.FieldOptions.OptionTargetType + * @enum {number} + * @property {number} TARGET_TYPE_UNKNOWN=0 TARGET_TYPE_UNKNOWN value + * @property {number} TARGET_TYPE_FILE=1 TARGET_TYPE_FILE value + * @property {number} TARGET_TYPE_EXTENSION_RANGE=2 TARGET_TYPE_EXTENSION_RANGE value + * @property {number} TARGET_TYPE_MESSAGE=3 TARGET_TYPE_MESSAGE value + * @property {number} TARGET_TYPE_FIELD=4 TARGET_TYPE_FIELD value + * @property {number} TARGET_TYPE_ONEOF=5 TARGET_TYPE_ONEOF value + * @property {number} TARGET_TYPE_ENUM=6 TARGET_TYPE_ENUM value + * @property {number} TARGET_TYPE_ENUM_ENTRY=7 TARGET_TYPE_ENUM_ENTRY value + * @property {number} TARGET_TYPE_SERVICE=8 TARGET_TYPE_SERVICE value + * @property {number} TARGET_TYPE_METHOD=9 TARGET_TYPE_METHOD value + */ + FieldOptions.OptionTargetType = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "TARGET_TYPE_UNKNOWN"] = 0; + values[valuesById[1] = "TARGET_TYPE_FILE"] = 1; + values[valuesById[2] = "TARGET_TYPE_EXTENSION_RANGE"] = 2; + values[valuesById[3] = "TARGET_TYPE_MESSAGE"] = 3; + values[valuesById[4] = "TARGET_TYPE_FIELD"] = 4; + values[valuesById[5] = "TARGET_TYPE_ONEOF"] = 5; + values[valuesById[6] = "TARGET_TYPE_ENUM"] = 6; + values[valuesById[7] = "TARGET_TYPE_ENUM_ENTRY"] = 7; + values[valuesById[8] = "TARGET_TYPE_SERVICE"] = 8; + values[valuesById[9] = "TARGET_TYPE_METHOD"] = 9; + return values; + })(); + + return FieldOptions; + })(); + + protobuf.OneofOptions = (function() { + + /** + * Properties of an OneofOptions. + * @memberof google.protobuf + * @interface IOneofOptions + * @property {Array.|null} [uninterpretedOption] OneofOptions uninterpretedOption + */ + + /** + * Constructs a new OneofOptions. + * @memberof google.protobuf + * @classdesc Represents an OneofOptions. + * @implements IOneofOptions + * @constructor + * @param {google.protobuf.IOneofOptions=} [properties] Properties to set + */ + function OneofOptions(properties) { + this.uninterpretedOption = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * OneofOptions uninterpretedOption. + * @member {Array.} uninterpretedOption + * @memberof google.protobuf.OneofOptions + * @instance + */ + OneofOptions.prototype.uninterpretedOption = $util.emptyArray; + + /** + * Creates a new OneofOptions instance using the specified properties. + * @function create + * @memberof google.protobuf.OneofOptions + * @static + * @param {google.protobuf.IOneofOptions=} [properties] Properties to set + * @returns {google.protobuf.OneofOptions} OneofOptions instance + */ + OneofOptions.create = function create(properties) { + return new OneofOptions(properties); + }; + + /** + * Encodes the specified OneofOptions message. Does not implicitly {@link google.protobuf.OneofOptions.verify|verify} messages. + * @function encode + * @memberof google.protobuf.OneofOptions + * @static + * @param {google.protobuf.IOneofOptions} message OneofOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + OneofOptions.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.uninterpretedOption != null && message.uninterpretedOption.length) + for (var i = 0; i < message.uninterpretedOption.length; ++i) + $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified OneofOptions message, length delimited. Does not implicitly {@link google.protobuf.OneofOptions.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.OneofOptions + * @static + * @param {google.protobuf.IOneofOptions} message OneofOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + OneofOptions.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an OneofOptions message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.OneofOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.OneofOptions} OneofOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + OneofOptions.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.OneofOptions(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 999: { + if (!(message.uninterpretedOption && message.uninterpretedOption.length)) + message.uninterpretedOption = []; + message.uninterpretedOption.push($root.google.protobuf.UninterpretedOption.decode(reader, reader.uint32())); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an OneofOptions message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.OneofOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.OneofOptions} OneofOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + OneofOptions.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an OneofOptions message. + * @function verify + * @memberof google.protobuf.OneofOptions + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + OneofOptions.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { + if (!Array.isArray(message.uninterpretedOption)) + return "uninterpretedOption: array expected"; + for (var i = 0; i < message.uninterpretedOption.length; ++i) { + var error = $root.google.protobuf.UninterpretedOption.verify(message.uninterpretedOption[i]); + if (error) + return "uninterpretedOption." + error; + } + } + return null; + }; + + /** + * Creates an OneofOptions message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.OneofOptions + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.OneofOptions} OneofOptions + */ + OneofOptions.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.OneofOptions) + return object; + var message = new $root.google.protobuf.OneofOptions(); + if (object.uninterpretedOption) { + if (!Array.isArray(object.uninterpretedOption)) + throw TypeError(".google.protobuf.OneofOptions.uninterpretedOption: array expected"); + message.uninterpretedOption = []; + for (var i = 0; i < object.uninterpretedOption.length; ++i) { + if (typeof object.uninterpretedOption[i] !== "object") + throw TypeError(".google.protobuf.OneofOptions.uninterpretedOption: object expected"); + message.uninterpretedOption[i] = $root.google.protobuf.UninterpretedOption.fromObject(object.uninterpretedOption[i]); + } + } + return message; + }; + + /** + * Creates a plain object from an OneofOptions message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.OneofOptions + * @static + * @param {google.protobuf.OneofOptions} message OneofOptions + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + OneofOptions.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.uninterpretedOption = []; + if (message.uninterpretedOption && message.uninterpretedOption.length) { + object.uninterpretedOption = []; + for (var j = 0; j < message.uninterpretedOption.length; ++j) + object.uninterpretedOption[j] = $root.google.protobuf.UninterpretedOption.toObject(message.uninterpretedOption[j], options); + } + return object; + }; + + /** + * Converts this OneofOptions to JSON. + * @function toJSON + * @memberof google.protobuf.OneofOptions + * @instance + * @returns {Object.} JSON object + */ + OneofOptions.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for OneofOptions + * @function getTypeUrl + * @memberof google.protobuf.OneofOptions + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + OneofOptions.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.OneofOptions"; + }; + + return OneofOptions; + })(); + + protobuf.EnumOptions = (function() { + + /** + * Properties of an EnumOptions. + * @memberof google.protobuf + * @interface IEnumOptions + * @property {boolean|null} [allowAlias] EnumOptions allowAlias + * @property {boolean|null} [deprecated] EnumOptions deprecated + * @property {boolean|null} [deprecatedLegacyJsonFieldConflicts] EnumOptions deprecatedLegacyJsonFieldConflicts + * @property {Array.|null} [uninterpretedOption] EnumOptions uninterpretedOption + */ + + /** + * Constructs a new EnumOptions. + * @memberof google.protobuf + * @classdesc Represents an EnumOptions. + * @implements IEnumOptions + * @constructor + * @param {google.protobuf.IEnumOptions=} [properties] Properties to set + */ + function EnumOptions(properties) { + this.uninterpretedOption = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * EnumOptions allowAlias. + * @member {boolean} allowAlias + * @memberof google.protobuf.EnumOptions + * @instance + */ + EnumOptions.prototype.allowAlias = false; + + /** + * EnumOptions deprecated. + * @member {boolean} deprecated + * @memberof google.protobuf.EnumOptions + * @instance + */ + EnumOptions.prototype.deprecated = false; + + /** + * EnumOptions deprecatedLegacyJsonFieldConflicts. + * @member {boolean} deprecatedLegacyJsonFieldConflicts + * @memberof google.protobuf.EnumOptions + * @instance + */ + EnumOptions.prototype.deprecatedLegacyJsonFieldConflicts = false; + + /** + * EnumOptions uninterpretedOption. + * @member {Array.} uninterpretedOption + * @memberof google.protobuf.EnumOptions + * @instance + */ + EnumOptions.prototype.uninterpretedOption = $util.emptyArray; + + /** + * Creates a new EnumOptions instance using the specified properties. + * @function create + * @memberof google.protobuf.EnumOptions + * @static + * @param {google.protobuf.IEnumOptions=} [properties] Properties to set + * @returns {google.protobuf.EnumOptions} EnumOptions instance + */ + EnumOptions.create = function create(properties) { + return new EnumOptions(properties); + }; + + /** + * Encodes the specified EnumOptions message. Does not implicitly {@link google.protobuf.EnumOptions.verify|verify} messages. + * @function encode + * @memberof google.protobuf.EnumOptions + * @static + * @param {google.protobuf.IEnumOptions} message EnumOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + EnumOptions.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.allowAlias != null && Object.hasOwnProperty.call(message, "allowAlias")) + writer.uint32(/* id 2, wireType 0 =*/16).bool(message.allowAlias); + if (message.deprecated != null && Object.hasOwnProperty.call(message, "deprecated")) + writer.uint32(/* id 3, wireType 0 =*/24).bool(message.deprecated); + if (message.deprecatedLegacyJsonFieldConflicts != null && Object.hasOwnProperty.call(message, "deprecatedLegacyJsonFieldConflicts")) + writer.uint32(/* id 6, wireType 0 =*/48).bool(message.deprecatedLegacyJsonFieldConflicts); + if (message.uninterpretedOption != null && message.uninterpretedOption.length) + for (var i = 0; i < message.uninterpretedOption.length; ++i) + $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified EnumOptions message, length delimited. Does not implicitly {@link google.protobuf.EnumOptions.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.EnumOptions + * @static + * @param {google.protobuf.IEnumOptions} message EnumOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + EnumOptions.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an EnumOptions message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.EnumOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.EnumOptions} EnumOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + EnumOptions.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.EnumOptions(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 2: { + message.allowAlias = reader.bool(); + break; + } + case 3: { + message.deprecated = reader.bool(); + break; + } + case 6: { + message.deprecatedLegacyJsonFieldConflicts = reader.bool(); + break; + } + case 999: { + if (!(message.uninterpretedOption && message.uninterpretedOption.length)) + message.uninterpretedOption = []; + message.uninterpretedOption.push($root.google.protobuf.UninterpretedOption.decode(reader, reader.uint32())); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an EnumOptions message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.EnumOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.EnumOptions} EnumOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + EnumOptions.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an EnumOptions message. + * @function verify + * @memberof google.protobuf.EnumOptions + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + EnumOptions.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.allowAlias != null && message.hasOwnProperty("allowAlias")) + if (typeof message.allowAlias !== "boolean") + return "allowAlias: boolean expected"; + if (message.deprecated != null && message.hasOwnProperty("deprecated")) + if (typeof message.deprecated !== "boolean") + return "deprecated: boolean expected"; + if (message.deprecatedLegacyJsonFieldConflicts != null && message.hasOwnProperty("deprecatedLegacyJsonFieldConflicts")) + if (typeof message.deprecatedLegacyJsonFieldConflicts !== "boolean") + return "deprecatedLegacyJsonFieldConflicts: boolean expected"; + if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { + if (!Array.isArray(message.uninterpretedOption)) + return "uninterpretedOption: array expected"; + for (var i = 0; i < message.uninterpretedOption.length; ++i) { + var error = $root.google.protobuf.UninterpretedOption.verify(message.uninterpretedOption[i]); + if (error) + return "uninterpretedOption." + error; + } + } + return null; + }; + + /** + * Creates an EnumOptions message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.EnumOptions + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.EnumOptions} EnumOptions + */ + EnumOptions.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.EnumOptions) + return object; + var message = new $root.google.protobuf.EnumOptions(); + if (object.allowAlias != null) + message.allowAlias = Boolean(object.allowAlias); + if (object.deprecated != null) + message.deprecated = Boolean(object.deprecated); + if (object.deprecatedLegacyJsonFieldConflicts != null) + message.deprecatedLegacyJsonFieldConflicts = Boolean(object.deprecatedLegacyJsonFieldConflicts); + if (object.uninterpretedOption) { + if (!Array.isArray(object.uninterpretedOption)) + throw TypeError(".google.protobuf.EnumOptions.uninterpretedOption: array expected"); + message.uninterpretedOption = []; + for (var i = 0; i < object.uninterpretedOption.length; ++i) { + if (typeof object.uninterpretedOption[i] !== "object") + throw TypeError(".google.protobuf.EnumOptions.uninterpretedOption: object expected"); + message.uninterpretedOption[i] = $root.google.protobuf.UninterpretedOption.fromObject(object.uninterpretedOption[i]); + } + } + return message; + }; + + /** + * Creates a plain object from an EnumOptions message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.EnumOptions + * @static + * @param {google.protobuf.EnumOptions} message EnumOptions + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + EnumOptions.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.uninterpretedOption = []; + if (options.defaults) { + object.allowAlias = false; + object.deprecated = false; + object.deprecatedLegacyJsonFieldConflicts = false; + } + if (message.allowAlias != null && message.hasOwnProperty("allowAlias")) + object.allowAlias = message.allowAlias; + if (message.deprecated != null && message.hasOwnProperty("deprecated")) + object.deprecated = message.deprecated; + if (message.deprecatedLegacyJsonFieldConflicts != null && message.hasOwnProperty("deprecatedLegacyJsonFieldConflicts")) + object.deprecatedLegacyJsonFieldConflicts = message.deprecatedLegacyJsonFieldConflicts; + if (message.uninterpretedOption && message.uninterpretedOption.length) { + object.uninterpretedOption = []; + for (var j = 0; j < message.uninterpretedOption.length; ++j) + object.uninterpretedOption[j] = $root.google.protobuf.UninterpretedOption.toObject(message.uninterpretedOption[j], options); + } + return object; + }; + + /** + * Converts this EnumOptions to JSON. + * @function toJSON + * @memberof google.protobuf.EnumOptions + * @instance + * @returns {Object.} JSON object + */ + EnumOptions.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for EnumOptions + * @function getTypeUrl + * @memberof google.protobuf.EnumOptions + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + EnumOptions.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.EnumOptions"; + }; + + return EnumOptions; + })(); + + protobuf.EnumValueOptions = (function() { + + /** + * Properties of an EnumValueOptions. + * @memberof google.protobuf + * @interface IEnumValueOptions + * @property {boolean|null} [deprecated] EnumValueOptions deprecated + * @property {Array.|null} [uninterpretedOption] EnumValueOptions uninterpretedOption + */ + + /** + * Constructs a new EnumValueOptions. + * @memberof google.protobuf + * @classdesc Represents an EnumValueOptions. + * @implements IEnumValueOptions + * @constructor + * @param {google.protobuf.IEnumValueOptions=} [properties] Properties to set + */ + function EnumValueOptions(properties) { + this.uninterpretedOption = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * EnumValueOptions deprecated. + * @member {boolean} deprecated + * @memberof google.protobuf.EnumValueOptions + * @instance + */ + EnumValueOptions.prototype.deprecated = false; + + /** + * EnumValueOptions uninterpretedOption. + * @member {Array.} uninterpretedOption + * @memberof google.protobuf.EnumValueOptions + * @instance + */ + EnumValueOptions.prototype.uninterpretedOption = $util.emptyArray; + + /** + * Creates a new EnumValueOptions instance using the specified properties. + * @function create + * @memberof google.protobuf.EnumValueOptions + * @static + * @param {google.protobuf.IEnumValueOptions=} [properties] Properties to set + * @returns {google.protobuf.EnumValueOptions} EnumValueOptions instance + */ + EnumValueOptions.create = function create(properties) { + return new EnumValueOptions(properties); + }; + + /** + * Encodes the specified EnumValueOptions message. Does not implicitly {@link google.protobuf.EnumValueOptions.verify|verify} messages. + * @function encode + * @memberof google.protobuf.EnumValueOptions + * @static + * @param {google.protobuf.IEnumValueOptions} message EnumValueOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + EnumValueOptions.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.deprecated != null && Object.hasOwnProperty.call(message, "deprecated")) + writer.uint32(/* id 1, wireType 0 =*/8).bool(message.deprecated); + if (message.uninterpretedOption != null && message.uninterpretedOption.length) + for (var i = 0; i < message.uninterpretedOption.length; ++i) + $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified EnumValueOptions message, length delimited. Does not implicitly {@link google.protobuf.EnumValueOptions.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.EnumValueOptions + * @static + * @param {google.protobuf.IEnumValueOptions} message EnumValueOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + EnumValueOptions.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an EnumValueOptions message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.EnumValueOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.EnumValueOptions} EnumValueOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + EnumValueOptions.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.EnumValueOptions(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.deprecated = reader.bool(); + break; + } + case 999: { + if (!(message.uninterpretedOption && message.uninterpretedOption.length)) + message.uninterpretedOption = []; + message.uninterpretedOption.push($root.google.protobuf.UninterpretedOption.decode(reader, reader.uint32())); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an EnumValueOptions message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.EnumValueOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.EnumValueOptions} EnumValueOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + EnumValueOptions.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an EnumValueOptions message. + * @function verify + * @memberof google.protobuf.EnumValueOptions + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + EnumValueOptions.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.deprecated != null && message.hasOwnProperty("deprecated")) + if (typeof message.deprecated !== "boolean") + return "deprecated: boolean expected"; + if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { + if (!Array.isArray(message.uninterpretedOption)) + return "uninterpretedOption: array expected"; + for (var i = 0; i < message.uninterpretedOption.length; ++i) { + var error = $root.google.protobuf.UninterpretedOption.verify(message.uninterpretedOption[i]); + if (error) + return "uninterpretedOption." + error; + } + } + return null; + }; + + /** + * Creates an EnumValueOptions message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.EnumValueOptions + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.EnumValueOptions} EnumValueOptions + */ + EnumValueOptions.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.EnumValueOptions) + return object; + var message = new $root.google.protobuf.EnumValueOptions(); + if (object.deprecated != null) + message.deprecated = Boolean(object.deprecated); + if (object.uninterpretedOption) { + if (!Array.isArray(object.uninterpretedOption)) + throw TypeError(".google.protobuf.EnumValueOptions.uninterpretedOption: array expected"); + message.uninterpretedOption = []; + for (var i = 0; i < object.uninterpretedOption.length; ++i) { + if (typeof object.uninterpretedOption[i] !== "object") + throw TypeError(".google.protobuf.EnumValueOptions.uninterpretedOption: object expected"); + message.uninterpretedOption[i] = $root.google.protobuf.UninterpretedOption.fromObject(object.uninterpretedOption[i]); + } + } + return message; + }; + + /** + * Creates a plain object from an EnumValueOptions message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.EnumValueOptions + * @static + * @param {google.protobuf.EnumValueOptions} message EnumValueOptions + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + EnumValueOptions.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.uninterpretedOption = []; + if (options.defaults) + object.deprecated = false; + if (message.deprecated != null && message.hasOwnProperty("deprecated")) + object.deprecated = message.deprecated; + if (message.uninterpretedOption && message.uninterpretedOption.length) { + object.uninterpretedOption = []; + for (var j = 0; j < message.uninterpretedOption.length; ++j) + object.uninterpretedOption[j] = $root.google.protobuf.UninterpretedOption.toObject(message.uninterpretedOption[j], options); + } + return object; + }; + + /** + * Converts this EnumValueOptions to JSON. + * @function toJSON + * @memberof google.protobuf.EnumValueOptions + * @instance + * @returns {Object.} JSON object + */ + EnumValueOptions.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for EnumValueOptions + * @function getTypeUrl + * @memberof google.protobuf.EnumValueOptions + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + EnumValueOptions.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.EnumValueOptions"; + }; + + return EnumValueOptions; + })(); + + protobuf.ServiceOptions = (function() { + + /** + * Properties of a ServiceOptions. + * @memberof google.protobuf + * @interface IServiceOptions + * @property {boolean|null} [deprecated] ServiceOptions deprecated + * @property {Array.|null} [uninterpretedOption] ServiceOptions uninterpretedOption + * @property {string|null} [".google.api.defaultHost"] ServiceOptions .google.api.defaultHost + * @property {string|null} [".google.api.oauthScopes"] ServiceOptions .google.api.oauthScopes + */ + + /** + * Constructs a new ServiceOptions. + * @memberof google.protobuf + * @classdesc Represents a ServiceOptions. + * @implements IServiceOptions + * @constructor + * @param {google.protobuf.IServiceOptions=} [properties] Properties to set + */ + function ServiceOptions(properties) { + this.uninterpretedOption = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ServiceOptions deprecated. + * @member {boolean} deprecated + * @memberof google.protobuf.ServiceOptions + * @instance + */ + ServiceOptions.prototype.deprecated = false; + + /** + * ServiceOptions uninterpretedOption. + * @member {Array.} uninterpretedOption + * @memberof google.protobuf.ServiceOptions + * @instance + */ + ServiceOptions.prototype.uninterpretedOption = $util.emptyArray; + + /** + * ServiceOptions .google.api.defaultHost. + * @member {string} .google.api.defaultHost + * @memberof google.protobuf.ServiceOptions + * @instance + */ + ServiceOptions.prototype[".google.api.defaultHost"] = ""; + + /** + * ServiceOptions .google.api.oauthScopes. + * @member {string} .google.api.oauthScopes + * @memberof google.protobuf.ServiceOptions + * @instance + */ + ServiceOptions.prototype[".google.api.oauthScopes"] = ""; + + /** + * Creates a new ServiceOptions instance using the specified properties. + * @function create + * @memberof google.protobuf.ServiceOptions + * @static + * @param {google.protobuf.IServiceOptions=} [properties] Properties to set + * @returns {google.protobuf.ServiceOptions} ServiceOptions instance + */ + ServiceOptions.create = function create(properties) { + return new ServiceOptions(properties); + }; + + /** + * Encodes the specified ServiceOptions message. Does not implicitly {@link google.protobuf.ServiceOptions.verify|verify} messages. + * @function encode + * @memberof google.protobuf.ServiceOptions + * @static + * @param {google.protobuf.IServiceOptions} message ServiceOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ServiceOptions.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.deprecated != null && Object.hasOwnProperty.call(message, "deprecated")) + writer.uint32(/* id 33, wireType 0 =*/264).bool(message.deprecated); + if (message.uninterpretedOption != null && message.uninterpretedOption.length) + for (var i = 0; i < message.uninterpretedOption.length; ++i) + $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); + if (message[".google.api.defaultHost"] != null && Object.hasOwnProperty.call(message, ".google.api.defaultHost")) + writer.uint32(/* id 1049, wireType 2 =*/8394).string(message[".google.api.defaultHost"]); + if (message[".google.api.oauthScopes"] != null && Object.hasOwnProperty.call(message, ".google.api.oauthScopes")) + writer.uint32(/* id 1050, wireType 2 =*/8402).string(message[".google.api.oauthScopes"]); + return writer; + }; + + /** + * Encodes the specified ServiceOptions message, length delimited. Does not implicitly {@link google.protobuf.ServiceOptions.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.ServiceOptions + * @static + * @param {google.protobuf.IServiceOptions} message ServiceOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ServiceOptions.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ServiceOptions message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.ServiceOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.ServiceOptions} ServiceOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ServiceOptions.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.ServiceOptions(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 33: { + message.deprecated = reader.bool(); + break; + } + case 999: { + if (!(message.uninterpretedOption && message.uninterpretedOption.length)) + message.uninterpretedOption = []; + message.uninterpretedOption.push($root.google.protobuf.UninterpretedOption.decode(reader, reader.uint32())); + break; + } + case 1049: { + message[".google.api.defaultHost"] = reader.string(); + break; + } + case 1050: { + message[".google.api.oauthScopes"] = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ServiceOptions message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.ServiceOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.ServiceOptions} ServiceOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ServiceOptions.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ServiceOptions message. + * @function verify + * @memberof google.protobuf.ServiceOptions + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ServiceOptions.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.deprecated != null && message.hasOwnProperty("deprecated")) + if (typeof message.deprecated !== "boolean") + return "deprecated: boolean expected"; + if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { + if (!Array.isArray(message.uninterpretedOption)) + return "uninterpretedOption: array expected"; + for (var i = 0; i < message.uninterpretedOption.length; ++i) { + var error = $root.google.protobuf.UninterpretedOption.verify(message.uninterpretedOption[i]); + if (error) + return "uninterpretedOption." + error; + } + } + if (message[".google.api.defaultHost"] != null && message.hasOwnProperty(".google.api.defaultHost")) + if (!$util.isString(message[".google.api.defaultHost"])) + return ".google.api.defaultHost: string expected"; + if (message[".google.api.oauthScopes"] != null && message.hasOwnProperty(".google.api.oauthScopes")) + if (!$util.isString(message[".google.api.oauthScopes"])) + return ".google.api.oauthScopes: string expected"; + return null; + }; + + /** + * Creates a ServiceOptions message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.ServiceOptions + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.ServiceOptions} ServiceOptions + */ + ServiceOptions.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.ServiceOptions) + return object; + var message = new $root.google.protobuf.ServiceOptions(); + if (object.deprecated != null) + message.deprecated = Boolean(object.deprecated); + if (object.uninterpretedOption) { + if (!Array.isArray(object.uninterpretedOption)) + throw TypeError(".google.protobuf.ServiceOptions.uninterpretedOption: array expected"); + message.uninterpretedOption = []; + for (var i = 0; i < object.uninterpretedOption.length; ++i) { + if (typeof object.uninterpretedOption[i] !== "object") + throw TypeError(".google.protobuf.ServiceOptions.uninterpretedOption: object expected"); + message.uninterpretedOption[i] = $root.google.protobuf.UninterpretedOption.fromObject(object.uninterpretedOption[i]); + } + } + if (object[".google.api.defaultHost"] != null) + message[".google.api.defaultHost"] = String(object[".google.api.defaultHost"]); + if (object[".google.api.oauthScopes"] != null) + message[".google.api.oauthScopes"] = String(object[".google.api.oauthScopes"]); + return message; + }; + + /** + * Creates a plain object from a ServiceOptions message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.ServiceOptions + * @static + * @param {google.protobuf.ServiceOptions} message ServiceOptions + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ServiceOptions.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.uninterpretedOption = []; + if (options.defaults) { + object.deprecated = false; + object[".google.api.defaultHost"] = ""; + object[".google.api.oauthScopes"] = ""; + } + if (message.deprecated != null && message.hasOwnProperty("deprecated")) + object.deprecated = message.deprecated; + if (message.uninterpretedOption && message.uninterpretedOption.length) { + object.uninterpretedOption = []; + for (var j = 0; j < message.uninterpretedOption.length; ++j) + object.uninterpretedOption[j] = $root.google.protobuf.UninterpretedOption.toObject(message.uninterpretedOption[j], options); + } + if (message[".google.api.defaultHost"] != null && message.hasOwnProperty(".google.api.defaultHost")) + object[".google.api.defaultHost"] = message[".google.api.defaultHost"]; + if (message[".google.api.oauthScopes"] != null && message.hasOwnProperty(".google.api.oauthScopes")) + object[".google.api.oauthScopes"] = message[".google.api.oauthScopes"]; + return object; + }; + + /** + * Converts this ServiceOptions to JSON. + * @function toJSON + * @memberof google.protobuf.ServiceOptions + * @instance + * @returns {Object.} JSON object + */ + ServiceOptions.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ServiceOptions + * @function getTypeUrl + * @memberof google.protobuf.ServiceOptions + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ServiceOptions.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.ServiceOptions"; + }; + + return ServiceOptions; + })(); + + protobuf.MethodOptions = (function() { + + /** + * Properties of a MethodOptions. + * @memberof google.protobuf + * @interface IMethodOptions + * @property {boolean|null} [deprecated] MethodOptions deprecated + * @property {google.protobuf.MethodOptions.IdempotencyLevel|null} [idempotencyLevel] MethodOptions idempotencyLevel + * @property {Array.|null} [uninterpretedOption] MethodOptions uninterpretedOption + * @property {google.api.IHttpRule|null} [".google.api.http"] MethodOptions .google.api.http + * @property {Array.|null} [".google.api.methodSignature"] MethodOptions .google.api.methodSignature + * @property {google.longrunning.IOperationInfo|null} [".google.longrunning.operationInfo"] MethodOptions .google.longrunning.operationInfo + */ + + /** + * Constructs a new MethodOptions. + * @memberof google.protobuf + * @classdesc Represents a MethodOptions. + * @implements IMethodOptions + * @constructor + * @param {google.protobuf.IMethodOptions=} [properties] Properties to set + */ + function MethodOptions(properties) { + this.uninterpretedOption = []; + this[".google.api.methodSignature"] = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * MethodOptions deprecated. + * @member {boolean} deprecated + * @memberof google.protobuf.MethodOptions + * @instance + */ + MethodOptions.prototype.deprecated = false; + + /** + * MethodOptions idempotencyLevel. + * @member {google.protobuf.MethodOptions.IdempotencyLevel} idempotencyLevel + * @memberof google.protobuf.MethodOptions + * @instance + */ + MethodOptions.prototype.idempotencyLevel = 0; + + /** + * MethodOptions uninterpretedOption. + * @member {Array.} uninterpretedOption + * @memberof google.protobuf.MethodOptions + * @instance + */ + MethodOptions.prototype.uninterpretedOption = $util.emptyArray; + + /** + * MethodOptions .google.api.http. + * @member {google.api.IHttpRule|null|undefined} .google.api.http + * @memberof google.protobuf.MethodOptions + * @instance + */ + MethodOptions.prototype[".google.api.http"] = null; + + /** + * MethodOptions .google.api.methodSignature. + * @member {Array.} .google.api.methodSignature + * @memberof google.protobuf.MethodOptions + * @instance + */ + MethodOptions.prototype[".google.api.methodSignature"] = $util.emptyArray; + + /** + * MethodOptions .google.longrunning.operationInfo. + * @member {google.longrunning.IOperationInfo|null|undefined} .google.longrunning.operationInfo + * @memberof google.protobuf.MethodOptions + * @instance + */ + MethodOptions.prototype[".google.longrunning.operationInfo"] = null; + + /** + * Creates a new MethodOptions instance using the specified properties. + * @function create + * @memberof google.protobuf.MethodOptions + * @static + * @param {google.protobuf.IMethodOptions=} [properties] Properties to set + * @returns {google.protobuf.MethodOptions} MethodOptions instance + */ + MethodOptions.create = function create(properties) { + return new MethodOptions(properties); + }; + + /** + * Encodes the specified MethodOptions message. Does not implicitly {@link google.protobuf.MethodOptions.verify|verify} messages. + * @function encode + * @memberof google.protobuf.MethodOptions + * @static + * @param {google.protobuf.IMethodOptions} message MethodOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + MethodOptions.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.deprecated != null && Object.hasOwnProperty.call(message, "deprecated")) + writer.uint32(/* id 33, wireType 0 =*/264).bool(message.deprecated); + if (message.idempotencyLevel != null && Object.hasOwnProperty.call(message, "idempotencyLevel")) + writer.uint32(/* id 34, wireType 0 =*/272).int32(message.idempotencyLevel); + if (message.uninterpretedOption != null && message.uninterpretedOption.length) + for (var i = 0; i < message.uninterpretedOption.length; ++i) + $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); + if (message[".google.longrunning.operationInfo"] != null && Object.hasOwnProperty.call(message, ".google.longrunning.operationInfo")) + $root.google.longrunning.OperationInfo.encode(message[".google.longrunning.operationInfo"], writer.uint32(/* id 1049, wireType 2 =*/8394).fork()).ldelim(); + if (message[".google.api.methodSignature"] != null && message[".google.api.methodSignature"].length) + for (var i = 0; i < message[".google.api.methodSignature"].length; ++i) + writer.uint32(/* id 1051, wireType 2 =*/8410).string(message[".google.api.methodSignature"][i]); + if (message[".google.api.http"] != null && Object.hasOwnProperty.call(message, ".google.api.http")) + $root.google.api.HttpRule.encode(message[".google.api.http"], writer.uint32(/* id 72295728, wireType 2 =*/578365826).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified MethodOptions message, length delimited. Does not implicitly {@link google.protobuf.MethodOptions.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.MethodOptions + * @static + * @param {google.protobuf.IMethodOptions} message MethodOptions message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + MethodOptions.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a MethodOptions message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.MethodOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.MethodOptions} MethodOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + MethodOptions.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.MethodOptions(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 33: { + message.deprecated = reader.bool(); + break; + } + case 34: { + message.idempotencyLevel = reader.int32(); + break; + } + case 999: { + if (!(message.uninterpretedOption && message.uninterpretedOption.length)) + message.uninterpretedOption = []; + message.uninterpretedOption.push($root.google.protobuf.UninterpretedOption.decode(reader, reader.uint32())); + break; + } + case 72295728: { + message[".google.api.http"] = $root.google.api.HttpRule.decode(reader, reader.uint32()); + break; + } + case 1051: { + if (!(message[".google.api.methodSignature"] && message[".google.api.methodSignature"].length)) + message[".google.api.methodSignature"] = []; + message[".google.api.methodSignature"].push(reader.string()); + break; + } + case 1049: { + message[".google.longrunning.operationInfo"] = $root.google.longrunning.OperationInfo.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a MethodOptions message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.MethodOptions + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.MethodOptions} MethodOptions + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + MethodOptions.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a MethodOptions message. + * @function verify + * @memberof google.protobuf.MethodOptions + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + MethodOptions.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.deprecated != null && message.hasOwnProperty("deprecated")) + if (typeof message.deprecated !== "boolean") + return "deprecated: boolean expected"; + if (message.idempotencyLevel != null && message.hasOwnProperty("idempotencyLevel")) + switch (message.idempotencyLevel) { + default: + return "idempotencyLevel: enum value expected"; + case 0: + case 1: + case 2: + break; + } + if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { + if (!Array.isArray(message.uninterpretedOption)) + return "uninterpretedOption: array expected"; + for (var i = 0; i < message.uninterpretedOption.length; ++i) { + var error = $root.google.protobuf.UninterpretedOption.verify(message.uninterpretedOption[i]); + if (error) + return "uninterpretedOption." + error; + } + } + if (message[".google.api.http"] != null && message.hasOwnProperty(".google.api.http")) { + var error = $root.google.api.HttpRule.verify(message[".google.api.http"]); + if (error) + return ".google.api.http." + error; + } + if (message[".google.api.methodSignature"] != null && message.hasOwnProperty(".google.api.methodSignature")) { + if (!Array.isArray(message[".google.api.methodSignature"])) + return ".google.api.methodSignature: array expected"; + for (var i = 0; i < message[".google.api.methodSignature"].length; ++i) + if (!$util.isString(message[".google.api.methodSignature"][i])) + return ".google.api.methodSignature: string[] expected"; + } + if (message[".google.longrunning.operationInfo"] != null && message.hasOwnProperty(".google.longrunning.operationInfo")) { + var error = $root.google.longrunning.OperationInfo.verify(message[".google.longrunning.operationInfo"]); + if (error) + return ".google.longrunning.operationInfo." + error; + } + return null; + }; + + /** + * Creates a MethodOptions message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.MethodOptions + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.MethodOptions} MethodOptions + */ + MethodOptions.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.MethodOptions) + return object; + var message = new $root.google.protobuf.MethodOptions(); + if (object.deprecated != null) + message.deprecated = Boolean(object.deprecated); + switch (object.idempotencyLevel) { + default: + if (typeof object.idempotencyLevel === "number") { + message.idempotencyLevel = object.idempotencyLevel; + break; + } + break; + case "IDEMPOTENCY_UNKNOWN": + case 0: + message.idempotencyLevel = 0; + break; + case "NO_SIDE_EFFECTS": + case 1: + message.idempotencyLevel = 1; + break; + case "IDEMPOTENT": + case 2: + message.idempotencyLevel = 2; + break; + } + if (object.uninterpretedOption) { + if (!Array.isArray(object.uninterpretedOption)) + throw TypeError(".google.protobuf.MethodOptions.uninterpretedOption: array expected"); + message.uninterpretedOption = []; + for (var i = 0; i < object.uninterpretedOption.length; ++i) { + if (typeof object.uninterpretedOption[i] !== "object") + throw TypeError(".google.protobuf.MethodOptions.uninterpretedOption: object expected"); + message.uninterpretedOption[i] = $root.google.protobuf.UninterpretedOption.fromObject(object.uninterpretedOption[i]); + } + } + if (object[".google.api.http"] != null) { + if (typeof object[".google.api.http"] !== "object") + throw TypeError(".google.protobuf.MethodOptions..google.api.http: object expected"); + message[".google.api.http"] = $root.google.api.HttpRule.fromObject(object[".google.api.http"]); + } + if (object[".google.api.methodSignature"]) { + if (!Array.isArray(object[".google.api.methodSignature"])) + throw TypeError(".google.protobuf.MethodOptions..google.api.methodSignature: array expected"); + message[".google.api.methodSignature"] = []; + for (var i = 0; i < object[".google.api.methodSignature"].length; ++i) + message[".google.api.methodSignature"][i] = String(object[".google.api.methodSignature"][i]); + } + if (object[".google.longrunning.operationInfo"] != null) { + if (typeof object[".google.longrunning.operationInfo"] !== "object") + throw TypeError(".google.protobuf.MethodOptions..google.longrunning.operationInfo: object expected"); + message[".google.longrunning.operationInfo"] = $root.google.longrunning.OperationInfo.fromObject(object[".google.longrunning.operationInfo"]); + } + return message; + }; + + /** + * Creates a plain object from a MethodOptions message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.MethodOptions + * @static + * @param {google.protobuf.MethodOptions} message MethodOptions + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + MethodOptions.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.uninterpretedOption = []; + object[".google.api.methodSignature"] = []; + } + if (options.defaults) { + object.deprecated = false; + object.idempotencyLevel = options.enums === String ? "IDEMPOTENCY_UNKNOWN" : 0; + object[".google.longrunning.operationInfo"] = null; + object[".google.api.http"] = null; + } + if (message.deprecated != null && message.hasOwnProperty("deprecated")) + object.deprecated = message.deprecated; + if (message.idempotencyLevel != null && message.hasOwnProperty("idempotencyLevel")) + object.idempotencyLevel = options.enums === String ? $root.google.protobuf.MethodOptions.IdempotencyLevel[message.idempotencyLevel] === undefined ? message.idempotencyLevel : $root.google.protobuf.MethodOptions.IdempotencyLevel[message.idempotencyLevel] : message.idempotencyLevel; + if (message.uninterpretedOption && message.uninterpretedOption.length) { + object.uninterpretedOption = []; + for (var j = 0; j < message.uninterpretedOption.length; ++j) + object.uninterpretedOption[j] = $root.google.protobuf.UninterpretedOption.toObject(message.uninterpretedOption[j], options); + } + if (message[".google.longrunning.operationInfo"] != null && message.hasOwnProperty(".google.longrunning.operationInfo")) + object[".google.longrunning.operationInfo"] = $root.google.longrunning.OperationInfo.toObject(message[".google.longrunning.operationInfo"], options); + if (message[".google.api.methodSignature"] && message[".google.api.methodSignature"].length) { + object[".google.api.methodSignature"] = []; + for (var j = 0; j < message[".google.api.methodSignature"].length; ++j) + object[".google.api.methodSignature"][j] = message[".google.api.methodSignature"][j]; + } + if (message[".google.api.http"] != null && message.hasOwnProperty(".google.api.http")) + object[".google.api.http"] = $root.google.api.HttpRule.toObject(message[".google.api.http"], options); + return object; + }; + + /** + * Converts this MethodOptions to JSON. + * @function toJSON + * @memberof google.protobuf.MethodOptions + * @instance + * @returns {Object.} JSON object + */ + MethodOptions.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for MethodOptions + * @function getTypeUrl + * @memberof google.protobuf.MethodOptions + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + MethodOptions.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.MethodOptions"; + }; + + /** + * IdempotencyLevel enum. + * @name google.protobuf.MethodOptions.IdempotencyLevel + * @enum {number} + * @property {number} IDEMPOTENCY_UNKNOWN=0 IDEMPOTENCY_UNKNOWN value + * @property {number} NO_SIDE_EFFECTS=1 NO_SIDE_EFFECTS value + * @property {number} IDEMPOTENT=2 IDEMPOTENT value + */ + MethodOptions.IdempotencyLevel = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "IDEMPOTENCY_UNKNOWN"] = 0; + values[valuesById[1] = "NO_SIDE_EFFECTS"] = 1; + values[valuesById[2] = "IDEMPOTENT"] = 2; + return values; + })(); + + return MethodOptions; + })(); + + protobuf.UninterpretedOption = (function() { + + /** + * Properties of an UninterpretedOption. + * @memberof google.protobuf + * @interface IUninterpretedOption + * @property {Array.|null} [name] UninterpretedOption name + * @property {string|null} [identifierValue] UninterpretedOption identifierValue + * @property {number|Long|null} [positiveIntValue] UninterpretedOption positiveIntValue + * @property {number|Long|null} [negativeIntValue] UninterpretedOption negativeIntValue + * @property {number|null} [doubleValue] UninterpretedOption doubleValue + * @property {Uint8Array|null} [stringValue] UninterpretedOption stringValue + * @property {string|null} [aggregateValue] UninterpretedOption aggregateValue + */ + + /** + * Constructs a new UninterpretedOption. + * @memberof google.protobuf + * @classdesc Represents an UninterpretedOption. + * @implements IUninterpretedOption + * @constructor + * @param {google.protobuf.IUninterpretedOption=} [properties] Properties to set + */ + function UninterpretedOption(properties) { + this.name = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * UninterpretedOption name. + * @member {Array.} name + * @memberof google.protobuf.UninterpretedOption + * @instance + */ + UninterpretedOption.prototype.name = $util.emptyArray; + + /** + * UninterpretedOption identifierValue. + * @member {string} identifierValue + * @memberof google.protobuf.UninterpretedOption + * @instance + */ + UninterpretedOption.prototype.identifierValue = ""; + + /** + * UninterpretedOption positiveIntValue. + * @member {number|Long} positiveIntValue + * @memberof google.protobuf.UninterpretedOption + * @instance + */ + UninterpretedOption.prototype.positiveIntValue = $util.Long ? $util.Long.fromBits(0,0,true) : 0; + + /** + * UninterpretedOption negativeIntValue. + * @member {number|Long} negativeIntValue + * @memberof google.protobuf.UninterpretedOption + * @instance + */ + UninterpretedOption.prototype.negativeIntValue = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * UninterpretedOption doubleValue. + * @member {number} doubleValue + * @memberof google.protobuf.UninterpretedOption + * @instance + */ + UninterpretedOption.prototype.doubleValue = 0; + + /** + * UninterpretedOption stringValue. + * @member {Uint8Array} stringValue + * @memberof google.protobuf.UninterpretedOption + * @instance + */ + UninterpretedOption.prototype.stringValue = $util.newBuffer([]); + + /** + * UninterpretedOption aggregateValue. + * @member {string} aggregateValue + * @memberof google.protobuf.UninterpretedOption + * @instance + */ + UninterpretedOption.prototype.aggregateValue = ""; + + /** + * Creates a new UninterpretedOption instance using the specified properties. + * @function create + * @memberof google.protobuf.UninterpretedOption + * @static + * @param {google.protobuf.IUninterpretedOption=} [properties] Properties to set + * @returns {google.protobuf.UninterpretedOption} UninterpretedOption instance + */ + UninterpretedOption.create = function create(properties) { + return new UninterpretedOption(properties); + }; + + /** + * Encodes the specified UninterpretedOption message. Does not implicitly {@link google.protobuf.UninterpretedOption.verify|verify} messages. + * @function encode + * @memberof google.protobuf.UninterpretedOption + * @static + * @param {google.protobuf.IUninterpretedOption} message UninterpretedOption message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + UninterpretedOption.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && message.name.length) + for (var i = 0; i < message.name.length; ++i) + $root.google.protobuf.UninterpretedOption.NamePart.encode(message.name[i], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.identifierValue != null && Object.hasOwnProperty.call(message, "identifierValue")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.identifierValue); + if (message.positiveIntValue != null && Object.hasOwnProperty.call(message, "positiveIntValue")) + writer.uint32(/* id 4, wireType 0 =*/32).uint64(message.positiveIntValue); + if (message.negativeIntValue != null && Object.hasOwnProperty.call(message, "negativeIntValue")) + writer.uint32(/* id 5, wireType 0 =*/40).int64(message.negativeIntValue); + if (message.doubleValue != null && Object.hasOwnProperty.call(message, "doubleValue")) + writer.uint32(/* id 6, wireType 1 =*/49).double(message.doubleValue); + if (message.stringValue != null && Object.hasOwnProperty.call(message, "stringValue")) + writer.uint32(/* id 7, wireType 2 =*/58).bytes(message.stringValue); + if (message.aggregateValue != null && Object.hasOwnProperty.call(message, "aggregateValue")) + writer.uint32(/* id 8, wireType 2 =*/66).string(message.aggregateValue); + return writer; + }; + + /** + * Encodes the specified UninterpretedOption message, length delimited. Does not implicitly {@link google.protobuf.UninterpretedOption.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.UninterpretedOption + * @static + * @param {google.protobuf.IUninterpretedOption} message UninterpretedOption message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + UninterpretedOption.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an UninterpretedOption message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.UninterpretedOption + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.UninterpretedOption} UninterpretedOption + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + UninterpretedOption.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.UninterpretedOption(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 2: { + if (!(message.name && message.name.length)) + message.name = []; + message.name.push($root.google.protobuf.UninterpretedOption.NamePart.decode(reader, reader.uint32())); + break; + } + case 3: { + message.identifierValue = reader.string(); + break; + } + case 4: { + message.positiveIntValue = reader.uint64(); + break; + } + case 5: { + message.negativeIntValue = reader.int64(); + break; + } + case 6: { + message.doubleValue = reader.double(); + break; + } + case 7: { + message.stringValue = reader.bytes(); + break; + } + case 8: { + message.aggregateValue = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an UninterpretedOption message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.UninterpretedOption + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.UninterpretedOption} UninterpretedOption + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + UninterpretedOption.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an UninterpretedOption message. + * @function verify + * @memberof google.protobuf.UninterpretedOption + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + UninterpretedOption.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) { + if (!Array.isArray(message.name)) + return "name: array expected"; + for (var i = 0; i < message.name.length; ++i) { + var error = $root.google.protobuf.UninterpretedOption.NamePart.verify(message.name[i]); + if (error) + return "name." + error; + } + } + if (message.identifierValue != null && message.hasOwnProperty("identifierValue")) + if (!$util.isString(message.identifierValue)) + return "identifierValue: string expected"; + if (message.positiveIntValue != null && message.hasOwnProperty("positiveIntValue")) + if (!$util.isInteger(message.positiveIntValue) && !(message.positiveIntValue && $util.isInteger(message.positiveIntValue.low) && $util.isInteger(message.positiveIntValue.high))) + return "positiveIntValue: integer|Long expected"; + if (message.negativeIntValue != null && message.hasOwnProperty("negativeIntValue")) + if (!$util.isInteger(message.negativeIntValue) && !(message.negativeIntValue && $util.isInteger(message.negativeIntValue.low) && $util.isInteger(message.negativeIntValue.high))) + return "negativeIntValue: integer|Long expected"; + if (message.doubleValue != null && message.hasOwnProperty("doubleValue")) + if (typeof message.doubleValue !== "number") + return "doubleValue: number expected"; + if (message.stringValue != null && message.hasOwnProperty("stringValue")) + if (!(message.stringValue && typeof message.stringValue.length === "number" || $util.isString(message.stringValue))) + return "stringValue: buffer expected"; + if (message.aggregateValue != null && message.hasOwnProperty("aggregateValue")) + if (!$util.isString(message.aggregateValue)) + return "aggregateValue: string expected"; + return null; + }; + + /** + * Creates an UninterpretedOption message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.UninterpretedOption + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.UninterpretedOption} UninterpretedOption + */ + UninterpretedOption.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.UninterpretedOption) + return object; + var message = new $root.google.protobuf.UninterpretedOption(); + if (object.name) { + if (!Array.isArray(object.name)) + throw TypeError(".google.protobuf.UninterpretedOption.name: array expected"); + message.name = []; + for (var i = 0; i < object.name.length; ++i) { + if (typeof object.name[i] !== "object") + throw TypeError(".google.protobuf.UninterpretedOption.name: object expected"); + message.name[i] = $root.google.protobuf.UninterpretedOption.NamePart.fromObject(object.name[i]); + } + } + if (object.identifierValue != null) + message.identifierValue = String(object.identifierValue); + if (object.positiveIntValue != null) + if ($util.Long) + (message.positiveIntValue = $util.Long.fromValue(object.positiveIntValue)).unsigned = true; + else if (typeof object.positiveIntValue === "string") + message.positiveIntValue = parseInt(object.positiveIntValue, 10); + else if (typeof object.positiveIntValue === "number") + message.positiveIntValue = object.positiveIntValue; + else if (typeof object.positiveIntValue === "object") + message.positiveIntValue = new $util.LongBits(object.positiveIntValue.low >>> 0, object.positiveIntValue.high >>> 0).toNumber(true); + if (object.negativeIntValue != null) + if ($util.Long) + (message.negativeIntValue = $util.Long.fromValue(object.negativeIntValue)).unsigned = false; + else if (typeof object.negativeIntValue === "string") + message.negativeIntValue = parseInt(object.negativeIntValue, 10); + else if (typeof object.negativeIntValue === "number") + message.negativeIntValue = object.negativeIntValue; + else if (typeof object.negativeIntValue === "object") + message.negativeIntValue = new $util.LongBits(object.negativeIntValue.low >>> 0, object.negativeIntValue.high >>> 0).toNumber(); + if (object.doubleValue != null) + message.doubleValue = Number(object.doubleValue); + if (object.stringValue != null) + if (typeof object.stringValue === "string") + $util.base64.decode(object.stringValue, message.stringValue = $util.newBuffer($util.base64.length(object.stringValue)), 0); + else if (object.stringValue.length >= 0) + message.stringValue = object.stringValue; + if (object.aggregateValue != null) + message.aggregateValue = String(object.aggregateValue); + return message; + }; + + /** + * Creates a plain object from an UninterpretedOption message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.UninterpretedOption + * @static + * @param {google.protobuf.UninterpretedOption} message UninterpretedOption + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + UninterpretedOption.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.name = []; + if (options.defaults) { + object.identifierValue = ""; + if ($util.Long) { + var long = new $util.Long(0, 0, true); + object.positiveIntValue = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.positiveIntValue = options.longs === String ? "0" : 0; + if ($util.Long) { + var long = new $util.Long(0, 0, false); + object.negativeIntValue = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.negativeIntValue = options.longs === String ? "0" : 0; + object.doubleValue = 0; + if (options.bytes === String) + object.stringValue = ""; + else { + object.stringValue = []; + if (options.bytes !== Array) + object.stringValue = $util.newBuffer(object.stringValue); + } + object.aggregateValue = ""; + } + if (message.name && message.name.length) { + object.name = []; + for (var j = 0; j < message.name.length; ++j) + object.name[j] = $root.google.protobuf.UninterpretedOption.NamePart.toObject(message.name[j], options); + } + if (message.identifierValue != null && message.hasOwnProperty("identifierValue")) + object.identifierValue = message.identifierValue; + if (message.positiveIntValue != null && message.hasOwnProperty("positiveIntValue")) + if (typeof message.positiveIntValue === "number") + object.positiveIntValue = options.longs === String ? String(message.positiveIntValue) : message.positiveIntValue; + else + object.positiveIntValue = options.longs === String ? $util.Long.prototype.toString.call(message.positiveIntValue) : options.longs === Number ? new $util.LongBits(message.positiveIntValue.low >>> 0, message.positiveIntValue.high >>> 0).toNumber(true) : message.positiveIntValue; + if (message.negativeIntValue != null && message.hasOwnProperty("negativeIntValue")) + if (typeof message.negativeIntValue === "number") + object.negativeIntValue = options.longs === String ? String(message.negativeIntValue) : message.negativeIntValue; + else + object.negativeIntValue = options.longs === String ? $util.Long.prototype.toString.call(message.negativeIntValue) : options.longs === Number ? new $util.LongBits(message.negativeIntValue.low >>> 0, message.negativeIntValue.high >>> 0).toNumber() : message.negativeIntValue; + if (message.doubleValue != null && message.hasOwnProperty("doubleValue")) + object.doubleValue = options.json && !isFinite(message.doubleValue) ? String(message.doubleValue) : message.doubleValue; + if (message.stringValue != null && message.hasOwnProperty("stringValue")) + object.stringValue = options.bytes === String ? $util.base64.encode(message.stringValue, 0, message.stringValue.length) : options.bytes === Array ? Array.prototype.slice.call(message.stringValue) : message.stringValue; + if (message.aggregateValue != null && message.hasOwnProperty("aggregateValue")) + object.aggregateValue = message.aggregateValue; + return object; + }; + + /** + * Converts this UninterpretedOption to JSON. + * @function toJSON + * @memberof google.protobuf.UninterpretedOption + * @instance + * @returns {Object.} JSON object + */ + UninterpretedOption.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for UninterpretedOption + * @function getTypeUrl + * @memberof google.protobuf.UninterpretedOption + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + UninterpretedOption.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.UninterpretedOption"; + }; + + UninterpretedOption.NamePart = (function() { + + /** + * Properties of a NamePart. + * @memberof google.protobuf.UninterpretedOption + * @interface INamePart + * @property {string} namePart NamePart namePart + * @property {boolean} isExtension NamePart isExtension + */ + + /** + * Constructs a new NamePart. + * @memberof google.protobuf.UninterpretedOption + * @classdesc Represents a NamePart. + * @implements INamePart + * @constructor + * @param {google.protobuf.UninterpretedOption.INamePart=} [properties] Properties to set + */ + function NamePart(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * NamePart namePart. + * @member {string} namePart + * @memberof google.protobuf.UninterpretedOption.NamePart + * @instance + */ + NamePart.prototype.namePart = ""; + + /** + * NamePart isExtension. + * @member {boolean} isExtension + * @memberof google.protobuf.UninterpretedOption.NamePart + * @instance + */ + NamePart.prototype.isExtension = false; + + /** + * Creates a new NamePart instance using the specified properties. + * @function create + * @memberof google.protobuf.UninterpretedOption.NamePart + * @static + * @param {google.protobuf.UninterpretedOption.INamePart=} [properties] Properties to set + * @returns {google.protobuf.UninterpretedOption.NamePart} NamePart instance + */ + NamePart.create = function create(properties) { + return new NamePart(properties); + }; + + /** + * Encodes the specified NamePart message. Does not implicitly {@link google.protobuf.UninterpretedOption.NamePart.verify|verify} messages. + * @function encode + * @memberof google.protobuf.UninterpretedOption.NamePart + * @static + * @param {google.protobuf.UninterpretedOption.INamePart} message NamePart message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + NamePart.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + writer.uint32(/* id 1, wireType 2 =*/10).string(message.namePart); + writer.uint32(/* id 2, wireType 0 =*/16).bool(message.isExtension); + return writer; + }; + + /** + * Encodes the specified NamePart message, length delimited. Does not implicitly {@link google.protobuf.UninterpretedOption.NamePart.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.UninterpretedOption.NamePart + * @static + * @param {google.protobuf.UninterpretedOption.INamePart} message NamePart message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + NamePart.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a NamePart message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.UninterpretedOption.NamePart + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.UninterpretedOption.NamePart} NamePart + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + NamePart.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.UninterpretedOption.NamePart(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.namePart = reader.string(); + break; + } + case 2: { + message.isExtension = reader.bool(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + if (!message.hasOwnProperty("namePart")) + throw $util.ProtocolError("missing required 'namePart'", { instance: message }); + if (!message.hasOwnProperty("isExtension")) + throw $util.ProtocolError("missing required 'isExtension'", { instance: message }); + return message; + }; + + /** + * Decodes a NamePart message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.UninterpretedOption.NamePart + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.UninterpretedOption.NamePart} NamePart + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + NamePart.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a NamePart message. + * @function verify + * @memberof google.protobuf.UninterpretedOption.NamePart + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + NamePart.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (!$util.isString(message.namePart)) + return "namePart: string expected"; + if (typeof message.isExtension !== "boolean") + return "isExtension: boolean expected"; + return null; + }; + + /** + * Creates a NamePart message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.UninterpretedOption.NamePart + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.UninterpretedOption.NamePart} NamePart + */ + NamePart.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.UninterpretedOption.NamePart) + return object; + var message = new $root.google.protobuf.UninterpretedOption.NamePart(); + if (object.namePart != null) + message.namePart = String(object.namePart); + if (object.isExtension != null) + message.isExtension = Boolean(object.isExtension); + return message; + }; + + /** + * Creates a plain object from a NamePart message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.UninterpretedOption.NamePart + * @static + * @param {google.protobuf.UninterpretedOption.NamePart} message NamePart + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + NamePart.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.namePart = ""; + object.isExtension = false; + } + if (message.namePart != null && message.hasOwnProperty("namePart")) + object.namePart = message.namePart; + if (message.isExtension != null && message.hasOwnProperty("isExtension")) + object.isExtension = message.isExtension; + return object; + }; + + /** + * Converts this NamePart to JSON. + * @function toJSON + * @memberof google.protobuf.UninterpretedOption.NamePart + * @instance + * @returns {Object.} JSON object + */ + NamePart.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for NamePart + * @function getTypeUrl + * @memberof google.protobuf.UninterpretedOption.NamePart + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + NamePart.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.UninterpretedOption.NamePart"; + }; + + return NamePart; + })(); + + return UninterpretedOption; + })(); + + protobuf.SourceCodeInfo = (function() { + + /** + * Properties of a SourceCodeInfo. + * @memberof google.protobuf + * @interface ISourceCodeInfo + * @property {Array.|null} [location] SourceCodeInfo location + */ + + /** + * Constructs a new SourceCodeInfo. + * @memberof google.protobuf + * @classdesc Represents a SourceCodeInfo. + * @implements ISourceCodeInfo + * @constructor + * @param {google.protobuf.ISourceCodeInfo=} [properties] Properties to set + */ + function SourceCodeInfo(properties) { + this.location = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * SourceCodeInfo location. + * @member {Array.} location + * @memberof google.protobuf.SourceCodeInfo + * @instance + */ + SourceCodeInfo.prototype.location = $util.emptyArray; + + /** + * Creates a new SourceCodeInfo instance using the specified properties. + * @function create + * @memberof google.protobuf.SourceCodeInfo + * @static + * @param {google.protobuf.ISourceCodeInfo=} [properties] Properties to set + * @returns {google.protobuf.SourceCodeInfo} SourceCodeInfo instance + */ + SourceCodeInfo.create = function create(properties) { + return new SourceCodeInfo(properties); + }; + + /** + * Encodes the specified SourceCodeInfo message. Does not implicitly {@link google.protobuf.SourceCodeInfo.verify|verify} messages. + * @function encode + * @memberof google.protobuf.SourceCodeInfo + * @static + * @param {google.protobuf.ISourceCodeInfo} message SourceCodeInfo message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + SourceCodeInfo.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.location != null && message.location.length) + for (var i = 0; i < message.location.length; ++i) + $root.google.protobuf.SourceCodeInfo.Location.encode(message.location[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified SourceCodeInfo message, length delimited. Does not implicitly {@link google.protobuf.SourceCodeInfo.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.SourceCodeInfo + * @static + * @param {google.protobuf.ISourceCodeInfo} message SourceCodeInfo message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + SourceCodeInfo.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a SourceCodeInfo message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.SourceCodeInfo + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.SourceCodeInfo} SourceCodeInfo + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + SourceCodeInfo.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.SourceCodeInfo(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + if (!(message.location && message.location.length)) + message.location = []; + message.location.push($root.google.protobuf.SourceCodeInfo.Location.decode(reader, reader.uint32())); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a SourceCodeInfo message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.SourceCodeInfo + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.SourceCodeInfo} SourceCodeInfo + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + SourceCodeInfo.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a SourceCodeInfo message. + * @function verify + * @memberof google.protobuf.SourceCodeInfo + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + SourceCodeInfo.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.location != null && message.hasOwnProperty("location")) { + if (!Array.isArray(message.location)) + return "location: array expected"; + for (var i = 0; i < message.location.length; ++i) { + var error = $root.google.protobuf.SourceCodeInfo.Location.verify(message.location[i]); + if (error) + return "location." + error; + } + } + return null; + }; + + /** + * Creates a SourceCodeInfo message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.SourceCodeInfo + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.SourceCodeInfo} SourceCodeInfo + */ + SourceCodeInfo.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.SourceCodeInfo) + return object; + var message = new $root.google.protobuf.SourceCodeInfo(); + if (object.location) { + if (!Array.isArray(object.location)) + throw TypeError(".google.protobuf.SourceCodeInfo.location: array expected"); + message.location = []; + for (var i = 0; i < object.location.length; ++i) { + if (typeof object.location[i] !== "object") + throw TypeError(".google.protobuf.SourceCodeInfo.location: object expected"); + message.location[i] = $root.google.protobuf.SourceCodeInfo.Location.fromObject(object.location[i]); + } + } + return message; + }; + + /** + * Creates a plain object from a SourceCodeInfo message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.SourceCodeInfo + * @static + * @param {google.protobuf.SourceCodeInfo} message SourceCodeInfo + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + SourceCodeInfo.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.location = []; + if (message.location && message.location.length) { + object.location = []; + for (var j = 0; j < message.location.length; ++j) + object.location[j] = $root.google.protobuf.SourceCodeInfo.Location.toObject(message.location[j], options); + } + return object; + }; + + /** + * Converts this SourceCodeInfo to JSON. + * @function toJSON + * @memberof google.protobuf.SourceCodeInfo + * @instance + * @returns {Object.} JSON object + */ + SourceCodeInfo.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for SourceCodeInfo + * @function getTypeUrl + * @memberof google.protobuf.SourceCodeInfo + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + SourceCodeInfo.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.SourceCodeInfo"; + }; + + SourceCodeInfo.Location = (function() { + + /** + * Properties of a Location. + * @memberof google.protobuf.SourceCodeInfo + * @interface ILocation + * @property {Array.|null} [path] Location path + * @property {Array.|null} [span] Location span + * @property {string|null} [leadingComments] Location leadingComments + * @property {string|null} [trailingComments] Location trailingComments + * @property {Array.|null} [leadingDetachedComments] Location leadingDetachedComments + */ + + /** + * Constructs a new Location. + * @memberof google.protobuf.SourceCodeInfo + * @classdesc Represents a Location. + * @implements ILocation + * @constructor + * @param {google.protobuf.SourceCodeInfo.ILocation=} [properties] Properties to set + */ + function Location(properties) { + this.path = []; + this.span = []; + this.leadingDetachedComments = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Location path. + * @member {Array.} path + * @memberof google.protobuf.SourceCodeInfo.Location + * @instance + */ + Location.prototype.path = $util.emptyArray; + + /** + * Location span. + * @member {Array.} span + * @memberof google.protobuf.SourceCodeInfo.Location + * @instance + */ + Location.prototype.span = $util.emptyArray; + + /** + * Location leadingComments. + * @member {string} leadingComments + * @memberof google.protobuf.SourceCodeInfo.Location + * @instance + */ + Location.prototype.leadingComments = ""; + + /** + * Location trailingComments. + * @member {string} trailingComments + * @memberof google.protobuf.SourceCodeInfo.Location + * @instance + */ + Location.prototype.trailingComments = ""; + + /** + * Location leadingDetachedComments. + * @member {Array.} leadingDetachedComments + * @memberof google.protobuf.SourceCodeInfo.Location + * @instance + */ + Location.prototype.leadingDetachedComments = $util.emptyArray; + + /** + * Creates a new Location instance using the specified properties. + * @function create + * @memberof google.protobuf.SourceCodeInfo.Location + * @static + * @param {google.protobuf.SourceCodeInfo.ILocation=} [properties] Properties to set + * @returns {google.protobuf.SourceCodeInfo.Location} Location instance + */ + Location.create = function create(properties) { + return new Location(properties); + }; + + /** + * Encodes the specified Location message. Does not implicitly {@link google.protobuf.SourceCodeInfo.Location.verify|verify} messages. + * @function encode + * @memberof google.protobuf.SourceCodeInfo.Location + * @static + * @param {google.protobuf.SourceCodeInfo.ILocation} message Location message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Location.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.path != null && message.path.length) { + writer.uint32(/* id 1, wireType 2 =*/10).fork(); + for (var i = 0; i < message.path.length; ++i) + writer.int32(message.path[i]); + writer.ldelim(); + } + if (message.span != null && message.span.length) { + writer.uint32(/* id 2, wireType 2 =*/18).fork(); + for (var i = 0; i < message.span.length; ++i) + writer.int32(message.span[i]); + writer.ldelim(); + } + if (message.leadingComments != null && Object.hasOwnProperty.call(message, "leadingComments")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.leadingComments); + if (message.trailingComments != null && Object.hasOwnProperty.call(message, "trailingComments")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.trailingComments); + if (message.leadingDetachedComments != null && message.leadingDetachedComments.length) + for (var i = 0; i < message.leadingDetachedComments.length; ++i) + writer.uint32(/* id 6, wireType 2 =*/50).string(message.leadingDetachedComments[i]); + return writer; + }; + + /** + * Encodes the specified Location message, length delimited. Does not implicitly {@link google.protobuf.SourceCodeInfo.Location.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.SourceCodeInfo.Location + * @static + * @param {google.protobuf.SourceCodeInfo.ILocation} message Location message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Location.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a Location message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.SourceCodeInfo.Location + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.SourceCodeInfo.Location} Location + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Location.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.SourceCodeInfo.Location(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + if (!(message.path && message.path.length)) + message.path = []; + if ((tag & 7) === 2) { + var end2 = reader.uint32() + reader.pos; + while (reader.pos < end2) + message.path.push(reader.int32()); + } else + message.path.push(reader.int32()); + break; + } + case 2: { + if (!(message.span && message.span.length)) + message.span = []; + if ((tag & 7) === 2) { + var end2 = reader.uint32() + reader.pos; + while (reader.pos < end2) + message.span.push(reader.int32()); + } else + message.span.push(reader.int32()); + break; + } + case 3: { + message.leadingComments = reader.string(); + break; + } + case 4: { + message.trailingComments = reader.string(); + break; + } + case 6: { + if (!(message.leadingDetachedComments && message.leadingDetachedComments.length)) + message.leadingDetachedComments = []; + message.leadingDetachedComments.push(reader.string()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a Location message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.SourceCodeInfo.Location + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.SourceCodeInfo.Location} Location + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Location.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a Location message. + * @function verify + * @memberof google.protobuf.SourceCodeInfo.Location + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Location.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.path != null && message.hasOwnProperty("path")) { + if (!Array.isArray(message.path)) + return "path: array expected"; + for (var i = 0; i < message.path.length; ++i) + if (!$util.isInteger(message.path[i])) + return "path: integer[] expected"; + } + if (message.span != null && message.hasOwnProperty("span")) { + if (!Array.isArray(message.span)) + return "span: array expected"; + for (var i = 0; i < message.span.length; ++i) + if (!$util.isInteger(message.span[i])) + return "span: integer[] expected"; + } + if (message.leadingComments != null && message.hasOwnProperty("leadingComments")) + if (!$util.isString(message.leadingComments)) + return "leadingComments: string expected"; + if (message.trailingComments != null && message.hasOwnProperty("trailingComments")) + if (!$util.isString(message.trailingComments)) + return "trailingComments: string expected"; + if (message.leadingDetachedComments != null && message.hasOwnProperty("leadingDetachedComments")) { + if (!Array.isArray(message.leadingDetachedComments)) + return "leadingDetachedComments: array expected"; + for (var i = 0; i < message.leadingDetachedComments.length; ++i) + if (!$util.isString(message.leadingDetachedComments[i])) + return "leadingDetachedComments: string[] expected"; + } + return null; + }; + + /** + * Creates a Location message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.SourceCodeInfo.Location + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.SourceCodeInfo.Location} Location + */ + Location.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.SourceCodeInfo.Location) + return object; + var message = new $root.google.protobuf.SourceCodeInfo.Location(); + if (object.path) { + if (!Array.isArray(object.path)) + throw TypeError(".google.protobuf.SourceCodeInfo.Location.path: array expected"); + message.path = []; + for (var i = 0; i < object.path.length; ++i) + message.path[i] = object.path[i] | 0; + } + if (object.span) { + if (!Array.isArray(object.span)) + throw TypeError(".google.protobuf.SourceCodeInfo.Location.span: array expected"); + message.span = []; + for (var i = 0; i < object.span.length; ++i) + message.span[i] = object.span[i] | 0; + } + if (object.leadingComments != null) + message.leadingComments = String(object.leadingComments); + if (object.trailingComments != null) + message.trailingComments = String(object.trailingComments); + if (object.leadingDetachedComments) { + if (!Array.isArray(object.leadingDetachedComments)) + throw TypeError(".google.protobuf.SourceCodeInfo.Location.leadingDetachedComments: array expected"); + message.leadingDetachedComments = []; + for (var i = 0; i < object.leadingDetachedComments.length; ++i) + message.leadingDetachedComments[i] = String(object.leadingDetachedComments[i]); + } + return message; + }; + + /** + * Creates a plain object from a Location message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.SourceCodeInfo.Location + * @static + * @param {google.protobuf.SourceCodeInfo.Location} message Location + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Location.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) { + object.path = []; + object.span = []; + object.leadingDetachedComments = []; + } + if (options.defaults) { + object.leadingComments = ""; + object.trailingComments = ""; + } + if (message.path && message.path.length) { + object.path = []; + for (var j = 0; j < message.path.length; ++j) + object.path[j] = message.path[j]; + } + if (message.span && message.span.length) { + object.span = []; + for (var j = 0; j < message.span.length; ++j) + object.span[j] = message.span[j]; + } + if (message.leadingComments != null && message.hasOwnProperty("leadingComments")) + object.leadingComments = message.leadingComments; + if (message.trailingComments != null && message.hasOwnProperty("trailingComments")) + object.trailingComments = message.trailingComments; + if (message.leadingDetachedComments && message.leadingDetachedComments.length) { + object.leadingDetachedComments = []; + for (var j = 0; j < message.leadingDetachedComments.length; ++j) + object.leadingDetachedComments[j] = message.leadingDetachedComments[j]; + } + return object; + }; + + /** + * Converts this Location to JSON. + * @function toJSON + * @memberof google.protobuf.SourceCodeInfo.Location + * @instance + * @returns {Object.} JSON object + */ + Location.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Location + * @function getTypeUrl + * @memberof google.protobuf.SourceCodeInfo.Location + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Location.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.SourceCodeInfo.Location"; + }; + + return Location; + })(); + + return SourceCodeInfo; + })(); + + protobuf.GeneratedCodeInfo = (function() { + + /** + * Properties of a GeneratedCodeInfo. + * @memberof google.protobuf + * @interface IGeneratedCodeInfo + * @property {Array.|null} [annotation] GeneratedCodeInfo annotation + */ + + /** + * Constructs a new GeneratedCodeInfo. + * @memberof google.protobuf + * @classdesc Represents a GeneratedCodeInfo. + * @implements IGeneratedCodeInfo + * @constructor + * @param {google.protobuf.IGeneratedCodeInfo=} [properties] Properties to set + */ + function GeneratedCodeInfo(properties) { + this.annotation = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * GeneratedCodeInfo annotation. + * @member {Array.} annotation + * @memberof google.protobuf.GeneratedCodeInfo + * @instance + */ + GeneratedCodeInfo.prototype.annotation = $util.emptyArray; + + /** + * Creates a new GeneratedCodeInfo instance using the specified properties. + * @function create + * @memberof google.protobuf.GeneratedCodeInfo + * @static + * @param {google.protobuf.IGeneratedCodeInfo=} [properties] Properties to set + * @returns {google.protobuf.GeneratedCodeInfo} GeneratedCodeInfo instance + */ + GeneratedCodeInfo.create = function create(properties) { + return new GeneratedCodeInfo(properties); + }; + + /** + * Encodes the specified GeneratedCodeInfo message. Does not implicitly {@link google.protobuf.GeneratedCodeInfo.verify|verify} messages. + * @function encode + * @memberof google.protobuf.GeneratedCodeInfo + * @static + * @param {google.protobuf.IGeneratedCodeInfo} message GeneratedCodeInfo message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GeneratedCodeInfo.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.annotation != null && message.annotation.length) + for (var i = 0; i < message.annotation.length; ++i) + $root.google.protobuf.GeneratedCodeInfo.Annotation.encode(message.annotation[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified GeneratedCodeInfo message, length delimited. Does not implicitly {@link google.protobuf.GeneratedCodeInfo.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.GeneratedCodeInfo + * @static + * @param {google.protobuf.IGeneratedCodeInfo} message GeneratedCodeInfo message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GeneratedCodeInfo.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a GeneratedCodeInfo message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.GeneratedCodeInfo + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.GeneratedCodeInfo} GeneratedCodeInfo + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GeneratedCodeInfo.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.GeneratedCodeInfo(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + if (!(message.annotation && message.annotation.length)) + message.annotation = []; + message.annotation.push($root.google.protobuf.GeneratedCodeInfo.Annotation.decode(reader, reader.uint32())); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a GeneratedCodeInfo message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.GeneratedCodeInfo + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.GeneratedCodeInfo} GeneratedCodeInfo + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GeneratedCodeInfo.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a GeneratedCodeInfo message. + * @function verify + * @memberof google.protobuf.GeneratedCodeInfo + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + GeneratedCodeInfo.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.annotation != null && message.hasOwnProperty("annotation")) { + if (!Array.isArray(message.annotation)) + return "annotation: array expected"; + for (var i = 0; i < message.annotation.length; ++i) { + var error = $root.google.protobuf.GeneratedCodeInfo.Annotation.verify(message.annotation[i]); + if (error) + return "annotation." + error; + } + } + return null; + }; + + /** + * Creates a GeneratedCodeInfo message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.GeneratedCodeInfo + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.GeneratedCodeInfo} GeneratedCodeInfo + */ + GeneratedCodeInfo.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.GeneratedCodeInfo) + return object; + var message = new $root.google.protobuf.GeneratedCodeInfo(); + if (object.annotation) { + if (!Array.isArray(object.annotation)) + throw TypeError(".google.protobuf.GeneratedCodeInfo.annotation: array expected"); + message.annotation = []; + for (var i = 0; i < object.annotation.length; ++i) { + if (typeof object.annotation[i] !== "object") + throw TypeError(".google.protobuf.GeneratedCodeInfo.annotation: object expected"); + message.annotation[i] = $root.google.protobuf.GeneratedCodeInfo.Annotation.fromObject(object.annotation[i]); + } + } + return message; + }; + + /** + * Creates a plain object from a GeneratedCodeInfo message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.GeneratedCodeInfo + * @static + * @param {google.protobuf.GeneratedCodeInfo} message GeneratedCodeInfo + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + GeneratedCodeInfo.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.annotation = []; + if (message.annotation && message.annotation.length) { + object.annotation = []; + for (var j = 0; j < message.annotation.length; ++j) + object.annotation[j] = $root.google.protobuf.GeneratedCodeInfo.Annotation.toObject(message.annotation[j], options); + } + return object; + }; + + /** + * Converts this GeneratedCodeInfo to JSON. + * @function toJSON + * @memberof google.protobuf.GeneratedCodeInfo + * @instance + * @returns {Object.} JSON object + */ + GeneratedCodeInfo.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for GeneratedCodeInfo + * @function getTypeUrl + * @memberof google.protobuf.GeneratedCodeInfo + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + GeneratedCodeInfo.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.GeneratedCodeInfo"; + }; + + GeneratedCodeInfo.Annotation = (function() { + + /** + * Properties of an Annotation. + * @memberof google.protobuf.GeneratedCodeInfo + * @interface IAnnotation + * @property {Array.|null} [path] Annotation path + * @property {string|null} [sourceFile] Annotation sourceFile + * @property {number|null} [begin] Annotation begin + * @property {number|null} [end] Annotation end + * @property {google.protobuf.GeneratedCodeInfo.Annotation.Semantic|null} [semantic] Annotation semantic + */ + + /** + * Constructs a new Annotation. + * @memberof google.protobuf.GeneratedCodeInfo + * @classdesc Represents an Annotation. + * @implements IAnnotation + * @constructor + * @param {google.protobuf.GeneratedCodeInfo.IAnnotation=} [properties] Properties to set + */ + function Annotation(properties) { + this.path = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Annotation path. + * @member {Array.} path + * @memberof google.protobuf.GeneratedCodeInfo.Annotation + * @instance + */ + Annotation.prototype.path = $util.emptyArray; + + /** + * Annotation sourceFile. + * @member {string} sourceFile + * @memberof google.protobuf.GeneratedCodeInfo.Annotation + * @instance + */ + Annotation.prototype.sourceFile = ""; + + /** + * Annotation begin. + * @member {number} begin + * @memberof google.protobuf.GeneratedCodeInfo.Annotation + * @instance + */ + Annotation.prototype.begin = 0; + + /** + * Annotation end. + * @member {number} end + * @memberof google.protobuf.GeneratedCodeInfo.Annotation + * @instance + */ + Annotation.prototype.end = 0; + + /** + * Annotation semantic. + * @member {google.protobuf.GeneratedCodeInfo.Annotation.Semantic} semantic + * @memberof google.protobuf.GeneratedCodeInfo.Annotation + * @instance + */ + Annotation.prototype.semantic = 0; + + /** + * Creates a new Annotation instance using the specified properties. + * @function create + * @memberof google.protobuf.GeneratedCodeInfo.Annotation + * @static + * @param {google.protobuf.GeneratedCodeInfo.IAnnotation=} [properties] Properties to set + * @returns {google.protobuf.GeneratedCodeInfo.Annotation} Annotation instance + */ + Annotation.create = function create(properties) { + return new Annotation(properties); + }; + + /** + * Encodes the specified Annotation message. Does not implicitly {@link google.protobuf.GeneratedCodeInfo.Annotation.verify|verify} messages. + * @function encode + * @memberof google.protobuf.GeneratedCodeInfo.Annotation + * @static + * @param {google.protobuf.GeneratedCodeInfo.IAnnotation} message Annotation message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Annotation.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.path != null && message.path.length) { + writer.uint32(/* id 1, wireType 2 =*/10).fork(); + for (var i = 0; i < message.path.length; ++i) + writer.int32(message.path[i]); + writer.ldelim(); + } + if (message.sourceFile != null && Object.hasOwnProperty.call(message, "sourceFile")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.sourceFile); + if (message.begin != null && Object.hasOwnProperty.call(message, "begin")) + writer.uint32(/* id 3, wireType 0 =*/24).int32(message.begin); + if (message.end != null && Object.hasOwnProperty.call(message, "end")) + writer.uint32(/* id 4, wireType 0 =*/32).int32(message.end); + if (message.semantic != null && Object.hasOwnProperty.call(message, "semantic")) + writer.uint32(/* id 5, wireType 0 =*/40).int32(message.semantic); + return writer; + }; + + /** + * Encodes the specified Annotation message, length delimited. Does not implicitly {@link google.protobuf.GeneratedCodeInfo.Annotation.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.GeneratedCodeInfo.Annotation + * @static + * @param {google.protobuf.GeneratedCodeInfo.IAnnotation} message Annotation message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Annotation.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an Annotation message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.GeneratedCodeInfo.Annotation + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.GeneratedCodeInfo.Annotation} Annotation + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Annotation.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.GeneratedCodeInfo.Annotation(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + if (!(message.path && message.path.length)) + message.path = []; + if ((tag & 7) === 2) { + var end2 = reader.uint32() + reader.pos; + while (reader.pos < end2) + message.path.push(reader.int32()); + } else + message.path.push(reader.int32()); + break; + } + case 2: { + message.sourceFile = reader.string(); + break; + } + case 3: { + message.begin = reader.int32(); + break; + } + case 4: { + message.end = reader.int32(); + break; + } + case 5: { + message.semantic = reader.int32(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an Annotation message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.GeneratedCodeInfo.Annotation + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.GeneratedCodeInfo.Annotation} Annotation + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Annotation.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an Annotation message. + * @function verify + * @memberof google.protobuf.GeneratedCodeInfo.Annotation + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Annotation.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.path != null && message.hasOwnProperty("path")) { + if (!Array.isArray(message.path)) + return "path: array expected"; + for (var i = 0; i < message.path.length; ++i) + if (!$util.isInteger(message.path[i])) + return "path: integer[] expected"; + } + if (message.sourceFile != null && message.hasOwnProperty("sourceFile")) + if (!$util.isString(message.sourceFile)) + return "sourceFile: string expected"; + if (message.begin != null && message.hasOwnProperty("begin")) + if (!$util.isInteger(message.begin)) + return "begin: integer expected"; + if (message.end != null && message.hasOwnProperty("end")) + if (!$util.isInteger(message.end)) + return "end: integer expected"; + if (message.semantic != null && message.hasOwnProperty("semantic")) + switch (message.semantic) { + default: + return "semantic: enum value expected"; + case 0: + case 1: + case 2: + break; + } + return null; + }; + + /** + * Creates an Annotation message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.GeneratedCodeInfo.Annotation + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.GeneratedCodeInfo.Annotation} Annotation + */ + Annotation.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.GeneratedCodeInfo.Annotation) + return object; + var message = new $root.google.protobuf.GeneratedCodeInfo.Annotation(); + if (object.path) { + if (!Array.isArray(object.path)) + throw TypeError(".google.protobuf.GeneratedCodeInfo.Annotation.path: array expected"); + message.path = []; + for (var i = 0; i < object.path.length; ++i) + message.path[i] = object.path[i] | 0; + } + if (object.sourceFile != null) + message.sourceFile = String(object.sourceFile); + if (object.begin != null) + message.begin = object.begin | 0; + if (object.end != null) + message.end = object.end | 0; + switch (object.semantic) { + default: + if (typeof object.semantic === "number") { + message.semantic = object.semantic; + break; + } + break; + case "NONE": + case 0: + message.semantic = 0; + break; + case "SET": + case 1: + message.semantic = 1; + break; + case "ALIAS": + case 2: + message.semantic = 2; + break; + } + return message; + }; + + /** + * Creates a plain object from an Annotation message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.GeneratedCodeInfo.Annotation + * @static + * @param {google.protobuf.GeneratedCodeInfo.Annotation} message Annotation + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Annotation.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.path = []; + if (options.defaults) { + object.sourceFile = ""; + object.begin = 0; + object.end = 0; + object.semantic = options.enums === String ? "NONE" : 0; + } + if (message.path && message.path.length) { + object.path = []; + for (var j = 0; j < message.path.length; ++j) + object.path[j] = message.path[j]; + } + if (message.sourceFile != null && message.hasOwnProperty("sourceFile")) + object.sourceFile = message.sourceFile; + if (message.begin != null && message.hasOwnProperty("begin")) + object.begin = message.begin; + if (message.end != null && message.hasOwnProperty("end")) + object.end = message.end; + if (message.semantic != null && message.hasOwnProperty("semantic")) + object.semantic = options.enums === String ? $root.google.protobuf.GeneratedCodeInfo.Annotation.Semantic[message.semantic] === undefined ? message.semantic : $root.google.protobuf.GeneratedCodeInfo.Annotation.Semantic[message.semantic] : message.semantic; + return object; + }; + + /** + * Converts this Annotation to JSON. + * @function toJSON + * @memberof google.protobuf.GeneratedCodeInfo.Annotation + * @instance + * @returns {Object.} JSON object + */ + Annotation.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Annotation + * @function getTypeUrl + * @memberof google.protobuf.GeneratedCodeInfo.Annotation + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Annotation.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.GeneratedCodeInfo.Annotation"; + }; + + /** + * Semantic enum. + * @name google.protobuf.GeneratedCodeInfo.Annotation.Semantic + * @enum {number} + * @property {number} NONE=0 NONE value + * @property {number} SET=1 SET value + * @property {number} ALIAS=2 ALIAS value + */ + Annotation.Semantic = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "NONE"] = 0; + values[valuesById[1] = "SET"] = 1; + values[valuesById[2] = "ALIAS"] = 2; + return values; + })(); + + return Annotation; + })(); + + return GeneratedCodeInfo; + })(); + + protobuf.Timestamp = (function() { + + /** + * Properties of a Timestamp. + * @memberof google.protobuf + * @interface ITimestamp + * @property {number|Long|null} [seconds] Timestamp seconds + * @property {number|null} [nanos] Timestamp nanos + */ + + /** + * Constructs a new Timestamp. + * @memberof google.protobuf + * @classdesc Represents a Timestamp. + * @implements ITimestamp + * @constructor + * @param {google.protobuf.ITimestamp=} [properties] Properties to set + */ + function Timestamp(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Timestamp seconds. + * @member {number|Long} seconds + * @memberof google.protobuf.Timestamp + * @instance + */ + Timestamp.prototype.seconds = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * Timestamp nanos. + * @member {number} nanos + * @memberof google.protobuf.Timestamp + * @instance + */ + Timestamp.prototype.nanos = 0; + + /** + * Creates a new Timestamp instance using the specified properties. + * @function create + * @memberof google.protobuf.Timestamp + * @static + * @param {google.protobuf.ITimestamp=} [properties] Properties to set + * @returns {google.protobuf.Timestamp} Timestamp instance + */ + Timestamp.create = function create(properties) { + return new Timestamp(properties); + }; + + /** + * Encodes the specified Timestamp message. Does not implicitly {@link google.protobuf.Timestamp.verify|verify} messages. + * @function encode + * @memberof google.protobuf.Timestamp + * @static + * @param {google.protobuf.ITimestamp} message Timestamp message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Timestamp.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.seconds != null && Object.hasOwnProperty.call(message, "seconds")) + writer.uint32(/* id 1, wireType 0 =*/8).int64(message.seconds); + if (message.nanos != null && Object.hasOwnProperty.call(message, "nanos")) + writer.uint32(/* id 2, wireType 0 =*/16).int32(message.nanos); + return writer; + }; + + /** + * Encodes the specified Timestamp message, length delimited. Does not implicitly {@link google.protobuf.Timestamp.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.Timestamp + * @static + * @param {google.protobuf.ITimestamp} message Timestamp message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Timestamp.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a Timestamp message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.Timestamp + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.Timestamp} Timestamp + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Timestamp.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.Timestamp(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.seconds = reader.int64(); + break; + } + case 2: { + message.nanos = reader.int32(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a Timestamp message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.Timestamp + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.Timestamp} Timestamp + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Timestamp.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a Timestamp message. + * @function verify + * @memberof google.protobuf.Timestamp + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Timestamp.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.seconds != null && message.hasOwnProperty("seconds")) + if (!$util.isInteger(message.seconds) && !(message.seconds && $util.isInteger(message.seconds.low) && $util.isInteger(message.seconds.high))) + return "seconds: integer|Long expected"; + if (message.nanos != null && message.hasOwnProperty("nanos")) + if (!$util.isInteger(message.nanos)) + return "nanos: integer expected"; + return null; + }; + + /** + * Creates a Timestamp message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.Timestamp + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.Timestamp} Timestamp + */ + Timestamp.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.Timestamp) + return object; + var message = new $root.google.protobuf.Timestamp(); + if (object.seconds != null) + if ($util.Long) + (message.seconds = $util.Long.fromValue(object.seconds)).unsigned = false; + else if (typeof object.seconds === "string") + message.seconds = parseInt(object.seconds, 10); + else if (typeof object.seconds === "number") + message.seconds = object.seconds; + else if (typeof object.seconds === "object") + message.seconds = new $util.LongBits(object.seconds.low >>> 0, object.seconds.high >>> 0).toNumber(); + if (object.nanos != null) + message.nanos = object.nanos | 0; + return message; + }; + + /** + * Creates a plain object from a Timestamp message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.Timestamp + * @static + * @param {google.protobuf.Timestamp} message Timestamp + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Timestamp.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + if ($util.Long) { + var long = new $util.Long(0, 0, false); + object.seconds = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.seconds = options.longs === String ? "0" : 0; + object.nanos = 0; + } + if (message.seconds != null && message.hasOwnProperty("seconds")) + if (typeof message.seconds === "number") + object.seconds = options.longs === String ? String(message.seconds) : message.seconds; + else + object.seconds = options.longs === String ? $util.Long.prototype.toString.call(message.seconds) : options.longs === Number ? new $util.LongBits(message.seconds.low >>> 0, message.seconds.high >>> 0).toNumber() : message.seconds; + if (message.nanos != null && message.hasOwnProperty("nanos")) + object.nanos = message.nanos; + return object; + }; + + /** + * Converts this Timestamp to JSON. + * @function toJSON + * @memberof google.protobuf.Timestamp + * @instance + * @returns {Object.} JSON object + */ + Timestamp.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Timestamp + * @function getTypeUrl + * @memberof google.protobuf.Timestamp + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Timestamp.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.Timestamp"; + }; + + return Timestamp; + })(); + + protobuf.Duration = (function() { + + /** + * Properties of a Duration. + * @memberof google.protobuf + * @interface IDuration + * @property {number|Long|null} [seconds] Duration seconds + * @property {number|null} [nanos] Duration nanos + */ + + /** + * Constructs a new Duration. + * @memberof google.protobuf + * @classdesc Represents a Duration. + * @implements IDuration + * @constructor + * @param {google.protobuf.IDuration=} [properties] Properties to set + */ + function Duration(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Duration seconds. + * @member {number|Long} seconds + * @memberof google.protobuf.Duration + * @instance + */ + Duration.prototype.seconds = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * Duration nanos. + * @member {number} nanos + * @memberof google.protobuf.Duration + * @instance + */ + Duration.prototype.nanos = 0; + + /** + * Creates a new Duration instance using the specified properties. + * @function create + * @memberof google.protobuf.Duration + * @static + * @param {google.protobuf.IDuration=} [properties] Properties to set + * @returns {google.protobuf.Duration} Duration instance + */ + Duration.create = function create(properties) { + return new Duration(properties); + }; + + /** + * Encodes the specified Duration message. Does not implicitly {@link google.protobuf.Duration.verify|verify} messages. + * @function encode + * @memberof google.protobuf.Duration + * @static + * @param {google.protobuf.IDuration} message Duration message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Duration.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.seconds != null && Object.hasOwnProperty.call(message, "seconds")) + writer.uint32(/* id 1, wireType 0 =*/8).int64(message.seconds); + if (message.nanos != null && Object.hasOwnProperty.call(message, "nanos")) + writer.uint32(/* id 2, wireType 0 =*/16).int32(message.nanos); + return writer; + }; + + /** + * Encodes the specified Duration message, length delimited. Does not implicitly {@link google.protobuf.Duration.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.Duration + * @static + * @param {google.protobuf.IDuration} message Duration message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Duration.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a Duration message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.Duration + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.Duration} Duration + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Duration.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.Duration(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.seconds = reader.int64(); + break; + } + case 2: { + message.nanos = reader.int32(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a Duration message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.Duration + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.Duration} Duration + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Duration.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a Duration message. + * @function verify + * @memberof google.protobuf.Duration + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Duration.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.seconds != null && message.hasOwnProperty("seconds")) + if (!$util.isInteger(message.seconds) && !(message.seconds && $util.isInteger(message.seconds.low) && $util.isInteger(message.seconds.high))) + return "seconds: integer|Long expected"; + if (message.nanos != null && message.hasOwnProperty("nanos")) + if (!$util.isInteger(message.nanos)) + return "nanos: integer expected"; + return null; + }; + + /** + * Creates a Duration message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.Duration + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.Duration} Duration + */ + Duration.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.Duration) + return object; + var message = new $root.google.protobuf.Duration(); + if (object.seconds != null) + if ($util.Long) + (message.seconds = $util.Long.fromValue(object.seconds)).unsigned = false; + else if (typeof object.seconds === "string") + message.seconds = parseInt(object.seconds, 10); + else if (typeof object.seconds === "number") + message.seconds = object.seconds; + else if (typeof object.seconds === "object") + message.seconds = new $util.LongBits(object.seconds.low >>> 0, object.seconds.high >>> 0).toNumber(); + if (object.nanos != null) + message.nanos = object.nanos | 0; + return message; + }; + + /** + * Creates a plain object from a Duration message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.Duration + * @static + * @param {google.protobuf.Duration} message Duration + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Duration.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + if ($util.Long) { + var long = new $util.Long(0, 0, false); + object.seconds = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; + } else + object.seconds = options.longs === String ? "0" : 0; + object.nanos = 0; + } + if (message.seconds != null && message.hasOwnProperty("seconds")) + if (typeof message.seconds === "number") + object.seconds = options.longs === String ? String(message.seconds) : message.seconds; + else + object.seconds = options.longs === String ? $util.Long.prototype.toString.call(message.seconds) : options.longs === Number ? new $util.LongBits(message.seconds.low >>> 0, message.seconds.high >>> 0).toNumber() : message.seconds; + if (message.nanos != null && message.hasOwnProperty("nanos")) + object.nanos = message.nanos; + return object; + }; + + /** + * Converts this Duration to JSON. + * @function toJSON + * @memberof google.protobuf.Duration + * @instance + * @returns {Object.} JSON object + */ + Duration.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Duration + * @function getTypeUrl + * @memberof google.protobuf.Duration + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Duration.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.Duration"; + }; + + return Duration; + })(); + + protobuf.Any = (function() { + + /** + * Properties of an Any. + * @memberof google.protobuf + * @interface IAny + * @property {string|null} [type_url] Any type_url + * @property {Uint8Array|null} [value] Any value + */ + + /** + * Constructs a new Any. + * @memberof google.protobuf + * @classdesc Represents an Any. + * @implements IAny + * @constructor + * @param {google.protobuf.IAny=} [properties] Properties to set + */ + function Any(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Any type_url. + * @member {string} type_url + * @memberof google.protobuf.Any + * @instance + */ + Any.prototype.type_url = ""; + + /** + * Any value. + * @member {Uint8Array} value + * @memberof google.protobuf.Any + * @instance + */ + Any.prototype.value = $util.newBuffer([]); + + /** + * Creates a new Any instance using the specified properties. + * @function create + * @memberof google.protobuf.Any + * @static + * @param {google.protobuf.IAny=} [properties] Properties to set + * @returns {google.protobuf.Any} Any instance + */ + Any.create = function create(properties) { + return new Any(properties); + }; + + /** + * Encodes the specified Any message. Does not implicitly {@link google.protobuf.Any.verify|verify} messages. + * @function encode + * @memberof google.protobuf.Any + * @static + * @param {google.protobuf.IAny} message Any message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Any.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.type_url != null && Object.hasOwnProperty.call(message, "type_url")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.type_url); + if (message.value != null && Object.hasOwnProperty.call(message, "value")) + writer.uint32(/* id 2, wireType 2 =*/18).bytes(message.value); + return writer; + }; + + /** + * Encodes the specified Any message, length delimited. Does not implicitly {@link google.protobuf.Any.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.Any + * @static + * @param {google.protobuf.IAny} message Any message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Any.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an Any message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.Any + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.Any} Any + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Any.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.Any(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.type_url = reader.string(); + break; + } + case 2: { + message.value = reader.bytes(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an Any message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.Any + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.Any} Any + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Any.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an Any message. + * @function verify + * @memberof google.protobuf.Any + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Any.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.type_url != null && message.hasOwnProperty("type_url")) + if (!$util.isString(message.type_url)) + return "type_url: string expected"; + if (message.value != null && message.hasOwnProperty("value")) + if (!(message.value && typeof message.value.length === "number" || $util.isString(message.value))) + return "value: buffer expected"; + return null; + }; + + /** + * Creates an Any message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.Any + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.Any} Any + */ + Any.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.Any) + return object; + var message = new $root.google.protobuf.Any(); + if (object.type_url != null) + message.type_url = String(object.type_url); + if (object.value != null) + if (typeof object.value === "string") + $util.base64.decode(object.value, message.value = $util.newBuffer($util.base64.length(object.value)), 0); + else if (object.value.length >= 0) + message.value = object.value; + return message; + }; + + /** + * Creates a plain object from an Any message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.Any + * @static + * @param {google.protobuf.Any} message Any + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Any.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.type_url = ""; + if (options.bytes === String) + object.value = ""; + else { + object.value = []; + if (options.bytes !== Array) + object.value = $util.newBuffer(object.value); + } + } + if (message.type_url != null && message.hasOwnProperty("type_url")) + object.type_url = message.type_url; + if (message.value != null && message.hasOwnProperty("value")) + object.value = options.bytes === String ? $util.base64.encode(message.value, 0, message.value.length) : options.bytes === Array ? Array.prototype.slice.call(message.value) : message.value; + return object; + }; + + /** + * Converts this Any to JSON. + * @function toJSON + * @memberof google.protobuf.Any + * @instance + * @returns {Object.} JSON object + */ + Any.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Any + * @function getTypeUrl + * @memberof google.protobuf.Any + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Any.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.Any"; + }; + + return Any; + })(); + + protobuf.Empty = (function() { + + /** + * Properties of an Empty. + * @memberof google.protobuf + * @interface IEmpty + */ + + /** + * Constructs a new Empty. + * @memberof google.protobuf + * @classdesc Represents an Empty. + * @implements IEmpty + * @constructor + * @param {google.protobuf.IEmpty=} [properties] Properties to set + */ + function Empty(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Creates a new Empty instance using the specified properties. + * @function create + * @memberof google.protobuf.Empty + * @static + * @param {google.protobuf.IEmpty=} [properties] Properties to set + * @returns {google.protobuf.Empty} Empty instance + */ + Empty.create = function create(properties) { + return new Empty(properties); + }; + + /** + * Encodes the specified Empty message. Does not implicitly {@link google.protobuf.Empty.verify|verify} messages. + * @function encode + * @memberof google.protobuf.Empty + * @static + * @param {google.protobuf.IEmpty} message Empty message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Empty.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + return writer; + }; + + /** + * Encodes the specified Empty message, length delimited. Does not implicitly {@link google.protobuf.Empty.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.Empty + * @static + * @param {google.protobuf.IEmpty} message Empty message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Empty.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an Empty message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.Empty + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.Empty} Empty + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Empty.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.Empty(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an Empty message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.Empty + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.Empty} Empty + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Empty.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an Empty message. + * @function verify + * @memberof google.protobuf.Empty + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Empty.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + return null; + }; + + /** + * Creates an Empty message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.Empty + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.Empty} Empty + */ + Empty.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.Empty) + return object; + return new $root.google.protobuf.Empty(); + }; + + /** + * Creates a plain object from an Empty message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.Empty + * @static + * @param {google.protobuf.Empty} message Empty + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Empty.toObject = function toObject() { + return {}; + }; + + /** + * Converts this Empty to JSON. + * @function toJSON + * @memberof google.protobuf.Empty + * @instance + * @returns {Object.} JSON object + */ + Empty.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Empty + * @function getTypeUrl + * @memberof google.protobuf.Empty + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Empty.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.Empty"; + }; + + return Empty; + })(); + + protobuf.FieldMask = (function() { + + /** + * Properties of a FieldMask. + * @memberof google.protobuf + * @interface IFieldMask + * @property {Array.|null} [paths] FieldMask paths + */ + + /** + * Constructs a new FieldMask. + * @memberof google.protobuf + * @classdesc Represents a FieldMask. + * @implements IFieldMask + * @constructor + * @param {google.protobuf.IFieldMask=} [properties] Properties to set + */ + function FieldMask(properties) { + this.paths = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * FieldMask paths. + * @member {Array.} paths + * @memberof google.protobuf.FieldMask + * @instance + */ + FieldMask.prototype.paths = $util.emptyArray; + + /** + * Creates a new FieldMask instance using the specified properties. + * @function create + * @memberof google.protobuf.FieldMask + * @static + * @param {google.protobuf.IFieldMask=} [properties] Properties to set + * @returns {google.protobuf.FieldMask} FieldMask instance + */ + FieldMask.create = function create(properties) { + return new FieldMask(properties); + }; + + /** + * Encodes the specified FieldMask message. Does not implicitly {@link google.protobuf.FieldMask.verify|verify} messages. + * @function encode + * @memberof google.protobuf.FieldMask + * @static + * @param {google.protobuf.IFieldMask} message FieldMask message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + FieldMask.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.paths != null && message.paths.length) + for (var i = 0; i < message.paths.length; ++i) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.paths[i]); + return writer; + }; + + /** + * Encodes the specified FieldMask message, length delimited. Does not implicitly {@link google.protobuf.FieldMask.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.FieldMask + * @static + * @param {google.protobuf.IFieldMask} message FieldMask message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + FieldMask.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a FieldMask message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.FieldMask + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.FieldMask} FieldMask + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + FieldMask.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.FieldMask(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + if (!(message.paths && message.paths.length)) + message.paths = []; + message.paths.push(reader.string()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a FieldMask message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.FieldMask + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.FieldMask} FieldMask + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + FieldMask.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a FieldMask message. + * @function verify + * @memberof google.protobuf.FieldMask + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + FieldMask.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.paths != null && message.hasOwnProperty("paths")) { + if (!Array.isArray(message.paths)) + return "paths: array expected"; + for (var i = 0; i < message.paths.length; ++i) + if (!$util.isString(message.paths[i])) + return "paths: string[] expected"; + } + return null; + }; + + /** + * Creates a FieldMask message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.FieldMask + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.FieldMask} FieldMask + */ + FieldMask.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.FieldMask) + return object; + var message = new $root.google.protobuf.FieldMask(); + if (object.paths) { + if (!Array.isArray(object.paths)) + throw TypeError(".google.protobuf.FieldMask.paths: array expected"); + message.paths = []; + for (var i = 0; i < object.paths.length; ++i) + message.paths[i] = String(object.paths[i]); + } + return message; + }; + + /** + * Creates a plain object from a FieldMask message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.FieldMask + * @static + * @param {google.protobuf.FieldMask} message FieldMask + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + FieldMask.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.paths = []; + if (message.paths && message.paths.length) { + object.paths = []; + for (var j = 0; j < message.paths.length; ++j) + object.paths[j] = message.paths[j]; + } + return object; + }; + + /** + * Converts this FieldMask to JSON. + * @function toJSON + * @memberof google.protobuf.FieldMask + * @instance + * @returns {Object.} JSON object + */ + FieldMask.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for FieldMask + * @function getTypeUrl + * @memberof google.protobuf.FieldMask + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + FieldMask.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.FieldMask"; + }; + + return FieldMask; + })(); + + return protobuf; + })(); + + google.longrunning = (function() { + + /** + * Namespace longrunning. + * @memberof google + * @namespace + */ + var longrunning = {}; + + longrunning.Operations = (function() { + + /** + * Constructs a new Operations service. + * @memberof google.longrunning + * @classdesc Represents an Operations + * @extends $protobuf.rpc.Service + * @constructor + * @param {$protobuf.RPCImpl} rpcImpl RPC implementation + * @param {boolean} [requestDelimited=false] Whether requests are length-delimited + * @param {boolean} [responseDelimited=false] Whether responses are length-delimited + */ + function Operations(rpcImpl, requestDelimited, responseDelimited) { + $protobuf.rpc.Service.call(this, rpcImpl, requestDelimited, responseDelimited); + } + + (Operations.prototype = Object.create($protobuf.rpc.Service.prototype)).constructor = Operations; + + /** + * Creates new Operations service using the specified rpc implementation. + * @function create + * @memberof google.longrunning.Operations + * @static + * @param {$protobuf.RPCImpl} rpcImpl RPC implementation + * @param {boolean} [requestDelimited=false] Whether requests are length-delimited + * @param {boolean} [responseDelimited=false] Whether responses are length-delimited + * @returns {Operations} RPC service. Useful where requests and/or responses are streamed. + */ + Operations.create = function create(rpcImpl, requestDelimited, responseDelimited) { + return new this(rpcImpl, requestDelimited, responseDelimited); + }; + + /** + * Callback as used by {@link google.longrunning.Operations|listOperations}. + * @memberof google.longrunning.Operations + * @typedef ListOperationsCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.longrunning.ListOperationsResponse} [response] ListOperationsResponse + */ + + /** + * Calls ListOperations. + * @function listOperations + * @memberof google.longrunning.Operations + * @instance + * @param {google.longrunning.IListOperationsRequest} request ListOperationsRequest message or plain object + * @param {google.longrunning.Operations.ListOperationsCallback} callback Node-style callback called with the error, if any, and ListOperationsResponse + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(Operations.prototype.listOperations = function listOperations(request, callback) { + return this.rpcCall(listOperations, $root.google.longrunning.ListOperationsRequest, $root.google.longrunning.ListOperationsResponse, request, callback); + }, "name", { value: "ListOperations" }); + + /** + * Calls ListOperations. + * @function listOperations + * @memberof google.longrunning.Operations + * @instance + * @param {google.longrunning.IListOperationsRequest} request ListOperationsRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.longrunning.Operations|getOperation}. + * @memberof google.longrunning.Operations + * @typedef GetOperationCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.longrunning.Operation} [response] Operation + */ + + /** + * Calls GetOperation. + * @function getOperation + * @memberof google.longrunning.Operations + * @instance + * @param {google.longrunning.IGetOperationRequest} request GetOperationRequest message or plain object + * @param {google.longrunning.Operations.GetOperationCallback} callback Node-style callback called with the error, if any, and Operation + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(Operations.prototype.getOperation = function getOperation(request, callback) { + return this.rpcCall(getOperation, $root.google.longrunning.GetOperationRequest, $root.google.longrunning.Operation, request, callback); + }, "name", { value: "GetOperation" }); + + /** + * Calls GetOperation. + * @function getOperation + * @memberof google.longrunning.Operations + * @instance + * @param {google.longrunning.IGetOperationRequest} request GetOperationRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.longrunning.Operations|deleteOperation}. + * @memberof google.longrunning.Operations + * @typedef DeleteOperationCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.protobuf.Empty} [response] Empty + */ + + /** + * Calls DeleteOperation. + * @function deleteOperation + * @memberof google.longrunning.Operations + * @instance + * @param {google.longrunning.IDeleteOperationRequest} request DeleteOperationRequest message or plain object + * @param {google.longrunning.Operations.DeleteOperationCallback} callback Node-style callback called with the error, if any, and Empty + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(Operations.prototype.deleteOperation = function deleteOperation(request, callback) { + return this.rpcCall(deleteOperation, $root.google.longrunning.DeleteOperationRequest, $root.google.protobuf.Empty, request, callback); + }, "name", { value: "DeleteOperation" }); + + /** + * Calls DeleteOperation. + * @function deleteOperation + * @memberof google.longrunning.Operations + * @instance + * @param {google.longrunning.IDeleteOperationRequest} request DeleteOperationRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.longrunning.Operations|cancelOperation}. + * @memberof google.longrunning.Operations + * @typedef CancelOperationCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.protobuf.Empty} [response] Empty + */ + + /** + * Calls CancelOperation. + * @function cancelOperation + * @memberof google.longrunning.Operations + * @instance + * @param {google.longrunning.ICancelOperationRequest} request CancelOperationRequest message or plain object + * @param {google.longrunning.Operations.CancelOperationCallback} callback Node-style callback called with the error, if any, and Empty + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(Operations.prototype.cancelOperation = function cancelOperation(request, callback) { + return this.rpcCall(cancelOperation, $root.google.longrunning.CancelOperationRequest, $root.google.protobuf.Empty, request, callback); + }, "name", { value: "CancelOperation" }); + + /** + * Calls CancelOperation. + * @function cancelOperation + * @memberof google.longrunning.Operations + * @instance + * @param {google.longrunning.ICancelOperationRequest} request CancelOperationRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link google.longrunning.Operations|waitOperation}. + * @memberof google.longrunning.Operations + * @typedef WaitOperationCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {google.longrunning.Operation} [response] Operation + */ + + /** + * Calls WaitOperation. + * @function waitOperation + * @memberof google.longrunning.Operations + * @instance + * @param {google.longrunning.IWaitOperationRequest} request WaitOperationRequest message or plain object + * @param {google.longrunning.Operations.WaitOperationCallback} callback Node-style callback called with the error, if any, and Operation + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(Operations.prototype.waitOperation = function waitOperation(request, callback) { + return this.rpcCall(waitOperation, $root.google.longrunning.WaitOperationRequest, $root.google.longrunning.Operation, request, callback); + }, "name", { value: "WaitOperation" }); + + /** + * Calls WaitOperation. + * @function waitOperation + * @memberof google.longrunning.Operations + * @instance + * @param {google.longrunning.IWaitOperationRequest} request WaitOperationRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + return Operations; + })(); + + longrunning.Operation = (function() { + + /** + * Properties of an Operation. + * @memberof google.longrunning + * @interface IOperation + * @property {string|null} [name] Operation name + * @property {google.protobuf.IAny|null} [metadata] Operation metadata + * @property {boolean|null} [done] Operation done + * @property {google.rpc.IStatus|null} [error] Operation error + * @property {google.protobuf.IAny|null} [response] Operation response + */ + + /** + * Constructs a new Operation. + * @memberof google.longrunning + * @classdesc Represents an Operation. + * @implements IOperation + * @constructor + * @param {google.longrunning.IOperation=} [properties] Properties to set + */ + function Operation(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Operation name. + * @member {string} name + * @memberof google.longrunning.Operation + * @instance + */ + Operation.prototype.name = ""; + + /** + * Operation metadata. + * @member {google.protobuf.IAny|null|undefined} metadata + * @memberof google.longrunning.Operation + * @instance + */ + Operation.prototype.metadata = null; + + /** + * Operation done. + * @member {boolean} done + * @memberof google.longrunning.Operation + * @instance + */ + Operation.prototype.done = false; + + /** + * Operation error. + * @member {google.rpc.IStatus|null|undefined} error + * @memberof google.longrunning.Operation + * @instance + */ + Operation.prototype.error = null; + + /** + * Operation response. + * @member {google.protobuf.IAny|null|undefined} response + * @memberof google.longrunning.Operation + * @instance + */ + Operation.prototype.response = null; + + // OneOf field names bound to virtual getters and setters + var $oneOfFields; + + /** + * Operation result. + * @member {"error"|"response"|undefined} result + * @memberof google.longrunning.Operation + * @instance + */ + Object.defineProperty(Operation.prototype, "result", { + get: $util.oneOfGetter($oneOfFields = ["error", "response"]), + set: $util.oneOfSetter($oneOfFields) + }); + + /** + * Creates a new Operation instance using the specified properties. + * @function create + * @memberof google.longrunning.Operation + * @static + * @param {google.longrunning.IOperation=} [properties] Properties to set + * @returns {google.longrunning.Operation} Operation instance + */ + Operation.create = function create(properties) { + return new Operation(properties); + }; + + /** + * Encodes the specified Operation message. Does not implicitly {@link google.longrunning.Operation.verify|verify} messages. + * @function encode + * @memberof google.longrunning.Operation + * @static + * @param {google.longrunning.IOperation} message Operation message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Operation.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.metadata != null && Object.hasOwnProperty.call(message, "metadata")) + $root.google.protobuf.Any.encode(message.metadata, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.done != null && Object.hasOwnProperty.call(message, "done")) + writer.uint32(/* id 3, wireType 0 =*/24).bool(message.done); + if (message.error != null && Object.hasOwnProperty.call(message, "error")) + $root.google.rpc.Status.encode(message.error, writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); + if (message.response != null && Object.hasOwnProperty.call(message, "response")) + $root.google.protobuf.Any.encode(message.response, writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified Operation message, length delimited. Does not implicitly {@link google.longrunning.Operation.verify|verify} messages. + * @function encodeDelimited + * @memberof google.longrunning.Operation + * @static + * @param {google.longrunning.IOperation} message Operation message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Operation.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an Operation message from the specified reader or buffer. + * @function decode + * @memberof google.longrunning.Operation + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.longrunning.Operation} Operation + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Operation.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.longrunning.Operation(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.metadata = $root.google.protobuf.Any.decode(reader, reader.uint32()); + break; + } + case 3: { + message.done = reader.bool(); + break; + } + case 4: { + message.error = $root.google.rpc.Status.decode(reader, reader.uint32()); + break; + } + case 5: { + message.response = $root.google.protobuf.Any.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an Operation message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.longrunning.Operation + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.longrunning.Operation} Operation + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Operation.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an Operation message. + * @function verify + * @memberof google.longrunning.Operation + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Operation.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + var properties = {}; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.metadata != null && message.hasOwnProperty("metadata")) { + var error = $root.google.protobuf.Any.verify(message.metadata); + if (error) + return "metadata." + error; + } + if (message.done != null && message.hasOwnProperty("done")) + if (typeof message.done !== "boolean") + return "done: boolean expected"; + if (message.error != null && message.hasOwnProperty("error")) { + properties.result = 1; + { + var error = $root.google.rpc.Status.verify(message.error); + if (error) + return "error." + error; + } + } + if (message.response != null && message.hasOwnProperty("response")) { + if (properties.result === 1) + return "result: multiple values"; + properties.result = 1; + { + var error = $root.google.protobuf.Any.verify(message.response); + if (error) + return "response." + error; + } + } + return null; + }; + + /** + * Creates an Operation message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.longrunning.Operation + * @static + * @param {Object.} object Plain object + * @returns {google.longrunning.Operation} Operation + */ + Operation.fromObject = function fromObject(object) { + if (object instanceof $root.google.longrunning.Operation) + return object; + var message = new $root.google.longrunning.Operation(); + if (object.name != null) + message.name = String(object.name); + if (object.metadata != null) { + if (typeof object.metadata !== "object") + throw TypeError(".google.longrunning.Operation.metadata: object expected"); + message.metadata = $root.google.protobuf.Any.fromObject(object.metadata); + } + if (object.done != null) + message.done = Boolean(object.done); + if (object.error != null) { + if (typeof object.error !== "object") + throw TypeError(".google.longrunning.Operation.error: object expected"); + message.error = $root.google.rpc.Status.fromObject(object.error); + } + if (object.response != null) { + if (typeof object.response !== "object") + throw TypeError(".google.longrunning.Operation.response: object expected"); + message.response = $root.google.protobuf.Any.fromObject(object.response); + } + return message; + }; + + /** + * Creates a plain object from an Operation message. Also converts values to other types if specified. + * @function toObject + * @memberof google.longrunning.Operation + * @static + * @param {google.longrunning.Operation} message Operation + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Operation.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.name = ""; + object.metadata = null; + object.done = false; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.metadata != null && message.hasOwnProperty("metadata")) + object.metadata = $root.google.protobuf.Any.toObject(message.metadata, options); + if (message.done != null && message.hasOwnProperty("done")) + object.done = message.done; + if (message.error != null && message.hasOwnProperty("error")) { + object.error = $root.google.rpc.Status.toObject(message.error, options); + if (options.oneofs) + object.result = "error"; + } + if (message.response != null && message.hasOwnProperty("response")) { + object.response = $root.google.protobuf.Any.toObject(message.response, options); + if (options.oneofs) + object.result = "response"; + } + return object; + }; + + /** + * Converts this Operation to JSON. + * @function toJSON + * @memberof google.longrunning.Operation + * @instance + * @returns {Object.} JSON object + */ + Operation.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Operation + * @function getTypeUrl + * @memberof google.longrunning.Operation + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Operation.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.longrunning.Operation"; + }; + + return Operation; + })(); + + longrunning.GetOperationRequest = (function() { + + /** + * Properties of a GetOperationRequest. + * @memberof google.longrunning + * @interface IGetOperationRequest + * @property {string|null} [name] GetOperationRequest name + */ + + /** + * Constructs a new GetOperationRequest. + * @memberof google.longrunning + * @classdesc Represents a GetOperationRequest. + * @implements IGetOperationRequest + * @constructor + * @param {google.longrunning.IGetOperationRequest=} [properties] Properties to set + */ + function GetOperationRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * GetOperationRequest name. + * @member {string} name + * @memberof google.longrunning.GetOperationRequest + * @instance + */ + GetOperationRequest.prototype.name = ""; + + /** + * Creates a new GetOperationRequest instance using the specified properties. + * @function create + * @memberof google.longrunning.GetOperationRequest + * @static + * @param {google.longrunning.IGetOperationRequest=} [properties] Properties to set + * @returns {google.longrunning.GetOperationRequest} GetOperationRequest instance + */ + GetOperationRequest.create = function create(properties) { + return new GetOperationRequest(properties); + }; + + /** + * Encodes the specified GetOperationRequest message. Does not implicitly {@link google.longrunning.GetOperationRequest.verify|verify} messages. + * @function encode + * @memberof google.longrunning.GetOperationRequest + * @static + * @param {google.longrunning.IGetOperationRequest} message GetOperationRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GetOperationRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + return writer; + }; + + /** + * Encodes the specified GetOperationRequest message, length delimited. Does not implicitly {@link google.longrunning.GetOperationRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.longrunning.GetOperationRequest + * @static + * @param {google.longrunning.IGetOperationRequest} message GetOperationRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GetOperationRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a GetOperationRequest message from the specified reader or buffer. + * @function decode + * @memberof google.longrunning.GetOperationRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.longrunning.GetOperationRequest} GetOperationRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GetOperationRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.longrunning.GetOperationRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a GetOperationRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.longrunning.GetOperationRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.longrunning.GetOperationRequest} GetOperationRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GetOperationRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a GetOperationRequest message. + * @function verify + * @memberof google.longrunning.GetOperationRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + GetOperationRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + return null; + }; + + /** + * Creates a GetOperationRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.longrunning.GetOperationRequest + * @static + * @param {Object.} object Plain object + * @returns {google.longrunning.GetOperationRequest} GetOperationRequest + */ + GetOperationRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.longrunning.GetOperationRequest) + return object; + var message = new $root.google.longrunning.GetOperationRequest(); + if (object.name != null) + message.name = String(object.name); + return message; + }; + + /** + * Creates a plain object from a GetOperationRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.longrunning.GetOperationRequest + * @static + * @param {google.longrunning.GetOperationRequest} message GetOperationRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + GetOperationRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.name = ""; + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + return object; + }; + + /** + * Converts this GetOperationRequest to JSON. + * @function toJSON + * @memberof google.longrunning.GetOperationRequest + * @instance + * @returns {Object.} JSON object + */ + GetOperationRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for GetOperationRequest + * @function getTypeUrl + * @memberof google.longrunning.GetOperationRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + GetOperationRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.longrunning.GetOperationRequest"; + }; + + return GetOperationRequest; + })(); + + longrunning.ListOperationsRequest = (function() { + + /** + * Properties of a ListOperationsRequest. + * @memberof google.longrunning + * @interface IListOperationsRequest + * @property {string|null} [name] ListOperationsRequest name + * @property {string|null} [filter] ListOperationsRequest filter + * @property {number|null} [pageSize] ListOperationsRequest pageSize + * @property {string|null} [pageToken] ListOperationsRequest pageToken + */ + + /** + * Constructs a new ListOperationsRequest. + * @memberof google.longrunning + * @classdesc Represents a ListOperationsRequest. + * @implements IListOperationsRequest + * @constructor + * @param {google.longrunning.IListOperationsRequest=} [properties] Properties to set + */ + function ListOperationsRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ListOperationsRequest name. + * @member {string} name + * @memberof google.longrunning.ListOperationsRequest + * @instance + */ + ListOperationsRequest.prototype.name = ""; + + /** + * ListOperationsRequest filter. + * @member {string} filter + * @memberof google.longrunning.ListOperationsRequest + * @instance + */ + ListOperationsRequest.prototype.filter = ""; + + /** + * ListOperationsRequest pageSize. + * @member {number} pageSize + * @memberof google.longrunning.ListOperationsRequest + * @instance + */ + ListOperationsRequest.prototype.pageSize = 0; + + /** + * ListOperationsRequest pageToken. + * @member {string} pageToken + * @memberof google.longrunning.ListOperationsRequest + * @instance + */ + ListOperationsRequest.prototype.pageToken = ""; + + /** + * Creates a new ListOperationsRequest instance using the specified properties. + * @function create + * @memberof google.longrunning.ListOperationsRequest + * @static + * @param {google.longrunning.IListOperationsRequest=} [properties] Properties to set + * @returns {google.longrunning.ListOperationsRequest} ListOperationsRequest instance + */ + ListOperationsRequest.create = function create(properties) { + return new ListOperationsRequest(properties); + }; + + /** + * Encodes the specified ListOperationsRequest message. Does not implicitly {@link google.longrunning.ListOperationsRequest.verify|verify} messages. + * @function encode + * @memberof google.longrunning.ListOperationsRequest + * @static + * @param {google.longrunning.IListOperationsRequest} message ListOperationsRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListOperationsRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.filter != null && Object.hasOwnProperty.call(message, "filter")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.filter); + if (message.pageSize != null && Object.hasOwnProperty.call(message, "pageSize")) + writer.uint32(/* id 2, wireType 0 =*/16).int32(message.pageSize); + if (message.pageToken != null && Object.hasOwnProperty.call(message, "pageToken")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.pageToken); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.name); + return writer; + }; + + /** + * Encodes the specified ListOperationsRequest message, length delimited. Does not implicitly {@link google.longrunning.ListOperationsRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.longrunning.ListOperationsRequest + * @static + * @param {google.longrunning.IListOperationsRequest} message ListOperationsRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListOperationsRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ListOperationsRequest message from the specified reader or buffer. + * @function decode + * @memberof google.longrunning.ListOperationsRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.longrunning.ListOperationsRequest} ListOperationsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListOperationsRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.longrunning.ListOperationsRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 4: { + message.name = reader.string(); + break; + } + case 1: { + message.filter = reader.string(); + break; + } + case 2: { + message.pageSize = reader.int32(); + break; + } + case 3: { + message.pageToken = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ListOperationsRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.longrunning.ListOperationsRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.longrunning.ListOperationsRequest} ListOperationsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListOperationsRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ListOperationsRequest message. + * @function verify + * @memberof google.longrunning.ListOperationsRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ListOperationsRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.filter != null && message.hasOwnProperty("filter")) + if (!$util.isString(message.filter)) + return "filter: string expected"; + if (message.pageSize != null && message.hasOwnProperty("pageSize")) + if (!$util.isInteger(message.pageSize)) + return "pageSize: integer expected"; + if (message.pageToken != null && message.hasOwnProperty("pageToken")) + if (!$util.isString(message.pageToken)) + return "pageToken: string expected"; + return null; + }; + + /** + * Creates a ListOperationsRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.longrunning.ListOperationsRequest + * @static + * @param {Object.} object Plain object + * @returns {google.longrunning.ListOperationsRequest} ListOperationsRequest + */ + ListOperationsRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.longrunning.ListOperationsRequest) + return object; + var message = new $root.google.longrunning.ListOperationsRequest(); + if (object.name != null) + message.name = String(object.name); + if (object.filter != null) + message.filter = String(object.filter); + if (object.pageSize != null) + message.pageSize = object.pageSize | 0; + if (object.pageToken != null) + message.pageToken = String(object.pageToken); + return message; + }; + + /** + * Creates a plain object from a ListOperationsRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.longrunning.ListOperationsRequest + * @static + * @param {google.longrunning.ListOperationsRequest} message ListOperationsRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ListOperationsRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.filter = ""; + object.pageSize = 0; + object.pageToken = ""; + object.name = ""; + } + if (message.filter != null && message.hasOwnProperty("filter")) + object.filter = message.filter; + if (message.pageSize != null && message.hasOwnProperty("pageSize")) + object.pageSize = message.pageSize; + if (message.pageToken != null && message.hasOwnProperty("pageToken")) + object.pageToken = message.pageToken; + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + return object; + }; + + /** + * Converts this ListOperationsRequest to JSON. + * @function toJSON + * @memberof google.longrunning.ListOperationsRequest + * @instance + * @returns {Object.} JSON object + */ + ListOperationsRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ListOperationsRequest + * @function getTypeUrl + * @memberof google.longrunning.ListOperationsRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ListOperationsRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.longrunning.ListOperationsRequest"; + }; + + return ListOperationsRequest; + })(); + + longrunning.ListOperationsResponse = (function() { + + /** + * Properties of a ListOperationsResponse. + * @memberof google.longrunning + * @interface IListOperationsResponse + * @property {Array.|null} [operations] ListOperationsResponse operations + * @property {string|null} [nextPageToken] ListOperationsResponse nextPageToken + */ + + /** + * Constructs a new ListOperationsResponse. + * @memberof google.longrunning + * @classdesc Represents a ListOperationsResponse. + * @implements IListOperationsResponse + * @constructor + * @param {google.longrunning.IListOperationsResponse=} [properties] Properties to set + */ + function ListOperationsResponse(properties) { + this.operations = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ListOperationsResponse operations. + * @member {Array.} operations + * @memberof google.longrunning.ListOperationsResponse + * @instance + */ + ListOperationsResponse.prototype.operations = $util.emptyArray; + + /** + * ListOperationsResponse nextPageToken. + * @member {string} nextPageToken + * @memberof google.longrunning.ListOperationsResponse + * @instance + */ + ListOperationsResponse.prototype.nextPageToken = ""; + + /** + * Creates a new ListOperationsResponse instance using the specified properties. + * @function create + * @memberof google.longrunning.ListOperationsResponse + * @static + * @param {google.longrunning.IListOperationsResponse=} [properties] Properties to set + * @returns {google.longrunning.ListOperationsResponse} ListOperationsResponse instance + */ + ListOperationsResponse.create = function create(properties) { + return new ListOperationsResponse(properties); + }; + + /** + * Encodes the specified ListOperationsResponse message. Does not implicitly {@link google.longrunning.ListOperationsResponse.verify|verify} messages. + * @function encode + * @memberof google.longrunning.ListOperationsResponse + * @static + * @param {google.longrunning.IListOperationsResponse} message ListOperationsResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListOperationsResponse.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.operations != null && message.operations.length) + for (var i = 0; i < message.operations.length; ++i) + $root.google.longrunning.Operation.encode(message.operations[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.nextPageToken != null && Object.hasOwnProperty.call(message, "nextPageToken")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.nextPageToken); + return writer; + }; + + /** + * Encodes the specified ListOperationsResponse message, length delimited. Does not implicitly {@link google.longrunning.ListOperationsResponse.verify|verify} messages. + * @function encodeDelimited + * @memberof google.longrunning.ListOperationsResponse + * @static + * @param {google.longrunning.IListOperationsResponse} message ListOperationsResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListOperationsResponse.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a ListOperationsResponse message from the specified reader or buffer. + * @function decode + * @memberof google.longrunning.ListOperationsResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.longrunning.ListOperationsResponse} ListOperationsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListOperationsResponse.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.longrunning.ListOperationsResponse(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + if (!(message.operations && message.operations.length)) + message.operations = []; + message.operations.push($root.google.longrunning.Operation.decode(reader, reader.uint32())); + break; + } + case 2: { + message.nextPageToken = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a ListOperationsResponse message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.longrunning.ListOperationsResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.longrunning.ListOperationsResponse} ListOperationsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListOperationsResponse.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a ListOperationsResponse message. + * @function verify + * @memberof google.longrunning.ListOperationsResponse + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ListOperationsResponse.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.operations != null && message.hasOwnProperty("operations")) { + if (!Array.isArray(message.operations)) + return "operations: array expected"; + for (var i = 0; i < message.operations.length; ++i) { + var error = $root.google.longrunning.Operation.verify(message.operations[i]); + if (error) + return "operations." + error; + } + } + if (message.nextPageToken != null && message.hasOwnProperty("nextPageToken")) + if (!$util.isString(message.nextPageToken)) + return "nextPageToken: string expected"; + return null; + }; + + /** + * Creates a ListOperationsResponse message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.longrunning.ListOperationsResponse + * @static + * @param {Object.} object Plain object + * @returns {google.longrunning.ListOperationsResponse} ListOperationsResponse + */ + ListOperationsResponse.fromObject = function fromObject(object) { + if (object instanceof $root.google.longrunning.ListOperationsResponse) + return object; + var message = new $root.google.longrunning.ListOperationsResponse(); + if (object.operations) { + if (!Array.isArray(object.operations)) + throw TypeError(".google.longrunning.ListOperationsResponse.operations: array expected"); + message.operations = []; + for (var i = 0; i < object.operations.length; ++i) { + if (typeof object.operations[i] !== "object") + throw TypeError(".google.longrunning.ListOperationsResponse.operations: object expected"); + message.operations[i] = $root.google.longrunning.Operation.fromObject(object.operations[i]); + } + } + if (object.nextPageToken != null) + message.nextPageToken = String(object.nextPageToken); + return message; + }; + + /** + * Creates a plain object from a ListOperationsResponse message. Also converts values to other types if specified. + * @function toObject + * @memberof google.longrunning.ListOperationsResponse + * @static + * @param {google.longrunning.ListOperationsResponse} message ListOperationsResponse + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + ListOperationsResponse.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.operations = []; + if (options.defaults) + object.nextPageToken = ""; + if (message.operations && message.operations.length) { + object.operations = []; + for (var j = 0; j < message.operations.length; ++j) + object.operations[j] = $root.google.longrunning.Operation.toObject(message.operations[j], options); + } + if (message.nextPageToken != null && message.hasOwnProperty("nextPageToken")) + object.nextPageToken = message.nextPageToken; + return object; + }; + + /** + * Converts this ListOperationsResponse to JSON. + * @function toJSON + * @memberof google.longrunning.ListOperationsResponse + * @instance + * @returns {Object.} JSON object + */ + ListOperationsResponse.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for ListOperationsResponse + * @function getTypeUrl + * @memberof google.longrunning.ListOperationsResponse + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + ListOperationsResponse.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.longrunning.ListOperationsResponse"; + }; + + return ListOperationsResponse; + })(); + + longrunning.CancelOperationRequest = (function() { + + /** + * Properties of a CancelOperationRequest. + * @memberof google.longrunning + * @interface ICancelOperationRequest + * @property {string|null} [name] CancelOperationRequest name + */ + + /** + * Constructs a new CancelOperationRequest. + * @memberof google.longrunning + * @classdesc Represents a CancelOperationRequest. + * @implements ICancelOperationRequest + * @constructor + * @param {google.longrunning.ICancelOperationRequest=} [properties] Properties to set + */ + function CancelOperationRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * CancelOperationRequest name. + * @member {string} name + * @memberof google.longrunning.CancelOperationRequest + * @instance + */ + CancelOperationRequest.prototype.name = ""; + + /** + * Creates a new CancelOperationRequest instance using the specified properties. + * @function create + * @memberof google.longrunning.CancelOperationRequest + * @static + * @param {google.longrunning.ICancelOperationRequest=} [properties] Properties to set + * @returns {google.longrunning.CancelOperationRequest} CancelOperationRequest instance + */ + CancelOperationRequest.create = function create(properties) { + return new CancelOperationRequest(properties); + }; + + /** + * Encodes the specified CancelOperationRequest message. Does not implicitly {@link google.longrunning.CancelOperationRequest.verify|verify} messages. + * @function encode + * @memberof google.longrunning.CancelOperationRequest + * @static + * @param {google.longrunning.ICancelOperationRequest} message CancelOperationRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + CancelOperationRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + return writer; + }; + + /** + * Encodes the specified CancelOperationRequest message, length delimited. Does not implicitly {@link google.longrunning.CancelOperationRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.longrunning.CancelOperationRequest + * @static + * @param {google.longrunning.ICancelOperationRequest} message CancelOperationRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + CancelOperationRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a CancelOperationRequest message from the specified reader or buffer. + * @function decode + * @memberof google.longrunning.CancelOperationRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.longrunning.CancelOperationRequest} CancelOperationRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + CancelOperationRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.longrunning.CancelOperationRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a CancelOperationRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.longrunning.CancelOperationRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.longrunning.CancelOperationRequest} CancelOperationRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + CancelOperationRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a CancelOperationRequest message. + * @function verify + * @memberof google.longrunning.CancelOperationRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + CancelOperationRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + return null; + }; + + /** + * Creates a CancelOperationRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.longrunning.CancelOperationRequest + * @static + * @param {Object.} object Plain object + * @returns {google.longrunning.CancelOperationRequest} CancelOperationRequest + */ + CancelOperationRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.longrunning.CancelOperationRequest) + return object; + var message = new $root.google.longrunning.CancelOperationRequest(); + if (object.name != null) + message.name = String(object.name); + return message; + }; + + /** + * Creates a plain object from a CancelOperationRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.longrunning.CancelOperationRequest + * @static + * @param {google.longrunning.CancelOperationRequest} message CancelOperationRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + CancelOperationRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.name = ""; + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + return object; + }; + + /** + * Converts this CancelOperationRequest to JSON. + * @function toJSON + * @memberof google.longrunning.CancelOperationRequest + * @instance + * @returns {Object.} JSON object + */ + CancelOperationRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for CancelOperationRequest + * @function getTypeUrl + * @memberof google.longrunning.CancelOperationRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + CancelOperationRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.longrunning.CancelOperationRequest"; + }; + + return CancelOperationRequest; + })(); + + longrunning.DeleteOperationRequest = (function() { + + /** + * Properties of a DeleteOperationRequest. + * @memberof google.longrunning + * @interface IDeleteOperationRequest + * @property {string|null} [name] DeleteOperationRequest name + */ + + /** + * Constructs a new DeleteOperationRequest. + * @memberof google.longrunning + * @classdesc Represents a DeleteOperationRequest. + * @implements IDeleteOperationRequest + * @constructor + * @param {google.longrunning.IDeleteOperationRequest=} [properties] Properties to set + */ + function DeleteOperationRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * DeleteOperationRequest name. + * @member {string} name + * @memberof google.longrunning.DeleteOperationRequest + * @instance + */ + DeleteOperationRequest.prototype.name = ""; + + /** + * Creates a new DeleteOperationRequest instance using the specified properties. + * @function create + * @memberof google.longrunning.DeleteOperationRequest + * @static + * @param {google.longrunning.IDeleteOperationRequest=} [properties] Properties to set + * @returns {google.longrunning.DeleteOperationRequest} DeleteOperationRequest instance + */ + DeleteOperationRequest.create = function create(properties) { + return new DeleteOperationRequest(properties); + }; + + /** + * Encodes the specified DeleteOperationRequest message. Does not implicitly {@link google.longrunning.DeleteOperationRequest.verify|verify} messages. + * @function encode + * @memberof google.longrunning.DeleteOperationRequest + * @static + * @param {google.longrunning.IDeleteOperationRequest} message DeleteOperationRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DeleteOperationRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + return writer; + }; + + /** + * Encodes the specified DeleteOperationRequest message, length delimited. Does not implicitly {@link google.longrunning.DeleteOperationRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.longrunning.DeleteOperationRequest + * @static + * @param {google.longrunning.IDeleteOperationRequest} message DeleteOperationRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + DeleteOperationRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a DeleteOperationRequest message from the specified reader or buffer. + * @function decode + * @memberof google.longrunning.DeleteOperationRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.longrunning.DeleteOperationRequest} DeleteOperationRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DeleteOperationRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.longrunning.DeleteOperationRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a DeleteOperationRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.longrunning.DeleteOperationRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.longrunning.DeleteOperationRequest} DeleteOperationRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + DeleteOperationRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a DeleteOperationRequest message. + * @function verify + * @memberof google.longrunning.DeleteOperationRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + DeleteOperationRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + return null; + }; + + /** + * Creates a DeleteOperationRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.longrunning.DeleteOperationRequest + * @static + * @param {Object.} object Plain object + * @returns {google.longrunning.DeleteOperationRequest} DeleteOperationRequest + */ + DeleteOperationRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.longrunning.DeleteOperationRequest) + return object; + var message = new $root.google.longrunning.DeleteOperationRequest(); + if (object.name != null) + message.name = String(object.name); + return message; + }; + + /** + * Creates a plain object from a DeleteOperationRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.longrunning.DeleteOperationRequest + * @static + * @param {google.longrunning.DeleteOperationRequest} message DeleteOperationRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + DeleteOperationRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) + object.name = ""; + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + return object; + }; + + /** + * Converts this DeleteOperationRequest to JSON. + * @function toJSON + * @memberof google.longrunning.DeleteOperationRequest + * @instance + * @returns {Object.} JSON object + */ + DeleteOperationRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for DeleteOperationRequest + * @function getTypeUrl + * @memberof google.longrunning.DeleteOperationRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + DeleteOperationRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.longrunning.DeleteOperationRequest"; + }; + + return DeleteOperationRequest; + })(); + + longrunning.WaitOperationRequest = (function() { + + /** + * Properties of a WaitOperationRequest. + * @memberof google.longrunning + * @interface IWaitOperationRequest + * @property {string|null} [name] WaitOperationRequest name + * @property {google.protobuf.IDuration|null} [timeout] WaitOperationRequest timeout + */ + + /** + * Constructs a new WaitOperationRequest. + * @memberof google.longrunning + * @classdesc Represents a WaitOperationRequest. + * @implements IWaitOperationRequest + * @constructor + * @param {google.longrunning.IWaitOperationRequest=} [properties] Properties to set + */ + function WaitOperationRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * WaitOperationRequest name. + * @member {string} name + * @memberof google.longrunning.WaitOperationRequest + * @instance + */ + WaitOperationRequest.prototype.name = ""; + + /** + * WaitOperationRequest timeout. + * @member {google.protobuf.IDuration|null|undefined} timeout + * @memberof google.longrunning.WaitOperationRequest + * @instance + */ + WaitOperationRequest.prototype.timeout = null; + + /** + * Creates a new WaitOperationRequest instance using the specified properties. + * @function create + * @memberof google.longrunning.WaitOperationRequest + * @static + * @param {google.longrunning.IWaitOperationRequest=} [properties] Properties to set + * @returns {google.longrunning.WaitOperationRequest} WaitOperationRequest instance + */ + WaitOperationRequest.create = function create(properties) { + return new WaitOperationRequest(properties); + }; + + /** + * Encodes the specified WaitOperationRequest message. Does not implicitly {@link google.longrunning.WaitOperationRequest.verify|verify} messages. + * @function encode + * @memberof google.longrunning.WaitOperationRequest + * @static + * @param {google.longrunning.IWaitOperationRequest} message WaitOperationRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + WaitOperationRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && Object.hasOwnProperty.call(message, "name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.timeout != null && Object.hasOwnProperty.call(message, "timeout")) + $root.google.protobuf.Duration.encode(message.timeout, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified WaitOperationRequest message, length delimited. Does not implicitly {@link google.longrunning.WaitOperationRequest.verify|verify} messages. + * @function encodeDelimited + * @memberof google.longrunning.WaitOperationRequest + * @static + * @param {google.longrunning.IWaitOperationRequest} message WaitOperationRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + WaitOperationRequest.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a WaitOperationRequest message from the specified reader or buffer. + * @function decode + * @memberof google.longrunning.WaitOperationRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.longrunning.WaitOperationRequest} WaitOperationRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + WaitOperationRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.longrunning.WaitOperationRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.name = reader.string(); + break; + } + case 2: { + message.timeout = $root.google.protobuf.Duration.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a WaitOperationRequest message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.longrunning.WaitOperationRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.longrunning.WaitOperationRequest} WaitOperationRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + WaitOperationRequest.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a WaitOperationRequest message. + * @function verify + * @memberof google.longrunning.WaitOperationRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + WaitOperationRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.timeout != null && message.hasOwnProperty("timeout")) { + var error = $root.google.protobuf.Duration.verify(message.timeout); + if (error) + return "timeout." + error; + } + return null; + }; + + /** + * Creates a WaitOperationRequest message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.longrunning.WaitOperationRequest + * @static + * @param {Object.} object Plain object + * @returns {google.longrunning.WaitOperationRequest} WaitOperationRequest + */ + WaitOperationRequest.fromObject = function fromObject(object) { + if (object instanceof $root.google.longrunning.WaitOperationRequest) + return object; + var message = new $root.google.longrunning.WaitOperationRequest(); + if (object.name != null) + message.name = String(object.name); + if (object.timeout != null) { + if (typeof object.timeout !== "object") + throw TypeError(".google.longrunning.WaitOperationRequest.timeout: object expected"); + message.timeout = $root.google.protobuf.Duration.fromObject(object.timeout); + } + return message; + }; + + /** + * Creates a plain object from a WaitOperationRequest message. Also converts values to other types if specified. + * @function toObject + * @memberof google.longrunning.WaitOperationRequest + * @static + * @param {google.longrunning.WaitOperationRequest} message WaitOperationRequest + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + WaitOperationRequest.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.name = ""; + object.timeout = null; + } + if (message.name != null && message.hasOwnProperty("name")) + object.name = message.name; + if (message.timeout != null && message.hasOwnProperty("timeout")) + object.timeout = $root.google.protobuf.Duration.toObject(message.timeout, options); + return object; + }; + + /** + * Converts this WaitOperationRequest to JSON. + * @function toJSON + * @memberof google.longrunning.WaitOperationRequest + * @instance + * @returns {Object.} JSON object + */ + WaitOperationRequest.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for WaitOperationRequest + * @function getTypeUrl + * @memberof google.longrunning.WaitOperationRequest + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + WaitOperationRequest.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.longrunning.WaitOperationRequest"; + }; + + return WaitOperationRequest; + })(); + + longrunning.OperationInfo = (function() { + + /** + * Properties of an OperationInfo. + * @memberof google.longrunning + * @interface IOperationInfo + * @property {string|null} [responseType] OperationInfo responseType + * @property {string|null} [metadataType] OperationInfo metadataType + */ + + /** + * Constructs a new OperationInfo. + * @memberof google.longrunning + * @classdesc Represents an OperationInfo. + * @implements IOperationInfo + * @constructor + * @param {google.longrunning.IOperationInfo=} [properties] Properties to set + */ + function OperationInfo(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * OperationInfo responseType. + * @member {string} responseType + * @memberof google.longrunning.OperationInfo + * @instance + */ + OperationInfo.prototype.responseType = ""; + + /** + * OperationInfo metadataType. + * @member {string} metadataType + * @memberof google.longrunning.OperationInfo + * @instance + */ + OperationInfo.prototype.metadataType = ""; + + /** + * Creates a new OperationInfo instance using the specified properties. + * @function create + * @memberof google.longrunning.OperationInfo + * @static + * @param {google.longrunning.IOperationInfo=} [properties] Properties to set + * @returns {google.longrunning.OperationInfo} OperationInfo instance + */ + OperationInfo.create = function create(properties) { + return new OperationInfo(properties); + }; + + /** + * Encodes the specified OperationInfo message. Does not implicitly {@link google.longrunning.OperationInfo.verify|verify} messages. + * @function encode + * @memberof google.longrunning.OperationInfo + * @static + * @param {google.longrunning.IOperationInfo} message OperationInfo message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + OperationInfo.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.responseType != null && Object.hasOwnProperty.call(message, "responseType")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.responseType); + if (message.metadataType != null && Object.hasOwnProperty.call(message, "metadataType")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.metadataType); + return writer; + }; + + /** + * Encodes the specified OperationInfo message, length delimited. Does not implicitly {@link google.longrunning.OperationInfo.verify|verify} messages. + * @function encodeDelimited + * @memberof google.longrunning.OperationInfo + * @static + * @param {google.longrunning.IOperationInfo} message OperationInfo message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + OperationInfo.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an OperationInfo message from the specified reader or buffer. + * @function decode + * @memberof google.longrunning.OperationInfo + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.longrunning.OperationInfo} OperationInfo + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + OperationInfo.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.longrunning.OperationInfo(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.responseType = reader.string(); + break; + } + case 2: { + message.metadataType = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an OperationInfo message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.longrunning.OperationInfo + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.longrunning.OperationInfo} OperationInfo + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + OperationInfo.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an OperationInfo message. + * @function verify + * @memberof google.longrunning.OperationInfo + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + OperationInfo.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.responseType != null && message.hasOwnProperty("responseType")) + if (!$util.isString(message.responseType)) + return "responseType: string expected"; + if (message.metadataType != null && message.hasOwnProperty("metadataType")) + if (!$util.isString(message.metadataType)) + return "metadataType: string expected"; + return null; + }; + + /** + * Creates an OperationInfo message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.longrunning.OperationInfo + * @static + * @param {Object.} object Plain object + * @returns {google.longrunning.OperationInfo} OperationInfo + */ + OperationInfo.fromObject = function fromObject(object) { + if (object instanceof $root.google.longrunning.OperationInfo) + return object; + var message = new $root.google.longrunning.OperationInfo(); + if (object.responseType != null) + message.responseType = String(object.responseType); + if (object.metadataType != null) + message.metadataType = String(object.metadataType); + return message; + }; + + /** + * Creates a plain object from an OperationInfo message. Also converts values to other types if specified. + * @function toObject + * @memberof google.longrunning.OperationInfo + * @static + * @param {google.longrunning.OperationInfo} message OperationInfo + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + OperationInfo.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.responseType = ""; + object.metadataType = ""; + } + if (message.responseType != null && message.hasOwnProperty("responseType")) + object.responseType = message.responseType; + if (message.metadataType != null && message.hasOwnProperty("metadataType")) + object.metadataType = message.metadataType; + return object; + }; + + /** + * Converts this OperationInfo to JSON. + * @function toJSON + * @memberof google.longrunning.OperationInfo + * @instance + * @returns {Object.} JSON object + */ + OperationInfo.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for OperationInfo + * @function getTypeUrl + * @memberof google.longrunning.OperationInfo + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + OperationInfo.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.longrunning.OperationInfo"; + }; + + return OperationInfo; + })(); + + return longrunning; + })(); + + google.rpc = (function() { + + /** + * Namespace rpc. + * @memberof google + * @namespace + */ + var rpc = {}; + + rpc.Status = (function() { + + /** + * Properties of a Status. + * @memberof google.rpc + * @interface IStatus + * @property {number|null} [code] Status code + * @property {string|null} [message] Status message + * @property {Array.|null} [details] Status details + */ + + /** + * Constructs a new Status. + * @memberof google.rpc + * @classdesc Represents a Status. + * @implements IStatus + * @constructor + * @param {google.rpc.IStatus=} [properties] Properties to set + */ + function Status(properties) { + this.details = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Status code. + * @member {number} code + * @memberof google.rpc.Status + * @instance + */ + Status.prototype.code = 0; + + /** + * Status message. + * @member {string} message + * @memberof google.rpc.Status + * @instance + */ + Status.prototype.message = ""; + + /** + * Status details. + * @member {Array.} details + * @memberof google.rpc.Status + * @instance + */ + Status.prototype.details = $util.emptyArray; + + /** + * Creates a new Status instance using the specified properties. + * @function create + * @memberof google.rpc.Status + * @static + * @param {google.rpc.IStatus=} [properties] Properties to set + * @returns {google.rpc.Status} Status instance + */ + Status.create = function create(properties) { + return new Status(properties); + }; + + /** + * Encodes the specified Status message. Does not implicitly {@link google.rpc.Status.verify|verify} messages. + * @function encode + * @memberof google.rpc.Status + * @static + * @param {google.rpc.IStatus} message Status message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Status.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.code != null && Object.hasOwnProperty.call(message, "code")) + writer.uint32(/* id 1, wireType 0 =*/8).int32(message.code); + if (message.message != null && Object.hasOwnProperty.call(message, "message")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.message); + if (message.details != null && message.details.length) + for (var i = 0; i < message.details.length; ++i) + $root.google.protobuf.Any.encode(message.details[i], writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified Status message, length delimited. Does not implicitly {@link google.rpc.Status.verify|verify} messages. + * @function encodeDelimited + * @memberof google.rpc.Status + * @static + * @param {google.rpc.IStatus} message Status message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Status.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a Status message from the specified reader or buffer. + * @function decode + * @memberof google.rpc.Status + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.rpc.Status} Status + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Status.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.rpc.Status(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.code = reader.int32(); + break; + } + case 2: { + message.message = reader.string(); + break; + } + case 3: { + if (!(message.details && message.details.length)) + message.details = []; + message.details.push($root.google.protobuf.Any.decode(reader, reader.uint32())); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a Status message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.rpc.Status + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.rpc.Status} Status + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Status.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a Status message. + * @function verify + * @memberof google.rpc.Status + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Status.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.code != null && message.hasOwnProperty("code")) + if (!$util.isInteger(message.code)) + return "code: integer expected"; + if (message.message != null && message.hasOwnProperty("message")) + if (!$util.isString(message.message)) + return "message: string expected"; + if (message.details != null && message.hasOwnProperty("details")) { + if (!Array.isArray(message.details)) + return "details: array expected"; + for (var i = 0; i < message.details.length; ++i) { + var error = $root.google.protobuf.Any.verify(message.details[i]); + if (error) + return "details." + error; + } + } + return null; + }; + + /** + * Creates a Status message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.rpc.Status + * @static + * @param {Object.} object Plain object + * @returns {google.rpc.Status} Status + */ + Status.fromObject = function fromObject(object) { + if (object instanceof $root.google.rpc.Status) + return object; + var message = new $root.google.rpc.Status(); + if (object.code != null) + message.code = object.code | 0; + if (object.message != null) + message.message = String(object.message); + if (object.details) { + if (!Array.isArray(object.details)) + throw TypeError(".google.rpc.Status.details: array expected"); + message.details = []; + for (var i = 0; i < object.details.length; ++i) { + if (typeof object.details[i] !== "object") + throw TypeError(".google.rpc.Status.details: object expected"); + message.details[i] = $root.google.protobuf.Any.fromObject(object.details[i]); + } + } + return message; + }; + + /** + * Creates a plain object from a Status message. Also converts values to other types if specified. + * @function toObject + * @memberof google.rpc.Status + * @static + * @param {google.rpc.Status} message Status + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Status.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.arrays || options.defaults) + object.details = []; + if (options.defaults) { + object.code = 0; + object.message = ""; + } + if (message.code != null && message.hasOwnProperty("code")) + object.code = message.code; + if (message.message != null && message.hasOwnProperty("message")) + object.message = message.message; + if (message.details && message.details.length) { + object.details = []; + for (var j = 0; j < message.details.length; ++j) + object.details[j] = $root.google.protobuf.Any.toObject(message.details[j], options); + } + return object; + }; + + /** + * Converts this Status to JSON. + * @function toJSON + * @memberof google.rpc.Status + * @instance + * @returns {Object.} JSON object + */ + Status.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Status + * @function getTypeUrl + * @memberof google.rpc.Status + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Status.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.rpc.Status"; + }; + + return Status; + })(); + + return rpc; + })(); + + return google; + })(); + + return $root; +}); diff --git a/packages/google-cloud-edgenetwork/protos/protos.json b/packages/google-cloud-edgenetwork/protos/protos.json new file mode 100644 index 000000000000..70d6a8d7c9ad --- /dev/null +++ b/packages/google-cloud-edgenetwork/protos/protos.json @@ -0,0 +1,3814 @@ +{ + "nested": { + "google": { + "nested": { + "cloud": { + "nested": { + "edgenetwork": { + "nested": { + "v1": { + "options": { + "go_package": "cloud.google.com/go/edgenetwork/apiv1/edgenetworkpb;edgenetworkpb", + "java_multiple_files": true, + "java_outer_classname": "ServiceProto", + "java_package": "google.cloud.edgenetwork.v1" + }, + "nested": { + "ResourceState": { + "values": { + "STATE_UNKNOWN": 0, + "STATE_PENDING": 1, + "STATE_PROVISIONING": 2, + "STATE_RUNNING": 3, + "STATE_SUSPENDED": 4, + "STATE_DELETING": 5 + } + }, + "Zone": { + "options": { + "(google.api.resource).type": "edgenetwork.googleapis.com/Zone", + "(google.api.resource).pattern": "projects/{project}/locations/{location}/zones/{zone}" + }, + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "createTime": { + "type": "google.protobuf.Timestamp", + "id": 2, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "updateTime": { + "type": "google.protobuf.Timestamp", + "id": 3, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "labels": { + "keyType": "string", + "type": "string", + "id": 4 + }, + "layoutName": { + "type": "string", + "id": 5 + } + } + }, + "Network": { + "options": { + "(google.api.resource).type": "edgenetwork.googleapis.com/Network", + "(google.api.resource).pattern": "projects/{project}/locations/{location}/zones/{zone}/networks/{network}" + }, + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "createTime": { + "type": "google.protobuf.Timestamp", + "id": 2, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "updateTime": { + "type": "google.protobuf.Timestamp", + "id": 3, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "labels": { + "keyType": "string", + "type": "string", + "id": 4 + }, + "description": { + "type": "string", + "id": 5, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + }, + "mtu": { + "type": "int32", + "id": 6 + } + } + }, + "Subnet": { + "options": { + "(google.api.resource).type": "edgenetwork.googleapis.com/Subnet", + "(google.api.resource).pattern": "projects/{project}/locations/{location}/zones/{zone}/subnets/{subnet}" + }, + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "createTime": { + "type": "google.protobuf.Timestamp", + "id": 2, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "updateTime": { + "type": "google.protobuf.Timestamp", + "id": 3, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "labels": { + "keyType": "string", + "type": "string", + "id": 4 + }, + "description": { + "type": "string", + "id": 5, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + }, + "network": { + "type": "string", + "id": 6, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Network" + } + }, + "ipv4Cidr": { + "rule": "repeated", + "type": "string", + "id": 7 + }, + "ipv6Cidr": { + "rule": "repeated", + "type": "string", + "id": 8 + }, + "vlanId": { + "type": "int32", + "id": 9, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + }, + "state": { + "type": "ResourceState", + "id": 10, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + } + } + }, + "Interconnect": { + "options": { + "(google.api.resource).type": "edgenetwork.googleapis.com/Interconnect", + "(google.api.resource).pattern": "projects/{project}/locations/{location}/zones/{zone}/interconnects/{interconnect}" + }, + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "createTime": { + "type": "google.protobuf.Timestamp", + "id": 2, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "updateTime": { + "type": "google.protobuf.Timestamp", + "id": 3, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "labels": { + "keyType": "string", + "type": "string", + "id": 4 + }, + "description": { + "type": "string", + "id": 5, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + }, + "interconnectType": { + "type": "InterconnectType", + "id": 6, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + }, + "uuid": { + "type": "string", + "id": 7, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "deviceCloudResourceName": { + "type": "string", + "id": 8, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "physicalPorts": { + "rule": "repeated", + "type": "string", + "id": 9, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + } + }, + "nested": { + "InterconnectType": { + "values": { + "INTERCONNECT_TYPE_UNSPECIFIED": 0, + "DEDICATED": 1 + } + } + } + }, + "InterconnectAttachment": { + "options": { + "(google.api.resource).type": "edgenetwork.googleapis.com/InterconnectAttachment", + "(google.api.resource).pattern": "projects/{project}/locations/{location}/zones/{zone}/interconnectAttachments/{interconnect_attachment}" + }, + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "createTime": { + "type": "google.protobuf.Timestamp", + "id": 2, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "updateTime": { + "type": "google.protobuf.Timestamp", + "id": 3, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "labels": { + "keyType": "string", + "type": "string", + "id": 4 + }, + "description": { + "type": "string", + "id": 5, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + }, + "interconnect": { + "type": "string", + "id": 6, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Interconnect" + } + }, + "network": { + "type": "string", + "id": 11, + "options": { + "(google.api.field_behavior)": "OPTIONAL", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Network" + } + }, + "vlanId": { + "type": "int32", + "id": 8, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "mtu": { + "type": "int32", + "id": 9 + }, + "state": { + "type": "ResourceState", + "id": 10, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + } + } + }, + "Router": { + "options": { + "(google.api.resource).type": "edgenetwork.googleapis.com/Router", + "(google.api.resource).pattern": "projects/{project}/locations/{location}/zones/{zone}/routers/{router}" + }, + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "createTime": { + "type": "google.protobuf.Timestamp", + "id": 2, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "updateTime": { + "type": "google.protobuf.Timestamp", + "id": 3, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "labels": { + "keyType": "string", + "type": "string", + "id": 4 + }, + "description": { + "type": "string", + "id": 5, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + }, + "network": { + "type": "string", + "id": 6, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Network" + } + }, + "interface": { + "rule": "repeated", + "type": "Interface", + "id": 7 + }, + "bgpPeer": { + "rule": "repeated", + "type": "BgpPeer", + "id": 8 + }, + "bgp": { + "type": "Bgp", + "id": 9 + }, + "state": { + "type": "ResourceState", + "id": 10, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "routeAdvertisements": { + "rule": "repeated", + "type": "string", + "id": 11, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + } + }, + "nested": { + "Interface": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "ipv4Cidr": { + "type": "string", + "id": 3 + }, + "ipv6Cidr": { + "type": "string", + "id": 6 + }, + "linkedInterconnectAttachment": { + "type": "string", + "id": 2 + }, + "subnetwork": { + "type": "string", + "id": 4 + }, + "loopbackIpAddresses": { + "rule": "repeated", + "type": "string", + "id": 5 + } + } + }, + "BgpPeer": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "interface": { + "type": "string", + "id": 2 + }, + "interfaceIpv4Cidr": { + "type": "string", + "id": 3 + }, + "interfaceIpv6Cidr": { + "type": "string", + "id": 7 + }, + "peerIpv4Cidr": { + "type": "string", + "id": 4 + }, + "peerIpv6Cidr": { + "type": "string", + "id": 6 + }, + "peerAsn": { + "type": "uint32", + "id": 5 + }, + "localAsn": { + "type": "uint32", + "id": 8, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + } + } + }, + "Bgp": { + "fields": { + "asn": { + "type": "uint32", + "id": 1 + }, + "keepaliveIntervalInSeconds": { + "type": "uint32", + "id": 2 + } + } + } + } + }, + "LinkLayerAddress": { + "fields": { + "macAddress": { + "type": "string", + "id": 1 + }, + "ipAddress": { + "type": "string", + "id": 2 + } + } + }, + "SubnetStatus": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "macAddress": { + "type": "string", + "id": 2 + }, + "linkLayerAddresses": { + "rule": "repeated", + "type": "LinkLayerAddress", + "id": 3 + } + } + }, + "InterconnectDiagnostics": { + "fields": { + "macAddress": { + "type": "string", + "id": 1 + }, + "linkLayerAddresses": { + "rule": "repeated", + "type": "LinkLayerAddress", + "id": 2 + }, + "links": { + "rule": "repeated", + "type": "LinkStatus", + "id": 3 + } + }, + "nested": { + "LinkStatus": { + "fields": { + "circuitId": { + "type": "string", + "id": 1 + }, + "lacpStatus": { + "type": "LinkLACPStatus", + "id": 2 + }, + "lldpStatuses": { + "rule": "repeated", + "type": "LinkLLDPStatus", + "id": 3 + }, + "packetCounts": { + "type": "PacketCounts", + "id": 4 + } + } + }, + "PacketCounts": { + "fields": { + "inboundUnicast": { + "type": "int64", + "id": 1 + }, + "inboundErrors": { + "type": "int64", + "id": 2 + }, + "inboundDiscards": { + "type": "int64", + "id": 3 + }, + "outboundUnicast": { + "type": "int64", + "id": 4 + }, + "outboundErrors": { + "type": "int64", + "id": 5 + }, + "outboundDiscards": { + "type": "int64", + "id": 6 + } + } + }, + "LinkLACPStatus": { + "fields": { + "state": { + "type": "State", + "id": 1 + }, + "googleSystemId": { + "type": "string", + "id": 2 + }, + "neighborSystemId": { + "type": "string", + "id": 3 + }, + "aggregatable": { + "type": "bool", + "id": 4 + }, + "collecting": { + "type": "bool", + "id": 5 + }, + "distributing": { + "type": "bool", + "id": 6 + } + }, + "nested": { + "State": { + "values": { + "UNKNOWN": 0, + "ACTIVE": 1, + "DETACHED": 2 + } + } + } + }, + "LinkLLDPStatus": { + "fields": { + "peerSystemName": { + "type": "string", + "id": 1 + }, + "peerSystemDescription": { + "type": "string", + "id": 2 + }, + "peerChassisId": { + "type": "string", + "id": 3 + }, + "peerChassisIdType": { + "type": "string", + "id": 4 + }, + "peerPortId": { + "type": "string", + "id": 5 + }, + "peerPortIdType": { + "type": "string", + "id": 6 + } + } + } + } + }, + "RouterStatus": { + "fields": { + "network": { + "type": "string", + "id": 1, + "options": { + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Network" + } + }, + "bgpPeerStatus": { + "rule": "repeated", + "type": "BgpPeerStatus", + "id": 2 + } + }, + "nested": { + "BgpPeerStatus": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "ipAddress": { + "type": "string", + "id": 2 + }, + "peerIpAddress": { + "type": "string", + "id": 3 + }, + "status": { + "type": "BgpStatus", + "id": 4 + }, + "state": { + "type": "string", + "id": 5 + }, + "uptime": { + "type": "string", + "id": 6 + }, + "uptimeSeconds": { + "type": "int64", + "id": 7 + }, + "prefixCounter": { + "type": "PrefixCounter", + "id": 8 + } + }, + "nested": { + "BgpStatus": { + "values": { + "UNKNOWN": 0, + "UP": 1, + "DOWN": 2 + } + } + } + }, + "PrefixCounter": { + "fields": { + "advertised": { + "type": "int64", + "id": 1 + }, + "denied": { + "type": "int64", + "id": 2 + }, + "received": { + "type": "int64", + "id": 3 + }, + "sent": { + "type": "int64", + "id": 4 + }, + "suppressed": { + "type": "int64", + "id": 5 + }, + "withdrawn": { + "type": "int64", + "id": 6 + } + } + } + } + }, + "EdgeNetwork": { + "options": { + "(google.api.default_host)": "edgenetwork.googleapis.com", + "(google.api.oauth_scopes)": "https://www.googleapis.com/auth/cloud-platform" + }, + "methods": { + "InitializeZone": { + "requestType": "InitializeZoneRequest", + "responseType": "InitializeZoneResponse", + "options": { + "(google.api.http).post": "/v1/{name=projects/*/locations/*/zones/*}:initialize", + "(google.api.http).body": "*", + "(google.api.method_signature)": "name" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "post": "/v1/{name=projects/*/locations/*/zones/*}:initialize", + "body": "*" + } + }, + { + "(google.api.method_signature)": "name" + } + ] + }, + "ListZones": { + "requestType": "ListZonesRequest", + "responseType": "ListZonesResponse", + "options": { + "(google.api.http).get": "/v1/{parent=projects/*/locations/*}/zones", + "(google.api.method_signature)": "parent" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{parent=projects/*/locations/*}/zones" + } + }, + { + "(google.api.method_signature)": "parent" + } + ] + }, + "GetZone": { + "requestType": "GetZoneRequest", + "responseType": "Zone", + "options": { + "(google.api.http).get": "/v1/{name=projects/*/locations/*/zones/*}", + "(google.api.method_signature)": "name" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{name=projects/*/locations/*/zones/*}" + } + }, + { + "(google.api.method_signature)": "name" + } + ] + }, + "ListNetworks": { + "requestType": "ListNetworksRequest", + "responseType": "ListNetworksResponse", + "options": { + "(google.api.http).get": "/v1/{parent=projects/*/locations/*/zones/*}/networks", + "(google.api.method_signature)": "parent" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{parent=projects/*/locations/*/zones/*}/networks" + } + }, + { + "(google.api.method_signature)": "parent" + } + ] + }, + "GetNetwork": { + "requestType": "GetNetworkRequest", + "responseType": "Network", + "options": { + "(google.api.http).get": "/v1/{name=projects/*/locations/*/zones/*/networks/*}", + "(google.api.method_signature)": "name" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{name=projects/*/locations/*/zones/*/networks/*}" + } + }, + { + "(google.api.method_signature)": "name" + } + ] + }, + "DiagnoseNetwork": { + "requestType": "DiagnoseNetworkRequest", + "responseType": "DiagnoseNetworkResponse", + "options": { + "(google.api.http).get": "/v1/{name=projects/*/locations/*/zones/*/networks/*}:diagnose", + "(google.api.method_signature)": "name" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{name=projects/*/locations/*/zones/*/networks/*}:diagnose" + } + }, + { + "(google.api.method_signature)": "name" + } + ] + }, + "CreateNetwork": { + "requestType": "CreateNetworkRequest", + "responseType": "google.longrunning.Operation", + "options": { + "(google.api.http).post": "/v1/{parent=projects/*/locations/*/zones/*}/networks", + "(google.api.http).body": "network", + "(google.api.method_signature)": "parent,network,network_id", + "(google.longrunning.operation_info).response_type": "Network", + "(google.longrunning.operation_info).metadata_type": "OperationMetadata" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "post": "/v1/{parent=projects/*/locations/*/zones/*}/networks", + "body": "network" + } + }, + { + "(google.api.method_signature)": "parent,network,network_id" + }, + { + "(google.longrunning.operation_info)": { + "response_type": "Network", + "metadata_type": "OperationMetadata" + } + } + ] + }, + "DeleteNetwork": { + "requestType": "DeleteNetworkRequest", + "responseType": "google.longrunning.Operation", + "options": { + "(google.api.http).delete": "/v1/{name=projects/*/locations/*/zones/*/networks/*}", + "(google.api.method_signature)": "name", + "(google.longrunning.operation_info).response_type": "google.protobuf.Empty", + "(google.longrunning.operation_info).metadata_type": "OperationMetadata" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "delete": "/v1/{name=projects/*/locations/*/zones/*/networks/*}" + } + }, + { + "(google.api.method_signature)": "name" + }, + { + "(google.longrunning.operation_info)": { + "response_type": "google.protobuf.Empty", + "metadata_type": "OperationMetadata" + } + } + ] + }, + "ListSubnets": { + "requestType": "ListSubnetsRequest", + "responseType": "ListSubnetsResponse", + "options": { + "(google.api.http).get": "/v1/{parent=projects/*/locations/*/zones/*}/subnets", + "(google.api.method_signature)": "parent" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{parent=projects/*/locations/*/zones/*}/subnets" + } + }, + { + "(google.api.method_signature)": "parent" + } + ] + }, + "GetSubnet": { + "requestType": "GetSubnetRequest", + "responseType": "Subnet", + "options": { + "(google.api.http).get": "/v1/{name=projects/*/locations/*/zones/*/subnets/*}", + "(google.api.method_signature)": "name" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{name=projects/*/locations/*/zones/*/subnets/*}" + } + }, + { + "(google.api.method_signature)": "name" + } + ] + }, + "CreateSubnet": { + "requestType": "CreateSubnetRequest", + "responseType": "google.longrunning.Operation", + "options": { + "(google.api.http).post": "/v1/{parent=projects/*/locations/*/zones/*}/subnets", + "(google.api.http).body": "subnet", + "(google.api.method_signature)": "parent,subnet,subnet_id", + "(google.longrunning.operation_info).response_type": "Subnet", + "(google.longrunning.operation_info).metadata_type": "OperationMetadata" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "post": "/v1/{parent=projects/*/locations/*/zones/*}/subnets", + "body": "subnet" + } + }, + { + "(google.api.method_signature)": "parent,subnet,subnet_id" + }, + { + "(google.longrunning.operation_info)": { + "response_type": "Subnet", + "metadata_type": "OperationMetadata" + } + } + ] + }, + "UpdateSubnet": { + "requestType": "UpdateSubnetRequest", + "responseType": "google.longrunning.Operation", + "options": { + "(google.api.http).patch": "/v1/{subnet.name=projects/*/locations/*/zones/*/subnets/*}", + "(google.api.http).body": "subnet", + "(google.api.method_signature)": "subnet,update_mask", + "(google.longrunning.operation_info).response_type": "Subnet", + "(google.longrunning.operation_info).metadata_type": "OperationMetadata" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "patch": "/v1/{subnet.name=projects/*/locations/*/zones/*/subnets/*}", + "body": "subnet" + } + }, + { + "(google.api.method_signature)": "subnet,update_mask" + }, + { + "(google.longrunning.operation_info)": { + "response_type": "Subnet", + "metadata_type": "OperationMetadata" + } + } + ] + }, + "DeleteSubnet": { + "requestType": "DeleteSubnetRequest", + "responseType": "google.longrunning.Operation", + "options": { + "(google.api.http).delete": "/v1/{name=projects/*/locations/*/zones/*/subnets/*}", + "(google.api.method_signature)": "name", + "(google.longrunning.operation_info).response_type": "google.protobuf.Empty", + "(google.longrunning.operation_info).metadata_type": "OperationMetadata" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "delete": "/v1/{name=projects/*/locations/*/zones/*/subnets/*}" + } + }, + { + "(google.api.method_signature)": "name" + }, + { + "(google.longrunning.operation_info)": { + "response_type": "google.protobuf.Empty", + "metadata_type": "OperationMetadata" + } + } + ] + }, + "ListInterconnects": { + "requestType": "ListInterconnectsRequest", + "responseType": "ListInterconnectsResponse", + "options": { + "(google.api.http).get": "/v1/{parent=projects/*/locations/*/zones/*}/interconnects", + "(google.api.method_signature)": "parent" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{parent=projects/*/locations/*/zones/*}/interconnects" + } + }, + { + "(google.api.method_signature)": "parent" + } + ] + }, + "GetInterconnect": { + "requestType": "GetInterconnectRequest", + "responseType": "Interconnect", + "options": { + "(google.api.http).get": "/v1/{name=projects/*/locations/*/zones/*/interconnects/*}", + "(google.api.method_signature)": "name" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{name=projects/*/locations/*/zones/*/interconnects/*}" + } + }, + { + "(google.api.method_signature)": "name" + } + ] + }, + "DiagnoseInterconnect": { + "requestType": "DiagnoseInterconnectRequest", + "responseType": "DiagnoseInterconnectResponse", + "options": { + "(google.api.http).get": "/v1/{name=projects/*/locations/*/zones/*/interconnects/*}:diagnose", + "(google.api.method_signature)": "name" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{name=projects/*/locations/*/zones/*/interconnects/*}:diagnose" + } + }, + { + "(google.api.method_signature)": "name" + } + ] + }, + "ListInterconnectAttachments": { + "requestType": "ListInterconnectAttachmentsRequest", + "responseType": "ListInterconnectAttachmentsResponse", + "options": { + "(google.api.http).get": "/v1/{parent=projects/*/locations/*/zones/*}/interconnectAttachments", + "(google.api.method_signature)": "parent" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{parent=projects/*/locations/*/zones/*}/interconnectAttachments" + } + }, + { + "(google.api.method_signature)": "parent" + } + ] + }, + "GetInterconnectAttachment": { + "requestType": "GetInterconnectAttachmentRequest", + "responseType": "InterconnectAttachment", + "options": { + "(google.api.http).get": "/v1/{name=projects/*/locations/*/zones/*/interconnectAttachments/*}", + "(google.api.method_signature)": "name" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{name=projects/*/locations/*/zones/*/interconnectAttachments/*}" + } + }, + { + "(google.api.method_signature)": "name" + } + ] + }, + "CreateInterconnectAttachment": { + "requestType": "CreateInterconnectAttachmentRequest", + "responseType": "google.longrunning.Operation", + "options": { + "(google.api.http).post": "/v1/{parent=projects/*/locations/*/zones/*}/interconnectAttachments", + "(google.api.http).body": "interconnect_attachment", + "(google.api.method_signature)": "parent,interconnect_attachment,interconnect_attachment_id", + "(google.longrunning.operation_info).response_type": "InterconnectAttachment", + "(google.longrunning.operation_info).metadata_type": "OperationMetadata" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "post": "/v1/{parent=projects/*/locations/*/zones/*}/interconnectAttachments", + "body": "interconnect_attachment" + } + }, + { + "(google.api.method_signature)": "parent,interconnect_attachment,interconnect_attachment_id" + }, + { + "(google.longrunning.operation_info)": { + "response_type": "InterconnectAttachment", + "metadata_type": "OperationMetadata" + } + } + ] + }, + "DeleteInterconnectAttachment": { + "requestType": "DeleteInterconnectAttachmentRequest", + "responseType": "google.longrunning.Operation", + "options": { + "(google.api.http).delete": "/v1/{name=projects/*/locations/*/zones/*/interconnectAttachments/*}", + "(google.api.method_signature)": "name", + "(google.longrunning.operation_info).response_type": "google.protobuf.Empty", + "(google.longrunning.operation_info).metadata_type": "OperationMetadata" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "delete": "/v1/{name=projects/*/locations/*/zones/*/interconnectAttachments/*}" + } + }, + { + "(google.api.method_signature)": "name" + }, + { + "(google.longrunning.operation_info)": { + "response_type": "google.protobuf.Empty", + "metadata_type": "OperationMetadata" + } + } + ] + }, + "ListRouters": { + "requestType": "ListRoutersRequest", + "responseType": "ListRoutersResponse", + "options": { + "(google.api.http).get": "/v1/{parent=projects/*/locations/*/zones/*}/routers", + "(google.api.method_signature)": "parent" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{parent=projects/*/locations/*/zones/*}/routers" + } + }, + { + "(google.api.method_signature)": "parent" + } + ] + }, + "GetRouter": { + "requestType": "GetRouterRequest", + "responseType": "Router", + "options": { + "(google.api.http).get": "/v1/{name=projects/*/locations/*/zones/*/routers/*}", + "(google.api.method_signature)": "name" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{name=projects/*/locations/*/zones/*/routers/*}" + } + }, + { + "(google.api.method_signature)": "name" + } + ] + }, + "DiagnoseRouter": { + "requestType": "DiagnoseRouterRequest", + "responseType": "DiagnoseRouterResponse", + "options": { + "(google.api.http).get": "/v1/{name=projects/*/locations/*/zones/*/routers/*}:diagnose", + "(google.api.method_signature)": "name" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{name=projects/*/locations/*/zones/*/routers/*}:diagnose" + } + }, + { + "(google.api.method_signature)": "name" + } + ] + }, + "CreateRouter": { + "requestType": "CreateRouterRequest", + "responseType": "google.longrunning.Operation", + "options": { + "(google.api.http).post": "/v1/{parent=projects/*/locations/*/zones/*}/routers", + "(google.api.http).body": "router", + "(google.api.method_signature)": "parent,router,router_id", + "(google.longrunning.operation_info).response_type": "Router", + "(google.longrunning.operation_info).metadata_type": "OperationMetadata" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "post": "/v1/{parent=projects/*/locations/*/zones/*}/routers", + "body": "router" + } + }, + { + "(google.api.method_signature)": "parent,router,router_id" + }, + { + "(google.longrunning.operation_info)": { + "response_type": "Router", + "metadata_type": "OperationMetadata" + } + } + ] + }, + "UpdateRouter": { + "requestType": "UpdateRouterRequest", + "responseType": "google.longrunning.Operation", + "options": { + "(google.api.http).patch": "/v1/{router.name=projects/*/locations/*/zones/*/routers/*}", + "(google.api.http).body": "router", + "(google.api.method_signature)": "router,update_mask", + "(google.longrunning.operation_info).response_type": "Router", + "(google.longrunning.operation_info).metadata_type": "OperationMetadata" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "patch": "/v1/{router.name=projects/*/locations/*/zones/*/routers/*}", + "body": "router" + } + }, + { + "(google.api.method_signature)": "router,update_mask" + }, + { + "(google.longrunning.operation_info)": { + "response_type": "Router", + "metadata_type": "OperationMetadata" + } + } + ] + }, + "DeleteRouter": { + "requestType": "DeleteRouterRequest", + "responseType": "google.longrunning.Operation", + "options": { + "(google.api.http).delete": "/v1/{name=projects/*/locations/*/zones/*/routers/*}", + "(google.api.method_signature)": "name", + "(google.longrunning.operation_info).response_type": "google.protobuf.Empty", + "(google.longrunning.operation_info).metadata_type": "OperationMetadata" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "delete": "/v1/{name=projects/*/locations/*/zones/*/routers/*}" + } + }, + { + "(google.api.method_signature)": "name" + }, + { + "(google.longrunning.operation_info)": { + "response_type": "google.protobuf.Empty", + "metadata_type": "OperationMetadata" + } + } + ] + } + } + }, + "ListZonesRequest": { + "fields": { + "parent": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).child_type": "edgenetwork.googleapis.com/Zone" + } + }, + "pageSize": { + "type": "int32", + "id": 2 + }, + "pageToken": { + "type": "string", + "id": 3 + }, + "filter": { + "type": "string", + "id": 4 + }, + "orderBy": { + "type": "string", + "id": 5 + } + } + }, + "ListZonesResponse": { + "fields": { + "zones": { + "rule": "repeated", + "type": "Zone", + "id": 1 + }, + "nextPageToken": { + "type": "string", + "id": 2 + }, + "unreachable": { + "rule": "repeated", + "type": "string", + "id": 3 + } + } + }, + "GetZoneRequest": { + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Zone" + } + } + } + }, + "ListNetworksRequest": { + "fields": { + "parent": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).child_type": "edgenetwork.googleapis.com/Network" + } + }, + "pageSize": { + "type": "int32", + "id": 2 + }, + "pageToken": { + "type": "string", + "id": 3 + }, + "filter": { + "type": "string", + "id": 4 + }, + "orderBy": { + "type": "string", + "id": 5 + } + } + }, + "ListNetworksResponse": { + "fields": { + "networks": { + "rule": "repeated", + "type": "Network", + "id": 1 + }, + "nextPageToken": { + "type": "string", + "id": 2 + }, + "unreachable": { + "rule": "repeated", + "type": "string", + "id": 3 + } + } + }, + "GetNetworkRequest": { + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Network" + } + } + } + }, + "CreateNetworkRequest": { + "fields": { + "parent": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).child_type": "edgenetwork.googleapis.com/Network" + } + }, + "networkId": { + "type": "string", + "id": 2, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "network": { + "type": "Network", + "id": 3, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "requestId": { + "type": "string", + "id": 4, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + } + } + }, + "DeleteNetworkRequest": { + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Network" + } + }, + "requestId": { + "type": "string", + "id": 2, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + } + } + }, + "ListSubnetsRequest": { + "fields": { + "parent": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).child_type": "edgenetwork.googleapis.com/Subnet" + } + }, + "pageSize": { + "type": "int32", + "id": 2 + }, + "pageToken": { + "type": "string", + "id": 3 + }, + "filter": { + "type": "string", + "id": 4 + }, + "orderBy": { + "type": "string", + "id": 5 + } + } + }, + "ListSubnetsResponse": { + "fields": { + "subnets": { + "rule": "repeated", + "type": "Subnet", + "id": 1 + }, + "nextPageToken": { + "type": "string", + "id": 2 + }, + "unreachable": { + "rule": "repeated", + "type": "string", + "id": 3 + } + } + }, + "GetSubnetRequest": { + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Subnet" + } + } + } + }, + "CreateSubnetRequest": { + "fields": { + "parent": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).child_type": "edgenetwork.googleapis.com/Subnet" + } + }, + "subnetId": { + "type": "string", + "id": 2, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "subnet": { + "type": "Subnet", + "id": 3, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "requestId": { + "type": "string", + "id": 4, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + } + } + }, + "UpdateSubnetRequest": { + "fields": { + "updateMask": { + "type": "google.protobuf.FieldMask", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "subnet": { + "type": "Subnet", + "id": 2, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "requestId": { + "type": "string", + "id": 3, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + } + } + }, + "DeleteSubnetRequest": { + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Subnet" + } + }, + "requestId": { + "type": "string", + "id": 2, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + } + } + }, + "ListInterconnectsRequest": { + "fields": { + "parent": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).child_type": "edgenetwork.googleapis.com/Interconnect" + } + }, + "pageSize": { + "type": "int32", + "id": 2 + }, + "pageToken": { + "type": "string", + "id": 3 + }, + "filter": { + "type": "string", + "id": 4 + }, + "orderBy": { + "type": "string", + "id": 5 + } + } + }, + "ListInterconnectsResponse": { + "fields": { + "interconnects": { + "rule": "repeated", + "type": "Interconnect", + "id": 1 + }, + "nextPageToken": { + "type": "string", + "id": 2 + }, + "unreachable": { + "rule": "repeated", + "type": "string", + "id": 3 + } + } + }, + "GetInterconnectRequest": { + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Interconnect" + } + } + } + }, + "ListInterconnectAttachmentsRequest": { + "fields": { + "parent": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).child_type": "edgenetwork.googleapis.com/InterconnectAttachment" + } + }, + "pageSize": { + "type": "int32", + "id": 2 + }, + "pageToken": { + "type": "string", + "id": 3 + }, + "filter": { + "type": "string", + "id": 4 + }, + "orderBy": { + "type": "string", + "id": 5 + } + } + }, + "ListInterconnectAttachmentsResponse": { + "fields": { + "interconnectAttachments": { + "rule": "repeated", + "type": "InterconnectAttachment", + "id": 1 + }, + "nextPageToken": { + "type": "string", + "id": 2 + }, + "unreachable": { + "rule": "repeated", + "type": "string", + "id": 3 + } + } + }, + "GetInterconnectAttachmentRequest": { + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/InterconnectAttachment" + } + } + } + }, + "CreateInterconnectAttachmentRequest": { + "fields": { + "parent": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).child_type": "edgenetwork.googleapis.com/InterconnectAttachment" + } + }, + "interconnectAttachmentId": { + "type": "string", + "id": 2, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "interconnectAttachment": { + "type": "InterconnectAttachment", + "id": 3, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "requestId": { + "type": "string", + "id": 4, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + } + } + }, + "DeleteInterconnectAttachmentRequest": { + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/InterconnectAttachment" + } + }, + "requestId": { + "type": "string", + "id": 2, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + } + } + }, + "ListRoutersRequest": { + "fields": { + "parent": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).child_type": "edgenetwork.googleapis.com/Router" + } + }, + "pageSize": { + "type": "int32", + "id": 2 + }, + "pageToken": { + "type": "string", + "id": 3 + }, + "filter": { + "type": "string", + "id": 4 + }, + "orderBy": { + "type": "string", + "id": 5 + } + } + }, + "ListRoutersResponse": { + "fields": { + "routers": { + "rule": "repeated", + "type": "Router", + "id": 1 + }, + "nextPageToken": { + "type": "string", + "id": 2 + }, + "unreachable": { + "rule": "repeated", + "type": "string", + "id": 3 + } + } + }, + "GetRouterRequest": { + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Router" + } + } + } + }, + "CreateRouterRequest": { + "fields": { + "parent": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).child_type": "edgenetwork.googleapis.com/Router" + } + }, + "routerId": { + "type": "string", + "id": 2, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "router": { + "type": "Router", + "id": 3, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "requestId": { + "type": "string", + "id": 4, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + } + } + }, + "UpdateRouterRequest": { + "fields": { + "updateMask": { + "type": "google.protobuf.FieldMask", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "router": { + "type": "Router", + "id": 2, + "options": { + "(google.api.field_behavior)": "REQUIRED" + } + }, + "requestId": { + "type": "string", + "id": 3, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + } + } + }, + "DeleteRouterRequest": { + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Router" + } + }, + "requestId": { + "type": "string", + "id": 2, + "options": { + "(google.api.field_behavior)": "OPTIONAL" + } + } + } + }, + "OperationMetadata": { + "fields": { + "createTime": { + "type": "google.protobuf.Timestamp", + "id": 1, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "endTime": { + "type": "google.protobuf.Timestamp", + "id": 2, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "target": { + "type": "string", + "id": 3, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "verb": { + "type": "string", + "id": 4, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "statusMessage": { + "type": "string", + "id": 5, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "requestedCancellation": { + "type": "bool", + "id": 6, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + }, + "apiVersion": { + "type": "string", + "id": 7, + "options": { + "(google.api.field_behavior)": "OUTPUT_ONLY" + } + } + } + }, + "DiagnoseNetworkRequest": { + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Network" + } + } + } + }, + "DiagnoseNetworkResponse": { + "fields": { + "updateTime": { + "type": "google.protobuf.Timestamp", + "id": 1 + }, + "result": { + "type": "NetworkStatus", + "id": 2 + } + }, + "nested": { + "NetworkStatus": { + "fields": { + "subnetStatus": { + "rule": "repeated", + "type": "SubnetStatus", + "id": 1 + } + } + } + } + }, + "DiagnoseInterconnectRequest": { + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Interconnect" + } + } + } + }, + "DiagnoseInterconnectResponse": { + "fields": { + "updateTime": { + "type": "google.protobuf.Timestamp", + "id": 1 + }, + "result": { + "type": "InterconnectDiagnostics", + "id": 2 + } + } + }, + "DiagnoseRouterRequest": { + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Router" + } + } + } + }, + "DiagnoseRouterResponse": { + "fields": { + "updateTime": { + "type": "google.protobuf.Timestamp", + "id": 1 + }, + "result": { + "type": "RouterStatus", + "id": 2 + } + } + }, + "InitializeZoneRequest": { + "fields": { + "name": { + "type": "string", + "id": 1, + "options": { + "(google.api.field_behavior)": "REQUIRED", + "(google.api.resource_reference).type": "edgenetwork.googleapis.com/Zone" + } + } + } + }, + "InitializeZoneResponse": { + "fields": {} + } + } + } + } + } + } + }, + "api": { + "options": { + "go_package": "google.golang.org/genproto/googleapis/api;api", + "java_multiple_files": true, + "java_outer_classname": "LaunchStageProto", + "java_package": "com.google.api", + "objc_class_prefix": "GAPI", + "cc_enable_arenas": true + }, + "nested": { + "fieldBehavior": { + "rule": "repeated", + "type": "google.api.FieldBehavior", + "id": 1052, + "extend": "google.protobuf.FieldOptions" + }, + "FieldBehavior": { + "values": { + "FIELD_BEHAVIOR_UNSPECIFIED": 0, + "OPTIONAL": 1, + "REQUIRED": 2, + "OUTPUT_ONLY": 3, + "INPUT_ONLY": 4, + "IMMUTABLE": 5, + "UNORDERED_LIST": 6, + "NON_EMPTY_DEFAULT": 7 + } + }, + "resourceReference": { + "type": "google.api.ResourceReference", + "id": 1055, + "extend": "google.protobuf.FieldOptions" + }, + "resourceDefinition": { + "rule": "repeated", + "type": "google.api.ResourceDescriptor", + "id": 1053, + "extend": "google.protobuf.FileOptions" + }, + "resource": { + "type": "google.api.ResourceDescriptor", + "id": 1053, + "extend": "google.protobuf.MessageOptions" + }, + "ResourceDescriptor": { + "fields": { + "type": { + "type": "string", + "id": 1 + }, + "pattern": { + "rule": "repeated", + "type": "string", + "id": 2 + }, + "nameField": { + "type": "string", + "id": 3 + }, + "history": { + "type": "History", + "id": 4 + }, + "plural": { + "type": "string", + "id": 5 + }, + "singular": { + "type": "string", + "id": 6 + }, + "style": { + "rule": "repeated", + "type": "Style", + "id": 10 + } + }, + "nested": { + "History": { + "values": { + "HISTORY_UNSPECIFIED": 0, + "ORIGINALLY_SINGLE_PATTERN": 1, + "FUTURE_MULTI_PATTERN": 2 + } + }, + "Style": { + "values": { + "STYLE_UNSPECIFIED": 0, + "DECLARATIVE_FRIENDLY": 1 + } + } + } + }, + "ResourceReference": { + "fields": { + "type": { + "type": "string", + "id": 1 + }, + "childType": { + "type": "string", + "id": 2 + } + } + }, + "http": { + "type": "HttpRule", + "id": 72295728, + "extend": "google.protobuf.MethodOptions" + }, + "Http": { + "fields": { + "rules": { + "rule": "repeated", + "type": "HttpRule", + "id": 1 + }, + "fullyDecodeReservedExpansion": { + "type": "bool", + "id": 2 + } + } + }, + "HttpRule": { + "oneofs": { + "pattern": { + "oneof": [ + "get", + "put", + "post", + "delete", + "patch", + "custom" + ] + } + }, + "fields": { + "selector": { + "type": "string", + "id": 1 + }, + "get": { + "type": "string", + "id": 2 + }, + "put": { + "type": "string", + "id": 3 + }, + "post": { + "type": "string", + "id": 4 + }, + "delete": { + "type": "string", + "id": 5 + }, + "patch": { + "type": "string", + "id": 6 + }, + "custom": { + "type": "CustomHttpPattern", + "id": 8 + }, + "body": { + "type": "string", + "id": 7 + }, + "responseBody": { + "type": "string", + "id": 12 + }, + "additionalBindings": { + "rule": "repeated", + "type": "HttpRule", + "id": 11 + } + } + }, + "CustomHttpPattern": { + "fields": { + "kind": { + "type": "string", + "id": 1 + }, + "path": { + "type": "string", + "id": 2 + } + } + }, + "methodSignature": { + "rule": "repeated", + "type": "string", + "id": 1051, + "extend": "google.protobuf.MethodOptions" + }, + "defaultHost": { + "type": "string", + "id": 1049, + "extend": "google.protobuf.ServiceOptions" + }, + "oauthScopes": { + "type": "string", + "id": 1050, + "extend": "google.protobuf.ServiceOptions" + }, + "CommonLanguageSettings": { + "fields": { + "referenceDocsUri": { + "type": "string", + "id": 1, + "options": { + "deprecated": true + } + }, + "destinations": { + "rule": "repeated", + "type": "ClientLibraryDestination", + "id": 2 + } + } + }, + "ClientLibrarySettings": { + "fields": { + "version": { + "type": "string", + "id": 1 + }, + "launchStage": { + "type": "LaunchStage", + "id": 2 + }, + "restNumericEnums": { + "type": "bool", + "id": 3 + }, + "javaSettings": { + "type": "JavaSettings", + "id": 21 + }, + "cppSettings": { + "type": "CppSettings", + "id": 22 + }, + "phpSettings": { + "type": "PhpSettings", + "id": 23 + }, + "pythonSettings": { + "type": "PythonSettings", + "id": 24 + }, + "nodeSettings": { + "type": "NodeSettings", + "id": 25 + }, + "dotnetSettings": { + "type": "DotnetSettings", + "id": 26 + }, + "rubySettings": { + "type": "RubySettings", + "id": 27 + }, + "goSettings": { + "type": "GoSettings", + "id": 28 + } + } + }, + "Publishing": { + "fields": { + "methodSettings": { + "rule": "repeated", + "type": "MethodSettings", + "id": 2 + }, + "newIssueUri": { + "type": "string", + "id": 101 + }, + "documentationUri": { + "type": "string", + "id": 102 + }, + "apiShortName": { + "type": "string", + "id": 103 + }, + "githubLabel": { + "type": "string", + "id": 104 + }, + "codeownerGithubTeams": { + "rule": "repeated", + "type": "string", + "id": 105 + }, + "docTagPrefix": { + "type": "string", + "id": 106 + }, + "organization": { + "type": "ClientLibraryOrganization", + "id": 107 + }, + "librarySettings": { + "rule": "repeated", + "type": "ClientLibrarySettings", + "id": 109 + } + } + }, + "JavaSettings": { + "fields": { + "libraryPackage": { + "type": "string", + "id": 1 + }, + "serviceClassNames": { + "keyType": "string", + "type": "string", + "id": 2 + }, + "common": { + "type": "CommonLanguageSettings", + "id": 3 + } + } + }, + "CppSettings": { + "fields": { + "common": { + "type": "CommonLanguageSettings", + "id": 1 + } + } + }, + "PhpSettings": { + "fields": { + "common": { + "type": "CommonLanguageSettings", + "id": 1 + } + } + }, + "PythonSettings": { + "fields": { + "common": { + "type": "CommonLanguageSettings", + "id": 1 + } + } + }, + "NodeSettings": { + "fields": { + "common": { + "type": "CommonLanguageSettings", + "id": 1 + } + } + }, + "DotnetSettings": { + "fields": { + "common": { + "type": "CommonLanguageSettings", + "id": 1 + } + } + }, + "RubySettings": { + "fields": { + "common": { + "type": "CommonLanguageSettings", + "id": 1 + } + } + }, + "GoSettings": { + "fields": { + "common": { + "type": "CommonLanguageSettings", + "id": 1 + } + } + }, + "MethodSettings": { + "fields": { + "selector": { + "type": "string", + "id": 1 + }, + "longRunning": { + "type": "LongRunning", + "id": 2 + } + }, + "nested": { + "LongRunning": { + "fields": { + "initialPollDelay": { + "type": "google.protobuf.Duration", + "id": 1 + }, + "pollDelayMultiplier": { + "type": "float", + "id": 2 + }, + "maxPollDelay": { + "type": "google.protobuf.Duration", + "id": 3 + }, + "totalPollTimeout": { + "type": "google.protobuf.Duration", + "id": 4 + } + } + } + } + }, + "ClientLibraryOrganization": { + "values": { + "CLIENT_LIBRARY_ORGANIZATION_UNSPECIFIED": 0, + "CLOUD": 1, + "ADS": 2, + "PHOTOS": 3, + "STREET_VIEW": 4 + } + }, + "ClientLibraryDestination": { + "values": { + "CLIENT_LIBRARY_DESTINATION_UNSPECIFIED": 0, + "GITHUB": 10, + "PACKAGE_MANAGER": 20 + } + }, + "LaunchStage": { + "values": { + "LAUNCH_STAGE_UNSPECIFIED": 0, + "UNIMPLEMENTED": 6, + "PRELAUNCH": 7, + "EARLY_ACCESS": 1, + "ALPHA": 2, + "BETA": 3, + "GA": 4, + "DEPRECATED": 5 + } + } + } + }, + "protobuf": { + "options": { + "go_package": "google.golang.org/protobuf/types/descriptorpb", + "java_package": "com.google.protobuf", + "java_outer_classname": "DescriptorProtos", + "csharp_namespace": "Google.Protobuf.Reflection", + "objc_class_prefix": "GPB", + "cc_enable_arenas": true, + "optimize_for": "SPEED" + }, + "nested": { + "FileDescriptorSet": { + "fields": { + "file": { + "rule": "repeated", + "type": "FileDescriptorProto", + "id": 1 + } + } + }, + "FileDescriptorProto": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "package": { + "type": "string", + "id": 2 + }, + "dependency": { + "rule": "repeated", + "type": "string", + "id": 3 + }, + "publicDependency": { + "rule": "repeated", + "type": "int32", + "id": 10, + "options": { + "packed": false + } + }, + "weakDependency": { + "rule": "repeated", + "type": "int32", + "id": 11, + "options": { + "packed": false + } + }, + "messageType": { + "rule": "repeated", + "type": "DescriptorProto", + "id": 4 + }, + "enumType": { + "rule": "repeated", + "type": "EnumDescriptorProto", + "id": 5 + }, + "service": { + "rule": "repeated", + "type": "ServiceDescriptorProto", + "id": 6 + }, + "extension": { + "rule": "repeated", + "type": "FieldDescriptorProto", + "id": 7 + }, + "options": { + "type": "FileOptions", + "id": 8 + }, + "sourceCodeInfo": { + "type": "SourceCodeInfo", + "id": 9 + }, + "syntax": { + "type": "string", + "id": 12 + }, + "edition": { + "type": "string", + "id": 13 + } + } + }, + "DescriptorProto": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "field": { + "rule": "repeated", + "type": "FieldDescriptorProto", + "id": 2 + }, + "extension": { + "rule": "repeated", + "type": "FieldDescriptorProto", + "id": 6 + }, + "nestedType": { + "rule": "repeated", + "type": "DescriptorProto", + "id": 3 + }, + "enumType": { + "rule": "repeated", + "type": "EnumDescriptorProto", + "id": 4 + }, + "extensionRange": { + "rule": "repeated", + "type": "ExtensionRange", + "id": 5 + }, + "oneofDecl": { + "rule": "repeated", + "type": "OneofDescriptorProto", + "id": 8 + }, + "options": { + "type": "MessageOptions", + "id": 7 + }, + "reservedRange": { + "rule": "repeated", + "type": "ReservedRange", + "id": 9 + }, + "reservedName": { + "rule": "repeated", + "type": "string", + "id": 10 + } + }, + "nested": { + "ExtensionRange": { + "fields": { + "start": { + "type": "int32", + "id": 1 + }, + "end": { + "type": "int32", + "id": 2 + }, + "options": { + "type": "ExtensionRangeOptions", + "id": 3 + } + } + }, + "ReservedRange": { + "fields": { + "start": { + "type": "int32", + "id": 1 + }, + "end": { + "type": "int32", + "id": 2 + } + } + } + } + }, + "ExtensionRangeOptions": { + "fields": { + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ] + }, + "FieldDescriptorProto": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "number": { + "type": "int32", + "id": 3 + }, + "label": { + "type": "Label", + "id": 4 + }, + "type": { + "type": "Type", + "id": 5 + }, + "typeName": { + "type": "string", + "id": 6 + }, + "extendee": { + "type": "string", + "id": 2 + }, + "defaultValue": { + "type": "string", + "id": 7 + }, + "oneofIndex": { + "type": "int32", + "id": 9 + }, + "jsonName": { + "type": "string", + "id": 10 + }, + "options": { + "type": "FieldOptions", + "id": 8 + }, + "proto3Optional": { + "type": "bool", + "id": 17 + } + }, + "nested": { + "Type": { + "values": { + "TYPE_DOUBLE": 1, + "TYPE_FLOAT": 2, + "TYPE_INT64": 3, + "TYPE_UINT64": 4, + "TYPE_INT32": 5, + "TYPE_FIXED64": 6, + "TYPE_FIXED32": 7, + "TYPE_BOOL": 8, + "TYPE_STRING": 9, + "TYPE_GROUP": 10, + "TYPE_MESSAGE": 11, + "TYPE_BYTES": 12, + "TYPE_UINT32": 13, + "TYPE_ENUM": 14, + "TYPE_SFIXED32": 15, + "TYPE_SFIXED64": 16, + "TYPE_SINT32": 17, + "TYPE_SINT64": 18 + } + }, + "Label": { + "values": { + "LABEL_OPTIONAL": 1, + "LABEL_REQUIRED": 2, + "LABEL_REPEATED": 3 + } + } + } + }, + "OneofDescriptorProto": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "options": { + "type": "OneofOptions", + "id": 2 + } + } + }, + "EnumDescriptorProto": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "value": { + "rule": "repeated", + "type": "EnumValueDescriptorProto", + "id": 2 + }, + "options": { + "type": "EnumOptions", + "id": 3 + }, + "reservedRange": { + "rule": "repeated", + "type": "EnumReservedRange", + "id": 4 + }, + "reservedName": { + "rule": "repeated", + "type": "string", + "id": 5 + } + }, + "nested": { + "EnumReservedRange": { + "fields": { + "start": { + "type": "int32", + "id": 1 + }, + "end": { + "type": "int32", + "id": 2 + } + } + } + } + }, + "EnumValueDescriptorProto": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "number": { + "type": "int32", + "id": 2 + }, + "options": { + "type": "EnumValueOptions", + "id": 3 + } + } + }, + "ServiceDescriptorProto": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "method": { + "rule": "repeated", + "type": "MethodDescriptorProto", + "id": 2 + }, + "options": { + "type": "ServiceOptions", + "id": 3 + } + } + }, + "MethodDescriptorProto": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "inputType": { + "type": "string", + "id": 2 + }, + "outputType": { + "type": "string", + "id": 3 + }, + "options": { + "type": "MethodOptions", + "id": 4 + }, + "clientStreaming": { + "type": "bool", + "id": 5, + "options": { + "default": false + } + }, + "serverStreaming": { + "type": "bool", + "id": 6, + "options": { + "default": false + } + } + } + }, + "FileOptions": { + "fields": { + "javaPackage": { + "type": "string", + "id": 1 + }, + "javaOuterClassname": { + "type": "string", + "id": 8 + }, + "javaMultipleFiles": { + "type": "bool", + "id": 10, + "options": { + "default": false + } + }, + "javaGenerateEqualsAndHash": { + "type": "bool", + "id": 20, + "options": { + "deprecated": true + } + }, + "javaStringCheckUtf8": { + "type": "bool", + "id": 27, + "options": { + "default": false + } + }, + "optimizeFor": { + "type": "OptimizeMode", + "id": 9, + "options": { + "default": "SPEED" + } + }, + "goPackage": { + "type": "string", + "id": 11 + }, + "ccGenericServices": { + "type": "bool", + "id": 16, + "options": { + "default": false + } + }, + "javaGenericServices": { + "type": "bool", + "id": 17, + "options": { + "default": false + } + }, + "pyGenericServices": { + "type": "bool", + "id": 18, + "options": { + "default": false + } + }, + "phpGenericServices": { + "type": "bool", + "id": 42, + "options": { + "default": false + } + }, + "deprecated": { + "type": "bool", + "id": 23, + "options": { + "default": false + } + }, + "ccEnableArenas": { + "type": "bool", + "id": 31, + "options": { + "default": true + } + }, + "objcClassPrefix": { + "type": "string", + "id": 36 + }, + "csharpNamespace": { + "type": "string", + "id": 37 + }, + "swiftPrefix": { + "type": "string", + "id": 39 + }, + "phpClassPrefix": { + "type": "string", + "id": 40 + }, + "phpNamespace": { + "type": "string", + "id": 41 + }, + "phpMetadataNamespace": { + "type": "string", + "id": 44 + }, + "rubyPackage": { + "type": "string", + "id": 45 + }, + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ], + "reserved": [ + [ + 38, + 38 + ] + ], + "nested": { + "OptimizeMode": { + "values": { + "SPEED": 1, + "CODE_SIZE": 2, + "LITE_RUNTIME": 3 + } + } + } + }, + "MessageOptions": { + "fields": { + "messageSetWireFormat": { + "type": "bool", + "id": 1, + "options": { + "default": false + } + }, + "noStandardDescriptorAccessor": { + "type": "bool", + "id": 2, + "options": { + "default": false + } + }, + "deprecated": { + "type": "bool", + "id": 3, + "options": { + "default": false + } + }, + "mapEntry": { + "type": "bool", + "id": 7 + }, + "deprecatedLegacyJsonFieldConflicts": { + "type": "bool", + "id": 11, + "options": { + "deprecated": true + } + }, + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ], + "reserved": [ + [ + 4, + 4 + ], + [ + 5, + 5 + ], + [ + 6, + 6 + ], + [ + 8, + 8 + ], + [ + 9, + 9 + ] + ] + }, + "FieldOptions": { + "fields": { + "ctype": { + "type": "CType", + "id": 1, + "options": { + "default": "STRING" + } + }, + "packed": { + "type": "bool", + "id": 2 + }, + "jstype": { + "type": "JSType", + "id": 6, + "options": { + "default": "JS_NORMAL" + } + }, + "lazy": { + "type": "bool", + "id": 5, + "options": { + "default": false + } + }, + "unverifiedLazy": { + "type": "bool", + "id": 15, + "options": { + "default": false + } + }, + "deprecated": { + "type": "bool", + "id": 3, + "options": { + "default": false + } + }, + "weak": { + "type": "bool", + "id": 10, + "options": { + "default": false + } + }, + "debugRedact": { + "type": "bool", + "id": 16, + "options": { + "default": false + } + }, + "retention": { + "type": "OptionRetention", + "id": 17 + }, + "target": { + "type": "OptionTargetType", + "id": 18 + }, + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ], + "reserved": [ + [ + 4, + 4 + ] + ], + "nested": { + "CType": { + "values": { + "STRING": 0, + "CORD": 1, + "STRING_PIECE": 2 + } + }, + "JSType": { + "values": { + "JS_NORMAL": 0, + "JS_STRING": 1, + "JS_NUMBER": 2 + } + }, + "OptionRetention": { + "values": { + "RETENTION_UNKNOWN": 0, + "RETENTION_RUNTIME": 1, + "RETENTION_SOURCE": 2 + } + }, + "OptionTargetType": { + "values": { + "TARGET_TYPE_UNKNOWN": 0, + "TARGET_TYPE_FILE": 1, + "TARGET_TYPE_EXTENSION_RANGE": 2, + "TARGET_TYPE_MESSAGE": 3, + "TARGET_TYPE_FIELD": 4, + "TARGET_TYPE_ONEOF": 5, + "TARGET_TYPE_ENUM": 6, + "TARGET_TYPE_ENUM_ENTRY": 7, + "TARGET_TYPE_SERVICE": 8, + "TARGET_TYPE_METHOD": 9 + } + } + } + }, + "OneofOptions": { + "fields": { + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ] + }, + "EnumOptions": { + "fields": { + "allowAlias": { + "type": "bool", + "id": 2 + }, + "deprecated": { + "type": "bool", + "id": 3, + "options": { + "default": false + } + }, + "deprecatedLegacyJsonFieldConflicts": { + "type": "bool", + "id": 6, + "options": { + "deprecated": true + } + }, + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ], + "reserved": [ + [ + 5, + 5 + ] + ] + }, + "EnumValueOptions": { + "fields": { + "deprecated": { + "type": "bool", + "id": 1, + "options": { + "default": false + } + }, + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ] + }, + "ServiceOptions": { + "fields": { + "deprecated": { + "type": "bool", + "id": 33, + "options": { + "default": false + } + }, + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ] + }, + "MethodOptions": { + "fields": { + "deprecated": { + "type": "bool", + "id": 33, + "options": { + "default": false + } + }, + "idempotencyLevel": { + "type": "IdempotencyLevel", + "id": 34, + "options": { + "default": "IDEMPOTENCY_UNKNOWN" + } + }, + "uninterpretedOption": { + "rule": "repeated", + "type": "UninterpretedOption", + "id": 999 + } + }, + "extensions": [ + [ + 1000, + 536870911 + ] + ], + "nested": { + "IdempotencyLevel": { + "values": { + "IDEMPOTENCY_UNKNOWN": 0, + "NO_SIDE_EFFECTS": 1, + "IDEMPOTENT": 2 + } + } + } + }, + "UninterpretedOption": { + "fields": { + "name": { + "rule": "repeated", + "type": "NamePart", + "id": 2 + }, + "identifierValue": { + "type": "string", + "id": 3 + }, + "positiveIntValue": { + "type": "uint64", + "id": 4 + }, + "negativeIntValue": { + "type": "int64", + "id": 5 + }, + "doubleValue": { + "type": "double", + "id": 6 + }, + "stringValue": { + "type": "bytes", + "id": 7 + }, + "aggregateValue": { + "type": "string", + "id": 8 + } + }, + "nested": { + "NamePart": { + "fields": { + "namePart": { + "rule": "required", + "type": "string", + "id": 1 + }, + "isExtension": { + "rule": "required", + "type": "bool", + "id": 2 + } + } + } + } + }, + "SourceCodeInfo": { + "fields": { + "location": { + "rule": "repeated", + "type": "Location", + "id": 1 + } + }, + "nested": { + "Location": { + "fields": { + "path": { + "rule": "repeated", + "type": "int32", + "id": 1 + }, + "span": { + "rule": "repeated", + "type": "int32", + "id": 2 + }, + "leadingComments": { + "type": "string", + "id": 3 + }, + "trailingComments": { + "type": "string", + "id": 4 + }, + "leadingDetachedComments": { + "rule": "repeated", + "type": "string", + "id": 6 + } + } + } + } + }, + "GeneratedCodeInfo": { + "fields": { + "annotation": { + "rule": "repeated", + "type": "Annotation", + "id": 1 + } + }, + "nested": { + "Annotation": { + "fields": { + "path": { + "rule": "repeated", + "type": "int32", + "id": 1 + }, + "sourceFile": { + "type": "string", + "id": 2 + }, + "begin": { + "type": "int32", + "id": 3 + }, + "end": { + "type": "int32", + "id": 4 + }, + "semantic": { + "type": "Semantic", + "id": 5 + } + }, + "nested": { + "Semantic": { + "values": { + "NONE": 0, + "SET": 1, + "ALIAS": 2 + } + } + } + } + } + }, + "Timestamp": { + "fields": { + "seconds": { + "type": "int64", + "id": 1 + }, + "nanos": { + "type": "int32", + "id": 2 + } + } + }, + "Duration": { + "fields": { + "seconds": { + "type": "int64", + "id": 1 + }, + "nanos": { + "type": "int32", + "id": 2 + } + } + }, + "Any": { + "fields": { + "type_url": { + "type": "string", + "id": 1 + }, + "value": { + "type": "bytes", + "id": 2 + } + } + }, + "Empty": { + "fields": {} + }, + "FieldMask": { + "fields": { + "paths": { + "rule": "repeated", + "type": "string", + "id": 1 + } + } + } + } + }, + "longrunning": { + "options": { + "cc_enable_arenas": true, + "csharp_namespace": "Google.LongRunning", + "go_package": "google.golang.org/genproto/googleapis/longrunning;longrunning", + "java_multiple_files": true, + "java_outer_classname": "OperationsProto", + "java_package": "com.google.longrunning", + "php_namespace": "Google\\LongRunning" + }, + "nested": { + "operationInfo": { + "type": "google.longrunning.OperationInfo", + "id": 1049, + "extend": "google.protobuf.MethodOptions" + }, + "Operations": { + "options": { + "(google.api.default_host)": "longrunning.googleapis.com" + }, + "methods": { + "ListOperations": { + "requestType": "ListOperationsRequest", + "responseType": "ListOperationsResponse", + "options": { + "(google.api.http).get": "/v1/{name=operations}", + "(google.api.method_signature)": "name,filter" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{name=operations}" + } + }, + { + "(google.api.method_signature)": "name,filter" + } + ] + }, + "GetOperation": { + "requestType": "GetOperationRequest", + "responseType": "Operation", + "options": { + "(google.api.http).get": "/v1/{name=operations/**}", + "(google.api.method_signature)": "name" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "get": "/v1/{name=operations/**}" + } + }, + { + "(google.api.method_signature)": "name" + } + ] + }, + "DeleteOperation": { + "requestType": "DeleteOperationRequest", + "responseType": "google.protobuf.Empty", + "options": { + "(google.api.http).delete": "/v1/{name=operations/**}", + "(google.api.method_signature)": "name" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "delete": "/v1/{name=operations/**}" + } + }, + { + "(google.api.method_signature)": "name" + } + ] + }, + "CancelOperation": { + "requestType": "CancelOperationRequest", + "responseType": "google.protobuf.Empty", + "options": { + "(google.api.http).post": "/v1/{name=operations/**}:cancel", + "(google.api.http).body": "*", + "(google.api.method_signature)": "name" + }, + "parsedOptions": [ + { + "(google.api.http)": { + "post": "/v1/{name=operations/**}:cancel", + "body": "*" + } + }, + { + "(google.api.method_signature)": "name" + } + ] + }, + "WaitOperation": { + "requestType": "WaitOperationRequest", + "responseType": "Operation" + } + } + }, + "Operation": { + "oneofs": { + "result": { + "oneof": [ + "error", + "response" + ] + } + }, + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "metadata": { + "type": "google.protobuf.Any", + "id": 2 + }, + "done": { + "type": "bool", + "id": 3 + }, + "error": { + "type": "google.rpc.Status", + "id": 4 + }, + "response": { + "type": "google.protobuf.Any", + "id": 5 + } + } + }, + "GetOperationRequest": { + "fields": { + "name": { + "type": "string", + "id": 1 + } + } + }, + "ListOperationsRequest": { + "fields": { + "name": { + "type": "string", + "id": 4 + }, + "filter": { + "type": "string", + "id": 1 + }, + "pageSize": { + "type": "int32", + "id": 2 + }, + "pageToken": { + "type": "string", + "id": 3 + } + } + }, + "ListOperationsResponse": { + "fields": { + "operations": { + "rule": "repeated", + "type": "Operation", + "id": 1 + }, + "nextPageToken": { + "type": "string", + "id": 2 + } + } + }, + "CancelOperationRequest": { + "fields": { + "name": { + "type": "string", + "id": 1 + } + } + }, + "DeleteOperationRequest": { + "fields": { + "name": { + "type": "string", + "id": 1 + } + } + }, + "WaitOperationRequest": { + "fields": { + "name": { + "type": "string", + "id": 1 + }, + "timeout": { + "type": "google.protobuf.Duration", + "id": 2 + } + } + }, + "OperationInfo": { + "fields": { + "responseType": { + "type": "string", + "id": 1 + }, + "metadataType": { + "type": "string", + "id": 2 + } + } + } + } + }, + "rpc": { + "options": { + "cc_enable_arenas": true, + "go_package": "google.golang.org/genproto/googleapis/rpc/status;status", + "java_multiple_files": true, + "java_outer_classname": "StatusProto", + "java_package": "com.google.rpc", + "objc_class_prefix": "RPC" + }, + "nested": { + "Status": { + "fields": { + "code": { + "type": "int32", + "id": 1 + }, + "message": { + "type": "string", + "id": 2 + }, + "details": { + "rule": "repeated", + "type": "google.protobuf.Any", + "id": 3 + } + } + } + } + } + } + } + } +} \ No newline at end of file diff --git a/packages/google-cloud-edgenetwork/samples/README.md b/packages/google-cloud-edgenetwork/samples/README.md new file mode 100644 index 000000000000..3f227e92dc30 --- /dev/null +++ b/packages/google-cloud-edgenetwork/samples/README.md @@ -0,0 +1,518 @@ +[//]: # "This README.md file is auto-generated, all changes to this file will be lost." +[//]: # "To regenerate it, use `python -m synthtool`." +Google Cloud Platform logo + +# [Distributed Cloud Edge Network API: Node.js Samples](https://github.com/googleapis/google-cloud-node) + +[![Open in Cloud Shell][shell_img]][shell_link] + + + +## Table of Contents + +* [Before you begin](#before-you-begin) +* [Samples](#samples) + * [Edge_network.create_interconnect_attachment](#edge_network.create_interconnect_attachment) + * [Edge_network.create_network](#edge_network.create_network) + * [Edge_network.create_router](#edge_network.create_router) + * [Edge_network.create_subnet](#edge_network.create_subnet) + * [Edge_network.delete_interconnect_attachment](#edge_network.delete_interconnect_attachment) + * [Edge_network.delete_network](#edge_network.delete_network) + * [Edge_network.delete_router](#edge_network.delete_router) + * [Edge_network.delete_subnet](#edge_network.delete_subnet) + * [Edge_network.diagnose_interconnect](#edge_network.diagnose_interconnect) + * [Edge_network.diagnose_network](#edge_network.diagnose_network) + * [Edge_network.diagnose_router](#edge_network.diagnose_router) + * [Edge_network.get_interconnect](#edge_network.get_interconnect) + * [Edge_network.get_interconnect_attachment](#edge_network.get_interconnect_attachment) + * [Edge_network.get_network](#edge_network.get_network) + * [Edge_network.get_router](#edge_network.get_router) + * [Edge_network.get_subnet](#edge_network.get_subnet) + * [Edge_network.get_zone](#edge_network.get_zone) + * [Edge_network.initialize_zone](#edge_network.initialize_zone) + * [Edge_network.list_interconnect_attachments](#edge_network.list_interconnect_attachments) + * [Edge_network.list_interconnects](#edge_network.list_interconnects) + * [Edge_network.list_networks](#edge_network.list_networks) + * [Edge_network.list_routers](#edge_network.list_routers) + * [Edge_network.list_subnets](#edge_network.list_subnets) + * [Edge_network.list_zones](#edge_network.list_zones) + * [Edge_network.update_router](#edge_network.update_router) + * [Edge_network.update_subnet](#edge_network.update_subnet) + * [Quickstart](#quickstart) + +## Before you begin + +Before running the samples, make sure you've followed the steps outlined in +[Using the client library](https://github.com/googleapis/google-cloud-node#using-the-client-library). + +`cd samples` + +`npm install` + +`cd ..` + +## Samples + + + +### Edge_network.create_interconnect_attachment + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_interconnect_attachment.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_interconnect_attachment.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_interconnect_attachment.js` + + +----- + + + + +### Edge_network.create_network + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_network.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_network.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_network.js` + + +----- + + + + +### Edge_network.create_router + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_router.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_router.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_router.js` + + +----- + + + + +### Edge_network.create_subnet + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_subnet.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_subnet.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_subnet.js` + + +----- + + + + +### Edge_network.delete_interconnect_attachment + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_interconnect_attachment.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_interconnect_attachment.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_interconnect_attachment.js` + + +----- + + + + +### Edge_network.delete_network + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_network.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_network.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_network.js` + + +----- + + + + +### Edge_network.delete_router + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_router.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_router.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_router.js` + + +----- + + + + +### Edge_network.delete_subnet + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_subnet.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_subnet.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_subnet.js` + + +----- + + + + +### Edge_network.diagnose_interconnect + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_interconnect.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_interconnect.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_interconnect.js` + + +----- + + + + +### Edge_network.diagnose_network + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_network.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_network.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_network.js` + + +----- + + + + +### Edge_network.diagnose_router + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_router.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_router.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_router.js` + + +----- + + + + +### Edge_network.get_interconnect + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_interconnect.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_interconnect.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_interconnect.js` + + +----- + + + + +### Edge_network.get_interconnect_attachment + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_interconnect_attachment.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_interconnect_attachment.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_interconnect_attachment.js` + + +----- + + + + +### Edge_network.get_network + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_network.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_network.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_network.js` + + +----- + + + + +### Edge_network.get_router + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_router.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_router.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_router.js` + + +----- + + + + +### Edge_network.get_subnet + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_subnet.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_subnet.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_subnet.js` + + +----- + + + + +### Edge_network.get_zone + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_zone.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_zone.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_zone.js` + + +----- + + + + +### Edge_network.initialize_zone + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.initialize_zone.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.initialize_zone.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.initialize_zone.js` + + +----- + + + + +### Edge_network.list_interconnect_attachments + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_interconnect_attachments.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_interconnect_attachments.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_interconnect_attachments.js` + + +----- + + + + +### Edge_network.list_interconnects + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_interconnects.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_interconnects.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_interconnects.js` + + +----- + + + + +### Edge_network.list_networks + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_networks.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_networks.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_networks.js` + + +----- + + + + +### Edge_network.list_routers + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_routers.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_routers.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_routers.js` + + +----- + + + + +### Edge_network.list_subnets + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_subnets.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_subnets.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_subnets.js` + + +----- + + + + +### Edge_network.list_zones + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_zones.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_zones.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_zones.js` + + +----- + + + + +### Edge_network.update_router + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.update_router.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.update_router.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.update_router.js` + + +----- + + + + +### Edge_network.update_subnet + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.update_subnet.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.update_subnet.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.update_subnet.js` + + +----- + + + + +### Quickstart + +View the [source code](https://github.com/googleapis/google-cloud-node/blob/main/packages/google-cloud-edgenetwork/samples/quickstart.js). + +[![Open in Cloud Shell][shell_img]](https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=packages/google-cloud-edgenetwork/samples/quickstart.js,samples/README.md) + +__Usage:__ + + +`node packages/google-cloud-edgenetwork/samples/quickstart.js` + + + + + + +[shell_img]: https://gstatic.com/cloudssh/images/open-btn.png +[shell_link]: https://console.cloud.google.com/cloudshell/open?git_repo=https://github.com/googleapis/google-cloud-node&page=editor&open_in_editor=samples/README.md +[product-docs]: https://cloud.google.com/distributed-cloud/edge/latest/docs/overview diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_interconnect_attachment.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_interconnect_attachment.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_interconnect_attachment.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_interconnect_attachment.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_network.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_network.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_network.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_network.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_router.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_router.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_router.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_router.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_subnet.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_subnet.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.create_subnet.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.create_subnet.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_interconnect_attachment.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_interconnect_attachment.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_interconnect_attachment.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_interconnect_attachment.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_network.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_network.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_network.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_network.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_router.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_router.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_router.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_router.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_subnet.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_subnet.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.delete_subnet.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.delete_subnet.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_interconnect.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_interconnect.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_interconnect.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_interconnect.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_network.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_network.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_network.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_network.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_router.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_router.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.diagnose_router.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.diagnose_router.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_interconnect.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_interconnect.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_interconnect.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_interconnect.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_interconnect_attachment.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_interconnect_attachment.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_interconnect_attachment.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_interconnect_attachment.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_network.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_network.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_network.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_network.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_router.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_router.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_router.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_router.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_subnet.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_subnet.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_subnet.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_subnet.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_zone.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_zone.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.get_zone.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.get_zone.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.initialize_zone.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.initialize_zone.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.initialize_zone.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.initialize_zone.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_interconnect_attachments.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_interconnect_attachments.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_interconnect_attachments.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_interconnect_attachments.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_interconnects.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_interconnects.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_interconnects.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_interconnects.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_networks.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_networks.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_networks.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_networks.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_routers.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_routers.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_routers.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_routers.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_subnets.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_subnets.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_subnets.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_subnets.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_zones.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_zones.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.list_zones.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.list_zones.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.update_router.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.update_router.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.update_router.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.update_router.js diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.update_subnet.js b/packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.update_subnet.js similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/samples/generated/v1/edge_network.update_subnet.js rename to packages/google-cloud-edgenetwork/samples/generated/v1/edge_network.update_subnet.js diff --git a/packages/google-cloud-edgenetwork/samples/generated/v1/snippet_metadata_google.cloud.edgenetwork.v1.json b/packages/google-cloud-edgenetwork/samples/generated/v1/snippet_metadata_google.cloud.edgenetwork.v1.json new file mode 100644 index 000000000000..12e1c8953244 --- /dev/null +++ b/packages/google-cloud-edgenetwork/samples/generated/v1/snippet_metadata_google.cloud.edgenetwork.v1.json @@ -0,0 +1,1231 @@ +{ + "clientLibrary": { + "name": "nodejs-edgenetwork", + "version": "0.0.0", + "language": "TYPESCRIPT", + "apis": [ + { + "id": "google.cloud.edgenetwork.v1", + "version": "v1" + } + ] + }, + "snippets": [ + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_InitializeZone_async", + "title": "EdgeNetwork initializeZone Sample", + "origin": "API_DEFINITION", + "description": " InitializeZone will initialize resources for a zone in a project.", + "canonical": true, + "file": "edge_network.initialize_zone.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "InitializeZone", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.InitializeZone", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.InitializeZoneResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "InitializeZone", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.InitializeZone", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListZones_async", + "title": "EdgeNetwork listZones Sample", + "origin": "API_DEFINITION", + "description": " Lists Zones in a given project and location.", + "canonical": true, + "file": "edge_network.list_zones.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 72, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "ListZones", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListZones", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "page_size", + "type": "TYPE_INT32" + }, + { + "name": "page_token", + "type": "TYPE_STRING" + }, + { + "name": "filter", + "type": "TYPE_STRING" + }, + { + "name": "order_by", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.ListZonesResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "ListZones", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListZones", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetZone_async", + "title": "EdgeNetwork getZone Sample", + "origin": "API_DEFINITION", + "description": " Gets details of a single Zone.", + "canonical": true, + "file": "edge_network.get_zone.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "GetZone", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetZone", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.Zone", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "GetZone", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetZone", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListNetworks_async", + "title": "EdgeNetwork listNetworks Sample", + "origin": "API_DEFINITION", + "description": " Lists Networks in a given project and location.", + "canonical": true, + "file": "edge_network.list_networks.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 72, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "ListNetworks", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListNetworks", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "page_size", + "type": "TYPE_INT32" + }, + { + "name": "page_token", + "type": "TYPE_STRING" + }, + { + "name": "filter", + "type": "TYPE_STRING" + }, + { + "name": "order_by", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.ListNetworksResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "ListNetworks", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListNetworks", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetNetwork_async", + "title": "EdgeNetwork getNetwork Sample", + "origin": "API_DEFINITION", + "description": " Gets details of a single Network.", + "canonical": true, + "file": "edge_network.get_network.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "GetNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetNetwork", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.Network", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "GetNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetNetwork", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DiagnoseNetwork_async", + "title": "EdgeNetwork diagnoseNetwork Sample", + "origin": "API_DEFINITION", + "description": " Get the diagnostics of a single network resource.", + "canonical": true, + "file": "edge_network.diagnose_network.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "DiagnoseNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseNetwork", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.DiagnoseNetworkResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "DiagnoseNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseNetwork", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_CreateNetwork_async", + "title": "EdgeNetwork createNetwork Sample", + "origin": "API_DEFINITION", + "description": " Creates a new Network in a given project and location.", + "canonical": true, + "file": "edge_network.create_network.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 80, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "CreateNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateNetwork", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "network_id", + "type": "TYPE_STRING" + }, + { + "name": "network", + "type": ".google.cloud.edgenetwork.v1.Network" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "CreateNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateNetwork", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DeleteNetwork_async", + "title": "EdgeNetwork deleteNetwork Sample", + "origin": "API_DEFINITION", + "description": " Deletes a single Network.", + "canonical": true, + "file": "edge_network.delete_network.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 68, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "DeleteNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteNetwork", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "DeleteNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteNetwork", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListSubnets_async", + "title": "EdgeNetwork listSubnets Sample", + "origin": "API_DEFINITION", + "description": " Lists Subnets in a given project and location.", + "canonical": true, + "file": "edge_network.list_subnets.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 72, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "ListSubnets", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListSubnets", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "page_size", + "type": "TYPE_INT32" + }, + { + "name": "page_token", + "type": "TYPE_STRING" + }, + { + "name": "filter", + "type": "TYPE_STRING" + }, + { + "name": "order_by", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.ListSubnetsResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "ListSubnets", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListSubnets", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetSubnet_async", + "title": "EdgeNetwork getSubnet Sample", + "origin": "API_DEFINITION", + "description": " Gets details of a single Subnet.", + "canonical": true, + "file": "edge_network.get_subnet.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "GetSubnet", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetSubnet", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.Subnet", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "GetSubnet", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetSubnet", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_CreateSubnet_async", + "title": "EdgeNetwork createSubnet Sample", + "origin": "API_DEFINITION", + "description": " Creates a new Subnet in a given project and location.", + "canonical": true, + "file": "edge_network.create_subnet.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 80, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "CreateSubnet", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateSubnet", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "subnet_id", + "type": "TYPE_STRING" + }, + { + "name": "subnet", + "type": ".google.cloud.edgenetwork.v1.Subnet" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "CreateSubnet", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateSubnet", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_UpdateSubnet_async", + "title": "EdgeNetwork updateSubnet Sample", + "origin": "API_DEFINITION", + "description": " Updates the parameters of a single Subnet.", + "canonical": true, + "file": "edge_network.update_subnet.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 77, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "UpdateSubnet", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.UpdateSubnet", + "async": true, + "parameters": [ + { + "name": "update_mask", + "type": ".google.protobuf.FieldMask" + }, + { + "name": "subnet", + "type": ".google.cloud.edgenetwork.v1.Subnet" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "UpdateSubnet", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.UpdateSubnet", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DeleteSubnet_async", + "title": "EdgeNetwork deleteSubnet Sample", + "origin": "API_DEFINITION", + "description": " Deletes a single Subnet.", + "canonical": true, + "file": "edge_network.delete_subnet.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 68, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "DeleteSubnet", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteSubnet", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "DeleteSubnet", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteSubnet", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListInterconnects_async", + "title": "EdgeNetwork listInterconnects Sample", + "origin": "API_DEFINITION", + "description": " Lists Interconnects in a given project and location.", + "canonical": true, + "file": "edge_network.list_interconnects.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 72, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "ListInterconnects", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListInterconnects", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "page_size", + "type": "TYPE_INT32" + }, + { + "name": "page_token", + "type": "TYPE_STRING" + }, + { + "name": "filter", + "type": "TYPE_STRING" + }, + { + "name": "order_by", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.ListInterconnectsResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "ListInterconnects", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListInterconnects", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetInterconnect_async", + "title": "EdgeNetwork getInterconnect Sample", + "origin": "API_DEFINITION", + "description": " Gets details of a single Interconnect.", + "canonical": true, + "file": "edge_network.get_interconnect.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "GetInterconnect", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetInterconnect", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.Interconnect", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "GetInterconnect", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetInterconnect", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DiagnoseInterconnect_async", + "title": "EdgeNetwork diagnoseInterconnect Sample", + "origin": "API_DEFINITION", + "description": " Get the diagnostics of a single interconnect resource.", + "canonical": true, + "file": "edge_network.diagnose_interconnect.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "DiagnoseInterconnect", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseInterconnect", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "DiagnoseInterconnect", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseInterconnect", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListInterconnectAttachments_async", + "title": "EdgeNetwork listInterconnectAttachments Sample", + "origin": "API_DEFINITION", + "description": " Lists InterconnectAttachments in a given project and location.", + "canonical": true, + "file": "edge_network.list_interconnect_attachments.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 72, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "ListInterconnectAttachments", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListInterconnectAttachments", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "page_size", + "type": "TYPE_INT32" + }, + { + "name": "page_token", + "type": "TYPE_STRING" + }, + { + "name": "filter", + "type": "TYPE_STRING" + }, + { + "name": "order_by", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.ListInterconnectAttachmentsResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "ListInterconnectAttachments", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListInterconnectAttachments", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetInterconnectAttachment_async", + "title": "EdgeNetwork getInterconnectAttachment Sample", + "origin": "API_DEFINITION", + "description": " Gets details of a single InterconnectAttachment.", + "canonical": true, + "file": "edge_network.get_interconnect_attachment.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "GetInterconnectAttachment", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetInterconnectAttachment", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.InterconnectAttachment", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "GetInterconnectAttachment", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetInterconnectAttachment", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_CreateInterconnectAttachment_async", + "title": "EdgeNetwork createInterconnectAttachment Sample", + "origin": "API_DEFINITION", + "description": " Creates a new InterconnectAttachment in a given project and location.", + "canonical": true, + "file": "edge_network.create_interconnect_attachment.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 80, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "CreateInterconnectAttachment", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateInterconnectAttachment", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "interconnect_attachment_id", + "type": "TYPE_STRING" + }, + { + "name": "interconnect_attachment", + "type": ".google.cloud.edgenetwork.v1.InterconnectAttachment" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "CreateInterconnectAttachment", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateInterconnectAttachment", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DeleteInterconnectAttachment_async", + "title": "EdgeNetwork deleteInterconnectAttachment Sample", + "origin": "API_DEFINITION", + "description": " Deletes a single InterconnectAttachment.", + "canonical": true, + "file": "edge_network.delete_interconnect_attachment.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 68, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "DeleteInterconnectAttachment", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteInterconnectAttachment", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "DeleteInterconnectAttachment", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteInterconnectAttachment", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_ListRouters_async", + "title": "EdgeNetwork listRouters Sample", + "origin": "API_DEFINITION", + "description": " Lists Routers in a given project and location.", + "canonical": true, + "file": "edge_network.list_routers.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 72, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "ListRouters", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListRouters", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "page_size", + "type": "TYPE_INT32" + }, + { + "name": "page_token", + "type": "TYPE_STRING" + }, + { + "name": "filter", + "type": "TYPE_STRING" + }, + { + "name": "order_by", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.ListRoutersResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "ListRouters", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.ListRouters", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_GetRouter_async", + "title": "EdgeNetwork getRouter Sample", + "origin": "API_DEFINITION", + "description": " Gets details of a single Router.", + "canonical": true, + "file": "edge_network.get_router.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "GetRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetRouter", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.Router", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "GetRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.GetRouter", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DiagnoseRouter_async", + "title": "EdgeNetwork diagnoseRouter Sample", + "origin": "API_DEFINITION", + "description": " Get the diagnostics of a single router resource.", + "canonical": true, + "file": "edge_network.diagnose_router.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 53, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "DiagnoseRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseRouter", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.cloud.edgenetwork.v1.DiagnoseRouterResponse", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "DiagnoseRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DiagnoseRouter", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_CreateRouter_async", + "title": "EdgeNetwork createRouter Sample", + "origin": "API_DEFINITION", + "description": " Creates a new Router in a given project and location.", + "canonical": true, + "file": "edge_network.create_router.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 80, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "CreateRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateRouter", + "async": true, + "parameters": [ + { + "name": "parent", + "type": "TYPE_STRING" + }, + { + "name": "router_id", + "type": "TYPE_STRING" + }, + { + "name": "router", + "type": ".google.cloud.edgenetwork.v1.Router" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "CreateRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.CreateRouter", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_UpdateRouter_async", + "title": "EdgeNetwork updateRouter Sample", + "origin": "API_DEFINITION", + "description": " Updates the parameters of a single Router.", + "canonical": true, + "file": "edge_network.update_router.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 77, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "UpdateRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.UpdateRouter", + "async": true, + "parameters": [ + { + "name": "update_mask", + "type": ".google.protobuf.FieldMask" + }, + { + "name": "router", + "type": ".google.cloud.edgenetwork.v1.Router" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "UpdateRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.UpdateRouter", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + }, + { + "regionTag": "edgenetwork_v1_generated_EdgeNetwork_DeleteRouter_async", + "title": "EdgeNetwork deleteRouter Sample", + "origin": "API_DEFINITION", + "description": " Deletes a single Router.", + "canonical": true, + "file": "edge_network.delete_router.js", + "language": "JAVASCRIPT", + "segments": [ + { + "start": 25, + "end": 68, + "type": "FULL" + } + ], + "clientMethod": { + "shortName": "DeleteRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteRouter", + "async": true, + "parameters": [ + { + "name": "name", + "type": "TYPE_STRING" + }, + { + "name": "request_id", + "type": "TYPE_STRING" + } + ], + "resultType": ".google.longrunning.Operation", + "client": { + "shortName": "EdgeNetworkClient", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetworkClient" + }, + "method": { + "shortName": "DeleteRouter", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork.DeleteRouter", + "service": { + "shortName": "EdgeNetwork", + "fullName": "google.cloud.edgenetwork.v1.EdgeNetwork" + } + } + } + } + ] +} \ No newline at end of file diff --git a/packages/google-cloud-edgenetwork/samples/quickstart.js b/packages/google-cloud-edgenetwork/samples/quickstart.js new file mode 100644 index 000000000000..0a57d77c8e2d --- /dev/null +++ b/packages/google-cloud-edgenetwork/samples/quickstart.js @@ -0,0 +1,78 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + +'use strict'; + +function main(parent) { + // [START edgenetwork_quickstart] + /** + * This snippet has been automatically generated and should be regarded as a code template only. + * It will require modifications to work. + * It may require correct/in-range values for request initialization. + * TODO(developer): Uncomment these variables before running the sample. + */ + /** + * Required. Parent value for ListRoutersRequest + */ + // const parent = 'abc123' + /** + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + */ + // const pageSize = 1234 + /** + * A token identifying a page of results the server should return. + */ + // const pageToken = 'abc123' + /** + * Filtering results + */ + // const filter = 'abc123' + /** + * Hint for how to order the results + */ + // const orderBy = 'abc123' + + // Imports the Edgenetwork library + const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; + + // Instantiates a client + const edgenetworkClient = new EdgeNetworkClient(); + + async function callListRouters() { + // Construct request + const request = { + parent, + }; + + // Run request + const iterable = await edgenetworkClient.listRoutersAsync(request); + for await (const response of iterable) { + console.log(response); + } + } + + callListRouters(); + // [END edgenetwork_quickstart] +} + +process.on('unhandledRejection', err => { + console.error(err.message); + process.exitCode = 1; +}); +main(...process.argv.slice(2)); diff --git a/packages/google-cloud-edgenetwork/samples/test/quickstart.js b/packages/google-cloud-edgenetwork/samples/test/quickstart.js index e61f3815c2b9..6df3e5cc5e04 100644 --- a/packages/google-cloud-edgenetwork/samples/test/quickstart.js +++ b/packages/google-cloud-edgenetwork/samples/test/quickstart.js @@ -18,7 +18,7 @@ const assert = require('assert'); const path = require('path'); const cp = require('child_process'); const {describe, it, before} = require('mocha'); -const { Client } = require('@google-cloud/edgenetwork').v1; +const {Client} = require('@google-cloud/edgenetwork').v1; const edgenetworkClient = new Client(); const execSync = cmd => cp.execSync(cmd, {encoding: 'utf-8'}); @@ -33,7 +33,10 @@ describe('Quickstart', () => { }); it('should run quickstart', async () => { - const output = execSync(`node ./quickstart.js projects/${projectId}/locations/us-central1`, {cwd}); + const output = execSync( + `node ./quickstart.js projects/${projectId}/locations/us-central1`, + {cwd} + ); assert(output !== null); }); }); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/src/index.ts b/packages/google-cloud-edgenetwork/src/index.ts similarity index 84% rename from owl-bot-staging/google-cloud-edgenetwork/v1/src/index.ts rename to packages/google-cloud-edgenetwork/src/index.ts index 9145aaaffd11..b58ffea46d22 100644 --- a/owl-bot-staging/google-cloud-edgenetwork/v1/src/index.ts +++ b/packages/google-cloud-edgenetwork/src/index.ts @@ -12,14 +12,16 @@ // See the License for the specific language governing permissions and // limitations under the License. // -// ** This file is automatically generated by gapic-generator-typescript. ** -// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** This file is automatically generated by synthtool. ** +// ** https://github.com/googleapis/synthtool ** // ** All changes to this file may be overwritten. ** import * as v1 from './v1'; + const EdgeNetworkClient = v1.EdgeNetworkClient; type EdgeNetworkClient = v1.EdgeNetworkClient; + export {v1, EdgeNetworkClient}; export default {v1, EdgeNetworkClient}; import * as protos from '../protos/protos'; -export {protos} +export {protos}; diff --git a/packages/google-cloud-edgenetwork/src/v1/edge_network_client.ts b/packages/google-cloud-edgenetwork/src/v1/edge_network_client.ts new file mode 100644 index 000000000000..9f521d42fe6a --- /dev/null +++ b/packages/google-cloud-edgenetwork/src/v1/edge_network_client.ts @@ -0,0 +1,4944 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + +/* global window */ +import type * as gax from 'google-gax'; +import type { + Callback, + CallOptions, + Descriptors, + ClientOptions, + GrpcClientOptions, + LROperation, + PaginationCallback, + GaxCall, + LocationsClient, + LocationProtos, +} from 'google-gax'; +import {Transform} from 'stream'; +import * as protos from '../../protos/protos'; +import jsonProtos = require('../../protos/protos.json'); +/** + * Client JSON configuration object, loaded from + * `src/v1/edge_network_client_config.json`. + * This file defines retry strategy and timeouts for all API methods in this library. + */ +import * as gapicConfig from './edge_network_client_config.json'; +const version = require('../../../package.json').version; + +/** + * EdgeNetwork API provides managed, highly available cloud dynamic network + * configuration service to the GEC customer to enable edge application and + * network function solutions. This allows the customers to easily define and + * configure the network setup and property to meet the workload requirement. + * @class + * @memberof v1 + */ +export class EdgeNetworkClient { + private _terminated = false; + private _opts: ClientOptions; + private _providedCustomServicePath: boolean; + private _gaxModule: typeof gax | typeof gax.fallback; + private _gaxGrpc: gax.GrpcClient | gax.fallback.GrpcClient; + private _protos: {}; + private _defaults: {[method: string]: gax.CallSettings}; + auth: gax.GoogleAuth; + descriptors: Descriptors = { + page: {}, + stream: {}, + longrunning: {}, + batching: {}, + }; + warn: (code: string, message: string, warnType?: string) => void; + innerApiCalls: {[name: string]: Function}; + locationsClient: LocationsClient; + pathTemplates: {[name: string]: gax.PathTemplate}; + operationsClient: gax.OperationsClient; + edgeNetworkStub?: Promise<{[name: string]: Function}>; + + /** + * Construct an instance of EdgeNetworkClient. + * + * @param {object} [options] - The configuration object. + * The options accepted by the constructor are described in detail + * in [this document](https://github.com/googleapis/gax-nodejs/blob/main/client-libraries.md#creating-the-client-instance). + * The common options are: + * @param {object} [options.credentials] - Credentials object. + * @param {string} [options.credentials.client_email] + * @param {string} [options.credentials.private_key] + * @param {string} [options.email] - Account email address. Required when + * using a .pem or .p12 keyFilename. + * @param {string} [options.keyFilename] - Full path to the a .json, .pem, or + * .p12 key downloaded from the Google Developers Console. If you provide + * a path to a JSON file, the projectId option below is not necessary. + * NOTE: .pem and .p12 require you to specify options.email as well. + * @param {number} [options.port] - The port on which to connect to + * the remote host. + * @param {string} [options.projectId] - The project ID from the Google + * Developer's Console, e.g. 'grape-spaceship-123'. We will also check + * the environment variable GCLOUD_PROJECT for your project ID. If your + * app is running in an environment which supports + * {@link https://developers.google.com/identity/protocols/application-default-credentials Application Default Credentials}, + * your project ID will be detected automatically. + * @param {string} [options.apiEndpoint] - The domain name of the + * API remote host. + * @param {gax.ClientConfig} [options.clientConfig] - Client configuration override. + * Follows the structure of {@link gapicConfig}. + * @param {boolean} [options.fallback] - Use HTTP/1.1 REST mode. + * For more information, please check the + * {@link https://github.com/googleapis/gax-nodejs/blob/main/client-libraries.md#http11-rest-api-mode documentation}. + * @param {gax} [gaxInstance]: loaded instance of `google-gax`. Useful if you + * need to avoid loading the default gRPC version and want to use the fallback + * HTTP implementation. Load only fallback version and pass it to the constructor: + * ``` + * const gax = require('google-gax/build/src/fallback'); // avoids loading google-gax with gRPC + * const client = new EdgeNetworkClient({fallback: true}, gax); + * ``` + */ + constructor( + opts?: ClientOptions, + gaxInstance?: typeof gax | typeof gax.fallback + ) { + // Ensure that options include all the required fields. + const staticMembers = this.constructor as typeof EdgeNetworkClient; + const servicePath = + opts?.servicePath || opts?.apiEndpoint || staticMembers.servicePath; + this._providedCustomServicePath = !!( + opts?.servicePath || opts?.apiEndpoint + ); + const port = opts?.port || staticMembers.port; + const clientConfig = opts?.clientConfig ?? {}; + const fallback = + opts?.fallback ?? + (typeof window !== 'undefined' && typeof window?.fetch === 'function'); + opts = Object.assign({servicePath, port, clientConfig, fallback}, opts); + + // Request numeric enum values if REST transport is used. + opts.numericEnums = true; + + // If scopes are unset in options and we're connecting to a non-default endpoint, set scopes just in case. + if (servicePath !== staticMembers.servicePath && !('scopes' in opts)) { + opts['scopes'] = staticMembers.scopes; + } + + // Load google-gax module synchronously if needed + if (!gaxInstance) { + gaxInstance = require('google-gax') as typeof gax; + } + + // Choose either gRPC or proto-over-HTTP implementation of google-gax. + this._gaxModule = opts.fallback ? gaxInstance.fallback : gaxInstance; + + // Create a `gaxGrpc` object, with any grpc-specific options sent to the client. + this._gaxGrpc = new this._gaxModule.GrpcClient(opts); + + // Save options to use in initialize() method. + this._opts = opts; + + // Save the auth object to the client, for use by other methods. + this.auth = this._gaxGrpc.auth as gax.GoogleAuth; + + // Set useJWTAccessWithScope on the auth object. + this.auth.useJWTAccessWithScope = true; + + // Set defaultServicePath on the auth object. + this.auth.defaultServicePath = staticMembers.servicePath; + + // Set the default scopes in auth client if needed. + if (servicePath === staticMembers.servicePath) { + this.auth.defaultScopes = staticMembers.scopes; + } + this.locationsClient = new this._gaxModule.LocationsClient( + this._gaxGrpc, + opts + ); + + // Determine the client header string. + const clientHeader = [`gax/${this._gaxModule.version}`, `gapic/${version}`]; + if (typeof process !== 'undefined' && 'versions' in process) { + clientHeader.push(`gl-node/${process.versions.node}`); + } else { + clientHeader.push(`gl-web/${this._gaxModule.version}`); + } + if (!opts.fallback) { + clientHeader.push(`grpc/${this._gaxGrpc.grpcVersion}`); + } else { + clientHeader.push(`rest/${this._gaxGrpc.grpcVersion}`); + } + if (opts.libName && opts.libVersion) { + clientHeader.push(`${opts.libName}/${opts.libVersion}`); + } + // Load the applicable protos. + this._protos = this._gaxGrpc.loadProtoJSON(jsonProtos); + + // This API contains "path templates"; forward-slash-separated + // identifiers to uniquely identify resources within the API. + // Create useful helper objects for these. + this.pathTemplates = { + interconnectPathTemplate: new this._gaxModule.PathTemplate( + 'projects/{project}/locations/{location}/zones/{zone}/interconnects/{interconnect}' + ), + interconnectAttachmentPathTemplate: new this._gaxModule.PathTemplate( + 'projects/{project}/locations/{location}/zones/{zone}/interconnectAttachments/{interconnect_attachment}' + ), + locationPathTemplate: new this._gaxModule.PathTemplate( + 'projects/{project}/locations/{location}' + ), + networkPathTemplate: new this._gaxModule.PathTemplate( + 'projects/{project}/locations/{location}/zones/{zone}/networks/{network}' + ), + projectPathTemplate: new this._gaxModule.PathTemplate( + 'projects/{project}' + ), + routerPathTemplate: new this._gaxModule.PathTemplate( + 'projects/{project}/locations/{location}/zones/{zone}/routers/{router}' + ), + subnetPathTemplate: new this._gaxModule.PathTemplate( + 'projects/{project}/locations/{location}/zones/{zone}/subnets/{subnet}' + ), + zonePathTemplate: new this._gaxModule.PathTemplate( + 'projects/{project}/locations/{location}/zones/{zone}' + ), + }; + + // Some of the methods on this service return "paged" results, + // (e.g. 50 results at a time, with tokens to get subsequent + // pages). Denote the keys used for pagination and results. + this.descriptors.page = { + listZones: new this._gaxModule.PageDescriptor( + 'pageToken', + 'nextPageToken', + 'zones' + ), + listNetworks: new this._gaxModule.PageDescriptor( + 'pageToken', + 'nextPageToken', + 'networks' + ), + listSubnets: new this._gaxModule.PageDescriptor( + 'pageToken', + 'nextPageToken', + 'subnets' + ), + listInterconnects: new this._gaxModule.PageDescriptor( + 'pageToken', + 'nextPageToken', + 'interconnects' + ), + listInterconnectAttachments: new this._gaxModule.PageDescriptor( + 'pageToken', + 'nextPageToken', + 'interconnectAttachments' + ), + listRouters: new this._gaxModule.PageDescriptor( + 'pageToken', + 'nextPageToken', + 'routers' + ), + }; + + const protoFilesRoot = this._gaxModule.protobuf.Root.fromJSON(jsonProtos); + // This API contains "long-running operations", which return a + // an Operation object that allows for tracking of the operation, + // rather than holding a request open. + const lroOptions: GrpcClientOptions = { + auth: this.auth, + grpc: 'grpc' in this._gaxGrpc ? this._gaxGrpc.grpc : undefined, + }; + if (opts.fallback) { + lroOptions.protoJson = protoFilesRoot; + lroOptions.httpRules = [ + { + selector: 'google.cloud.location.Locations.GetLocation', + get: '/v1/{name=projects/*/locations/*}', + }, + { + selector: 'google.cloud.location.Locations.ListLocations', + get: '/v1/{name=projects/*}/locations', + }, + { + selector: 'google.longrunning.Operations.CancelOperation', + post: '/v1/{name=projects/*/locations/*/operations/*}:cancel', + body: '*', + }, + { + selector: 'google.longrunning.Operations.DeleteOperation', + delete: '/v1/{name=projects/*/locations/*/operations/*}', + }, + { + selector: 'google.longrunning.Operations.GetOperation', + get: '/v1/{name=projects/*/locations/*/operations/*}', + }, + { + selector: 'google.longrunning.Operations.ListOperations', + get: '/v1/{name=projects/*/locations/*}/operations', + }, + ]; + } + this.operationsClient = this._gaxModule + .lro(lroOptions) + .operationsClient(opts); + const createNetworkResponse = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.Network' + ) as gax.protobuf.Type; + const createNetworkMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata' + ) as gax.protobuf.Type; + const deleteNetworkResponse = protoFilesRoot.lookup( + '.google.protobuf.Empty' + ) as gax.protobuf.Type; + const deleteNetworkMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata' + ) as gax.protobuf.Type; + const createSubnetResponse = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.Subnet' + ) as gax.protobuf.Type; + const createSubnetMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata' + ) as gax.protobuf.Type; + const updateSubnetResponse = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.Subnet' + ) as gax.protobuf.Type; + const updateSubnetMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata' + ) as gax.protobuf.Type; + const deleteSubnetResponse = protoFilesRoot.lookup( + '.google.protobuf.Empty' + ) as gax.protobuf.Type; + const deleteSubnetMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata' + ) as gax.protobuf.Type; + const createInterconnectAttachmentResponse = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.InterconnectAttachment' + ) as gax.protobuf.Type; + const createInterconnectAttachmentMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata' + ) as gax.protobuf.Type; + const deleteInterconnectAttachmentResponse = protoFilesRoot.lookup( + '.google.protobuf.Empty' + ) as gax.protobuf.Type; + const deleteInterconnectAttachmentMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata' + ) as gax.protobuf.Type; + const createRouterResponse = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.Router' + ) as gax.protobuf.Type; + const createRouterMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata' + ) as gax.protobuf.Type; + const updateRouterResponse = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.Router' + ) as gax.protobuf.Type; + const updateRouterMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata' + ) as gax.protobuf.Type; + const deleteRouterResponse = protoFilesRoot.lookup( + '.google.protobuf.Empty' + ) as gax.protobuf.Type; + const deleteRouterMetadata = protoFilesRoot.lookup( + '.google.cloud.edgenetwork.v1.OperationMetadata' + ) as gax.protobuf.Type; + + this.descriptors.longrunning = { + createNetwork: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + createNetworkResponse.decode.bind(createNetworkResponse), + createNetworkMetadata.decode.bind(createNetworkMetadata) + ), + deleteNetwork: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + deleteNetworkResponse.decode.bind(deleteNetworkResponse), + deleteNetworkMetadata.decode.bind(deleteNetworkMetadata) + ), + createSubnet: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + createSubnetResponse.decode.bind(createSubnetResponse), + createSubnetMetadata.decode.bind(createSubnetMetadata) + ), + updateSubnet: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + updateSubnetResponse.decode.bind(updateSubnetResponse), + updateSubnetMetadata.decode.bind(updateSubnetMetadata) + ), + deleteSubnet: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + deleteSubnetResponse.decode.bind(deleteSubnetResponse), + deleteSubnetMetadata.decode.bind(deleteSubnetMetadata) + ), + createInterconnectAttachment: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + createInterconnectAttachmentResponse.decode.bind( + createInterconnectAttachmentResponse + ), + createInterconnectAttachmentMetadata.decode.bind( + createInterconnectAttachmentMetadata + ) + ), + deleteInterconnectAttachment: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + deleteInterconnectAttachmentResponse.decode.bind( + deleteInterconnectAttachmentResponse + ), + deleteInterconnectAttachmentMetadata.decode.bind( + deleteInterconnectAttachmentMetadata + ) + ), + createRouter: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + createRouterResponse.decode.bind(createRouterResponse), + createRouterMetadata.decode.bind(createRouterMetadata) + ), + updateRouter: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + updateRouterResponse.decode.bind(updateRouterResponse), + updateRouterMetadata.decode.bind(updateRouterMetadata) + ), + deleteRouter: new this._gaxModule.LongrunningDescriptor( + this.operationsClient, + deleteRouterResponse.decode.bind(deleteRouterResponse), + deleteRouterMetadata.decode.bind(deleteRouterMetadata) + ), + }; + + // Put together the default options sent with requests. + this._defaults = this._gaxGrpc.constructSettings( + 'google.cloud.edgenetwork.v1.EdgeNetwork', + gapicConfig as gax.ClientConfig, + opts.clientConfig || {}, + {'x-goog-api-client': clientHeader.join(' ')} + ); + + // Set up a dictionary of "inner API calls"; the core implementation + // of calling the API is handled in `google-gax`, with this code + // merely providing the destination and request information. + this.innerApiCalls = {}; + + // Add a warn function to the client constructor so it can be easily tested. + this.warn = this._gaxModule.warn; + } + + /** + * Initialize the client. + * Performs asynchronous operations (such as authentication) and prepares the client. + * This function will be called automatically when any class method is called for the + * first time, but if you need to initialize it before calling an actual method, + * feel free to call initialize() directly. + * + * You can await on this method if you want to make sure the client is initialized. + * + * @returns {Promise} A promise that resolves to an authenticated service stub. + */ + initialize() { + // If the client stub promise is already initialized, return immediately. + if (this.edgeNetworkStub) { + return this.edgeNetworkStub; + } + + // Put together the "service stub" for + // google.cloud.edgenetwork.v1.EdgeNetwork. + this.edgeNetworkStub = this._gaxGrpc.createStub( + this._opts.fallback + ? (this._protos as protobuf.Root).lookupService( + 'google.cloud.edgenetwork.v1.EdgeNetwork' + ) + : // eslint-disable-next-line @typescript-eslint/no-explicit-any + (this._protos as any).google.cloud.edgenetwork.v1.EdgeNetwork, + this._opts, + this._providedCustomServicePath + ) as Promise<{[method: string]: Function}>; + + // Iterate over each of the methods that the service provides + // and create an API call method for each. + const edgeNetworkStubMethods = [ + 'initializeZone', + 'listZones', + 'getZone', + 'listNetworks', + 'getNetwork', + 'diagnoseNetwork', + 'createNetwork', + 'deleteNetwork', + 'listSubnets', + 'getSubnet', + 'createSubnet', + 'updateSubnet', + 'deleteSubnet', + 'listInterconnects', + 'getInterconnect', + 'diagnoseInterconnect', + 'listInterconnectAttachments', + 'getInterconnectAttachment', + 'createInterconnectAttachment', + 'deleteInterconnectAttachment', + 'listRouters', + 'getRouter', + 'diagnoseRouter', + 'createRouter', + 'updateRouter', + 'deleteRouter', + ]; + for (const methodName of edgeNetworkStubMethods) { + const callPromise = this.edgeNetworkStub.then( + stub => + (...args: Array<{}>) => { + if (this._terminated) { + return Promise.reject('The client has already been closed.'); + } + const func = stub[methodName]; + return func.apply(stub, args); + }, + (err: Error | null | undefined) => () => { + throw err; + } + ); + + const descriptor = + this.descriptors.page[methodName] || + this.descriptors.longrunning[methodName] || + undefined; + const apiCall = this._gaxModule.createApiCall( + callPromise, + this._defaults[methodName], + descriptor, + this._opts.fallback + ); + + this.innerApiCalls[methodName] = apiCall; + } + + return this.edgeNetworkStub; + } + + /** + * The DNS address for this API service. + * @returns {string} The DNS address for this service. + */ + static get servicePath() { + return 'edgenetwork.googleapis.com'; + } + + /** + * The DNS address for this API service - same as servicePath(), + * exists for compatibility reasons. + * @returns {string} The DNS address for this service. + */ + static get apiEndpoint() { + return 'edgenetwork.googleapis.com'; + } + + /** + * The port for this API service. + * @returns {number} The default port for this service. + */ + static get port() { + return 443; + } + + /** + * The scopes needed to make gRPC calls for every method defined + * in this service. + * @returns {string[]} List of default scopes. + */ + static get scopes() { + return ['https://www.googleapis.com/auth/cloud-platform']; + } + + getProjectId(): Promise; + getProjectId(callback: Callback): void; + /** + * Return the project ID used by this class. + * @returns {Promise} A promise that resolves to string containing the project ID. + */ + getProjectId( + callback?: Callback + ): Promise | void { + if (callback) { + this.auth.getProjectId(callback); + return; + } + return this.auth.getProjectId(); + } + + // ------------------- + // -- Service calls -- + // ------------------- + /** + * InitializeZone will initialize resources for a zone in a project. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. The name of the zone resource. + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.InitializeZoneResponse|InitializeZoneResponse}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.initialize_zone.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_InitializeZone_async + */ + initializeZone( + request?: protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest, + options?: CallOptions + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, + protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest | undefined, + {} | undefined, + ] + >; + initializeZone( + request: protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, + | protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest + | null + | undefined, + {} | null | undefined + > + ): void; + initializeZone( + request: protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, + | protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest + | null + | undefined, + {} | null | undefined + > + ): void; + initializeZone( + request?: protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest, + optionsOrCallback?: + | CallOptions + | Callback< + protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, + | protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest + | null + | undefined, + {} | null | undefined + >, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, + | protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest + | null + | undefined, + {} | null | undefined + > + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse, + protos.google.cloud.edgenetwork.v1.IInitializeZoneRequest | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + name: request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.initializeZone(request, options, callback); + } + /** + * Gets details of a single Zone. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.Zone|Zone}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.get_zone.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetZone_async + */ + getZone( + request?: protos.google.cloud.edgenetwork.v1.IGetZoneRequest, + options?: CallOptions + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IZone, + protos.google.cloud.edgenetwork.v1.IGetZoneRequest | undefined, + {} | undefined, + ] + >; + getZone( + request: protos.google.cloud.edgenetwork.v1.IGetZoneRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IZone, + protos.google.cloud.edgenetwork.v1.IGetZoneRequest | null | undefined, + {} | null | undefined + > + ): void; + getZone( + request: protos.google.cloud.edgenetwork.v1.IGetZoneRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IZone, + protos.google.cloud.edgenetwork.v1.IGetZoneRequest | null | undefined, + {} | null | undefined + > + ): void; + getZone( + request?: protos.google.cloud.edgenetwork.v1.IGetZoneRequest, + optionsOrCallback?: + | CallOptions + | Callback< + protos.google.cloud.edgenetwork.v1.IZone, + protos.google.cloud.edgenetwork.v1.IGetZoneRequest | null | undefined, + {} | null | undefined + >, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.IZone, + protos.google.cloud.edgenetwork.v1.IGetZoneRequest | null | undefined, + {} | null | undefined + > + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IZone, + protos.google.cloud.edgenetwork.v1.IGetZoneRequest | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + name: request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.getZone(request, options, callback); + } + /** + * Gets details of a single Network. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.Network|Network}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.get_network.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetNetwork_async + */ + getNetwork( + request?: protos.google.cloud.edgenetwork.v1.IGetNetworkRequest, + options?: CallOptions + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IGetNetworkRequest | undefined, + {} | undefined, + ] + >; + getNetwork( + request: protos.google.cloud.edgenetwork.v1.IGetNetworkRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IGetNetworkRequest | null | undefined, + {} | null | undefined + > + ): void; + getNetwork( + request: protos.google.cloud.edgenetwork.v1.IGetNetworkRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IGetNetworkRequest | null | undefined, + {} | null | undefined + > + ): void; + getNetwork( + request?: protos.google.cloud.edgenetwork.v1.IGetNetworkRequest, + optionsOrCallback?: + | CallOptions + | Callback< + protos.google.cloud.edgenetwork.v1.INetwork, + | protos.google.cloud.edgenetwork.v1.IGetNetworkRequest + | null + | undefined, + {} | null | undefined + >, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IGetNetworkRequest | null | undefined, + {} | null | undefined + > + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IGetNetworkRequest | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + name: request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.getNetwork(request, options, callback); + } + /** + * Get the diagnostics of a single network resource. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. The name of the network resource. + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse|DiagnoseNetworkResponse}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.diagnose_network.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DiagnoseNetwork_async + */ + diagnoseNetwork( + request?: protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest, + options?: CallOptions + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest | undefined, + {} | undefined, + ] + >; + diagnoseNetwork( + request: protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, + | protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest + | null + | undefined, + {} | null | undefined + > + ): void; + diagnoseNetwork( + request: protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, + | protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest + | null + | undefined, + {} | null | undefined + > + ): void; + diagnoseNetwork( + request?: protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest, + optionsOrCallback?: + | CallOptions + | Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, + | protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest + | null + | undefined, + {} | null | undefined + >, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, + | protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest + | null + | undefined, + {} | null | undefined + > + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkRequest | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + name: request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.diagnoseNetwork(request, options, callback); + } + /** + * Gets details of a single Subnet. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.Subnet|Subnet}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.get_subnet.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetSubnet_async + */ + getSubnet( + request?: protos.google.cloud.edgenetwork.v1.IGetSubnetRequest, + options?: CallOptions + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IGetSubnetRequest | undefined, + {} | undefined, + ] + >; + getSubnet( + request: protos.google.cloud.edgenetwork.v1.IGetSubnetRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IGetSubnetRequest | null | undefined, + {} | null | undefined + > + ): void; + getSubnet( + request: protos.google.cloud.edgenetwork.v1.IGetSubnetRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IGetSubnetRequest | null | undefined, + {} | null | undefined + > + ): void; + getSubnet( + request?: protos.google.cloud.edgenetwork.v1.IGetSubnetRequest, + optionsOrCallback?: + | CallOptions + | Callback< + protos.google.cloud.edgenetwork.v1.ISubnet, + | protos.google.cloud.edgenetwork.v1.IGetSubnetRequest + | null + | undefined, + {} | null | undefined + >, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IGetSubnetRequest | null | undefined, + {} | null | undefined + > + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IGetSubnetRequest | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + name: request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.getSubnet(request, options, callback); + } + /** + * Gets details of a single Interconnect. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.Interconnect|Interconnect}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.get_interconnect.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetInterconnect_async + */ + getInterconnect( + request?: protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest, + options?: CallOptions + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IInterconnect, + protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest | undefined, + {} | undefined, + ] + >; + getInterconnect( + request: protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IInterconnect, + | protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest + | null + | undefined, + {} | null | undefined + > + ): void; + getInterconnect( + request: protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IInterconnect, + | protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest + | null + | undefined, + {} | null | undefined + > + ): void; + getInterconnect( + request?: protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest, + optionsOrCallback?: + | CallOptions + | Callback< + protos.google.cloud.edgenetwork.v1.IInterconnect, + | protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest + | null + | undefined, + {} | null | undefined + >, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.IInterconnect, + | protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest + | null + | undefined, + {} | null | undefined + > + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IInterconnect, + protos.google.cloud.edgenetwork.v1.IGetInterconnectRequest | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + name: request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.getInterconnect(request, options, callback); + } + /** + * Get the diagnostics of a single interconnect resource. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. The name of the interconnect resource. + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse|DiagnoseInterconnectResponse}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.diagnose_interconnect.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DiagnoseInterconnect_async + */ + diagnoseInterconnect( + request?: protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest, + options?: CallOptions + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, + ( + | protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest + | undefined + ), + {} | undefined, + ] + >; + diagnoseInterconnect( + request: protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, + | protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest + | null + | undefined, + {} | null | undefined + > + ): void; + diagnoseInterconnect( + request: protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, + | protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest + | null + | undefined, + {} | null | undefined + > + ): void; + diagnoseInterconnect( + request?: protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest, + optionsOrCallback?: + | CallOptions + | Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, + | protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest + | null + | undefined, + {} | null | undefined + >, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, + | protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest + | null + | undefined, + {} | null | undefined + > + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse, + ( + | protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectRequest + | undefined + ), + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + name: request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.diagnoseInterconnect(request, options, callback); + } + /** + * Gets details of a single InterconnectAttachment. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.InterconnectAttachment|InterconnectAttachment}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.get_interconnect_attachment.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetInterconnectAttachment_async + */ + getInterconnectAttachment( + request?: protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest, + options?: CallOptions + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + ( + | protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest + | undefined + ), + {} | undefined, + ] + >; + getInterconnectAttachment( + request: protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + | protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest + | null + | undefined, + {} | null | undefined + > + ): void; + getInterconnectAttachment( + request: protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + | protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest + | null + | undefined, + {} | null | undefined + > + ): void; + getInterconnectAttachment( + request?: protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest, + optionsOrCallback?: + | CallOptions + | Callback< + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + | protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest + | null + | undefined, + {} | null | undefined + >, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + | protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest + | null + | undefined, + {} | null | undefined + > + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + ( + | protos.google.cloud.edgenetwork.v1.IGetInterconnectAttachmentRequest + | undefined + ), + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + name: request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.getInterconnectAttachment( + request, + options, + callback + ); + } + /** + * Gets details of a single Router. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.Router|Router}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.get_router.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_GetRouter_async + */ + getRouter( + request?: protos.google.cloud.edgenetwork.v1.IGetRouterRequest, + options?: CallOptions + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IGetRouterRequest | undefined, + {} | undefined, + ] + >; + getRouter( + request: protos.google.cloud.edgenetwork.v1.IGetRouterRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IGetRouterRequest | null | undefined, + {} | null | undefined + > + ): void; + getRouter( + request: protos.google.cloud.edgenetwork.v1.IGetRouterRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IGetRouterRequest | null | undefined, + {} | null | undefined + > + ): void; + getRouter( + request?: protos.google.cloud.edgenetwork.v1.IGetRouterRequest, + optionsOrCallback?: + | CallOptions + | Callback< + protos.google.cloud.edgenetwork.v1.IRouter, + | protos.google.cloud.edgenetwork.v1.IGetRouterRequest + | null + | undefined, + {} | null | undefined + >, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IGetRouterRequest | null | undefined, + {} | null | undefined + > + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IGetRouterRequest | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + name: request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.getRouter(request, options, callback); + } + /** + * Get the diagnostics of a single router resource. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. The name of the router resource. + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link protos.google.cloud.edgenetwork.v1.DiagnoseRouterResponse|DiagnoseRouterResponse}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.diagnose_router.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DiagnoseRouter_async + */ + diagnoseRouter( + request?: protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest, + options?: CallOptions + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest | undefined, + {} | undefined, + ] + >; + diagnoseRouter( + request: protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest, + options: CallOptions, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, + | protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest + | null + | undefined, + {} | null | undefined + > + ): void; + diagnoseRouter( + request: protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest, + callback: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, + | protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest + | null + | undefined, + {} | null | undefined + > + ): void; + diagnoseRouter( + request?: protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest, + optionsOrCallback?: + | CallOptions + | Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, + | protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest + | null + | undefined, + {} | null | undefined + >, + callback?: Callback< + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, + | protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest + | null + | undefined, + {} | null | undefined + > + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse, + protos.google.cloud.edgenetwork.v1.IDiagnoseRouterRequest | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + name: request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.diagnoseRouter(request, options, callback); + } + + /** + * Creates a new Network in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Value for parent. + * @param {string} request.networkId + * Required. Id of the requesting object + * If auto-generating Id server-side, remove this field and + * network_id from the method_signature of Create RPC + * @param {google.cloud.edgenetwork.v1.Network} request.network + * Required. The resource being created + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.create_network.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateNetwork_async + */ + createNetwork( + request?: protos.google.cloud.edgenetwork.v1.ICreateNetworkRequest, + options?: CallOptions + ): Promise< + [ + LROperation< + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + >; + createNetwork( + request: protos.google.cloud.edgenetwork.v1.ICreateNetworkRequest, + options: CallOptions, + callback: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + createNetwork( + request: protos.google.cloud.edgenetwork.v1.ICreateNetworkRequest, + callback: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + createNetwork( + request?: protos.google.cloud.edgenetwork.v1.ICreateNetworkRequest, + optionsOrCallback?: + | CallOptions + | Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + >, + callback?: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): Promise< + [ + LROperation< + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.createNetwork(request, options, callback); + } + /** + * Check the status of the long running operation returned by `createNetwork()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.create_network.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateNetwork_async + */ + async checkCreateNetworkProgress( + name: string + ): Promise< + LROperation< + protos.google.cloud.edgenetwork.v1.Network, + protos.google.cloud.edgenetwork.v1.OperationMetadata + > + > { + const request = + new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest( + {name} + ); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation( + operation, + this.descriptors.longrunning.createNetwork, + this._gaxModule.createDefaultBackoffSettings() + ); + return decodeOperation as LROperation< + protos.google.cloud.edgenetwork.v1.Network, + protos.google.cloud.edgenetwork.v1.OperationMetadata + >; + } + /** + * Deletes a single Network. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes after the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.delete_network.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteNetwork_async + */ + deleteNetwork( + request?: protos.google.cloud.edgenetwork.v1.IDeleteNetworkRequest, + options?: CallOptions + ): Promise< + [ + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + >; + deleteNetwork( + request: protos.google.cloud.edgenetwork.v1.IDeleteNetworkRequest, + options: CallOptions, + callback: Callback< + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + deleteNetwork( + request: protos.google.cloud.edgenetwork.v1.IDeleteNetworkRequest, + callback: Callback< + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + deleteNetwork( + request?: protos.google.cloud.edgenetwork.v1.IDeleteNetworkRequest, + optionsOrCallback?: + | CallOptions + | Callback< + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + >, + callback?: Callback< + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): Promise< + [ + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + name: request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.deleteNetwork(request, options, callback); + } + /** + * Check the status of the long running operation returned by `deleteNetwork()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.delete_network.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteNetwork_async + */ + async checkDeleteNetworkProgress( + name: string + ): Promise< + LROperation< + protos.google.protobuf.Empty, + protos.google.cloud.edgenetwork.v1.OperationMetadata + > + > { + const request = + new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest( + {name} + ); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation( + operation, + this.descriptors.longrunning.deleteNetwork, + this._gaxModule.createDefaultBackoffSettings() + ); + return decodeOperation as LROperation< + protos.google.protobuf.Empty, + protos.google.cloud.edgenetwork.v1.OperationMetadata + >; + } + /** + * Creates a new Subnet in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Value for parent. + * @param {string} request.subnetId + * Required. Id of the requesting object + * If auto-generating Id server-side, remove this field and + * subnet_id from the method_signature of Create RPC + * @param {google.cloud.edgenetwork.v1.Subnet} request.subnet + * Required. The resource being created + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.create_subnet.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateSubnet_async + */ + createSubnet( + request?: protos.google.cloud.edgenetwork.v1.ICreateSubnetRequest, + options?: CallOptions + ): Promise< + [ + LROperation< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + >; + createSubnet( + request: protos.google.cloud.edgenetwork.v1.ICreateSubnetRequest, + options: CallOptions, + callback: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + createSubnet( + request: protos.google.cloud.edgenetwork.v1.ICreateSubnetRequest, + callback: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + createSubnet( + request?: protos.google.cloud.edgenetwork.v1.ICreateSubnetRequest, + optionsOrCallback?: + | CallOptions + | Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + >, + callback?: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): Promise< + [ + LROperation< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.createSubnet(request, options, callback); + } + /** + * Check the status of the long running operation returned by `createSubnet()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.create_subnet.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateSubnet_async + */ + async checkCreateSubnetProgress( + name: string + ): Promise< + LROperation< + protos.google.cloud.edgenetwork.v1.Subnet, + protos.google.cloud.edgenetwork.v1.OperationMetadata + > + > { + const request = + new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest( + {name} + ); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation( + operation, + this.descriptors.longrunning.createSubnet, + this._gaxModule.createDefaultBackoffSettings() + ); + return decodeOperation as LROperation< + protos.google.cloud.edgenetwork.v1.Subnet, + protos.google.cloud.edgenetwork.v1.OperationMetadata + >; + } + /** + * Updates the parameters of a single Subnet. + * + * @param {Object} request + * The request object that will be sent. + * @param {google.protobuf.FieldMask} request.updateMask + * Required. Field mask is used to specify the fields to be overwritten in the + * Subnet resource by the update. + * The fields specified in the update_mask are relative to the resource, not + * the full request. A field will be overwritten if it is in the mask. If the + * user does not provide a mask then all fields will be overwritten. + * @param {google.cloud.edgenetwork.v1.Subnet} request.subnet + * Required. The resource being updated + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.update_subnet.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_UpdateSubnet_async + */ + updateSubnet( + request?: protos.google.cloud.edgenetwork.v1.IUpdateSubnetRequest, + options?: CallOptions + ): Promise< + [ + LROperation< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + >; + updateSubnet( + request: protos.google.cloud.edgenetwork.v1.IUpdateSubnetRequest, + options: CallOptions, + callback: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + updateSubnet( + request: protos.google.cloud.edgenetwork.v1.IUpdateSubnetRequest, + callback: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + updateSubnet( + request?: protos.google.cloud.edgenetwork.v1.IUpdateSubnetRequest, + optionsOrCallback?: + | CallOptions + | Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + >, + callback?: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): Promise< + [ + LROperation< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + 'subnet.name': request.subnet!.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.updateSubnet(request, options, callback); + } + /** + * Check the status of the long running operation returned by `updateSubnet()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.update_subnet.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_UpdateSubnet_async + */ + async checkUpdateSubnetProgress( + name: string + ): Promise< + LROperation< + protos.google.cloud.edgenetwork.v1.Subnet, + protos.google.cloud.edgenetwork.v1.OperationMetadata + > + > { + const request = + new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest( + {name} + ); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation( + operation, + this.descriptors.longrunning.updateSubnet, + this._gaxModule.createDefaultBackoffSettings() + ); + return decodeOperation as LROperation< + protos.google.cloud.edgenetwork.v1.Subnet, + protos.google.cloud.edgenetwork.v1.OperationMetadata + >; + } + /** + * Deletes a single Subnet. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes after the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.delete_subnet.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteSubnet_async + */ + deleteSubnet( + request?: protos.google.cloud.edgenetwork.v1.IDeleteSubnetRequest, + options?: CallOptions + ): Promise< + [ + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + >; + deleteSubnet( + request: protos.google.cloud.edgenetwork.v1.IDeleteSubnetRequest, + options: CallOptions, + callback: Callback< + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + deleteSubnet( + request: protos.google.cloud.edgenetwork.v1.IDeleteSubnetRequest, + callback: Callback< + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + deleteSubnet( + request?: protos.google.cloud.edgenetwork.v1.IDeleteSubnetRequest, + optionsOrCallback?: + | CallOptions + | Callback< + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + >, + callback?: Callback< + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): Promise< + [ + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + name: request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.deleteSubnet(request, options, callback); + } + /** + * Check the status of the long running operation returned by `deleteSubnet()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.delete_subnet.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteSubnet_async + */ + async checkDeleteSubnetProgress( + name: string + ): Promise< + LROperation< + protos.google.protobuf.Empty, + protos.google.cloud.edgenetwork.v1.OperationMetadata + > + > { + const request = + new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest( + {name} + ); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation( + operation, + this.descriptors.longrunning.deleteSubnet, + this._gaxModule.createDefaultBackoffSettings() + ); + return decodeOperation as LROperation< + protos.google.protobuf.Empty, + protos.google.cloud.edgenetwork.v1.OperationMetadata + >; + } + /** + * Creates a new InterconnectAttachment in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Value for parent. + * @param {string} request.interconnectAttachmentId + * Required. Id of the requesting object + * If auto-generating Id server-side, remove this field and + * interconnect_attachment_id from the method_signature of Create RPC + * @param {google.cloud.edgenetwork.v1.InterconnectAttachment} request.interconnectAttachment + * Required. The resource being created + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.create_interconnect_attachment.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateInterconnectAttachment_async + */ + createInterconnectAttachment( + request?: protos.google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest, + options?: CallOptions + ): Promise< + [ + LROperation< + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + >; + createInterconnectAttachment( + request: protos.google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest, + options: CallOptions, + callback: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + createInterconnectAttachment( + request: protos.google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest, + callback: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + createInterconnectAttachment( + request?: protos.google.cloud.edgenetwork.v1.ICreateInterconnectAttachmentRequest, + optionsOrCallback?: + | CallOptions + | Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + >, + callback?: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): Promise< + [ + LROperation< + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.createInterconnectAttachment( + request, + options, + callback + ); + } + /** + * Check the status of the long running operation returned by `createInterconnectAttachment()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.create_interconnect_attachment.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateInterconnectAttachment_async + */ + async checkCreateInterconnectAttachmentProgress( + name: string + ): Promise< + LROperation< + protos.google.cloud.edgenetwork.v1.InterconnectAttachment, + protos.google.cloud.edgenetwork.v1.OperationMetadata + > + > { + const request = + new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest( + {name} + ); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation( + operation, + this.descriptors.longrunning.createInterconnectAttachment, + this._gaxModule.createDefaultBackoffSettings() + ); + return decodeOperation as LROperation< + protos.google.cloud.edgenetwork.v1.InterconnectAttachment, + protos.google.cloud.edgenetwork.v1.OperationMetadata + >; + } + /** + * Deletes a single InterconnectAttachment. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes after the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.delete_interconnect_attachment.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteInterconnectAttachment_async + */ + deleteInterconnectAttachment( + request?: protos.google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest, + options?: CallOptions + ): Promise< + [ + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + >; + deleteInterconnectAttachment( + request: protos.google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest, + options: CallOptions, + callback: Callback< + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + deleteInterconnectAttachment( + request: protos.google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest, + callback: Callback< + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + deleteInterconnectAttachment( + request?: protos.google.cloud.edgenetwork.v1.IDeleteInterconnectAttachmentRequest, + optionsOrCallback?: + | CallOptions + | Callback< + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + >, + callback?: Callback< + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): Promise< + [ + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + name: request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.deleteInterconnectAttachment( + request, + options, + callback + ); + } + /** + * Check the status of the long running operation returned by `deleteInterconnectAttachment()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.delete_interconnect_attachment.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteInterconnectAttachment_async + */ + async checkDeleteInterconnectAttachmentProgress( + name: string + ): Promise< + LROperation< + protos.google.protobuf.Empty, + protos.google.cloud.edgenetwork.v1.OperationMetadata + > + > { + const request = + new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest( + {name} + ); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation( + operation, + this.descriptors.longrunning.deleteInterconnectAttachment, + this._gaxModule.createDefaultBackoffSettings() + ); + return decodeOperation as LROperation< + protos.google.protobuf.Empty, + protos.google.cloud.edgenetwork.v1.OperationMetadata + >; + } + /** + * Creates a new Router in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Value for parent. + * @param {string} request.routerId + * Required. Id of the requesting object + * If auto-generating Id server-side, remove this field and + * router_id from the method_signature of Create RPC + * @param {google.cloud.edgenetwork.v1.Router} request.router + * Required. The resource being created + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.create_router.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateRouter_async + */ + createRouter( + request?: protos.google.cloud.edgenetwork.v1.ICreateRouterRequest, + options?: CallOptions + ): Promise< + [ + LROperation< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + >; + createRouter( + request: protos.google.cloud.edgenetwork.v1.ICreateRouterRequest, + options: CallOptions, + callback: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + createRouter( + request: protos.google.cloud.edgenetwork.v1.ICreateRouterRequest, + callback: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + createRouter( + request?: protos.google.cloud.edgenetwork.v1.ICreateRouterRequest, + optionsOrCallback?: + | CallOptions + | Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + >, + callback?: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): Promise< + [ + LROperation< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.createRouter(request, options, callback); + } + /** + * Check the status of the long running operation returned by `createRouter()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.create_router.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_CreateRouter_async + */ + async checkCreateRouterProgress( + name: string + ): Promise< + LROperation< + protos.google.cloud.edgenetwork.v1.Router, + protos.google.cloud.edgenetwork.v1.OperationMetadata + > + > { + const request = + new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest( + {name} + ); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation( + operation, + this.descriptors.longrunning.createRouter, + this._gaxModule.createDefaultBackoffSettings() + ); + return decodeOperation as LROperation< + protos.google.cloud.edgenetwork.v1.Router, + protos.google.cloud.edgenetwork.v1.OperationMetadata + >; + } + /** + * Updates the parameters of a single Router. + * + * @param {Object} request + * The request object that will be sent. + * @param {google.protobuf.FieldMask} request.updateMask + * Required. Field mask is used to specify the fields to be overwritten in the + * Router resource by the update. + * The fields specified in the update_mask are relative to the resource, not + * the full request. A field will be overwritten if it is in the mask. If the + * user does not provide a mask then all fields will be overwritten. + * @param {google.cloud.edgenetwork.v1.Router} request.router + * Required. The resource being updated + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes since the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.update_router.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_UpdateRouter_async + */ + updateRouter( + request?: protos.google.cloud.edgenetwork.v1.IUpdateRouterRequest, + options?: CallOptions + ): Promise< + [ + LROperation< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + >; + updateRouter( + request: protos.google.cloud.edgenetwork.v1.IUpdateRouterRequest, + options: CallOptions, + callback: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + updateRouter( + request: protos.google.cloud.edgenetwork.v1.IUpdateRouterRequest, + callback: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + updateRouter( + request?: protos.google.cloud.edgenetwork.v1.IUpdateRouterRequest, + optionsOrCallback?: + | CallOptions + | Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + >, + callback?: Callback< + LROperation< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): Promise< + [ + LROperation< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + 'router.name': request.router!.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.updateRouter(request, options, callback); + } + /** + * Check the status of the long running operation returned by `updateRouter()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.update_router.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_UpdateRouter_async + */ + async checkUpdateRouterProgress( + name: string + ): Promise< + LROperation< + protos.google.cloud.edgenetwork.v1.Router, + protos.google.cloud.edgenetwork.v1.OperationMetadata + > + > { + const request = + new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest( + {name} + ); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation( + operation, + this.descriptors.longrunning.updateRouter, + this._gaxModule.createDefaultBackoffSettings() + ); + return decodeOperation as LROperation< + protos.google.cloud.edgenetwork.v1.Router, + protos.google.cloud.edgenetwork.v1.OperationMetadata + >; + } + /** + * Deletes a single Router. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Required. Name of the resource + * @param {string} [request.requestId] + * Optional. An optional request ID to identify requests. Specify a unique + * request ID so that if you must retry your request, the server will know to + * ignore the request if it has already been completed. The server will + * guarantee that for at least 60 minutes after the first request. + * + * For example, consider a situation where you make an initial request and + * the request times out. If you make the request again with the same request + * ID, the server can check if original operation with the same request ID + * was received, and if so, will ignore the second request. This prevents + * clients from accidentally creating duplicate commitments. + * + * The request ID must be a valid UUID with the exception that zero UUID is + * not supported (00000000-0000-0000-0000-000000000000). + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * a long running operation. Its `promise()` method returns a promise + * you can `await` for. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.delete_router.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteRouter_async + */ + deleteRouter( + request?: protos.google.cloud.edgenetwork.v1.IDeleteRouterRequest, + options?: CallOptions + ): Promise< + [ + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + >; + deleteRouter( + request: protos.google.cloud.edgenetwork.v1.IDeleteRouterRequest, + options: CallOptions, + callback: Callback< + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + deleteRouter( + request: protos.google.cloud.edgenetwork.v1.IDeleteRouterRequest, + callback: Callback< + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): void; + deleteRouter( + request?: protos.google.cloud.edgenetwork.v1.IDeleteRouterRequest, + optionsOrCallback?: + | CallOptions + | Callback< + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + >, + callback?: Callback< + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | null | undefined, + {} | null | undefined + > + ): Promise< + [ + LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >, + protos.google.longrunning.IOperation | undefined, + {} | undefined, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + name: request.name ?? '', + }); + this.initialize(); + return this.innerApiCalls.deleteRouter(request, options, callback); + } + /** + * Check the status of the long running operation returned by `deleteRouter()`. + * @param {String} name + * The operation name that will be passed. + * @returns {Promise} - The promise which resolves to an object. + * The decoded operation object has result and metadata field to get information from. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#long-running-operations | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.delete_router.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_DeleteRouter_async + */ + async checkDeleteRouterProgress( + name: string + ): Promise< + LROperation< + protos.google.protobuf.Empty, + protos.google.cloud.edgenetwork.v1.OperationMetadata + > + > { + const request = + new this._gaxModule.operationsProtos.google.longrunning.GetOperationRequest( + {name} + ); + const [operation] = await this.operationsClient.getOperation(request); + const decodeOperation = new this._gaxModule.Operation( + operation, + this.descriptors.longrunning.deleteRouter, + this._gaxModule.createDefaultBackoffSettings() + ); + return decodeOperation as LROperation< + protos.google.protobuf.Empty, + protos.google.cloud.edgenetwork.v1.OperationMetadata + >; + } + /** + * Lists Zones in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListZonesRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.Zone|Zone}. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed and will merge results from all the pages into this array. + * Note that it can affect your quota. + * We recommend using `listZonesAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listZones( + request?: protos.google.cloud.edgenetwork.v1.IListZonesRequest, + options?: CallOptions + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IZone[], + protos.google.cloud.edgenetwork.v1.IListZonesRequest | null, + protos.google.cloud.edgenetwork.v1.IListZonesResponse, + ] + >; + listZones( + request: protos.google.cloud.edgenetwork.v1.IListZonesRequest, + options: CallOptions, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListZonesRequest, + protos.google.cloud.edgenetwork.v1.IListZonesResponse | null | undefined, + protos.google.cloud.edgenetwork.v1.IZone + > + ): void; + listZones( + request: protos.google.cloud.edgenetwork.v1.IListZonesRequest, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListZonesRequest, + protos.google.cloud.edgenetwork.v1.IListZonesResponse | null | undefined, + protos.google.cloud.edgenetwork.v1.IZone + > + ): void; + listZones( + request?: protos.google.cloud.edgenetwork.v1.IListZonesRequest, + optionsOrCallback?: + | CallOptions + | PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListZonesRequest, + | protos.google.cloud.edgenetwork.v1.IListZonesResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.IZone + >, + callback?: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListZonesRequest, + protos.google.cloud.edgenetwork.v1.IListZonesResponse | null | undefined, + protos.google.cloud.edgenetwork.v1.IZone + > + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IZone[], + protos.google.cloud.edgenetwork.v1.IListZonesRequest | null, + protos.google.cloud.edgenetwork.v1.IListZonesResponse, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.listZones(request, options, callback); + } + + /** + * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListZonesRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Stream} + * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.Zone|Zone} on 'data' event. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed. Note that it can affect your quota. + * We recommend using `listZonesAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listZonesStream( + request?: protos.google.cloud.edgenetwork.v1.IListZonesRequest, + options?: CallOptions + ): Transform { + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listZones']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listZones.createStream( + this.innerApiCalls.listZones as GaxCall, + request, + callSettings + ); + } + + /** + * Equivalent to `listZones`, but returns an iterable object. + * + * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListZonesRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Object} + * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. + * When you iterate the returned iterable, each element will be an object representing + * {@link protos.google.cloud.edgenetwork.v1.Zone|Zone}. The API will be called under the hood as needed, once per the page, + * so you can stop the iteration when you don't need more results. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.list_zones.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListZones_async + */ + listZonesAsync( + request?: protos.google.cloud.edgenetwork.v1.IListZonesRequest, + options?: CallOptions + ): AsyncIterable { + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listZones']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listZones.asyncIterate( + this.innerApiCalls['listZones'] as GaxCall, + request as {}, + callSettings + ) as AsyncIterable; + } + /** + * Lists Networks in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListNetworksRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.Network|Network}. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed and will merge results from all the pages into this array. + * Note that it can affect your quota. + * We recommend using `listNetworksAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listNetworks( + request?: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + options?: CallOptions + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.INetwork[], + protos.google.cloud.edgenetwork.v1.IListNetworksRequest | null, + protos.google.cloud.edgenetwork.v1.IListNetworksResponse, + ] + >; + listNetworks( + request: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + options: CallOptions, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + | protos.google.cloud.edgenetwork.v1.IListNetworksResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.INetwork + > + ): void; + listNetworks( + request: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + | protos.google.cloud.edgenetwork.v1.IListNetworksResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.INetwork + > + ): void; + listNetworks( + request?: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + optionsOrCallback?: + | CallOptions + | PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + | protos.google.cloud.edgenetwork.v1.IListNetworksResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.INetwork + >, + callback?: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + | protos.google.cloud.edgenetwork.v1.IListNetworksResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.INetwork + > + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.INetwork[], + protos.google.cloud.edgenetwork.v1.IListNetworksRequest | null, + protos.google.cloud.edgenetwork.v1.IListNetworksResponse, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.listNetworks(request, options, callback); + } + + /** + * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListNetworksRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Stream} + * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.Network|Network} on 'data' event. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed. Note that it can affect your quota. + * We recommend using `listNetworksAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listNetworksStream( + request?: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + options?: CallOptions + ): Transform { + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listNetworks']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listNetworks.createStream( + this.innerApiCalls.listNetworks as GaxCall, + request, + callSettings + ); + } + + /** + * Equivalent to `listNetworks`, but returns an iterable object. + * + * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListNetworksRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Object} + * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. + * When you iterate the returned iterable, each element will be an object representing + * {@link protos.google.cloud.edgenetwork.v1.Network|Network}. The API will be called under the hood as needed, once per the page, + * so you can stop the iteration when you don't need more results. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.list_networks.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListNetworks_async + */ + listNetworksAsync( + request?: protos.google.cloud.edgenetwork.v1.IListNetworksRequest, + options?: CallOptions + ): AsyncIterable { + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listNetworks']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listNetworks.asyncIterate( + this.innerApiCalls['listNetworks'] as GaxCall, + request as {}, + callSettings + ) as AsyncIterable; + } + /** + * Lists Subnets in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListSubnetsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.Subnet|Subnet}. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed and will merge results from all the pages into this array. + * Note that it can affect your quota. + * We recommend using `listSubnetsAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listSubnets( + request?: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + options?: CallOptions + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.ISubnet[], + protos.google.cloud.edgenetwork.v1.IListSubnetsRequest | null, + protos.google.cloud.edgenetwork.v1.IListSubnetsResponse, + ] + >; + listSubnets( + request: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + options: CallOptions, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + | protos.google.cloud.edgenetwork.v1.IListSubnetsResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.ISubnet + > + ): void; + listSubnets( + request: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + | protos.google.cloud.edgenetwork.v1.IListSubnetsResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.ISubnet + > + ): void; + listSubnets( + request?: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + optionsOrCallback?: + | CallOptions + | PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + | protos.google.cloud.edgenetwork.v1.IListSubnetsResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.ISubnet + >, + callback?: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + | protos.google.cloud.edgenetwork.v1.IListSubnetsResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.ISubnet + > + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.ISubnet[], + protos.google.cloud.edgenetwork.v1.IListSubnetsRequest | null, + protos.google.cloud.edgenetwork.v1.IListSubnetsResponse, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.listSubnets(request, options, callback); + } + + /** + * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListSubnetsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Stream} + * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.Subnet|Subnet} on 'data' event. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed. Note that it can affect your quota. + * We recommend using `listSubnetsAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listSubnetsStream( + request?: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + options?: CallOptions + ): Transform { + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listSubnets']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listSubnets.createStream( + this.innerApiCalls.listSubnets as GaxCall, + request, + callSettings + ); + } + + /** + * Equivalent to `listSubnets`, but returns an iterable object. + * + * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListSubnetsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Object} + * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. + * When you iterate the returned iterable, each element will be an object representing + * {@link protos.google.cloud.edgenetwork.v1.Subnet|Subnet}. The API will be called under the hood as needed, once per the page, + * so you can stop the iteration when you don't need more results. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.list_subnets.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListSubnets_async + */ + listSubnetsAsync( + request?: protos.google.cloud.edgenetwork.v1.IListSubnetsRequest, + options?: CallOptions + ): AsyncIterable { + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listSubnets']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listSubnets.asyncIterate( + this.innerApiCalls['listSubnets'] as GaxCall, + request as {}, + callSettings + ) as AsyncIterable; + } + /** + * Lists Interconnects in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListInterconnectsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.Interconnect|Interconnect}. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed and will merge results from all the pages into this array. + * Note that it can affect your quota. + * We recommend using `listInterconnectsAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listInterconnects( + request?: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + options?: CallOptions + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IInterconnect[], + protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest | null, + protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse, + ] + >; + listInterconnects( + request: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + options: CallOptions, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + | protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.IInterconnect + > + ): void; + listInterconnects( + request: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + | protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.IInterconnect + > + ): void; + listInterconnects( + request?: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + optionsOrCallback?: + | CallOptions + | PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + | protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.IInterconnect + >, + callback?: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + | protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.IInterconnect + > + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IInterconnect[], + protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest | null, + protos.google.cloud.edgenetwork.v1.IListInterconnectsResponse, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.listInterconnects(request, options, callback); + } + + /** + * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListInterconnectsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Stream} + * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.Interconnect|Interconnect} on 'data' event. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed. Note that it can affect your quota. + * We recommend using `listInterconnectsAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listInterconnectsStream( + request?: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + options?: CallOptions + ): Transform { + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listInterconnects']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listInterconnects.createStream( + this.innerApiCalls.listInterconnects as GaxCall, + request, + callSettings + ); + } + + /** + * Equivalent to `listInterconnects`, but returns an iterable object. + * + * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListInterconnectsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Object} + * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. + * When you iterate the returned iterable, each element will be an object representing + * {@link protos.google.cloud.edgenetwork.v1.Interconnect|Interconnect}. The API will be called under the hood as needed, once per the page, + * so you can stop the iteration when you don't need more results. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.list_interconnects.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListInterconnects_async + */ + listInterconnectsAsync( + request?: protos.google.cloud.edgenetwork.v1.IListInterconnectsRequest, + options?: CallOptions + ): AsyncIterable { + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listInterconnects']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listInterconnects.asyncIterate( + this.innerApiCalls['listInterconnects'] as GaxCall, + request as {}, + callSettings + ) as AsyncIterable; + } + /** + * Lists InterconnectAttachments in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListInterconnectAttachmentsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.InterconnectAttachment|InterconnectAttachment}. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed and will merge results from all the pages into this array. + * Note that it can affect your quota. + * We recommend using `listInterconnectAttachmentsAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listInterconnectAttachments( + request?: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + options?: CallOptions + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment[], + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest | null, + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse, + ] + >; + listInterconnectAttachments( + request: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + options: CallOptions, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + | protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment + > + ): void; + listInterconnectAttachments( + request: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + | protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment + > + ): void; + listInterconnectAttachments( + request?: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + optionsOrCallback?: + | CallOptions + | PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + | protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment + >, + callback?: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + | protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment + > + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment[], + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest | null, + protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsResponse, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.listInterconnectAttachments( + request, + options, + callback + ); + } + + /** + * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListInterconnectAttachmentsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Stream} + * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.InterconnectAttachment|InterconnectAttachment} on 'data' event. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed. Note that it can affect your quota. + * We recommend using `listInterconnectAttachmentsAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listInterconnectAttachmentsStream( + request?: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + options?: CallOptions + ): Transform { + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listInterconnectAttachments']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listInterconnectAttachments.createStream( + this.innerApiCalls.listInterconnectAttachments as GaxCall, + request, + callSettings + ); + } + + /** + * Equivalent to `listInterconnectAttachments`, but returns an iterable object. + * + * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListInterconnectAttachmentsRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Object} + * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. + * When you iterate the returned iterable, each element will be an object representing + * {@link protos.google.cloud.edgenetwork.v1.InterconnectAttachment|InterconnectAttachment}. The API will be called under the hood as needed, once per the page, + * so you can stop the iteration when you don't need more results. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.list_interconnect_attachments.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListInterconnectAttachments_async + */ + listInterconnectAttachmentsAsync( + request?: protos.google.cloud.edgenetwork.v1.IListInterconnectAttachmentsRequest, + options?: CallOptions + ): AsyncIterable { + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listInterconnectAttachments']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listInterconnectAttachments.asyncIterate( + this.innerApiCalls['listInterconnectAttachments'] as GaxCall, + request as {}, + callSettings + ) as AsyncIterable; + } + /** + * Lists Routers in a given project and location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListRoutersRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is Array of {@link protos.google.cloud.edgenetwork.v1.Router|Router}. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed and will merge results from all the pages into this array. + * Note that it can affect your quota. + * We recommend using `listRoutersAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listRouters( + request?: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + options?: CallOptions + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IRouter[], + protos.google.cloud.edgenetwork.v1.IListRoutersRequest | null, + protos.google.cloud.edgenetwork.v1.IListRoutersResponse, + ] + >; + listRouters( + request: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + options: CallOptions, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + | protos.google.cloud.edgenetwork.v1.IListRoutersResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.IRouter + > + ): void; + listRouters( + request: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + callback: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + | protos.google.cloud.edgenetwork.v1.IListRoutersResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.IRouter + > + ): void; + listRouters( + request?: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + optionsOrCallback?: + | CallOptions + | PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + | protos.google.cloud.edgenetwork.v1.IListRoutersResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.IRouter + >, + callback?: PaginationCallback< + protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + | protos.google.cloud.edgenetwork.v1.IListRoutersResponse + | null + | undefined, + protos.google.cloud.edgenetwork.v1.IRouter + > + ): Promise< + [ + protos.google.cloud.edgenetwork.v1.IRouter[], + protos.google.cloud.edgenetwork.v1.IListRoutersRequest | null, + protos.google.cloud.edgenetwork.v1.IListRoutersResponse, + ] + > | void { + request = request || {}; + let options: CallOptions; + if (typeof optionsOrCallback === 'function' && callback === undefined) { + callback = optionsOrCallback; + options = {}; + } else { + options = optionsOrCallback as CallOptions; + } + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + this.initialize(); + return this.innerApiCalls.listRouters(request, options, callback); + } + + /** + * Equivalent to `method.name.toCamelCase()`, but returns a NodeJS Stream object. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListRoutersRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Stream} + * An object stream which emits an object representing {@link protos.google.cloud.edgenetwork.v1.Router|Router} on 'data' event. + * The client library will perform auto-pagination by default: it will call the API as many + * times as needed. Note that it can affect your quota. + * We recommend using `listRoutersAsync()` + * method described below for async iteration which you can stop as needed. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + */ + listRoutersStream( + request?: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + options?: CallOptions + ): Transform { + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listRouters']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listRouters.createStream( + this.innerApiCalls.listRouters as GaxCall, + request, + callSettings + ); + } + + /** + * Equivalent to `listRouters`, but returns an iterable object. + * + * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.parent + * Required. Parent value for ListRoutersRequest + * @param {number} request.pageSize + * Requested page size. Server may return fewer items than requested. + * If unspecified, server will pick an appropriate default. + * @param {string} request.pageToken + * A token identifying a page of results the server should return. + * @param {string} request.filter + * Filtering results + * @param {string} request.orderBy + * Hint for how to order the results + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Object} + * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. + * When you iterate the returned iterable, each element will be an object representing + * {@link protos.google.cloud.edgenetwork.v1.Router|Router}. The API will be called under the hood as needed, once per the page, + * so you can stop the iteration when you don't need more results. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + * @example include:samples/generated/v1/edge_network.list_routers.js + * region_tag:edgenetwork_v1_generated_EdgeNetwork_ListRouters_async + */ + listRoutersAsync( + request?: protos.google.cloud.edgenetwork.v1.IListRoutersRequest, + options?: CallOptions + ): AsyncIterable { + request = request || {}; + options = options || {}; + options.otherArgs = options.otherArgs || {}; + options.otherArgs.headers = options.otherArgs.headers || {}; + options.otherArgs.headers['x-goog-request-params'] = + this._gaxModule.routingHeader.fromParams({ + parent: request.parent ?? '', + }); + const defaultCallSettings = this._defaults['listRouters']; + const callSettings = defaultCallSettings.merge(options); + this.initialize(); + return this.descriptors.page.listRouters.asyncIterate( + this.innerApiCalls['listRouters'] as GaxCall, + request as {}, + callSettings + ) as AsyncIterable; + } + /** + * Gets information about a location. + * + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * Resource name for the location. + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html | CallOptions} for more details. + * @returns {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing {@link google.cloud.location.Location | Location}. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#regular-methods | documentation } + * for more details and examples. + * @example + * ``` + * const [response] = await client.getLocation(request); + * ``` + */ + getLocation( + request: LocationProtos.google.cloud.location.IGetLocationRequest, + options?: + | gax.CallOptions + | Callback< + LocationProtos.google.cloud.location.ILocation, + | LocationProtos.google.cloud.location.IGetLocationRequest + | null + | undefined, + {} | null | undefined + >, + callback?: Callback< + LocationProtos.google.cloud.location.ILocation, + | LocationProtos.google.cloud.location.IGetLocationRequest + | null + | undefined, + {} | null | undefined + > + ): Promise { + return this.locationsClient.getLocation(request, options, callback); + } + + /** + * Lists information about the supported locations for this service. Returns an iterable object. + * + * `for`-`await`-`of` syntax is used with the iterable to get response elements on-demand. + * @param {Object} request + * The request object that will be sent. + * @param {string} request.name + * The resource that owns the locations collection, if applicable. + * @param {string} request.filter + * The standard list filter. + * @param {number} request.pageSize + * The standard list page size. + * @param {string} request.pageToken + * The standard list page token. + * @param {object} [options] + * Call options. See {@link https://googleapis.dev/nodejs/google-gax/latest/interfaces/CallOptions.html|CallOptions} for more details. + * @returns {Object} + * An iterable Object that allows {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | async iteration }. + * When you iterate the returned iterable, each element will be an object representing + * {@link google.cloud.location.Location | Location}. The API will be called under the hood as needed, once per the page, + * so you can stop the iteration when you don't need more results. + * Please see the {@link https://github.com/googleapis/gax-nodejs/blob/master/client-libraries.md#auto-pagination | documentation } + * for more details and examples. + * @example + * ``` + * const iterable = client.listLocationsAsync(request); + * for await (const response of iterable) { + * // process response + * } + * ``` + */ + listLocationsAsync( + request: LocationProtos.google.cloud.location.IListLocationsRequest, + options?: CallOptions + ): AsyncIterable { + return this.locationsClient.listLocationsAsync(request, options); + } + + /** + * Gets the latest state of a long-running operation. Clients can use this + * method to poll the operation result at intervals as recommended by the API + * service. + * + * @param {Object} request - The request object that will be sent. + * @param {string} request.name - The name of the operation resource. + * @param {Object=} options + * Optional parameters. You can override the default settings for this call, + * e.g, timeout, retries, paginations, etc. See {@link + * https://googleapis.github.io/gax-nodejs/global.html#CallOptions | gax.CallOptions} + * for the details. + * @param {function(?Error, ?Object)=} callback + * The function which will be called with the result of the API call. + * + * The second parameter to the callback is an object representing + * {@link google.longrunning.Operation | google.longrunning.Operation}. + * @return {Promise} - The promise which resolves to an array. + * The first element of the array is an object representing + * {@link google.longrunning.Operation | google.longrunning.Operation}. + * The promise has a method named "cancel" which cancels the ongoing API call. + * + * @example + * ``` + * const client = longrunning.operationsClient(); + * const name = ''; + * const [response] = await client.getOperation({name}); + * // doThingsWith(response) + * ``` + */ + getOperation( + request: protos.google.longrunning.GetOperationRequest, + options?: + | gax.CallOptions + | Callback< + protos.google.longrunning.Operation, + protos.google.longrunning.GetOperationRequest, + {} | null | undefined + >, + callback?: Callback< + protos.google.longrunning.Operation, + protos.google.longrunning.GetOperationRequest, + {} | null | undefined + > + ): Promise<[protos.google.longrunning.Operation]> { + return this.operationsClient.getOperation(request, options, callback); + } + /** + * Lists operations that match the specified filter in the request. If the + * server doesn't support this method, it returns `UNIMPLEMENTED`. Returns an iterable object. + * + * For-await-of syntax is used with the iterable to recursively get response element on-demand. + * + * @param {Object} request - The request object that will be sent. + * @param {string} request.name - The name of the operation collection. + * @param {string} request.filter - The standard list filter. + * @param {number=} request.pageSize - + * The maximum number of resources contained in the underlying API + * response. If page streaming is performed per-resource, this + * parameter does not affect the return value. If page streaming is + * performed per-page, this determines the maximum number of + * resources in a page. + * @param {Object=} options + * Optional parameters. You can override the default settings for this call, + * e.g, timeout, retries, paginations, etc. See {@link + * https://googleapis.github.io/gax-nodejs/global.html#CallOptions | gax.CallOptions} for the + * details. + * @returns {Object} + * An iterable Object that conforms to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols | iteration protocols}. + * + * @example + * ``` + * const client = longrunning.operationsClient(); + * for await (const response of client.listOperationsAsync(request)); + * // doThingsWith(response) + * ``` + */ + listOperationsAsync( + request: protos.google.longrunning.ListOperationsRequest, + options?: gax.CallOptions + ): AsyncIterable { + return this.operationsClient.listOperationsAsync(request, options); + } + /** + * Starts asynchronous cancellation on a long-running operation. The server + * makes a best effort to cancel the operation, but success is not + * guaranteed. If the server doesn't support this method, it returns + * `google.rpc.Code.UNIMPLEMENTED`. Clients can use + * {@link Operations.GetOperation} or + * other methods to check whether the cancellation succeeded or whether the + * operation completed despite cancellation. On successful cancellation, + * the operation is not deleted; instead, it becomes an operation with + * an {@link Operation.error} value with a {@link google.rpc.Status.code} of + * 1, corresponding to `Code.CANCELLED`. + * + * @param {Object} request - The request object that will be sent. + * @param {string} request.name - The name of the operation resource to be cancelled. + * @param {Object=} options + * Optional parameters. You can override the default settings for this call, + * e.g, timeout, retries, paginations, etc. See {@link + * https://googleapis.github.io/gax-nodejs/global.html#CallOptions | gax.CallOptions} for the + * details. + * @param {function(?Error)=} callback + * The function which will be called with the result of the API call. + * @return {Promise} - The promise which resolves when API call finishes. + * The promise has a method named "cancel" which cancels the ongoing API + * call. + * + * @example + * ``` + * const client = longrunning.operationsClient(); + * await client.cancelOperation({name: ''}); + * ``` + */ + cancelOperation( + request: protos.google.longrunning.CancelOperationRequest, + options?: + | gax.CallOptions + | Callback< + protos.google.protobuf.Empty, + protos.google.longrunning.CancelOperationRequest, + {} | undefined | null + >, + callback?: Callback< + protos.google.longrunning.CancelOperationRequest, + protos.google.protobuf.Empty, + {} | undefined | null + > + ): Promise { + return this.operationsClient.cancelOperation(request, options, callback); + } + + /** + * Deletes a long-running operation. This method indicates that the client is + * no longer interested in the operation result. It does not cancel the + * operation. If the server doesn't support this method, it returns + * `google.rpc.Code.UNIMPLEMENTED`. + * + * @param {Object} request - The request object that will be sent. + * @param {string} request.name - The name of the operation resource to be deleted. + * @param {Object=} options + * Optional parameters. You can override the default settings for this call, + * e.g, timeout, retries, paginations, etc. See {@link + * https://googleapis.github.io/gax-nodejs/global.html#CallOptions | gax.CallOptions} + * for the details. + * @param {function(?Error)=} callback + * The function which will be called with the result of the API call. + * @return {Promise} - The promise which resolves when API call finishes. + * The promise has a method named "cancel" which cancels the ongoing API + * call. + * + * @example + * ``` + * const client = longrunning.operationsClient(); + * await client.deleteOperation({name: ''}); + * ``` + */ + deleteOperation( + request: protos.google.longrunning.DeleteOperationRequest, + options?: + | gax.CallOptions + | Callback< + protos.google.protobuf.Empty, + protos.google.longrunning.DeleteOperationRequest, + {} | null | undefined + >, + callback?: Callback< + protos.google.protobuf.Empty, + protos.google.longrunning.DeleteOperationRequest, + {} | null | undefined + > + ): Promise { + return this.operationsClient.deleteOperation(request, options, callback); + } + + // -------------------- + // -- Path templates -- + // -------------------- + + /** + * Return a fully-qualified interconnect resource name string. + * + * @param {string} project + * @param {string} location + * @param {string} zone + * @param {string} interconnect + * @returns {string} Resource name string. + */ + interconnectPath( + project: string, + location: string, + zone: string, + interconnect: string + ) { + return this.pathTemplates.interconnectPathTemplate.render({ + project: project, + location: location, + zone: zone, + interconnect: interconnect, + }); + } + + /** + * Parse the project from Interconnect resource. + * + * @param {string} interconnectName + * A fully-qualified path representing Interconnect resource. + * @returns {string} A string representing the project. + */ + matchProjectFromInterconnectName(interconnectName: string) { + return this.pathTemplates.interconnectPathTemplate.match(interconnectName) + .project; + } + + /** + * Parse the location from Interconnect resource. + * + * @param {string} interconnectName + * A fully-qualified path representing Interconnect resource. + * @returns {string} A string representing the location. + */ + matchLocationFromInterconnectName(interconnectName: string) { + return this.pathTemplates.interconnectPathTemplate.match(interconnectName) + .location; + } + + /** + * Parse the zone from Interconnect resource. + * + * @param {string} interconnectName + * A fully-qualified path representing Interconnect resource. + * @returns {string} A string representing the zone. + */ + matchZoneFromInterconnectName(interconnectName: string) { + return this.pathTemplates.interconnectPathTemplate.match(interconnectName) + .zone; + } + + /** + * Parse the interconnect from Interconnect resource. + * + * @param {string} interconnectName + * A fully-qualified path representing Interconnect resource. + * @returns {string} A string representing the interconnect. + */ + matchInterconnectFromInterconnectName(interconnectName: string) { + return this.pathTemplates.interconnectPathTemplate.match(interconnectName) + .interconnect; + } + + /** + * Return a fully-qualified interconnectAttachment resource name string. + * + * @param {string} project + * @param {string} location + * @param {string} zone + * @param {string} interconnect_attachment + * @returns {string} Resource name string. + */ + interconnectAttachmentPath( + project: string, + location: string, + zone: string, + interconnectAttachment: string + ) { + return this.pathTemplates.interconnectAttachmentPathTemplate.render({ + project: project, + location: location, + zone: zone, + interconnect_attachment: interconnectAttachment, + }); + } + + /** + * Parse the project from InterconnectAttachment resource. + * + * @param {string} interconnectAttachmentName + * A fully-qualified path representing InterconnectAttachment resource. + * @returns {string} A string representing the project. + */ + matchProjectFromInterconnectAttachmentName( + interconnectAttachmentName: string + ) { + return this.pathTemplates.interconnectAttachmentPathTemplate.match( + interconnectAttachmentName + ).project; + } + + /** + * Parse the location from InterconnectAttachment resource. + * + * @param {string} interconnectAttachmentName + * A fully-qualified path representing InterconnectAttachment resource. + * @returns {string} A string representing the location. + */ + matchLocationFromInterconnectAttachmentName( + interconnectAttachmentName: string + ) { + return this.pathTemplates.interconnectAttachmentPathTemplate.match( + interconnectAttachmentName + ).location; + } + + /** + * Parse the zone from InterconnectAttachment resource. + * + * @param {string} interconnectAttachmentName + * A fully-qualified path representing InterconnectAttachment resource. + * @returns {string} A string representing the zone. + */ + matchZoneFromInterconnectAttachmentName(interconnectAttachmentName: string) { + return this.pathTemplates.interconnectAttachmentPathTemplate.match( + interconnectAttachmentName + ).zone; + } + + /** + * Parse the interconnect_attachment from InterconnectAttachment resource. + * + * @param {string} interconnectAttachmentName + * A fully-qualified path representing InterconnectAttachment resource. + * @returns {string} A string representing the interconnect_attachment. + */ + matchInterconnectAttachmentFromInterconnectAttachmentName( + interconnectAttachmentName: string + ) { + return this.pathTemplates.interconnectAttachmentPathTemplate.match( + interconnectAttachmentName + ).interconnect_attachment; + } + + /** + * Return a fully-qualified location resource name string. + * + * @param {string} project + * @param {string} location + * @returns {string} Resource name string. + */ + locationPath(project: string, location: string) { + return this.pathTemplates.locationPathTemplate.render({ + project: project, + location: location, + }); + } + + /** + * Parse the project from Location resource. + * + * @param {string} locationName + * A fully-qualified path representing Location resource. + * @returns {string} A string representing the project. + */ + matchProjectFromLocationName(locationName: string) { + return this.pathTemplates.locationPathTemplate.match(locationName).project; + } + + /** + * Parse the location from Location resource. + * + * @param {string} locationName + * A fully-qualified path representing Location resource. + * @returns {string} A string representing the location. + */ + matchLocationFromLocationName(locationName: string) { + return this.pathTemplates.locationPathTemplate.match(locationName).location; + } + + /** + * Return a fully-qualified network resource name string. + * + * @param {string} project + * @param {string} location + * @param {string} zone + * @param {string} network + * @returns {string} Resource name string. + */ + networkPath( + project: string, + location: string, + zone: string, + network: string + ) { + return this.pathTemplates.networkPathTemplate.render({ + project: project, + location: location, + zone: zone, + network: network, + }); + } + + /** + * Parse the project from Network resource. + * + * @param {string} networkName + * A fully-qualified path representing Network resource. + * @returns {string} A string representing the project. + */ + matchProjectFromNetworkName(networkName: string) { + return this.pathTemplates.networkPathTemplate.match(networkName).project; + } + + /** + * Parse the location from Network resource. + * + * @param {string} networkName + * A fully-qualified path representing Network resource. + * @returns {string} A string representing the location. + */ + matchLocationFromNetworkName(networkName: string) { + return this.pathTemplates.networkPathTemplate.match(networkName).location; + } + + /** + * Parse the zone from Network resource. + * + * @param {string} networkName + * A fully-qualified path representing Network resource. + * @returns {string} A string representing the zone. + */ + matchZoneFromNetworkName(networkName: string) { + return this.pathTemplates.networkPathTemplate.match(networkName).zone; + } + + /** + * Parse the network from Network resource. + * + * @param {string} networkName + * A fully-qualified path representing Network resource. + * @returns {string} A string representing the network. + */ + matchNetworkFromNetworkName(networkName: string) { + return this.pathTemplates.networkPathTemplate.match(networkName).network; + } + + /** + * Return a fully-qualified project resource name string. + * + * @param {string} project + * @returns {string} Resource name string. + */ + projectPath(project: string) { + return this.pathTemplates.projectPathTemplate.render({ + project: project, + }); + } + + /** + * Parse the project from Project resource. + * + * @param {string} projectName + * A fully-qualified path representing Project resource. + * @returns {string} A string representing the project. + */ + matchProjectFromProjectName(projectName: string) { + return this.pathTemplates.projectPathTemplate.match(projectName).project; + } + + /** + * Return a fully-qualified router resource name string. + * + * @param {string} project + * @param {string} location + * @param {string} zone + * @param {string} router + * @returns {string} Resource name string. + */ + routerPath(project: string, location: string, zone: string, router: string) { + return this.pathTemplates.routerPathTemplate.render({ + project: project, + location: location, + zone: zone, + router: router, + }); + } + + /** + * Parse the project from Router resource. + * + * @param {string} routerName + * A fully-qualified path representing Router resource. + * @returns {string} A string representing the project. + */ + matchProjectFromRouterName(routerName: string) { + return this.pathTemplates.routerPathTemplate.match(routerName).project; + } + + /** + * Parse the location from Router resource. + * + * @param {string} routerName + * A fully-qualified path representing Router resource. + * @returns {string} A string representing the location. + */ + matchLocationFromRouterName(routerName: string) { + return this.pathTemplates.routerPathTemplate.match(routerName).location; + } + + /** + * Parse the zone from Router resource. + * + * @param {string} routerName + * A fully-qualified path representing Router resource. + * @returns {string} A string representing the zone. + */ + matchZoneFromRouterName(routerName: string) { + return this.pathTemplates.routerPathTemplate.match(routerName).zone; + } + + /** + * Parse the router from Router resource. + * + * @param {string} routerName + * A fully-qualified path representing Router resource. + * @returns {string} A string representing the router. + */ + matchRouterFromRouterName(routerName: string) { + return this.pathTemplates.routerPathTemplate.match(routerName).router; + } + + /** + * Return a fully-qualified subnet resource name string. + * + * @param {string} project + * @param {string} location + * @param {string} zone + * @param {string} subnet + * @returns {string} Resource name string. + */ + subnetPath(project: string, location: string, zone: string, subnet: string) { + return this.pathTemplates.subnetPathTemplate.render({ + project: project, + location: location, + zone: zone, + subnet: subnet, + }); + } + + /** + * Parse the project from Subnet resource. + * + * @param {string} subnetName + * A fully-qualified path representing Subnet resource. + * @returns {string} A string representing the project. + */ + matchProjectFromSubnetName(subnetName: string) { + return this.pathTemplates.subnetPathTemplate.match(subnetName).project; + } + + /** + * Parse the location from Subnet resource. + * + * @param {string} subnetName + * A fully-qualified path representing Subnet resource. + * @returns {string} A string representing the location. + */ + matchLocationFromSubnetName(subnetName: string) { + return this.pathTemplates.subnetPathTemplate.match(subnetName).location; + } + + /** + * Parse the zone from Subnet resource. + * + * @param {string} subnetName + * A fully-qualified path representing Subnet resource. + * @returns {string} A string representing the zone. + */ + matchZoneFromSubnetName(subnetName: string) { + return this.pathTemplates.subnetPathTemplate.match(subnetName).zone; + } + + /** + * Parse the subnet from Subnet resource. + * + * @param {string} subnetName + * A fully-qualified path representing Subnet resource. + * @returns {string} A string representing the subnet. + */ + matchSubnetFromSubnetName(subnetName: string) { + return this.pathTemplates.subnetPathTemplate.match(subnetName).subnet; + } + + /** + * Return a fully-qualified zone resource name string. + * + * @param {string} project + * @param {string} location + * @param {string} zone + * @returns {string} Resource name string. + */ + zonePath(project: string, location: string, zone: string) { + return this.pathTemplates.zonePathTemplate.render({ + project: project, + location: location, + zone: zone, + }); + } + + /** + * Parse the project from Zone resource. + * + * @param {string} zoneName + * A fully-qualified path representing Zone resource. + * @returns {string} A string representing the project. + */ + matchProjectFromZoneName(zoneName: string) { + return this.pathTemplates.zonePathTemplate.match(zoneName).project; + } + + /** + * Parse the location from Zone resource. + * + * @param {string} zoneName + * A fully-qualified path representing Zone resource. + * @returns {string} A string representing the location. + */ + matchLocationFromZoneName(zoneName: string) { + return this.pathTemplates.zonePathTemplate.match(zoneName).location; + } + + /** + * Parse the zone from Zone resource. + * + * @param {string} zoneName + * A fully-qualified path representing Zone resource. + * @returns {string} A string representing the zone. + */ + matchZoneFromZoneName(zoneName: string) { + return this.pathTemplates.zonePathTemplate.match(zoneName).zone; + } + + /** + * Terminate the gRPC channel and close the client. + * + * The client will no longer be usable and all future behavior is undefined. + * @returns {Promise} A promise that resolves when the client is closed. + */ + close(): Promise { + if (this.edgeNetworkStub && !this._terminated) { + return this.edgeNetworkStub.then(stub => { + this._terminated = true; + stub.close(); + this.locationsClient.close(); + this.operationsClient.close(); + }); + } + return Promise.resolve(); + } +} diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_client_config.json b/packages/google-cloud-edgenetwork/src/v1/edge_network_client_config.json similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_client_config.json rename to packages/google-cloud-edgenetwork/src/v1/edge_network_client_config.json diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_proto_list.json b/packages/google-cloud-edgenetwork/src/v1/edge_network_proto_list.json similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/edge_network_proto_list.json rename to packages/google-cloud-edgenetwork/src/v1/edge_network_proto_list.json diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/gapic_metadata.json b/packages/google-cloud-edgenetwork/src/v1/gapic_metadata.json similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/gapic_metadata.json rename to packages/google-cloud-edgenetwork/src/v1/gapic_metadata.json diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/index.ts b/packages/google-cloud-edgenetwork/src/v1/index.ts similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/src/v1/index.ts rename to packages/google-cloud-edgenetwork/src/v1/index.ts diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/system-test/fixtures/sample/src/index.js b/packages/google-cloud-edgenetwork/system-test/fixtures/sample/src/index.js similarity index 99% rename from owl-bot-staging/google-cloud-edgenetwork/v1/system-test/fixtures/sample/src/index.js rename to packages/google-cloud-edgenetwork/system-test/fixtures/sample/src/index.js index 7616467dcfc2..f00ff3d6a91a 100644 --- a/owl-bot-staging/google-cloud-edgenetwork/v1/system-test/fixtures/sample/src/index.js +++ b/packages/google-cloud-edgenetwork/system-test/fixtures/sample/src/index.js @@ -16,7 +16,6 @@ // ** https://github.com/googleapis/gapic-generator-typescript ** // ** All changes to this file may be overwritten. ** - /* eslint-disable node/no-missing-require, no-unused-vars */ const edgenetwork = require('@google-cloud/edgenetwork'); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/system-test/fixtures/sample/src/index.ts b/packages/google-cloud-edgenetwork/system-test/fixtures/sample/src/index.ts similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/system-test/fixtures/sample/src/index.ts rename to packages/google-cloud-edgenetwork/system-test/fixtures/sample/src/index.ts diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/system-test/install.ts b/packages/google-cloud-edgenetwork/system-test/install.ts similarity index 81% rename from owl-bot-staging/google-cloud-edgenetwork/v1/system-test/install.ts rename to packages/google-cloud-edgenetwork/system-test/install.ts index c8f81b25a865..f61fe236476b 100644 --- a/owl-bot-staging/google-cloud-edgenetwork/v1/system-test/install.ts +++ b/packages/google-cloud-edgenetwork/system-test/install.ts @@ -21,29 +21,31 @@ import {readFileSync} from 'fs'; import {describe, it} from 'mocha'; describe('📦 pack-n-play test', () => { - - it('TypeScript code', async function() { + it('TypeScript code', async function () { this.timeout(300000); const options = { packageDir: process.cwd(), sample: { description: 'TypeScript user can use the type definitions', - ts: readFileSync('./system-test/fixtures/sample/src/index.ts').toString() - } + ts: readFileSync( + './system-test/fixtures/sample/src/index.ts' + ).toString(), + }, }; await packNTest(options); }); - it('JavaScript code', async function() { + it('JavaScript code', async function () { this.timeout(300000); const options = { packageDir: process.cwd(), sample: { description: 'JavaScript user can use the library', - ts: readFileSync('./system-test/fixtures/sample/src/index.js').toString() - } + ts: readFileSync( + './system-test/fixtures/sample/src/index.js' + ).toString(), + }, }; await packNTest(options); }); - }); diff --git a/packages/google-cloud-edgenetwork/test/gapic_edge_network_v1.ts b/packages/google-cloud-edgenetwork/test/gapic_edge_network_v1.ts new file mode 100644 index 000000000000..f64ceb20f3ea --- /dev/null +++ b/packages/google-cloud-edgenetwork/test/gapic_edge_network_v1.ts @@ -0,0 +1,6449 @@ +// Copyright 2023 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ** This file is automatically generated by gapic-generator-typescript. ** +// ** https://github.com/googleapis/gapic-generator-typescript ** +// ** All changes to this file may be overwritten. ** + +import * as protos from '../protos/protos'; +import * as assert from 'assert'; +import * as sinon from 'sinon'; +import {SinonStub} from 'sinon'; +import {describe, it} from 'mocha'; +import * as edgenetworkModule from '../src'; + +import {PassThrough} from 'stream'; + +import { + protobuf, + LROperation, + operationsProtos, + LocationProtos, +} from 'google-gax'; + +// Dynamically loaded proto JSON is needed to get the type information +// to fill in default values for request objects +const root = protobuf.Root.fromJSON( + require('../protos/protos.json') +).resolveAll(); + +// eslint-disable-next-line @typescript-eslint/no-unused-vars +function getTypeDefaultValue(typeName: string, fields: string[]) { + let type = root.lookupType(typeName) as protobuf.Type; + for (const field of fields.slice(0, -1)) { + type = type.fields[field]?.resolvedType as protobuf.Type; + } + return type.fields[fields[fields.length - 1]]?.defaultValue; +} + +function generateSampleMessage(instance: T) { + const filledObject = ( + instance.constructor as typeof protobuf.Message + ).toObject(instance as protobuf.Message, {defaults: true}); + return (instance.constructor as typeof protobuf.Message).fromObject( + filledObject + ) as T; +} + +function stubSimpleCall(response?: ResponseType, error?: Error) { + return error + ? sinon.stub().rejects(error) + : sinon.stub().resolves([response]); +} + +function stubSimpleCallWithCallback( + response?: ResponseType, + error?: Error +) { + return error + ? sinon.stub().callsArgWith(2, error) + : sinon.stub().callsArgWith(2, null, response); +} + +function stubLongRunningCall( + response?: ResponseType, + callError?: Error, + lroError?: Error +) { + const innerStub = lroError + ? sinon.stub().rejects(lroError) + : sinon.stub().resolves([response]); + const mockOperation = { + promise: innerStub, + }; + return callError + ? sinon.stub().rejects(callError) + : sinon.stub().resolves([mockOperation]); +} + +function stubLongRunningCallWithCallback( + response?: ResponseType, + callError?: Error, + lroError?: Error +) { + const innerStub = lroError + ? sinon.stub().rejects(lroError) + : sinon.stub().resolves([response]); + const mockOperation = { + promise: innerStub, + }; + return callError + ? sinon.stub().callsArgWith(2, callError) + : sinon.stub().callsArgWith(2, null, mockOperation); +} + +function stubPageStreamingCall( + responses?: ResponseType[], + error?: Error +) { + const pagingStub = sinon.stub(); + if (responses) { + for (let i = 0; i < responses.length; ++i) { + pagingStub.onCall(i).callsArgWith(2, null, responses[i]); + } + } + const transformStub = error + ? sinon.stub().callsArgWith(2, error) + : pagingStub; + const mockStream = new PassThrough({ + objectMode: true, + transform: transformStub, + }); + // trigger as many responses as needed + if (responses) { + for (let i = 0; i < responses.length; ++i) { + setImmediate(() => { + mockStream.write({}); + }); + } + setImmediate(() => { + mockStream.end(); + }); + } else { + setImmediate(() => { + mockStream.write({}); + }); + setImmediate(() => { + mockStream.end(); + }); + } + return sinon.stub().returns(mockStream); +} + +function stubAsyncIterationCall( + responses?: ResponseType[], + error?: Error +) { + let counter = 0; + const asyncIterable = { + [Symbol.asyncIterator]() { + return { + async next() { + if (error) { + return Promise.reject(error); + } + if (counter >= responses!.length) { + return Promise.resolve({done: true, value: undefined}); + } + return Promise.resolve({done: false, value: responses![counter++]}); + }, + }; + }, + }; + return sinon.stub().returns(asyncIterable); +} + +describe('v1.EdgeNetworkClient', () => { + describe('Common methods', () => { + it('has servicePath', () => { + const servicePath = edgenetworkModule.v1.EdgeNetworkClient.servicePath; + assert(servicePath); + }); + + it('has apiEndpoint', () => { + const apiEndpoint = edgenetworkModule.v1.EdgeNetworkClient.apiEndpoint; + assert(apiEndpoint); + }); + + it('has port', () => { + const port = edgenetworkModule.v1.EdgeNetworkClient.port; + assert(port); + assert(typeof port === 'number'); + }); + + it('should create a client with no option', () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient(); + assert(client); + }); + + it('should create a client with gRPC fallback', () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + fallback: true, + }); + assert(client); + }); + + it('has initialize method and supports deferred initialization', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + assert.strictEqual(client.edgeNetworkStub, undefined); + await client.initialize(); + assert(client.edgeNetworkStub); + }); + + it('has close method for the initialized client', done => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + assert(client.edgeNetworkStub); + client.close().then(() => { + done(); + }); + }); + + it('has close method for the non-initialized client', done => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + assert.strictEqual(client.edgeNetworkStub, undefined); + client.close().then(() => { + done(); + }); + }); + + it('has getProjectId method', async () => { + const fakeProjectId = 'fake-project-id'; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.auth.getProjectId = sinon.stub().resolves(fakeProjectId); + const result = await client.getProjectId(); + assert.strictEqual(result, fakeProjectId); + assert((client.auth.getProjectId as SinonStub).calledWithExactly()); + }); + + it('has getProjectId method with callback', async () => { + const fakeProjectId = 'fake-project-id'; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.auth.getProjectId = sinon + .stub() + .callsArgWith(0, null, fakeProjectId); + const promise = new Promise((resolve, reject) => { + client.getProjectId((err?: Error | null, projectId?: string | null) => { + if (err) { + reject(err); + } else { + resolve(projectId); + } + }); + }); + const result = await promise; + assert.strictEqual(result, fakeProjectId); + }); + }); + + describe('initializeZone', () => { + it('invokes initializeZone without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InitializeZoneRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.InitializeZoneRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InitializeZoneResponse() + ); + client.innerApiCalls.initializeZone = stubSimpleCall(expectedResponse); + const [response] = await client.initializeZone(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.initializeZone as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.initializeZone as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes initializeZone without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InitializeZoneRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.InitializeZoneRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InitializeZoneResponse() + ); + client.innerApiCalls.initializeZone = + stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.initializeZone( + request, + ( + err?: Error | null, + result?: protos.google.cloud.edgenetwork.v1.IInitializeZoneResponse | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.initializeZone as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.initializeZone as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes initializeZone with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InitializeZoneRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.InitializeZoneRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.initializeZone = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(client.initializeZone(request), expectedError); + const actualRequest = ( + client.innerApiCalls.initializeZone as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.initializeZone as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes initializeZone with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InitializeZoneRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.InitializeZoneRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.initializeZone(request), expectedError); + }); + }); + + describe('getZone', () => { + it('invokes getZone without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetZoneRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetZoneRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Zone() + ); + client.innerApiCalls.getZone = stubSimpleCall(expectedResponse); + const [response] = await client.getZone(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.getZone as SinonStub).getCall( + 0 + ).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getZone as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getZone without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetZoneRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetZoneRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Zone() + ); + client.innerApiCalls.getZone = + stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.getZone( + request, + ( + err?: Error | null, + result?: protos.google.cloud.edgenetwork.v1.IZone | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = (client.innerApiCalls.getZone as SinonStub).getCall( + 0 + ).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getZone as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getZone with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetZoneRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetZoneRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.getZone = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.getZone(request), expectedError); + const actualRequest = (client.innerApiCalls.getZone as SinonStub).getCall( + 0 + ).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getZone as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getZone with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetZoneRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetZoneRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.getZone(request), expectedError); + }); + }); + + describe('getNetwork', () => { + it('invokes getNetwork without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetNetworkRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetNetworkRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Network() + ); + client.innerApiCalls.getNetwork = stubSimpleCall(expectedResponse); + const [response] = await client.getNetwork(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.getNetwork as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getNetwork as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getNetwork without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetNetworkRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetNetworkRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Network() + ); + client.innerApiCalls.getNetwork = + stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.getNetwork( + request, + ( + err?: Error | null, + result?: protos.google.cloud.edgenetwork.v1.INetwork | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.getNetwork as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getNetwork as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getNetwork with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetNetworkRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetNetworkRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.getNetwork = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(client.getNetwork(request), expectedError); + const actualRequest = ( + client.innerApiCalls.getNetwork as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getNetwork as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getNetwork with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetNetworkRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetNetworkRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.getNetwork(request), expectedError); + }); + }); + + describe('diagnoseNetwork', () => { + it('invokes diagnoseNetwork without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse() + ); + client.innerApiCalls.diagnoseNetwork = stubSimpleCall(expectedResponse); + const [response] = await client.diagnoseNetwork(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.diagnoseNetwork as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.diagnoseNetwork as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseNetwork without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkResponse() + ); + client.innerApiCalls.diagnoseNetwork = + stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.diagnoseNetwork( + request, + ( + err?: Error | null, + result?: protos.google.cloud.edgenetwork.v1.IDiagnoseNetworkResponse | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.diagnoseNetwork as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.diagnoseNetwork as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseNetwork with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.diagnoseNetwork = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(client.diagnoseNetwork(request), expectedError); + const actualRequest = ( + client.innerApiCalls.diagnoseNetwork as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.diagnoseNetwork as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseNetwork with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DiagnoseNetworkRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.diagnoseNetwork(request), expectedError); + }); + }); + + describe('getSubnet', () => { + it('invokes getSubnet without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetSubnetRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetSubnetRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Subnet() + ); + client.innerApiCalls.getSubnet = stubSimpleCall(expectedResponse); + const [response] = await client.getSubnet(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.getSubnet as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getSubnet as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getSubnet without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetSubnetRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetSubnetRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Subnet() + ); + client.innerApiCalls.getSubnet = + stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.getSubnet( + request, + ( + err?: Error | null, + result?: protos.google.cloud.edgenetwork.v1.ISubnet | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.getSubnet as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getSubnet as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getSubnet with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetSubnetRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetSubnetRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.getSubnet = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.getSubnet(request), expectedError); + const actualRequest = ( + client.innerApiCalls.getSubnet as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getSubnet as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getSubnet with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetSubnetRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetSubnetRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.getSubnet(request), expectedError); + }); + }); + + describe('getInterconnect', () => { + it('invokes getInterconnect without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetInterconnectRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetInterconnectRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Interconnect() + ); + client.innerApiCalls.getInterconnect = stubSimpleCall(expectedResponse); + const [response] = await client.getInterconnect(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.getInterconnect as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getInterconnect as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getInterconnect without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetInterconnectRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetInterconnectRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Interconnect() + ); + client.innerApiCalls.getInterconnect = + stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.getInterconnect( + request, + ( + err?: Error | null, + result?: protos.google.cloud.edgenetwork.v1.IInterconnect | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.getInterconnect as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getInterconnect as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getInterconnect with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetInterconnectRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetInterconnectRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.getInterconnect = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(client.getInterconnect(request), expectedError); + const actualRequest = ( + client.innerApiCalls.getInterconnect as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getInterconnect as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getInterconnect with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetInterconnectRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetInterconnectRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.getInterconnect(request), expectedError); + }); + }); + + describe('diagnoseInterconnect', () => { + it('invokes diagnoseInterconnect without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse() + ); + client.innerApiCalls.diagnoseInterconnect = + stubSimpleCall(expectedResponse); + const [response] = await client.diagnoseInterconnect(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.diagnoseInterconnect as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.diagnoseInterconnect as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseInterconnect without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectResponse() + ); + client.innerApiCalls.diagnoseInterconnect = + stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.diagnoseInterconnect( + request, + ( + err?: Error | null, + result?: protos.google.cloud.edgenetwork.v1.IDiagnoseInterconnectResponse | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.diagnoseInterconnect as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.diagnoseInterconnect as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseInterconnect with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.diagnoseInterconnect = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(client.diagnoseInterconnect(request), expectedError); + const actualRequest = ( + client.innerApiCalls.diagnoseInterconnect as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.diagnoseInterconnect as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseInterconnect with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DiagnoseInterconnectRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.diagnoseInterconnect(request), expectedError); + }); + }); + + describe('getInterconnectAttachment', () => { + it('invokes getInterconnectAttachment without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() + ); + client.innerApiCalls.getInterconnectAttachment = + stubSimpleCall(expectedResponse); + const [response] = await client.getInterconnectAttachment(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.getInterconnectAttachment as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getInterconnectAttachment as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getInterconnectAttachment without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() + ); + client.innerApiCalls.getInterconnectAttachment = + stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.getInterconnectAttachment( + request, + ( + err?: Error | null, + result?: protos.google.cloud.edgenetwork.v1.IInterconnectAttachment | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.getInterconnectAttachment as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getInterconnectAttachment as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getInterconnectAttachment with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.getInterconnectAttachment = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects( + client.getInterconnectAttachment(request), + expectedError + ); + const actualRequest = ( + client.innerApiCalls.getInterconnectAttachment as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getInterconnectAttachment as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getInterconnectAttachment with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetInterconnectAttachmentRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects( + client.getInterconnectAttachment(request), + expectedError + ); + }); + }); + + describe('getRouter', () => { + it('invokes getRouter without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetRouterRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetRouterRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Router() + ); + client.innerApiCalls.getRouter = stubSimpleCall(expectedResponse); + const [response] = await client.getRouter(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.getRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getRouter without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetRouterRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetRouterRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Router() + ); + client.innerApiCalls.getRouter = + stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.getRouter( + request, + ( + err?: Error | null, + result?: protos.google.cloud.edgenetwork.v1.IRouter | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.getRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getRouter with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetRouterRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetRouterRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.getRouter = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.getRouter(request), expectedError); + const actualRequest = ( + client.innerApiCalls.getRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.getRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes getRouter with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.GetRouterRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.GetRouterRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.getRouter(request), expectedError); + }); + }); + + describe('diagnoseRouter', () => { + it('invokes diagnoseRouter without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseRouterRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DiagnoseRouterRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseRouterResponse() + ); + client.innerApiCalls.diagnoseRouter = stubSimpleCall(expectedResponse); + const [response] = await client.diagnoseRouter(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.diagnoseRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.diagnoseRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseRouter without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseRouterRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DiagnoseRouterRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseRouterResponse() + ); + client.innerApiCalls.diagnoseRouter = + stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.diagnoseRouter( + request, + ( + err?: Error | null, + result?: protos.google.cloud.edgenetwork.v1.IDiagnoseRouterResponse | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.diagnoseRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.diagnoseRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseRouter with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseRouterRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DiagnoseRouterRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.diagnoseRouter = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(client.diagnoseRouter(request), expectedError); + const actualRequest = ( + client.innerApiCalls.diagnoseRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.diagnoseRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes diagnoseRouter with closed client', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DiagnoseRouterRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DiagnoseRouterRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedError = new Error('The client has already been closed.'); + client.close(); + await assert.rejects(client.diagnoseRouter(request), expectedError); + }); + }); + + describe('createNetwork', () => { + it('invokes createNetwork without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateNetworkRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.CreateNetworkRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.createNetwork = + stubLongRunningCall(expectedResponse); + const [operation] = await client.createNetwork(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.createNetwork as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.createNetwork as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createNetwork without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateNetworkRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.CreateNetworkRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.createNetwork = + stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.createNetwork( + request, + ( + err?: Error | null, + result?: LROperation< + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + > | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const operation = (await promise) as LROperation< + protos.google.cloud.edgenetwork.v1.INetwork, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.createNetwork as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.createNetwork as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createNetwork with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateNetworkRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.CreateNetworkRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.createNetwork = stubLongRunningCall( + undefined, + expectedError + ); + await assert.rejects(client.createNetwork(request), expectedError); + const actualRequest = ( + client.innerApiCalls.createNetwork as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.createNetwork as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createNetwork with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateNetworkRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.CreateNetworkRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.createNetwork = stubLongRunningCall( + undefined, + undefined, + expectedError + ); + const [operation] = await client.createNetwork(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = ( + client.innerApiCalls.createNetwork as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.createNetwork as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkCreateNetworkProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')}; + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkCreateNetworkProgress( + expectedResponse.name + ); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkCreateNetworkProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects( + client.checkCreateNetworkProgress(''), + expectedError + ); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + }); + + describe('deleteNetwork', () => { + it('invokes deleteNetwork without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteNetworkRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DeleteNetworkRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.deleteNetwork = + stubLongRunningCall(expectedResponse); + const [operation] = await client.deleteNetwork(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.deleteNetwork as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.deleteNetwork as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteNetwork without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteNetworkRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DeleteNetworkRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.deleteNetwork = + stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.deleteNetwork( + request, + ( + err?: Error | null, + result?: LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + > | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const operation = (await promise) as LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.deleteNetwork as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.deleteNetwork as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteNetwork with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteNetworkRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DeleteNetworkRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.deleteNetwork = stubLongRunningCall( + undefined, + expectedError + ); + await assert.rejects(client.deleteNetwork(request), expectedError); + const actualRequest = ( + client.innerApiCalls.deleteNetwork as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.deleteNetwork as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteNetwork with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteNetworkRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DeleteNetworkRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.deleteNetwork = stubLongRunningCall( + undefined, + undefined, + expectedError + ); + const [operation] = await client.deleteNetwork(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = ( + client.innerApiCalls.deleteNetwork as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.deleteNetwork as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkDeleteNetworkProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')}; + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkDeleteNetworkProgress( + expectedResponse.name + ); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkDeleteNetworkProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects( + client.checkDeleteNetworkProgress(''), + expectedError + ); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + }); + + describe('createSubnet', () => { + it('invokes createSubnet without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateSubnetRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.CreateSubnetRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.createSubnet = stubLongRunningCall(expectedResponse); + const [operation] = await client.createSubnet(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.createSubnet as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.createSubnet as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createSubnet without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateSubnetRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.CreateSubnetRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.createSubnet = + stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.createSubnet( + request, + ( + err?: Error | null, + result?: LROperation< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + > | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const operation = (await promise) as LROperation< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.createSubnet as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.createSubnet as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createSubnet with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateSubnetRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.CreateSubnetRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.createSubnet = stubLongRunningCall( + undefined, + expectedError + ); + await assert.rejects(client.createSubnet(request), expectedError); + const actualRequest = ( + client.innerApiCalls.createSubnet as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.createSubnet as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createSubnet with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateSubnetRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.CreateSubnetRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.createSubnet = stubLongRunningCall( + undefined, + undefined, + expectedError + ); + const [operation] = await client.createSubnet(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = ( + client.innerApiCalls.createSubnet as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.createSubnet as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkCreateSubnetProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')}; + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkCreateSubnetProgress( + expectedResponse.name + ); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkCreateSubnetProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(client.checkCreateSubnetProgress(''), expectedError); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + }); + + describe('updateSubnet', () => { + it('invokes updateSubnet without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.UpdateSubnetRequest() + ); + request.subnet ??= {}; + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.UpdateSubnetRequest', + ['subnet', 'name'] + ); + request.subnet.name = defaultValue1; + const expectedHeaderRequestParams = `subnet.name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.updateSubnet = stubLongRunningCall(expectedResponse); + const [operation] = await client.updateSubnet(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.updateSubnet as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.updateSubnet as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes updateSubnet without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.UpdateSubnetRequest() + ); + request.subnet ??= {}; + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.UpdateSubnetRequest', + ['subnet', 'name'] + ); + request.subnet.name = defaultValue1; + const expectedHeaderRequestParams = `subnet.name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.updateSubnet = + stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.updateSubnet( + request, + ( + err?: Error | null, + result?: LROperation< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + > | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const operation = (await promise) as LROperation< + protos.google.cloud.edgenetwork.v1.ISubnet, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.updateSubnet as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.updateSubnet as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes updateSubnet with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.UpdateSubnetRequest() + ); + request.subnet ??= {}; + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.UpdateSubnetRequest', + ['subnet', 'name'] + ); + request.subnet.name = defaultValue1; + const expectedHeaderRequestParams = `subnet.name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.updateSubnet = stubLongRunningCall( + undefined, + expectedError + ); + await assert.rejects(client.updateSubnet(request), expectedError); + const actualRequest = ( + client.innerApiCalls.updateSubnet as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.updateSubnet as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes updateSubnet with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.UpdateSubnetRequest() + ); + request.subnet ??= {}; + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.UpdateSubnetRequest', + ['subnet', 'name'] + ); + request.subnet.name = defaultValue1; + const expectedHeaderRequestParams = `subnet.name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.updateSubnet = stubLongRunningCall( + undefined, + undefined, + expectedError + ); + const [operation] = await client.updateSubnet(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = ( + client.innerApiCalls.updateSubnet as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.updateSubnet as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkUpdateSubnetProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')}; + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkUpdateSubnetProgress( + expectedResponse.name + ); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkUpdateSubnetProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(client.checkUpdateSubnetProgress(''), expectedError); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + }); + + describe('deleteSubnet', () => { + it('invokes deleteSubnet without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteSubnetRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DeleteSubnetRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.deleteSubnet = stubLongRunningCall(expectedResponse); + const [operation] = await client.deleteSubnet(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.deleteSubnet as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.deleteSubnet as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteSubnet without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteSubnetRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DeleteSubnetRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.deleteSubnet = + stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.deleteSubnet( + request, + ( + err?: Error | null, + result?: LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + > | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const operation = (await promise) as LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.deleteSubnet as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.deleteSubnet as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteSubnet with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteSubnetRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DeleteSubnetRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.deleteSubnet = stubLongRunningCall( + undefined, + expectedError + ); + await assert.rejects(client.deleteSubnet(request), expectedError); + const actualRequest = ( + client.innerApiCalls.deleteSubnet as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.deleteSubnet as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteSubnet with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteSubnetRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DeleteSubnetRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.deleteSubnet = stubLongRunningCall( + undefined, + undefined, + expectedError + ); + const [operation] = await client.deleteSubnet(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = ( + client.innerApiCalls.deleteSubnet as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.deleteSubnet as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkDeleteSubnetProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')}; + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkDeleteSubnetProgress( + expectedResponse.name + ); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkDeleteSubnetProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(client.checkDeleteSubnetProgress(''), expectedError); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + }); + + describe('createInterconnectAttachment', () => { + it('invokes createInterconnectAttachment without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.createInterconnectAttachment = + stubLongRunningCall(expectedResponse); + const [operation] = await client.createInterconnectAttachment(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.createInterconnectAttachment as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.createInterconnectAttachment as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createInterconnectAttachment without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.createInterconnectAttachment = + stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.createInterconnectAttachment( + request, + ( + err?: Error | null, + result?: LROperation< + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + > | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const operation = (await promise) as LROperation< + protos.google.cloud.edgenetwork.v1.IInterconnectAttachment, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.createInterconnectAttachment as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.createInterconnectAttachment as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createInterconnectAttachment with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.createInterconnectAttachment = stubLongRunningCall( + undefined, + expectedError + ); + await assert.rejects( + client.createInterconnectAttachment(request), + expectedError + ); + const actualRequest = ( + client.innerApiCalls.createInterconnectAttachment as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.createInterconnectAttachment as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createInterconnectAttachment with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.CreateInterconnectAttachmentRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.createInterconnectAttachment = stubLongRunningCall( + undefined, + undefined, + expectedError + ); + const [operation] = await client.createInterconnectAttachment(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = ( + client.innerApiCalls.createInterconnectAttachment as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.createInterconnectAttachment as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkCreateInterconnectAttachmentProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')}; + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = + await client.checkCreateInterconnectAttachmentProgress( + expectedResponse.name + ); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkCreateInterconnectAttachmentProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects( + client.checkCreateInterconnectAttachmentProgress(''), + expectedError + ); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + }); + + describe('deleteInterconnectAttachment', () => { + it('invokes deleteInterconnectAttachment without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.deleteInterconnectAttachment = + stubLongRunningCall(expectedResponse); + const [operation] = await client.deleteInterconnectAttachment(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.deleteInterconnectAttachment as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.deleteInterconnectAttachment as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteInterconnectAttachment without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.deleteInterconnectAttachment = + stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.deleteInterconnectAttachment( + request, + ( + err?: Error | null, + result?: LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + > | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const operation = (await promise) as LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.deleteInterconnectAttachment as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.deleteInterconnectAttachment as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteInterconnectAttachment with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.deleteInterconnectAttachment = stubLongRunningCall( + undefined, + expectedError + ); + await assert.rejects( + client.deleteInterconnectAttachment(request), + expectedError + ); + const actualRequest = ( + client.innerApiCalls.deleteInterconnectAttachment as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.deleteInterconnectAttachment as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteInterconnectAttachment with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DeleteInterconnectAttachmentRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.deleteInterconnectAttachment = stubLongRunningCall( + undefined, + undefined, + expectedError + ); + const [operation] = await client.deleteInterconnectAttachment(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = ( + client.innerApiCalls.deleteInterconnectAttachment as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.deleteInterconnectAttachment as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkDeleteInterconnectAttachmentProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')}; + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = + await client.checkDeleteInterconnectAttachmentProgress( + expectedResponse.name + ); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkDeleteInterconnectAttachmentProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects( + client.checkDeleteInterconnectAttachmentProgress(''), + expectedError + ); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + }); + + describe('createRouter', () => { + it('invokes createRouter without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateRouterRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.CreateRouterRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.createRouter = stubLongRunningCall(expectedResponse); + const [operation] = await client.createRouter(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.createRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.createRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createRouter without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateRouterRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.CreateRouterRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.createRouter = + stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.createRouter( + request, + ( + err?: Error | null, + result?: LROperation< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + > | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const operation = (await promise) as LROperation< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.createRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.createRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createRouter with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateRouterRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.CreateRouterRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.createRouter = stubLongRunningCall( + undefined, + expectedError + ); + await assert.rejects(client.createRouter(request), expectedError); + const actualRequest = ( + client.innerApiCalls.createRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.createRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes createRouter with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.CreateRouterRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.CreateRouterRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.createRouter = stubLongRunningCall( + undefined, + undefined, + expectedError + ); + const [operation] = await client.createRouter(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = ( + client.innerApiCalls.createRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.createRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkCreateRouterProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')}; + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkCreateRouterProgress( + expectedResponse.name + ); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkCreateRouterProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(client.checkCreateRouterProgress(''), expectedError); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + }); + + describe('updateRouter', () => { + it('invokes updateRouter without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.UpdateRouterRequest() + ); + request.router ??= {}; + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.UpdateRouterRequest', + ['router', 'name'] + ); + request.router.name = defaultValue1; + const expectedHeaderRequestParams = `router.name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.updateRouter = stubLongRunningCall(expectedResponse); + const [operation] = await client.updateRouter(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.updateRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.updateRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes updateRouter without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.UpdateRouterRequest() + ); + request.router ??= {}; + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.UpdateRouterRequest', + ['router', 'name'] + ); + request.router.name = defaultValue1; + const expectedHeaderRequestParams = `router.name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.updateRouter = + stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.updateRouter( + request, + ( + err?: Error | null, + result?: LROperation< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + > | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const operation = (await promise) as LROperation< + protos.google.cloud.edgenetwork.v1.IRouter, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.updateRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.updateRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes updateRouter with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.UpdateRouterRequest() + ); + request.router ??= {}; + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.UpdateRouterRequest', + ['router', 'name'] + ); + request.router.name = defaultValue1; + const expectedHeaderRequestParams = `router.name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.updateRouter = stubLongRunningCall( + undefined, + expectedError + ); + await assert.rejects(client.updateRouter(request), expectedError); + const actualRequest = ( + client.innerApiCalls.updateRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.updateRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes updateRouter with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.UpdateRouterRequest() + ); + request.router ??= {}; + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.UpdateRouterRequest', + ['router', 'name'] + ); + request.router.name = defaultValue1; + const expectedHeaderRequestParams = `router.name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.updateRouter = stubLongRunningCall( + undefined, + undefined, + expectedError + ); + const [operation] = await client.updateRouter(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = ( + client.innerApiCalls.updateRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.updateRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkUpdateRouterProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')}; + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkUpdateRouterProgress( + expectedResponse.name + ); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkUpdateRouterProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(client.checkUpdateRouterProgress(''), expectedError); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + }); + + describe('deleteRouter', () => { + it('invokes deleteRouter without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteRouterRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DeleteRouterRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.deleteRouter = stubLongRunningCall(expectedResponse); + const [operation] = await client.deleteRouter(request); + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.deleteRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.deleteRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteRouter without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteRouterRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DeleteRouterRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedResponse = generateSampleMessage( + new protos.google.longrunning.Operation() + ); + client.innerApiCalls.deleteRouter = + stubLongRunningCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.deleteRouter( + request, + ( + err?: Error | null, + result?: LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + > | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const operation = (await promise) as LROperation< + protos.google.protobuf.IEmpty, + protos.google.cloud.edgenetwork.v1.IOperationMetadata + >; + const [response] = await operation.promise(); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.deleteRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.deleteRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteRouter with call error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteRouterRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DeleteRouterRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.deleteRouter = stubLongRunningCall( + undefined, + expectedError + ); + await assert.rejects(client.deleteRouter(request), expectedError); + const actualRequest = ( + client.innerApiCalls.deleteRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.deleteRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes deleteRouter with LRO error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.DeleteRouterRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.DeleteRouterRequest', + ['name'] + ); + request.name = defaultValue1; + const expectedHeaderRequestParams = `name=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.deleteRouter = stubLongRunningCall( + undefined, + undefined, + expectedError + ); + const [operation] = await client.deleteRouter(request); + await assert.rejects(operation.promise(), expectedError); + const actualRequest = ( + client.innerApiCalls.deleteRouter as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.deleteRouter as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes checkDeleteRouterProgress without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + expectedResponse.name = 'test'; + expectedResponse.response = {type_url: 'url', value: Buffer.from('')}; + expectedResponse.metadata = {type_url: 'url', value: Buffer.from('')}; + + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const decodedOperation = await client.checkDeleteRouterProgress( + expectedResponse.name + ); + assert.deepStrictEqual(decodedOperation.name, expectedResponse.name); + assert(decodedOperation.metadata); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + + it('invokes checkDeleteRouterProgress with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const expectedError = new Error('expected'); + + client.operationsClient.getOperation = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(client.checkDeleteRouterProgress(''), expectedError); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + }); + + describe('listZones', () => { + it('invokes listZones without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListZonesRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListZonesRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + ]; + client.innerApiCalls.listZones = stubSimpleCall(expectedResponse); + const [response] = await client.listZones(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.listZones as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listZones as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listZones without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListZonesRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListZonesRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + ]; + client.innerApiCalls.listZones = + stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.listZones( + request, + ( + err?: Error | null, + result?: protos.google.cloud.edgenetwork.v1.IZone[] | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.listZones as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listZones as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listZones with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListZonesRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListZonesRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.listZones = stubSimpleCall(undefined, expectedError); + await assert.rejects(client.listZones(request), expectedError); + const actualRequest = ( + client.innerApiCalls.listZones as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listZones as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listZonesStream without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListZonesRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListZonesRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + ]; + client.descriptors.page.listZones.createStream = + stubPageStreamingCall(expectedResponse); + const stream = client.listZonesStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Zone[] = []; + stream.on( + 'data', + (response: protos.google.cloud.edgenetwork.v1.Zone) => { + responses.push(response); + } + ); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + const responses = await promise; + assert.deepStrictEqual(responses, expectedResponse); + assert( + (client.descriptors.page.listZones.createStream as SinonStub) + .getCall(0) + .calledWith(client.innerApiCalls.listZones, request) + ); + assert( + (client.descriptors.page.listZones.createStream as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('invokes listZonesStream with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListZonesRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListZonesRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listZones.createStream = stubPageStreamingCall( + undefined, + expectedError + ); + const stream = client.listZonesStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Zone[] = []; + stream.on( + 'data', + (response: protos.google.cloud.edgenetwork.v1.Zone) => { + responses.push(response); + } + ); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + await assert.rejects(promise, expectedError); + assert( + (client.descriptors.page.listZones.createStream as SinonStub) + .getCall(0) + .calledWith(client.innerApiCalls.listZones, request) + ); + assert( + (client.descriptors.page.listZones.createStream as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listZones without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListZonesRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListZonesRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Zone()), + ]; + client.descriptors.page.listZones.asyncIterate = + stubAsyncIterationCall(expectedResponse); + const responses: protos.google.cloud.edgenetwork.v1.IZone[] = []; + const iterable = client.listZonesAsync(request); + for await (const resource of iterable) { + responses.push(resource!); + } + assert.deepStrictEqual(responses, expectedResponse); + assert.deepStrictEqual( + (client.descriptors.page.listZones.asyncIterate as SinonStub).getCall(0) + .args[1], + request + ); + assert( + (client.descriptors.page.listZones.asyncIterate as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listZones with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListZonesRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListZonesRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listZones.asyncIterate = stubAsyncIterationCall( + undefined, + expectedError + ); + const iterable = client.listZonesAsync(request); + await assert.rejects(async () => { + const responses: protos.google.cloud.edgenetwork.v1.IZone[] = []; + for await (const resource of iterable) { + responses.push(resource!); + } + }); + assert.deepStrictEqual( + (client.descriptors.page.listZones.asyncIterate as SinonStub).getCall(0) + .args[1], + request + ); + assert( + (client.descriptors.page.listZones.asyncIterate as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + }); + + describe('listNetworks', () => { + it('invokes listNetworks without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListNetworksRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + ]; + client.innerApiCalls.listNetworks = stubSimpleCall(expectedResponse); + const [response] = await client.listNetworks(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.listNetworks as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listNetworks as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listNetworks without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListNetworksRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + ]; + client.innerApiCalls.listNetworks = + stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.listNetworks( + request, + ( + err?: Error | null, + result?: protos.google.cloud.edgenetwork.v1.INetwork[] | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.listNetworks as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listNetworks as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listNetworks with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListNetworksRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.listNetworks = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(client.listNetworks(request), expectedError); + const actualRequest = ( + client.innerApiCalls.listNetworks as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listNetworks as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listNetworksStream without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListNetworksRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + ]; + client.descriptors.page.listNetworks.createStream = + stubPageStreamingCall(expectedResponse); + const stream = client.listNetworksStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Network[] = []; + stream.on( + 'data', + (response: protos.google.cloud.edgenetwork.v1.Network) => { + responses.push(response); + } + ); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + const responses = await promise; + assert.deepStrictEqual(responses, expectedResponse); + assert( + (client.descriptors.page.listNetworks.createStream as SinonStub) + .getCall(0) + .calledWith(client.innerApiCalls.listNetworks, request) + ); + assert( + (client.descriptors.page.listNetworks.createStream as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('invokes listNetworksStream with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListNetworksRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listNetworks.createStream = stubPageStreamingCall( + undefined, + expectedError + ); + const stream = client.listNetworksStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Network[] = []; + stream.on( + 'data', + (response: protos.google.cloud.edgenetwork.v1.Network) => { + responses.push(response); + } + ); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + await assert.rejects(promise, expectedError); + assert( + (client.descriptors.page.listNetworks.createStream as SinonStub) + .getCall(0) + .calledWith(client.innerApiCalls.listNetworks, request) + ); + assert( + (client.descriptors.page.listNetworks.createStream as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listNetworks without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListNetworksRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Network()), + ]; + client.descriptors.page.listNetworks.asyncIterate = + stubAsyncIterationCall(expectedResponse); + const responses: protos.google.cloud.edgenetwork.v1.INetwork[] = []; + const iterable = client.listNetworksAsync(request); + for await (const resource of iterable) { + responses.push(resource!); + } + assert.deepStrictEqual(responses, expectedResponse); + assert.deepStrictEqual( + ( + client.descriptors.page.listNetworks.asyncIterate as SinonStub + ).getCall(0).args[1], + request + ); + assert( + (client.descriptors.page.listNetworks.asyncIterate as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listNetworks with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListNetworksRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListNetworksRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listNetworks.asyncIterate = + stubAsyncIterationCall(undefined, expectedError); + const iterable = client.listNetworksAsync(request); + await assert.rejects(async () => { + const responses: protos.google.cloud.edgenetwork.v1.INetwork[] = []; + for await (const resource of iterable) { + responses.push(resource!); + } + }); + assert.deepStrictEqual( + ( + client.descriptors.page.listNetworks.asyncIterate as SinonStub + ).getCall(0).args[1], + request + ); + assert( + (client.descriptors.page.listNetworks.asyncIterate as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + }); + + describe('listSubnets', () => { + it('invokes listSubnets without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListSubnetsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + ]; + client.innerApiCalls.listSubnets = stubSimpleCall(expectedResponse); + const [response] = await client.listSubnets(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.listSubnets as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listSubnets as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listSubnets without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListSubnetsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + ]; + client.innerApiCalls.listSubnets = + stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.listSubnets( + request, + ( + err?: Error | null, + result?: protos.google.cloud.edgenetwork.v1.ISubnet[] | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.listSubnets as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listSubnets as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listSubnets with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListSubnetsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.listSubnets = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(client.listSubnets(request), expectedError); + const actualRequest = ( + client.innerApiCalls.listSubnets as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listSubnets as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listSubnetsStream without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListSubnetsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + ]; + client.descriptors.page.listSubnets.createStream = + stubPageStreamingCall(expectedResponse); + const stream = client.listSubnetsStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Subnet[] = []; + stream.on( + 'data', + (response: protos.google.cloud.edgenetwork.v1.Subnet) => { + responses.push(response); + } + ); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + const responses = await promise; + assert.deepStrictEqual(responses, expectedResponse); + assert( + (client.descriptors.page.listSubnets.createStream as SinonStub) + .getCall(0) + .calledWith(client.innerApiCalls.listSubnets, request) + ); + assert( + (client.descriptors.page.listSubnets.createStream as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('invokes listSubnetsStream with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListSubnetsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listSubnets.createStream = stubPageStreamingCall( + undefined, + expectedError + ); + const stream = client.listSubnetsStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Subnet[] = []; + stream.on( + 'data', + (response: protos.google.cloud.edgenetwork.v1.Subnet) => { + responses.push(response); + } + ); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + await assert.rejects(promise, expectedError); + assert( + (client.descriptors.page.listSubnets.createStream as SinonStub) + .getCall(0) + .calledWith(client.innerApiCalls.listSubnets, request) + ); + assert( + (client.descriptors.page.listSubnets.createStream as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listSubnets without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListSubnetsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Subnet()), + ]; + client.descriptors.page.listSubnets.asyncIterate = + stubAsyncIterationCall(expectedResponse); + const responses: protos.google.cloud.edgenetwork.v1.ISubnet[] = []; + const iterable = client.listSubnetsAsync(request); + for await (const resource of iterable) { + responses.push(resource!); + } + assert.deepStrictEqual(responses, expectedResponse); + assert.deepStrictEqual( + (client.descriptors.page.listSubnets.asyncIterate as SinonStub).getCall( + 0 + ).args[1], + request + ); + assert( + (client.descriptors.page.listSubnets.asyncIterate as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listSubnets with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListSubnetsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListSubnetsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listSubnets.asyncIterate = stubAsyncIterationCall( + undefined, + expectedError + ); + const iterable = client.listSubnetsAsync(request); + await assert.rejects(async () => { + const responses: protos.google.cloud.edgenetwork.v1.ISubnet[] = []; + for await (const resource of iterable) { + responses.push(resource!); + } + }); + assert.deepStrictEqual( + (client.descriptors.page.listSubnets.asyncIterate as SinonStub).getCall( + 0 + ).args[1], + request + ); + assert( + (client.descriptors.page.listSubnets.asyncIterate as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + }); + + describe('listInterconnects', () => { + it('invokes listInterconnects without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListInterconnectsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Interconnect() + ), + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Interconnect() + ), + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Interconnect() + ), + ]; + client.innerApiCalls.listInterconnects = stubSimpleCall(expectedResponse); + const [response] = await client.listInterconnects(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.listInterconnects as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listInterconnects as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listInterconnects without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListInterconnectsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Interconnect() + ), + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Interconnect() + ), + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Interconnect() + ), + ]; + client.innerApiCalls.listInterconnects = + stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.listInterconnects( + request, + ( + err?: Error | null, + result?: protos.google.cloud.edgenetwork.v1.IInterconnect[] | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.listInterconnects as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listInterconnects as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listInterconnects with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListInterconnectsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.listInterconnects = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(client.listInterconnects(request), expectedError); + const actualRequest = ( + client.innerApiCalls.listInterconnects as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listInterconnects as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listInterconnectsStream without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListInterconnectsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Interconnect() + ), + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Interconnect() + ), + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Interconnect() + ), + ]; + client.descriptors.page.listInterconnects.createStream = + stubPageStreamingCall(expectedResponse); + const stream = client.listInterconnectsStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Interconnect[] = []; + stream.on( + 'data', + (response: protos.google.cloud.edgenetwork.v1.Interconnect) => { + responses.push(response); + } + ); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + const responses = await promise; + assert.deepStrictEqual(responses, expectedResponse); + assert( + (client.descriptors.page.listInterconnects.createStream as SinonStub) + .getCall(0) + .calledWith(client.innerApiCalls.listInterconnects, request) + ); + assert( + (client.descriptors.page.listInterconnects.createStream as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('invokes listInterconnectsStream with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListInterconnectsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listInterconnects.createStream = + stubPageStreamingCall(undefined, expectedError); + const stream = client.listInterconnectsStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Interconnect[] = []; + stream.on( + 'data', + (response: protos.google.cloud.edgenetwork.v1.Interconnect) => { + responses.push(response); + } + ); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + await assert.rejects(promise, expectedError); + assert( + (client.descriptors.page.listInterconnects.createStream as SinonStub) + .getCall(0) + .calledWith(client.innerApiCalls.listInterconnects, request) + ); + assert( + (client.descriptors.page.listInterconnects.createStream as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listInterconnects without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListInterconnectsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Interconnect() + ), + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Interconnect() + ), + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.Interconnect() + ), + ]; + client.descriptors.page.listInterconnects.asyncIterate = + stubAsyncIterationCall(expectedResponse); + const responses: protos.google.cloud.edgenetwork.v1.IInterconnect[] = []; + const iterable = client.listInterconnectsAsync(request); + for await (const resource of iterable) { + responses.push(resource!); + } + assert.deepStrictEqual(responses, expectedResponse); + assert.deepStrictEqual( + ( + client.descriptors.page.listInterconnects.asyncIterate as SinonStub + ).getCall(0).args[1], + request + ); + assert( + (client.descriptors.page.listInterconnects.asyncIterate as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listInterconnects with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListInterconnectsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listInterconnects.asyncIterate = + stubAsyncIterationCall(undefined, expectedError); + const iterable = client.listInterconnectsAsync(request); + await assert.rejects(async () => { + const responses: protos.google.cloud.edgenetwork.v1.IInterconnect[] = + []; + for await (const resource of iterable) { + responses.push(resource!); + } + }); + assert.deepStrictEqual( + ( + client.descriptors.page.listInterconnects.asyncIterate as SinonStub + ).getCall(0).args[1], + request + ); + assert( + (client.descriptors.page.listInterconnects.asyncIterate as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + }); + + describe('listInterconnectAttachments', () => { + it('invokes listInterconnectAttachments without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() + ), + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() + ), + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() + ), + ]; + client.innerApiCalls.listInterconnectAttachments = + stubSimpleCall(expectedResponse); + const [response] = await client.listInterconnectAttachments(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.listInterconnectAttachments as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listInterconnectAttachments as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listInterconnectAttachments without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() + ), + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() + ), + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() + ), + ]; + client.innerApiCalls.listInterconnectAttachments = + stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.listInterconnectAttachments( + request, + ( + err?: Error | null, + result?: + | protos.google.cloud.edgenetwork.v1.IInterconnectAttachment[] + | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.listInterconnectAttachments as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listInterconnectAttachments as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listInterconnectAttachments with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.listInterconnectAttachments = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects( + client.listInterconnectAttachments(request), + expectedError + ); + const actualRequest = ( + client.innerApiCalls.listInterconnectAttachments as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listInterconnectAttachments as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listInterconnectAttachmentsStream without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() + ), + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() + ), + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() + ), + ]; + client.descriptors.page.listInterconnectAttachments.createStream = + stubPageStreamingCall(expectedResponse); + const stream = client.listInterconnectAttachmentsStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.InterconnectAttachment[] = + []; + stream.on( + 'data', + ( + response: protos.google.cloud.edgenetwork.v1.InterconnectAttachment + ) => { + responses.push(response); + } + ); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + const responses = await promise; + assert.deepStrictEqual(responses, expectedResponse); + assert( + ( + client.descriptors.page.listInterconnectAttachments + .createStream as SinonStub + ) + .getCall(0) + .calledWith(client.innerApiCalls.listInterconnectAttachments, request) + ); + assert( + ( + client.descriptors.page.listInterconnectAttachments + .createStream as SinonStub + ) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('invokes listInterconnectAttachmentsStream with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listInterconnectAttachments.createStream = + stubPageStreamingCall(undefined, expectedError); + const stream = client.listInterconnectAttachmentsStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.InterconnectAttachment[] = + []; + stream.on( + 'data', + ( + response: protos.google.cloud.edgenetwork.v1.InterconnectAttachment + ) => { + responses.push(response); + } + ); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + await assert.rejects(promise, expectedError); + assert( + ( + client.descriptors.page.listInterconnectAttachments + .createStream as SinonStub + ) + .getCall(0) + .calledWith(client.innerApiCalls.listInterconnectAttachments, request) + ); + assert( + ( + client.descriptors.page.listInterconnectAttachments + .createStream as SinonStub + ) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listInterconnectAttachments without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() + ), + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() + ), + generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.InterconnectAttachment() + ), + ]; + client.descriptors.page.listInterconnectAttachments.asyncIterate = + stubAsyncIterationCall(expectedResponse); + const responses: protos.google.cloud.edgenetwork.v1.IInterconnectAttachment[] = + []; + const iterable = client.listInterconnectAttachmentsAsync(request); + for await (const resource of iterable) { + responses.push(resource!); + } + assert.deepStrictEqual(responses, expectedResponse); + assert.deepStrictEqual( + ( + client.descriptors.page.listInterconnectAttachments + .asyncIterate as SinonStub + ).getCall(0).args[1], + request + ); + assert( + ( + client.descriptors.page.listInterconnectAttachments + .asyncIterate as SinonStub + ) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listInterconnectAttachments with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListInterconnectAttachmentsRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listInterconnectAttachments.asyncIterate = + stubAsyncIterationCall(undefined, expectedError); + const iterable = client.listInterconnectAttachmentsAsync(request); + await assert.rejects(async () => { + const responses: protos.google.cloud.edgenetwork.v1.IInterconnectAttachment[] = + []; + for await (const resource of iterable) { + responses.push(resource!); + } + }); + assert.deepStrictEqual( + ( + client.descriptors.page.listInterconnectAttachments + .asyncIterate as SinonStub + ).getCall(0).args[1], + request + ); + assert( + ( + client.descriptors.page.listInterconnectAttachments + .asyncIterate as SinonStub + ) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + }); + + describe('listRouters', () => { + it('invokes listRouters without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListRoutersRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + ]; + client.innerApiCalls.listRouters = stubSimpleCall(expectedResponse); + const [response] = await client.listRouters(request); + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.listRouters as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listRouters as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listRouters without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListRoutersRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + ]; + client.innerApiCalls.listRouters = + stubSimpleCallWithCallback(expectedResponse); + const promise = new Promise((resolve, reject) => { + client.listRouters( + request, + ( + err?: Error | null, + result?: protos.google.cloud.edgenetwork.v1.IRouter[] | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + const actualRequest = ( + client.innerApiCalls.listRouters as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listRouters as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listRouters with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListRoutersRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.innerApiCalls.listRouters = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(client.listRouters(request), expectedError); + const actualRequest = ( + client.innerApiCalls.listRouters as SinonStub + ).getCall(0).args[0]; + assert.deepStrictEqual(actualRequest, request); + const actualHeaderRequestParams = ( + client.innerApiCalls.listRouters as SinonStub + ).getCall(0).args[1].otherArgs.headers['x-goog-request-params']; + assert(actualHeaderRequestParams.includes(expectedHeaderRequestParams)); + }); + + it('invokes listRoutersStream without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListRoutersRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + ]; + client.descriptors.page.listRouters.createStream = + stubPageStreamingCall(expectedResponse); + const stream = client.listRoutersStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Router[] = []; + stream.on( + 'data', + (response: protos.google.cloud.edgenetwork.v1.Router) => { + responses.push(response); + } + ); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + const responses = await promise; + assert.deepStrictEqual(responses, expectedResponse); + assert( + (client.descriptors.page.listRouters.createStream as SinonStub) + .getCall(0) + .calledWith(client.innerApiCalls.listRouters, request) + ); + assert( + (client.descriptors.page.listRouters.createStream as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('invokes listRoutersStream with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListRoutersRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listRouters.createStream = stubPageStreamingCall( + undefined, + expectedError + ); + const stream = client.listRoutersStream(request); + const promise = new Promise((resolve, reject) => { + const responses: protos.google.cloud.edgenetwork.v1.Router[] = []; + stream.on( + 'data', + (response: protos.google.cloud.edgenetwork.v1.Router) => { + responses.push(response); + } + ); + stream.on('end', () => { + resolve(responses); + }); + stream.on('error', (err: Error) => { + reject(err); + }); + }); + await assert.rejects(promise, expectedError); + assert( + (client.descriptors.page.listRouters.createStream as SinonStub) + .getCall(0) + .calledWith(client.innerApiCalls.listRouters, request) + ); + assert( + (client.descriptors.page.listRouters.createStream as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listRouters without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListRoutersRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedResponse = [ + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + generateSampleMessage(new protos.google.cloud.edgenetwork.v1.Router()), + ]; + client.descriptors.page.listRouters.asyncIterate = + stubAsyncIterationCall(expectedResponse); + const responses: protos.google.cloud.edgenetwork.v1.IRouter[] = []; + const iterable = client.listRoutersAsync(request); + for await (const resource of iterable) { + responses.push(resource!); + } + assert.deepStrictEqual(responses, expectedResponse); + assert.deepStrictEqual( + (client.descriptors.page.listRouters.asyncIterate as SinonStub).getCall( + 0 + ).args[1], + request + ); + assert( + (client.descriptors.page.listRouters.asyncIterate as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + + it('uses async iteration with listRouters with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new protos.google.cloud.edgenetwork.v1.ListRoutersRequest() + ); + const defaultValue1 = getTypeDefaultValue( + '.google.cloud.edgenetwork.v1.ListRoutersRequest', + ['parent'] + ); + request.parent = defaultValue1; + const expectedHeaderRequestParams = `parent=${defaultValue1}`; + const expectedError = new Error('expected'); + client.descriptors.page.listRouters.asyncIterate = stubAsyncIterationCall( + undefined, + expectedError + ); + const iterable = client.listRoutersAsync(request); + await assert.rejects(async () => { + const responses: protos.google.cloud.edgenetwork.v1.IRouter[] = []; + for await (const resource of iterable) { + responses.push(resource!); + } + }); + assert.deepStrictEqual( + (client.descriptors.page.listRouters.asyncIterate as SinonStub).getCall( + 0 + ).args[1], + request + ); + assert( + (client.descriptors.page.listRouters.asyncIterate as SinonStub) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + }); + describe('getLocation', () => { + it('invokes getLocation without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new LocationProtos.google.cloud.location.GetLocationRequest() + ); + request.name = ''; + const expectedHeaderRequestParams = 'name='; + const expectedOptions = { + otherArgs: { + headers: { + 'x-goog-request-params': expectedHeaderRequestParams, + }, + }, + }; + const expectedResponse = generateSampleMessage( + new LocationProtos.google.cloud.location.Location() + ); + client.locationsClient.getLocation = stubSimpleCall(expectedResponse); + const response = await client.getLocation(request, expectedOptions); + assert.deepStrictEqual(response, [expectedResponse]); + assert( + (client.locationsClient.getLocation as SinonStub) + .getCall(0) + .calledWith(request, expectedOptions, undefined) + ); + }); + it('invokes getLocation without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new LocationProtos.google.cloud.location.GetLocationRequest() + ); + request.name = ''; + const expectedHeaderRequestParams = 'name='; + const expectedOptions = { + otherArgs: { + headers: { + 'x-goog-request-params': expectedHeaderRequestParams, + }, + }, + }; + const expectedResponse = generateSampleMessage( + new LocationProtos.google.cloud.location.Location() + ); + client.locationsClient.getLocation = sinon + .stub() + .callsArgWith(2, null, expectedResponse); + const promise = new Promise((resolve, reject) => { + client.getLocation( + request, + expectedOptions, + ( + err?: Error | null, + result?: LocationProtos.google.cloud.location.ILocation | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + assert((client.locationsClient.getLocation as SinonStub).getCall(0)); + }); + it('invokes getLocation with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new LocationProtos.google.cloud.location.GetLocationRequest() + ); + request.name = ''; + const expectedHeaderRequestParams = 'name='; + const expectedOptions = { + otherArgs: { + headers: { + 'x-goog-request-params': expectedHeaderRequestParams, + }, + }, + }; + const expectedError = new Error('expected'); + client.locationsClient.getLocation = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects( + client.getLocation(request, expectedOptions), + expectedError + ); + assert( + (client.locationsClient.getLocation as SinonStub) + .getCall(0) + .calledWith(request, expectedOptions, undefined) + ); + }); + }); + describe('listLocationsAsync', () => { + it('uses async iteration with listLocations without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new LocationProtos.google.cloud.location.ListLocationsRequest() + ); + request.name = ''; + const expectedHeaderRequestParams = 'name='; + const expectedResponse = [ + generateSampleMessage( + new LocationProtos.google.cloud.location.Location() + ), + generateSampleMessage( + new LocationProtos.google.cloud.location.Location() + ), + generateSampleMessage( + new LocationProtos.google.cloud.location.Location() + ), + ]; + client.locationsClient.descriptors.page.listLocations.asyncIterate = + stubAsyncIterationCall(expectedResponse); + const responses: LocationProtos.google.cloud.location.ILocation[] = []; + const iterable = client.listLocationsAsync(request); + for await (const resource of iterable) { + responses.push(resource!); + } + assert.deepStrictEqual(responses, expectedResponse); + assert.deepStrictEqual( + ( + client.locationsClient.descriptors.page.listLocations + .asyncIterate as SinonStub + ).getCall(0).args[1], + request + ); + assert( + ( + client.locationsClient.descriptors.page.listLocations + .asyncIterate as SinonStub + ) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + it('uses async iteration with listLocations with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new LocationProtos.google.cloud.location.ListLocationsRequest() + ); + request.name = ''; + const expectedHeaderRequestParams = 'name='; + const expectedError = new Error('expected'); + client.locationsClient.descriptors.page.listLocations.asyncIterate = + stubAsyncIterationCall(undefined, expectedError); + const iterable = client.listLocationsAsync(request); + await assert.rejects(async () => { + const responses: LocationProtos.google.cloud.location.ILocation[] = []; + for await (const resource of iterable) { + responses.push(resource!); + } + }); + assert.deepStrictEqual( + ( + client.locationsClient.descriptors.page.listLocations + .asyncIterate as SinonStub + ).getCall(0).args[1], + request + ); + assert( + ( + client.locationsClient.descriptors.page.listLocations + .asyncIterate as SinonStub + ) + .getCall(0) + .args[2].otherArgs.headers['x-goog-request-params'].includes( + expectedHeaderRequestParams + ) + ); + }); + }); + describe('getOperation', () => { + it('invokes getOperation without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.GetOperationRequest() + ); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + client.operationsClient.getOperation = stubSimpleCall(expectedResponse); + const response = await client.getOperation(request); + assert.deepStrictEqual(response, [expectedResponse]); + assert( + (client.operationsClient.getOperation as SinonStub) + .getCall(0) + .calledWith(request) + ); + }); + it('invokes getOperation without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.GetOperationRequest() + ); + const expectedResponse = generateSampleMessage( + new operationsProtos.google.longrunning.Operation() + ); + client.operationsClient.getOperation = sinon + .stub() + .callsArgWith(2, null, expectedResponse); + const promise = new Promise((resolve, reject) => { + client.operationsClient.getOperation( + request, + undefined, + ( + err?: Error | null, + result?: operationsProtos.google.longrunning.Operation | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + assert((client.operationsClient.getOperation as SinonStub).getCall(0)); + }); + it('invokes getOperation with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.GetOperationRequest() + ); + const expectedError = new Error('expected'); + client.operationsClient.getOperation = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(async () => { + await client.getOperation(request); + }, expectedError); + assert( + (client.operationsClient.getOperation as SinonStub) + .getCall(0) + .calledWith(request) + ); + }); + }); + describe('cancelOperation', () => { + it('invokes cancelOperation without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.CancelOperationRequest() + ); + const expectedResponse = generateSampleMessage( + new protos.google.protobuf.Empty() + ); + client.operationsClient.cancelOperation = + stubSimpleCall(expectedResponse); + const response = await client.cancelOperation(request); + assert.deepStrictEqual(response, [expectedResponse]); + assert( + (client.operationsClient.cancelOperation as SinonStub) + .getCall(0) + .calledWith(request) + ); + }); + it('invokes cancelOperation without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.CancelOperationRequest() + ); + const expectedResponse = generateSampleMessage( + new protos.google.protobuf.Empty() + ); + client.operationsClient.cancelOperation = sinon + .stub() + .callsArgWith(2, null, expectedResponse); + const promise = new Promise((resolve, reject) => { + client.operationsClient.cancelOperation( + request, + undefined, + ( + err?: Error | null, + result?: protos.google.protobuf.Empty | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + assert((client.operationsClient.cancelOperation as SinonStub).getCall(0)); + }); + it('invokes cancelOperation with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.CancelOperationRequest() + ); + const expectedError = new Error('expected'); + client.operationsClient.cancelOperation = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(async () => { + await client.cancelOperation(request); + }, expectedError); + assert( + (client.operationsClient.cancelOperation as SinonStub) + .getCall(0) + .calledWith(request) + ); + }); + }); + describe('deleteOperation', () => { + it('invokes deleteOperation without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.DeleteOperationRequest() + ); + const expectedResponse = generateSampleMessage( + new protos.google.protobuf.Empty() + ); + client.operationsClient.deleteOperation = + stubSimpleCall(expectedResponse); + const response = await client.deleteOperation(request); + assert.deepStrictEqual(response, [expectedResponse]); + assert( + (client.operationsClient.deleteOperation as SinonStub) + .getCall(0) + .calledWith(request) + ); + }); + it('invokes deleteOperation without error using callback', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.DeleteOperationRequest() + ); + const expectedResponse = generateSampleMessage( + new protos.google.protobuf.Empty() + ); + client.operationsClient.deleteOperation = sinon + .stub() + .callsArgWith(2, null, expectedResponse); + const promise = new Promise((resolve, reject) => { + client.operationsClient.deleteOperation( + request, + undefined, + ( + err?: Error | null, + result?: protos.google.protobuf.Empty | null + ) => { + if (err) { + reject(err); + } else { + resolve(result); + } + } + ); + }); + const response = await promise; + assert.deepStrictEqual(response, expectedResponse); + assert((client.operationsClient.deleteOperation as SinonStub).getCall(0)); + }); + it('invokes deleteOperation with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.DeleteOperationRequest() + ); + const expectedError = new Error('expected'); + client.operationsClient.deleteOperation = stubSimpleCall( + undefined, + expectedError + ); + await assert.rejects(async () => { + await client.deleteOperation(request); + }, expectedError); + assert( + (client.operationsClient.deleteOperation as SinonStub) + .getCall(0) + .calledWith(request) + ); + }); + }); + describe('listOperationsAsync', () => { + it('uses async iteration with listOperations without error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.ListOperationsRequest() + ); + const expectedResponse = [ + generateSampleMessage( + new operationsProtos.google.longrunning.ListOperationsResponse() + ), + generateSampleMessage( + new operationsProtos.google.longrunning.ListOperationsResponse() + ), + generateSampleMessage( + new operationsProtos.google.longrunning.ListOperationsResponse() + ), + ]; + client.operationsClient.descriptor.listOperations.asyncIterate = + stubAsyncIterationCall(expectedResponse); + const responses: operationsProtos.google.longrunning.ListOperationsResponse[] = + []; + const iterable = client.operationsClient.listOperationsAsync(request); + for await (const resource of iterable) { + responses.push(resource!); + } + assert.deepStrictEqual(responses, expectedResponse); + assert.deepStrictEqual( + ( + client.operationsClient.descriptor.listOperations + .asyncIterate as SinonStub + ).getCall(0).args[1], + request + ); + }); + it('uses async iteration with listOperations with error', async () => { + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + const request = generateSampleMessage( + new operationsProtos.google.longrunning.ListOperationsRequest() + ); + const expectedError = new Error('expected'); + client.operationsClient.descriptor.listOperations.asyncIterate = + stubAsyncIterationCall(undefined, expectedError); + const iterable = client.operationsClient.listOperationsAsync(request); + await assert.rejects(async () => { + const responses: operationsProtos.google.longrunning.ListOperationsResponse[] = + []; + for await (const resource of iterable) { + responses.push(resource!); + } + }); + assert.deepStrictEqual( + ( + client.operationsClient.descriptor.listOperations + .asyncIterate as SinonStub + ).getCall(0).args[1], + request + ); + }); + }); + + describe('Path templates', () => { + describe('interconnect', () => { + const fakePath = '/rendered/path/interconnect'; + const expectedParameters = { + project: 'projectValue', + location: 'locationValue', + zone: 'zoneValue', + interconnect: 'interconnectValue', + }; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + client.pathTemplates.interconnectPathTemplate.render = sinon + .stub() + .returns(fakePath); + client.pathTemplates.interconnectPathTemplate.match = sinon + .stub() + .returns(expectedParameters); + + it('interconnectPath', () => { + const result = client.interconnectPath( + 'projectValue', + 'locationValue', + 'zoneValue', + 'interconnectValue' + ); + assert.strictEqual(result, fakePath); + assert( + (client.pathTemplates.interconnectPathTemplate.render as SinonStub) + .getCall(-1) + .calledWith(expectedParameters) + ); + }); + + it('matchProjectFromInterconnectName', () => { + const result = client.matchProjectFromInterconnectName(fakePath); + assert.strictEqual(result, 'projectValue'); + assert( + (client.pathTemplates.interconnectPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchLocationFromInterconnectName', () => { + const result = client.matchLocationFromInterconnectName(fakePath); + assert.strictEqual(result, 'locationValue'); + assert( + (client.pathTemplates.interconnectPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchZoneFromInterconnectName', () => { + const result = client.matchZoneFromInterconnectName(fakePath); + assert.strictEqual(result, 'zoneValue'); + assert( + (client.pathTemplates.interconnectPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchInterconnectFromInterconnectName', () => { + const result = client.matchInterconnectFromInterconnectName(fakePath); + assert.strictEqual(result, 'interconnectValue'); + assert( + (client.pathTemplates.interconnectPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + }); + + describe('interconnectAttachment', () => { + const fakePath = '/rendered/path/interconnectAttachment'; + const expectedParameters = { + project: 'projectValue', + location: 'locationValue', + zone: 'zoneValue', + interconnect_attachment: 'interconnectAttachmentValue', + }; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + client.pathTemplates.interconnectAttachmentPathTemplate.render = sinon + .stub() + .returns(fakePath); + client.pathTemplates.interconnectAttachmentPathTemplate.match = sinon + .stub() + .returns(expectedParameters); + + it('interconnectAttachmentPath', () => { + const result = client.interconnectAttachmentPath( + 'projectValue', + 'locationValue', + 'zoneValue', + 'interconnectAttachmentValue' + ); + assert.strictEqual(result, fakePath); + assert( + ( + client.pathTemplates.interconnectAttachmentPathTemplate + .render as SinonStub + ) + .getCall(-1) + .calledWith(expectedParameters) + ); + }); + + it('matchProjectFromInterconnectAttachmentName', () => { + const result = + client.matchProjectFromInterconnectAttachmentName(fakePath); + assert.strictEqual(result, 'projectValue'); + assert( + ( + client.pathTemplates.interconnectAttachmentPathTemplate + .match as SinonStub + ) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchLocationFromInterconnectAttachmentName', () => { + const result = + client.matchLocationFromInterconnectAttachmentName(fakePath); + assert.strictEqual(result, 'locationValue'); + assert( + ( + client.pathTemplates.interconnectAttachmentPathTemplate + .match as SinonStub + ) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchZoneFromInterconnectAttachmentName', () => { + const result = client.matchZoneFromInterconnectAttachmentName(fakePath); + assert.strictEqual(result, 'zoneValue'); + assert( + ( + client.pathTemplates.interconnectAttachmentPathTemplate + .match as SinonStub + ) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchInterconnectAttachmentFromInterconnectAttachmentName', () => { + const result = + client.matchInterconnectAttachmentFromInterconnectAttachmentName( + fakePath + ); + assert.strictEqual(result, 'interconnectAttachmentValue'); + assert( + ( + client.pathTemplates.interconnectAttachmentPathTemplate + .match as SinonStub + ) + .getCall(-1) + .calledWith(fakePath) + ); + }); + }); + + describe('location', () => { + const fakePath = '/rendered/path/location'; + const expectedParameters = { + project: 'projectValue', + location: 'locationValue', + }; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + client.pathTemplates.locationPathTemplate.render = sinon + .stub() + .returns(fakePath); + client.pathTemplates.locationPathTemplate.match = sinon + .stub() + .returns(expectedParameters); + + it('locationPath', () => { + const result = client.locationPath('projectValue', 'locationValue'); + assert.strictEqual(result, fakePath); + assert( + (client.pathTemplates.locationPathTemplate.render as SinonStub) + .getCall(-1) + .calledWith(expectedParameters) + ); + }); + + it('matchProjectFromLocationName', () => { + const result = client.matchProjectFromLocationName(fakePath); + assert.strictEqual(result, 'projectValue'); + assert( + (client.pathTemplates.locationPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchLocationFromLocationName', () => { + const result = client.matchLocationFromLocationName(fakePath); + assert.strictEqual(result, 'locationValue'); + assert( + (client.pathTemplates.locationPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + }); + + describe('network', () => { + const fakePath = '/rendered/path/network'; + const expectedParameters = { + project: 'projectValue', + location: 'locationValue', + zone: 'zoneValue', + network: 'networkValue', + }; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + client.pathTemplates.networkPathTemplate.render = sinon + .stub() + .returns(fakePath); + client.pathTemplates.networkPathTemplate.match = sinon + .stub() + .returns(expectedParameters); + + it('networkPath', () => { + const result = client.networkPath( + 'projectValue', + 'locationValue', + 'zoneValue', + 'networkValue' + ); + assert.strictEqual(result, fakePath); + assert( + (client.pathTemplates.networkPathTemplate.render as SinonStub) + .getCall(-1) + .calledWith(expectedParameters) + ); + }); + + it('matchProjectFromNetworkName', () => { + const result = client.matchProjectFromNetworkName(fakePath); + assert.strictEqual(result, 'projectValue'); + assert( + (client.pathTemplates.networkPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchLocationFromNetworkName', () => { + const result = client.matchLocationFromNetworkName(fakePath); + assert.strictEqual(result, 'locationValue'); + assert( + (client.pathTemplates.networkPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchZoneFromNetworkName', () => { + const result = client.matchZoneFromNetworkName(fakePath); + assert.strictEqual(result, 'zoneValue'); + assert( + (client.pathTemplates.networkPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchNetworkFromNetworkName', () => { + const result = client.matchNetworkFromNetworkName(fakePath); + assert.strictEqual(result, 'networkValue'); + assert( + (client.pathTemplates.networkPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + }); + + describe('project', () => { + const fakePath = '/rendered/path/project'; + const expectedParameters = { + project: 'projectValue', + }; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + client.pathTemplates.projectPathTemplate.render = sinon + .stub() + .returns(fakePath); + client.pathTemplates.projectPathTemplate.match = sinon + .stub() + .returns(expectedParameters); + + it('projectPath', () => { + const result = client.projectPath('projectValue'); + assert.strictEqual(result, fakePath); + assert( + (client.pathTemplates.projectPathTemplate.render as SinonStub) + .getCall(-1) + .calledWith(expectedParameters) + ); + }); + + it('matchProjectFromProjectName', () => { + const result = client.matchProjectFromProjectName(fakePath); + assert.strictEqual(result, 'projectValue'); + assert( + (client.pathTemplates.projectPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + }); + + describe('router', () => { + const fakePath = '/rendered/path/router'; + const expectedParameters = { + project: 'projectValue', + location: 'locationValue', + zone: 'zoneValue', + router: 'routerValue', + }; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + client.pathTemplates.routerPathTemplate.render = sinon + .stub() + .returns(fakePath); + client.pathTemplates.routerPathTemplate.match = sinon + .stub() + .returns(expectedParameters); + + it('routerPath', () => { + const result = client.routerPath( + 'projectValue', + 'locationValue', + 'zoneValue', + 'routerValue' + ); + assert.strictEqual(result, fakePath); + assert( + (client.pathTemplates.routerPathTemplate.render as SinonStub) + .getCall(-1) + .calledWith(expectedParameters) + ); + }); + + it('matchProjectFromRouterName', () => { + const result = client.matchProjectFromRouterName(fakePath); + assert.strictEqual(result, 'projectValue'); + assert( + (client.pathTemplates.routerPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchLocationFromRouterName', () => { + const result = client.matchLocationFromRouterName(fakePath); + assert.strictEqual(result, 'locationValue'); + assert( + (client.pathTemplates.routerPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchZoneFromRouterName', () => { + const result = client.matchZoneFromRouterName(fakePath); + assert.strictEqual(result, 'zoneValue'); + assert( + (client.pathTemplates.routerPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchRouterFromRouterName', () => { + const result = client.matchRouterFromRouterName(fakePath); + assert.strictEqual(result, 'routerValue'); + assert( + (client.pathTemplates.routerPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + }); + + describe('subnet', () => { + const fakePath = '/rendered/path/subnet'; + const expectedParameters = { + project: 'projectValue', + location: 'locationValue', + zone: 'zoneValue', + subnet: 'subnetValue', + }; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + client.pathTemplates.subnetPathTemplate.render = sinon + .stub() + .returns(fakePath); + client.pathTemplates.subnetPathTemplate.match = sinon + .stub() + .returns(expectedParameters); + + it('subnetPath', () => { + const result = client.subnetPath( + 'projectValue', + 'locationValue', + 'zoneValue', + 'subnetValue' + ); + assert.strictEqual(result, fakePath); + assert( + (client.pathTemplates.subnetPathTemplate.render as SinonStub) + .getCall(-1) + .calledWith(expectedParameters) + ); + }); + + it('matchProjectFromSubnetName', () => { + const result = client.matchProjectFromSubnetName(fakePath); + assert.strictEqual(result, 'projectValue'); + assert( + (client.pathTemplates.subnetPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchLocationFromSubnetName', () => { + const result = client.matchLocationFromSubnetName(fakePath); + assert.strictEqual(result, 'locationValue'); + assert( + (client.pathTemplates.subnetPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchZoneFromSubnetName', () => { + const result = client.matchZoneFromSubnetName(fakePath); + assert.strictEqual(result, 'zoneValue'); + assert( + (client.pathTemplates.subnetPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchSubnetFromSubnetName', () => { + const result = client.matchSubnetFromSubnetName(fakePath); + assert.strictEqual(result, 'subnetValue'); + assert( + (client.pathTemplates.subnetPathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + }); + + describe('zone', () => { + const fakePath = '/rendered/path/zone'; + const expectedParameters = { + project: 'projectValue', + location: 'locationValue', + zone: 'zoneValue', + }; + const client = new edgenetworkModule.v1.EdgeNetworkClient({ + credentials: {client_email: 'bogus', private_key: 'bogus'}, + projectId: 'bogus', + }); + client.initialize(); + client.pathTemplates.zonePathTemplate.render = sinon + .stub() + .returns(fakePath); + client.pathTemplates.zonePathTemplate.match = sinon + .stub() + .returns(expectedParameters); + + it('zonePath', () => { + const result = client.zonePath( + 'projectValue', + 'locationValue', + 'zoneValue' + ); + assert.strictEqual(result, fakePath); + assert( + (client.pathTemplates.zonePathTemplate.render as SinonStub) + .getCall(-1) + .calledWith(expectedParameters) + ); + }); + + it('matchProjectFromZoneName', () => { + const result = client.matchProjectFromZoneName(fakePath); + assert.strictEqual(result, 'projectValue'); + assert( + (client.pathTemplates.zonePathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchLocationFromZoneName', () => { + const result = client.matchLocationFromZoneName(fakePath); + assert.strictEqual(result, 'locationValue'); + assert( + (client.pathTemplates.zonePathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + + it('matchZoneFromZoneName', () => { + const result = client.matchZoneFromZoneName(fakePath); + assert.strictEqual(result, 'zoneValue'); + assert( + (client.pathTemplates.zonePathTemplate.match as SinonStub) + .getCall(-1) + .calledWith(fakePath) + ); + }); + }); + }); +}); diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/tsconfig.json b/packages/google-cloud-edgenetwork/tsconfig.json similarity index 100% rename from owl-bot-staging/google-cloud-edgenetwork/v1/tsconfig.json rename to packages/google-cloud-edgenetwork/tsconfig.json diff --git a/owl-bot-staging/google-cloud-edgenetwork/v1/webpack.config.js b/packages/google-cloud-edgenetwork/webpack.config.js similarity index 89% rename from owl-bot-staging/google-cloud-edgenetwork/v1/webpack.config.js rename to packages/google-cloud-edgenetwork/webpack.config.js index 7c40e326dca7..12940dc6339d 100644 --- a/owl-bot-staging/google-cloud-edgenetwork/v1/webpack.config.js +++ b/packages/google-cloud-edgenetwork/webpack.config.js @@ -36,27 +36,27 @@ module.exports = { { test: /\.tsx?$/, use: 'ts-loader', - exclude: /node_modules/ + exclude: /node_modules/, }, { test: /node_modules[\\/]@grpc[\\/]grpc-js/, - use: 'null-loader' + use: 'null-loader', }, { test: /node_modules[\\/]grpc/, - use: 'null-loader' + use: 'null-loader', }, { test: /node_modules[\\/]retry-request/, - use: 'null-loader' + use: 'null-loader', }, { test: /node_modules[\\/]https?-proxy-agent/, - use: 'null-loader' + use: 'null-loader', }, { test: /node_modules[\\/]gtoken/, - use: 'null-loader' + use: 'null-loader', }, ], }, diff --git a/release-please-config.json b/release-please-config.json index 932a2b94537a..64414a8728e7 100644 --- a/release-please-config.json +++ b/release-please-config.json @@ -156,7 +156,8 @@ "packages/google-privacy-dlp": {}, "packages/google-storagetransfer": {}, "packages/grafeas": {}, - "packages/typeless-sample-bot": {} + "packages/typeless-sample-bot": {}, + "packages/google-cloud-edgenetwork": {} }, "plugins": [ { From 070a333c3e15a1b4a40cbfd9a182ad2649e92138 Mon Sep 17 00:00:00 2001 From: Owl Bot Date: Thu, 9 Nov 2023 22:32:19 +0000 Subject: [PATCH 5/7] =?UTF-8?q?=F0=9F=A6=89=20Updates=20from=20OwlBot=20po?= =?UTF-8?q?st-processor?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit See https://github.com/googleapis/repo-automation-bots/blob/main/packages/owl-bot/README.md --- packages/google-cloud-edgenetwork/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/google-cloud-edgenetwork/README.md b/packages/google-cloud-edgenetwork/README.md index ae0bf125471d..d93e8cd5eb46 100644 --- a/packages/google-cloud-edgenetwork/README.md +++ b/packages/google-cloud-edgenetwork/README.md @@ -100,7 +100,7 @@ async function callListRouters() { // Run request const iterable = await edgenetworkClient.listRoutersAsync(request); for await (const response of iterable) { - console.log(response); + console.log(response); } } From b9e86012a3c0077ecc257bc7877d214bedfc377a Mon Sep 17 00:00:00 2001 From: Alexander Fenster Date: Thu, 9 Nov 2023 23:04:58 +0000 Subject: [PATCH 6/7] docs: add samples --- .../protos/protos.d.ts | 540 ++++- .../google-cloud-edgenetwork/protos/protos.js | 2143 +++++++++++++++-- .../protos/protos.json | 294 ++- .../samples/quickstart.js | 27 +- .../samples/test/quickstart.js | 6 +- 5 files changed, 2828 insertions(+), 182 deletions(-) diff --git a/packages/google-cloud-edgenetwork/protos/protos.d.ts b/packages/google-cloud-edgenetwork/protos/protos.d.ts index 1d1e21f82264..0687a6accfc7 100644 --- a/packages/google-cloud-edgenetwork/protos/protos.d.ts +++ b/packages/google-cloud-edgenetwork/protos/protos.d.ts @@ -8043,6 +8043,9 @@ export namespace google { /** Publishing librarySettings */ librarySettings?: (google.api.IClientLibrarySettings[]|null); + + /** Publishing protoReferenceDocumentationUri */ + protoReferenceDocumentationUri?: (string|null); } /** Represents a Publishing. */ @@ -8081,6 +8084,9 @@ export namespace google { /** Publishing librarySettings. */ public librarySettings: google.api.IClientLibrarySettings[]; + /** Publishing protoReferenceDocumentationUri. */ + public protoReferenceDocumentationUri: string; + /** * Creates a new Publishing instance using the specified properties. * @param [properties] Properties to set @@ -8661,6 +8667,21 @@ export namespace google { /** DotnetSettings common */ common?: (google.api.ICommonLanguageSettings|null); + + /** DotnetSettings renamedServices */ + renamedServices?: ({ [k: string]: string }|null); + + /** DotnetSettings renamedResources */ + renamedResources?: ({ [k: string]: string }|null); + + /** DotnetSettings ignoredResources */ + ignoredResources?: (string[]|null); + + /** DotnetSettings forcedNamespaceAliases */ + forcedNamespaceAliases?: (string[]|null); + + /** DotnetSettings handwrittenSignatures */ + handwrittenSignatures?: (string[]|null); } /** Represents a DotnetSettings. */ @@ -8675,6 +8696,21 @@ export namespace google { /** DotnetSettings common. */ public common?: (google.api.ICommonLanguageSettings|null); + /** DotnetSettings renamedServices. */ + public renamedServices: { [k: string]: string }; + + /** DotnetSettings renamedResources. */ + public renamedResources: { [k: string]: string }; + + /** DotnetSettings ignoredResources. */ + public ignoredResources: string[]; + + /** DotnetSettings forcedNamespaceAliases. */ + public forcedNamespaceAliases: string[]; + + /** DotnetSettings handwrittenSignatures. */ + public handwrittenSignatures: string[]; + /** * Creates a new DotnetSettings instance using the specified properties. * @param [properties] Properties to set @@ -9174,7 +9210,10 @@ export namespace google { CLOUD = 1, ADS = 2, PHOTOS = 3, - STREET_VIEW = 4 + STREET_VIEW = 4, + SHOPPING = 5, + GEO = 6, + GENERATIVE_AI = 7 } /** ClientLibraryDestination enum. */ @@ -9837,6 +9876,15 @@ export namespace google { /** ExtensionRangeOptions uninterpretedOption */ uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); + + /** ExtensionRangeOptions declaration */ + declaration?: (google.protobuf.ExtensionRangeOptions.IDeclaration[]|null); + + /** ExtensionRangeOptions features */ + features?: (google.protobuf.IFeatureSet|null); + + /** ExtensionRangeOptions verification */ + verification?: (google.protobuf.ExtensionRangeOptions.VerificationState|keyof typeof google.protobuf.ExtensionRangeOptions.VerificationState|null); } /** Represents an ExtensionRangeOptions. */ @@ -9851,6 +9899,15 @@ export namespace google { /** ExtensionRangeOptions uninterpretedOption. */ public uninterpretedOption: google.protobuf.IUninterpretedOption[]; + /** ExtensionRangeOptions declaration. */ + public declaration: google.protobuf.ExtensionRangeOptions.IDeclaration[]; + + /** ExtensionRangeOptions features. */ + public features?: (google.protobuf.IFeatureSet|null); + + /** ExtensionRangeOptions verification. */ + public verification: (google.protobuf.ExtensionRangeOptions.VerificationState|keyof typeof google.protobuf.ExtensionRangeOptions.VerificationState); + /** * Creates a new ExtensionRangeOptions instance using the specified properties. * @param [properties] Properties to set @@ -9929,6 +9986,136 @@ export namespace google { public static getTypeUrl(typeUrlPrefix?: string): string; } + namespace ExtensionRangeOptions { + + /** Properties of a Declaration. */ + interface IDeclaration { + + /** Declaration number */ + number?: (number|null); + + /** Declaration fullName */ + fullName?: (string|null); + + /** Declaration type */ + type?: (string|null); + + /** Declaration reserved */ + reserved?: (boolean|null); + + /** Declaration repeated */ + repeated?: (boolean|null); + } + + /** Represents a Declaration. */ + class Declaration implements IDeclaration { + + /** + * Constructs a new Declaration. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.ExtensionRangeOptions.IDeclaration); + + /** Declaration number. */ + public number: number; + + /** Declaration fullName. */ + public fullName: string; + + /** Declaration type. */ + public type: string; + + /** Declaration reserved. */ + public reserved: boolean; + + /** Declaration repeated. */ + public repeated: boolean; + + /** + * Creates a new Declaration instance using the specified properties. + * @param [properties] Properties to set + * @returns Declaration instance + */ + public static create(properties?: google.protobuf.ExtensionRangeOptions.IDeclaration): google.protobuf.ExtensionRangeOptions.Declaration; + + /** + * Encodes the specified Declaration message. Does not implicitly {@link google.protobuf.ExtensionRangeOptions.Declaration.verify|verify} messages. + * @param message Declaration message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.ExtensionRangeOptions.IDeclaration, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified Declaration message, length delimited. Does not implicitly {@link google.protobuf.ExtensionRangeOptions.Declaration.verify|verify} messages. + * @param message Declaration message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.ExtensionRangeOptions.IDeclaration, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a Declaration message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Declaration + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.ExtensionRangeOptions.Declaration; + + /** + * Decodes a Declaration message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns Declaration + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.ExtensionRangeOptions.Declaration; + + /** + * Verifies a Declaration message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a Declaration message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns Declaration + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.ExtensionRangeOptions.Declaration; + + /** + * Creates a plain object from a Declaration message. Also converts values to other types if specified. + * @param message Declaration + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.ExtensionRangeOptions.Declaration, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this Declaration to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for Declaration + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + /** VerificationState enum. */ + enum VerificationState { + DECLARATION = 0, + UNVERIFIED = 1 + } + } + /** Properties of a FieldDescriptorProto. */ interface IFieldDescriptorProto { @@ -10856,6 +11043,9 @@ export namespace google { /** FileOptions rubyPackage */ rubyPackage?: (string|null); + /** FileOptions features */ + features?: (google.protobuf.IFeatureSet|null); + /** FileOptions uninterpretedOption */ uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); @@ -10932,6 +11122,9 @@ export namespace google { /** FileOptions rubyPackage. */ public rubyPackage: string; + /** FileOptions features. */ + public features?: (google.protobuf.IFeatureSet|null); + /** FileOptions uninterpretedOption. */ public uninterpretedOption: google.protobuf.IUninterpretedOption[]; @@ -11041,6 +11234,9 @@ export namespace google { /** MessageOptions deprecatedLegacyJsonFieldConflicts */ deprecatedLegacyJsonFieldConflicts?: (boolean|null); + /** MessageOptions features */ + features?: (google.protobuf.IFeatureSet|null); + /** MessageOptions uninterpretedOption */ uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); @@ -11072,6 +11268,9 @@ export namespace google { /** MessageOptions deprecatedLegacyJsonFieldConflicts. */ public deprecatedLegacyJsonFieldConflicts: boolean; + /** MessageOptions features. */ + public features?: (google.protobuf.IFeatureSet|null); + /** MessageOptions uninterpretedOption. */ public uninterpretedOption: google.protobuf.IUninterpretedOption[]; @@ -11183,8 +11382,14 @@ export namespace google { /** FieldOptions retention */ retention?: (google.protobuf.FieldOptions.OptionRetention|keyof typeof google.protobuf.FieldOptions.OptionRetention|null); - /** FieldOptions target */ - target?: (google.protobuf.FieldOptions.OptionTargetType|keyof typeof google.protobuf.FieldOptions.OptionTargetType|null); + /** FieldOptions targets */ + targets?: (google.protobuf.FieldOptions.OptionTargetType[]|null); + + /** FieldOptions editionDefaults */ + editionDefaults?: (google.protobuf.FieldOptions.IEditionDefault[]|null); + + /** FieldOptions features */ + features?: (google.protobuf.IFeatureSet|null); /** FieldOptions uninterpretedOption */ uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); @@ -11232,8 +11437,14 @@ export namespace google { /** FieldOptions retention. */ public retention: (google.protobuf.FieldOptions.OptionRetention|keyof typeof google.protobuf.FieldOptions.OptionRetention); - /** FieldOptions target. */ - public target: (google.protobuf.FieldOptions.OptionTargetType|keyof typeof google.protobuf.FieldOptions.OptionTargetType); + /** FieldOptions targets. */ + public targets: google.protobuf.FieldOptions.OptionTargetType[]; + + /** FieldOptions editionDefaults. */ + public editionDefaults: google.protobuf.FieldOptions.IEditionDefault[]; + + /** FieldOptions features. */ + public features?: (google.protobuf.IFeatureSet|null); /** FieldOptions uninterpretedOption. */ public uninterpretedOption: google.protobuf.IUninterpretedOption[]; @@ -11352,11 +11563,117 @@ export namespace google { TARGET_TYPE_SERVICE = 8, TARGET_TYPE_METHOD = 9 } + + /** Properties of an EditionDefault. */ + interface IEditionDefault { + + /** EditionDefault edition */ + edition?: (string|null); + + /** EditionDefault value */ + value?: (string|null); + } + + /** Represents an EditionDefault. */ + class EditionDefault implements IEditionDefault { + + /** + * Constructs a new EditionDefault. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.FieldOptions.IEditionDefault); + + /** EditionDefault edition. */ + public edition: string; + + /** EditionDefault value. */ + public value: string; + + /** + * Creates a new EditionDefault instance using the specified properties. + * @param [properties] Properties to set + * @returns EditionDefault instance + */ + public static create(properties?: google.protobuf.FieldOptions.IEditionDefault): google.protobuf.FieldOptions.EditionDefault; + + /** + * Encodes the specified EditionDefault message. Does not implicitly {@link google.protobuf.FieldOptions.EditionDefault.verify|verify} messages. + * @param message EditionDefault message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.FieldOptions.IEditionDefault, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified EditionDefault message, length delimited. Does not implicitly {@link google.protobuf.FieldOptions.EditionDefault.verify|verify} messages. + * @param message EditionDefault message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.FieldOptions.IEditionDefault, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an EditionDefault message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns EditionDefault + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.FieldOptions.EditionDefault; + + /** + * Decodes an EditionDefault message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns EditionDefault + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.FieldOptions.EditionDefault; + + /** + * Verifies an EditionDefault message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates an EditionDefault message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns EditionDefault + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.FieldOptions.EditionDefault; + + /** + * Creates a plain object from an EditionDefault message. Also converts values to other types if specified. + * @param message EditionDefault + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.FieldOptions.EditionDefault, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this EditionDefault to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for EditionDefault + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } } /** Properties of an OneofOptions. */ interface IOneofOptions { + /** OneofOptions features */ + features?: (google.protobuf.IFeatureSet|null); + /** OneofOptions uninterpretedOption */ uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); } @@ -11370,6 +11687,9 @@ export namespace google { */ constructor(properties?: google.protobuf.IOneofOptions); + /** OneofOptions features. */ + public features?: (google.protobuf.IFeatureSet|null); + /** OneofOptions uninterpretedOption. */ public uninterpretedOption: google.protobuf.IUninterpretedOption[]; @@ -11463,6 +11783,9 @@ export namespace google { /** EnumOptions deprecatedLegacyJsonFieldConflicts */ deprecatedLegacyJsonFieldConflicts?: (boolean|null); + /** EnumOptions features */ + features?: (google.protobuf.IFeatureSet|null); + /** EnumOptions uninterpretedOption */ uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); } @@ -11485,6 +11808,9 @@ export namespace google { /** EnumOptions deprecatedLegacyJsonFieldConflicts. */ public deprecatedLegacyJsonFieldConflicts: boolean; + /** EnumOptions features. */ + public features?: (google.protobuf.IFeatureSet|null); + /** EnumOptions uninterpretedOption. */ public uninterpretedOption: google.protobuf.IUninterpretedOption[]; @@ -11572,6 +11898,12 @@ export namespace google { /** EnumValueOptions deprecated */ deprecated?: (boolean|null); + /** EnumValueOptions features */ + features?: (google.protobuf.IFeatureSet|null); + + /** EnumValueOptions debugRedact */ + debugRedact?: (boolean|null); + /** EnumValueOptions uninterpretedOption */ uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); } @@ -11588,6 +11920,12 @@ export namespace google { /** EnumValueOptions deprecated. */ public deprecated: boolean; + /** EnumValueOptions features. */ + public features?: (google.protobuf.IFeatureSet|null); + + /** EnumValueOptions debugRedact. */ + public debugRedact: boolean; + /** EnumValueOptions uninterpretedOption. */ public uninterpretedOption: google.protobuf.IUninterpretedOption[]; @@ -11672,6 +12010,9 @@ export namespace google { /** Properties of a ServiceOptions. */ interface IServiceOptions { + /** ServiceOptions features */ + features?: (google.protobuf.IFeatureSet|null); + /** ServiceOptions deprecated */ deprecated?: (boolean|null); @@ -11694,6 +12035,9 @@ export namespace google { */ constructor(properties?: google.protobuf.IServiceOptions); + /** ServiceOptions features. */ + public features?: (google.protobuf.IFeatureSet|null); + /** ServiceOptions deprecated. */ public deprecated: boolean; @@ -11787,6 +12131,9 @@ export namespace google { /** MethodOptions idempotencyLevel */ idempotencyLevel?: (google.protobuf.MethodOptions.IdempotencyLevel|keyof typeof google.protobuf.MethodOptions.IdempotencyLevel|null); + /** MethodOptions features */ + features?: (google.protobuf.IFeatureSet|null); + /** MethodOptions uninterpretedOption */ uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); @@ -11815,6 +12162,9 @@ export namespace google { /** MethodOptions idempotencyLevel. */ public idempotencyLevel: (google.protobuf.MethodOptions.IdempotencyLevel|keyof typeof google.protobuf.MethodOptions.IdempotencyLevel); + /** MethodOptions features. */ + public features?: (google.protobuf.IFeatureSet|null); + /** MethodOptions uninterpretedOption. */ public uninterpretedOption: google.protobuf.IUninterpretedOption[]; @@ -12145,6 +12495,186 @@ export namespace google { } } + /** Properties of a FeatureSet. */ + interface IFeatureSet { + + /** FeatureSet fieldPresence */ + fieldPresence?: (google.protobuf.FeatureSet.FieldPresence|keyof typeof google.protobuf.FeatureSet.FieldPresence|null); + + /** FeatureSet enumType */ + enumType?: (google.protobuf.FeatureSet.EnumType|keyof typeof google.protobuf.FeatureSet.EnumType|null); + + /** FeatureSet repeatedFieldEncoding */ + repeatedFieldEncoding?: (google.protobuf.FeatureSet.RepeatedFieldEncoding|keyof typeof google.protobuf.FeatureSet.RepeatedFieldEncoding|null); + + /** FeatureSet stringFieldValidation */ + stringFieldValidation?: (google.protobuf.FeatureSet.StringFieldValidation|keyof typeof google.protobuf.FeatureSet.StringFieldValidation|null); + + /** FeatureSet messageEncoding */ + messageEncoding?: (google.protobuf.FeatureSet.MessageEncoding|keyof typeof google.protobuf.FeatureSet.MessageEncoding|null); + + /** FeatureSet jsonFormat */ + jsonFormat?: (google.protobuf.FeatureSet.JsonFormat|keyof typeof google.protobuf.FeatureSet.JsonFormat|null); + + /** FeatureSet rawFeatures */ + rawFeatures?: (google.protobuf.IFeatureSet|null); + } + + /** Represents a FeatureSet. */ + class FeatureSet implements IFeatureSet { + + /** + * Constructs a new FeatureSet. + * @param [properties] Properties to set + */ + constructor(properties?: google.protobuf.IFeatureSet); + + /** FeatureSet fieldPresence. */ + public fieldPresence: (google.protobuf.FeatureSet.FieldPresence|keyof typeof google.protobuf.FeatureSet.FieldPresence); + + /** FeatureSet enumType. */ + public enumType: (google.protobuf.FeatureSet.EnumType|keyof typeof google.protobuf.FeatureSet.EnumType); + + /** FeatureSet repeatedFieldEncoding. */ + public repeatedFieldEncoding: (google.protobuf.FeatureSet.RepeatedFieldEncoding|keyof typeof google.protobuf.FeatureSet.RepeatedFieldEncoding); + + /** FeatureSet stringFieldValidation. */ + public stringFieldValidation: (google.protobuf.FeatureSet.StringFieldValidation|keyof typeof google.protobuf.FeatureSet.StringFieldValidation); + + /** FeatureSet messageEncoding. */ + public messageEncoding: (google.protobuf.FeatureSet.MessageEncoding|keyof typeof google.protobuf.FeatureSet.MessageEncoding); + + /** FeatureSet jsonFormat. */ + public jsonFormat: (google.protobuf.FeatureSet.JsonFormat|keyof typeof google.protobuf.FeatureSet.JsonFormat); + + /** FeatureSet rawFeatures. */ + public rawFeatures?: (google.protobuf.IFeatureSet|null); + + /** + * Creates a new FeatureSet instance using the specified properties. + * @param [properties] Properties to set + * @returns FeatureSet instance + */ + public static create(properties?: google.protobuf.IFeatureSet): google.protobuf.FeatureSet; + + /** + * Encodes the specified FeatureSet message. Does not implicitly {@link google.protobuf.FeatureSet.verify|verify} messages. + * @param message FeatureSet message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: google.protobuf.IFeatureSet, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Encodes the specified FeatureSet message, length delimited. Does not implicitly {@link google.protobuf.FeatureSet.verify|verify} messages. + * @param message FeatureSet message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encodeDelimited(message: google.protobuf.IFeatureSet, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a FeatureSet message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns FeatureSet + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.FeatureSet; + + /** + * Decodes a FeatureSet message from the specified reader or buffer, length delimited. + * @param reader Reader or buffer to decode from + * @returns FeatureSet + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.FeatureSet; + + /** + * Verifies a FeatureSet message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + + /** + * Creates a FeatureSet message from a plain object. Also converts values to their respective internal types. + * @param object Plain object + * @returns FeatureSet + */ + public static fromObject(object: { [k: string]: any }): google.protobuf.FeatureSet; + + /** + * Creates a plain object from a FeatureSet message. Also converts values to other types if specified. + * @param message FeatureSet + * @param [options] Conversion options + * @returns Plain object + */ + public static toObject(message: google.protobuf.FeatureSet, options?: $protobuf.IConversionOptions): { [k: string]: any }; + + /** + * Converts this FeatureSet to JSON. + * @returns JSON object + */ + public toJSON(): { [k: string]: any }; + + /** + * Gets the default type url for FeatureSet + * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns The default type url + */ + public static getTypeUrl(typeUrlPrefix?: string): string; + } + + namespace FeatureSet { + + /** FieldPresence enum. */ + enum FieldPresence { + FIELD_PRESENCE_UNKNOWN = 0, + EXPLICIT = 1, + IMPLICIT = 2, + LEGACY_REQUIRED = 3 + } + + /** EnumType enum. */ + enum EnumType { + ENUM_TYPE_UNKNOWN = 0, + OPEN = 1, + CLOSED = 2 + } + + /** RepeatedFieldEncoding enum. */ + enum RepeatedFieldEncoding { + REPEATED_FIELD_ENCODING_UNKNOWN = 0, + PACKED = 1, + EXPANDED = 2 + } + + /** StringFieldValidation enum. */ + enum StringFieldValidation { + STRING_FIELD_VALIDATION_UNKNOWN = 0, + MANDATORY = 1, + HINT = 2, + NONE = 3 + } + + /** MessageEncoding enum. */ + enum MessageEncoding { + MESSAGE_ENCODING_UNKNOWN = 0, + LENGTH_PREFIXED = 1, + DELIMITED = 2 + } + + /** JsonFormat enum. */ + enum JsonFormat { + JSON_FORMAT_UNKNOWN = 0, + ALLOW = 1, + LEGACY_BEST_EFFORT = 2 + } + } + /** Properties of a SourceCodeInfo. */ interface ISourceCodeInfo { diff --git a/packages/google-cloud-edgenetwork/protos/protos.js b/packages/google-cloud-edgenetwork/protos/protos.js index 9fb7a9007736..b405c3a211c4 100644 --- a/packages/google-cloud-edgenetwork/protos/protos.js +++ b/packages/google-cloud-edgenetwork/protos/protos.js @@ -20003,6 +20003,7 @@ * @property {string|null} [docTagPrefix] Publishing docTagPrefix * @property {google.api.ClientLibraryOrganization|null} [organization] Publishing organization * @property {Array.|null} [librarySettings] Publishing librarySettings + * @property {string|null} [protoReferenceDocumentationUri] Publishing protoReferenceDocumentationUri */ /** @@ -20095,6 +20096,14 @@ */ Publishing.prototype.librarySettings = $util.emptyArray; + /** + * Publishing protoReferenceDocumentationUri. + * @member {string} protoReferenceDocumentationUri + * @memberof google.api.Publishing + * @instance + */ + Publishing.prototype.protoReferenceDocumentationUri = ""; + /** * Creates a new Publishing instance using the specified properties. * @function create @@ -20140,6 +20149,8 @@ if (message.librarySettings != null && message.librarySettings.length) for (var i = 0; i < message.librarySettings.length; ++i) $root.google.api.ClientLibrarySettings.encode(message.librarySettings[i], writer.uint32(/* id 109, wireType 2 =*/874).fork()).ldelim(); + if (message.protoReferenceDocumentationUri != null && Object.hasOwnProperty.call(message, "protoReferenceDocumentationUri")) + writer.uint32(/* id 110, wireType 2 =*/882).string(message.protoReferenceDocumentationUri); return writer; }; @@ -20216,6 +20227,10 @@ message.librarySettings.push($root.google.api.ClientLibrarySettings.decode(reader, reader.uint32())); break; } + case 110: { + message.protoReferenceDocumentationUri = reader.string(); + break; + } default: reader.skipType(tag & 7); break; @@ -20291,6 +20306,9 @@ case 2: case 3: case 4: + case 5: + case 6: + case 7: break; } if (message.librarySettings != null && message.hasOwnProperty("librarySettings")) { @@ -20302,6 +20320,9 @@ return "librarySettings." + error; } } + if (message.protoReferenceDocumentationUri != null && message.hasOwnProperty("protoReferenceDocumentationUri")) + if (!$util.isString(message.protoReferenceDocumentationUri)) + return "protoReferenceDocumentationUri: string expected"; return null; }; @@ -20371,6 +20392,18 @@ case 4: message.organization = 4; break; + case "SHOPPING": + case 5: + message.organization = 5; + break; + case "GEO": + case 6: + message.organization = 6; + break; + case "GENERATIVE_AI": + case 7: + message.organization = 7; + break; } if (object.librarySettings) { if (!Array.isArray(object.librarySettings)) @@ -20382,6 +20415,8 @@ message.librarySettings[i] = $root.google.api.ClientLibrarySettings.fromObject(object.librarySettings[i]); } } + if (object.protoReferenceDocumentationUri != null) + message.protoReferenceDocumentationUri = String(object.protoReferenceDocumentationUri); return message; }; @@ -20410,6 +20445,7 @@ object.githubLabel = ""; object.docTagPrefix = ""; object.organization = options.enums === String ? "CLIENT_LIBRARY_ORGANIZATION_UNSPECIFIED" : 0; + object.protoReferenceDocumentationUri = ""; } if (message.methodSettings && message.methodSettings.length) { object.methodSettings = []; @@ -20438,6 +20474,8 @@ for (var j = 0; j < message.librarySettings.length; ++j) object.librarySettings[j] = $root.google.api.ClientLibrarySettings.toObject(message.librarySettings[j], options); } + if (message.protoReferenceDocumentationUri != null && message.hasOwnProperty("protoReferenceDocumentationUri")) + object.protoReferenceDocumentationUri = message.protoReferenceDocumentationUri; return object; }; @@ -21600,6 +21638,11 @@ * @memberof google.api * @interface IDotnetSettings * @property {google.api.ICommonLanguageSettings|null} [common] DotnetSettings common + * @property {Object.|null} [renamedServices] DotnetSettings renamedServices + * @property {Object.|null} [renamedResources] DotnetSettings renamedResources + * @property {Array.|null} [ignoredResources] DotnetSettings ignoredResources + * @property {Array.|null} [forcedNamespaceAliases] DotnetSettings forcedNamespaceAliases + * @property {Array.|null} [handwrittenSignatures] DotnetSettings handwrittenSignatures */ /** @@ -21611,6 +21654,11 @@ * @param {google.api.IDotnetSettings=} [properties] Properties to set */ function DotnetSettings(properties) { + this.renamedServices = {}; + this.renamedResources = {}; + this.ignoredResources = []; + this.forcedNamespaceAliases = []; + this.handwrittenSignatures = []; if (properties) for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -21625,6 +21673,46 @@ */ DotnetSettings.prototype.common = null; + /** + * DotnetSettings renamedServices. + * @member {Object.} renamedServices + * @memberof google.api.DotnetSettings + * @instance + */ + DotnetSettings.prototype.renamedServices = $util.emptyObject; + + /** + * DotnetSettings renamedResources. + * @member {Object.} renamedResources + * @memberof google.api.DotnetSettings + * @instance + */ + DotnetSettings.prototype.renamedResources = $util.emptyObject; + + /** + * DotnetSettings ignoredResources. + * @member {Array.} ignoredResources + * @memberof google.api.DotnetSettings + * @instance + */ + DotnetSettings.prototype.ignoredResources = $util.emptyArray; + + /** + * DotnetSettings forcedNamespaceAliases. + * @member {Array.} forcedNamespaceAliases + * @memberof google.api.DotnetSettings + * @instance + */ + DotnetSettings.prototype.forcedNamespaceAliases = $util.emptyArray; + + /** + * DotnetSettings handwrittenSignatures. + * @member {Array.} handwrittenSignatures + * @memberof google.api.DotnetSettings + * @instance + */ + DotnetSettings.prototype.handwrittenSignatures = $util.emptyArray; + /** * Creates a new DotnetSettings instance using the specified properties. * @function create @@ -21651,6 +21739,21 @@ writer = $Writer.create(); if (message.common != null && Object.hasOwnProperty.call(message, "common")) $root.google.api.CommonLanguageSettings.encode(message.common, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.renamedServices != null && Object.hasOwnProperty.call(message, "renamedServices")) + for (var keys = Object.keys(message.renamedServices), i = 0; i < keys.length; ++i) + writer.uint32(/* id 2, wireType 2 =*/18).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]).uint32(/* id 2, wireType 2 =*/18).string(message.renamedServices[keys[i]]).ldelim(); + if (message.renamedResources != null && Object.hasOwnProperty.call(message, "renamedResources")) + for (var keys = Object.keys(message.renamedResources), i = 0; i < keys.length; ++i) + writer.uint32(/* id 3, wireType 2 =*/26).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]).uint32(/* id 2, wireType 2 =*/18).string(message.renamedResources[keys[i]]).ldelim(); + if (message.ignoredResources != null && message.ignoredResources.length) + for (var i = 0; i < message.ignoredResources.length; ++i) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.ignoredResources[i]); + if (message.forcedNamespaceAliases != null && message.forcedNamespaceAliases.length) + for (var i = 0; i < message.forcedNamespaceAliases.length; ++i) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.forcedNamespaceAliases[i]); + if (message.handwrittenSignatures != null && message.handwrittenSignatures.length) + for (var i = 0; i < message.handwrittenSignatures.length; ++i) + writer.uint32(/* id 6, wireType 2 =*/50).string(message.handwrittenSignatures[i]); return writer; }; @@ -21681,7 +21784,7 @@ DotnetSettings.decode = function decode(reader, length) { if (!(reader instanceof $Reader)) reader = $Reader.create(reader); - var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.DotnetSettings(); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.DotnetSettings(), key, value; while (reader.pos < end) { var tag = reader.uint32(); switch (tag >>> 3) { @@ -21689,6 +21792,70 @@ message.common = $root.google.api.CommonLanguageSettings.decode(reader, reader.uint32()); break; } + case 2: { + if (message.renamedServices === $util.emptyObject) + message.renamedServices = {}; + var end2 = reader.uint32() + reader.pos; + key = ""; + value = ""; + while (reader.pos < end2) { + var tag2 = reader.uint32(); + switch (tag2 >>> 3) { + case 1: + key = reader.string(); + break; + case 2: + value = reader.string(); + break; + default: + reader.skipType(tag2 & 7); + break; + } + } + message.renamedServices[key] = value; + break; + } + case 3: { + if (message.renamedResources === $util.emptyObject) + message.renamedResources = {}; + var end2 = reader.uint32() + reader.pos; + key = ""; + value = ""; + while (reader.pos < end2) { + var tag2 = reader.uint32(); + switch (tag2 >>> 3) { + case 1: + key = reader.string(); + break; + case 2: + value = reader.string(); + break; + default: + reader.skipType(tag2 & 7); + break; + } + } + message.renamedResources[key] = value; + break; + } + case 4: { + if (!(message.ignoredResources && message.ignoredResources.length)) + message.ignoredResources = []; + message.ignoredResources.push(reader.string()); + break; + } + case 5: { + if (!(message.forcedNamespaceAliases && message.forcedNamespaceAliases.length)) + message.forcedNamespaceAliases = []; + message.forcedNamespaceAliases.push(reader.string()); + break; + } + case 6: { + if (!(message.handwrittenSignatures && message.handwrittenSignatures.length)) + message.handwrittenSignatures = []; + message.handwrittenSignatures.push(reader.string()); + break; + } default: reader.skipType(tag & 7); break; @@ -21729,6 +21896,43 @@ if (error) return "common." + error; } + if (message.renamedServices != null && message.hasOwnProperty("renamedServices")) { + if (!$util.isObject(message.renamedServices)) + return "renamedServices: object expected"; + var key = Object.keys(message.renamedServices); + for (var i = 0; i < key.length; ++i) + if (!$util.isString(message.renamedServices[key[i]])) + return "renamedServices: string{k:string} expected"; + } + if (message.renamedResources != null && message.hasOwnProperty("renamedResources")) { + if (!$util.isObject(message.renamedResources)) + return "renamedResources: object expected"; + var key = Object.keys(message.renamedResources); + for (var i = 0; i < key.length; ++i) + if (!$util.isString(message.renamedResources[key[i]])) + return "renamedResources: string{k:string} expected"; + } + if (message.ignoredResources != null && message.hasOwnProperty("ignoredResources")) { + if (!Array.isArray(message.ignoredResources)) + return "ignoredResources: array expected"; + for (var i = 0; i < message.ignoredResources.length; ++i) + if (!$util.isString(message.ignoredResources[i])) + return "ignoredResources: string[] expected"; + } + if (message.forcedNamespaceAliases != null && message.hasOwnProperty("forcedNamespaceAliases")) { + if (!Array.isArray(message.forcedNamespaceAliases)) + return "forcedNamespaceAliases: array expected"; + for (var i = 0; i < message.forcedNamespaceAliases.length; ++i) + if (!$util.isString(message.forcedNamespaceAliases[i])) + return "forcedNamespaceAliases: string[] expected"; + } + if (message.handwrittenSignatures != null && message.hasOwnProperty("handwrittenSignatures")) { + if (!Array.isArray(message.handwrittenSignatures)) + return "handwrittenSignatures: array expected"; + for (var i = 0; i < message.handwrittenSignatures.length; ++i) + if (!$util.isString(message.handwrittenSignatures[i])) + return "handwrittenSignatures: string[] expected"; + } return null; }; @@ -21749,6 +21953,41 @@ throw TypeError(".google.api.DotnetSettings.common: object expected"); message.common = $root.google.api.CommonLanguageSettings.fromObject(object.common); } + if (object.renamedServices) { + if (typeof object.renamedServices !== "object") + throw TypeError(".google.api.DotnetSettings.renamedServices: object expected"); + message.renamedServices = {}; + for (var keys = Object.keys(object.renamedServices), i = 0; i < keys.length; ++i) + message.renamedServices[keys[i]] = String(object.renamedServices[keys[i]]); + } + if (object.renamedResources) { + if (typeof object.renamedResources !== "object") + throw TypeError(".google.api.DotnetSettings.renamedResources: object expected"); + message.renamedResources = {}; + for (var keys = Object.keys(object.renamedResources), i = 0; i < keys.length; ++i) + message.renamedResources[keys[i]] = String(object.renamedResources[keys[i]]); + } + if (object.ignoredResources) { + if (!Array.isArray(object.ignoredResources)) + throw TypeError(".google.api.DotnetSettings.ignoredResources: array expected"); + message.ignoredResources = []; + for (var i = 0; i < object.ignoredResources.length; ++i) + message.ignoredResources[i] = String(object.ignoredResources[i]); + } + if (object.forcedNamespaceAliases) { + if (!Array.isArray(object.forcedNamespaceAliases)) + throw TypeError(".google.api.DotnetSettings.forcedNamespaceAliases: array expected"); + message.forcedNamespaceAliases = []; + for (var i = 0; i < object.forcedNamespaceAliases.length; ++i) + message.forcedNamespaceAliases[i] = String(object.forcedNamespaceAliases[i]); + } + if (object.handwrittenSignatures) { + if (!Array.isArray(object.handwrittenSignatures)) + throw TypeError(".google.api.DotnetSettings.handwrittenSignatures: array expected"); + message.handwrittenSignatures = []; + for (var i = 0; i < object.handwrittenSignatures.length; ++i) + message.handwrittenSignatures[i] = String(object.handwrittenSignatures[i]); + } return message; }; @@ -21765,10 +22004,45 @@ if (!options) options = {}; var object = {}; + if (options.arrays || options.defaults) { + object.ignoredResources = []; + object.forcedNamespaceAliases = []; + object.handwrittenSignatures = []; + } + if (options.objects || options.defaults) { + object.renamedServices = {}; + object.renamedResources = {}; + } if (options.defaults) object.common = null; if (message.common != null && message.hasOwnProperty("common")) object.common = $root.google.api.CommonLanguageSettings.toObject(message.common, options); + var keys2; + if (message.renamedServices && (keys2 = Object.keys(message.renamedServices)).length) { + object.renamedServices = {}; + for (var j = 0; j < keys2.length; ++j) + object.renamedServices[keys2[j]] = message.renamedServices[keys2[j]]; + } + if (message.renamedResources && (keys2 = Object.keys(message.renamedResources)).length) { + object.renamedResources = {}; + for (var j = 0; j < keys2.length; ++j) + object.renamedResources[keys2[j]] = message.renamedResources[keys2[j]]; + } + if (message.ignoredResources && message.ignoredResources.length) { + object.ignoredResources = []; + for (var j = 0; j < message.ignoredResources.length; ++j) + object.ignoredResources[j] = message.ignoredResources[j]; + } + if (message.forcedNamespaceAliases && message.forcedNamespaceAliases.length) { + object.forcedNamespaceAliases = []; + for (var j = 0; j < message.forcedNamespaceAliases.length; ++j) + object.forcedNamespaceAliases[j] = message.forcedNamespaceAliases[j]; + } + if (message.handwrittenSignatures && message.handwrittenSignatures.length) { + object.handwrittenSignatures = []; + for (var j = 0; j < message.handwrittenSignatures.length; ++j) + object.handwrittenSignatures[j] = message.handwrittenSignatures[j]; + } return object; }; @@ -22746,6 +23020,9 @@ * @property {number} ADS=2 ADS value * @property {number} PHOTOS=3 PHOTOS value * @property {number} STREET_VIEW=4 STREET_VIEW value + * @property {number} SHOPPING=5 SHOPPING value + * @property {number} GEO=6 GEO value + * @property {number} GENERATIVE_AI=7 GENERATIVE_AI value */ api.ClientLibraryOrganization = (function() { var valuesById = {}, values = Object.create(valuesById); @@ -22754,6 +23031,9 @@ values[valuesById[2] = "ADS"] = 2; values[valuesById[3] = "PHOTOS"] = 3; values[valuesById[4] = "STREET_VIEW"] = 4; + values[valuesById[5] = "SHOPPING"] = 5; + values[valuesById[6] = "GEO"] = 6; + values[valuesById[7] = "GENERATIVE_AI"] = 7; return values; })(); @@ -24739,6 +25019,9 @@ * @memberof google.protobuf * @interface IExtensionRangeOptions * @property {Array.|null} [uninterpretedOption] ExtensionRangeOptions uninterpretedOption + * @property {Array.|null} [declaration] ExtensionRangeOptions declaration + * @property {google.protobuf.IFeatureSet|null} [features] ExtensionRangeOptions features + * @property {google.protobuf.ExtensionRangeOptions.VerificationState|null} [verification] ExtensionRangeOptions verification */ /** @@ -24751,6 +25034,7 @@ */ function ExtensionRangeOptions(properties) { this.uninterpretedOption = []; + this.declaration = []; if (properties) for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -24765,6 +25049,30 @@ */ ExtensionRangeOptions.prototype.uninterpretedOption = $util.emptyArray; + /** + * ExtensionRangeOptions declaration. + * @member {Array.} declaration + * @memberof google.protobuf.ExtensionRangeOptions + * @instance + */ + ExtensionRangeOptions.prototype.declaration = $util.emptyArray; + + /** + * ExtensionRangeOptions features. + * @member {google.protobuf.IFeatureSet|null|undefined} features + * @memberof google.protobuf.ExtensionRangeOptions + * @instance + */ + ExtensionRangeOptions.prototype.features = null; + + /** + * ExtensionRangeOptions verification. + * @member {google.protobuf.ExtensionRangeOptions.VerificationState} verification + * @memberof google.protobuf.ExtensionRangeOptions + * @instance + */ + ExtensionRangeOptions.prototype.verification = 1; + /** * Creates a new ExtensionRangeOptions instance using the specified properties. * @function create @@ -24789,6 +25097,13 @@ ExtensionRangeOptions.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); + if (message.declaration != null && message.declaration.length) + for (var i = 0; i < message.declaration.length; ++i) + $root.google.protobuf.ExtensionRangeOptions.Declaration.encode(message.declaration[i], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.verification != null && Object.hasOwnProperty.call(message, "verification")) + writer.uint32(/* id 3, wireType 0 =*/24).int32(message.verification); + if (message.features != null && Object.hasOwnProperty.call(message, "features")) + $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 50, wireType 2 =*/402).fork()).ldelim(); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -24832,6 +25147,20 @@ message.uninterpretedOption.push($root.google.protobuf.UninterpretedOption.decode(reader, reader.uint32())); break; } + case 2: { + if (!(message.declaration && message.declaration.length)) + message.declaration = []; + message.declaration.push($root.google.protobuf.ExtensionRangeOptions.Declaration.decode(reader, reader.uint32())); + break; + } + case 50: { + message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); + break; + } + case 3: { + message.verification = reader.int32(); + break; + } default: reader.skipType(tag & 7); break; @@ -24876,6 +25205,28 @@ return "uninterpretedOption." + error; } } + if (message.declaration != null && message.hasOwnProperty("declaration")) { + if (!Array.isArray(message.declaration)) + return "declaration: array expected"; + for (var i = 0; i < message.declaration.length; ++i) { + var error = $root.google.protobuf.ExtensionRangeOptions.Declaration.verify(message.declaration[i]); + if (error) + return "declaration." + error; + } + } + if (message.features != null && message.hasOwnProperty("features")) { + var error = $root.google.protobuf.FeatureSet.verify(message.features); + if (error) + return "features." + error; + } + if (message.verification != null && message.hasOwnProperty("verification")) + switch (message.verification) { + default: + return "verification: enum value expected"; + case 0: + case 1: + break; + } return null; }; @@ -24901,6 +25252,37 @@ message.uninterpretedOption[i] = $root.google.protobuf.UninterpretedOption.fromObject(object.uninterpretedOption[i]); } } + if (object.declaration) { + if (!Array.isArray(object.declaration)) + throw TypeError(".google.protobuf.ExtensionRangeOptions.declaration: array expected"); + message.declaration = []; + for (var i = 0; i < object.declaration.length; ++i) { + if (typeof object.declaration[i] !== "object") + throw TypeError(".google.protobuf.ExtensionRangeOptions.declaration: object expected"); + message.declaration[i] = $root.google.protobuf.ExtensionRangeOptions.Declaration.fromObject(object.declaration[i]); + } + } + if (object.features != null) { + if (typeof object.features !== "object") + throw TypeError(".google.protobuf.ExtensionRangeOptions.features: object expected"); + message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); + } + switch (object.verification) { + case "DECLARATION": + case 0: + message.verification = 0; + break; + default: + if (typeof object.verification === "number") { + message.verification = object.verification; + break; + } + break; + case "UNVERIFIED": + case 1: + message.verification = 1; + break; + } return message; }; @@ -24917,8 +25299,23 @@ if (!options) options = {}; var object = {}; - if (options.arrays || options.defaults) + if (options.arrays || options.defaults) { + object.declaration = []; object.uninterpretedOption = []; + } + if (options.defaults) { + object.verification = options.enums === String ? "UNVERIFIED" : 1; + object.features = null; + } + if (message.declaration && message.declaration.length) { + object.declaration = []; + for (var j = 0; j < message.declaration.length; ++j) + object.declaration[j] = $root.google.protobuf.ExtensionRangeOptions.Declaration.toObject(message.declaration[j], options); + } + if (message.verification != null && message.hasOwnProperty("verification")) + object.verification = options.enums === String ? $root.google.protobuf.ExtensionRangeOptions.VerificationState[message.verification] === undefined ? message.verification : $root.google.protobuf.ExtensionRangeOptions.VerificationState[message.verification] : message.verification; + if (message.features != null && message.hasOwnProperty("features")) + object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -24953,86 +25350,396 @@ return typeUrlPrefix + "/google.protobuf.ExtensionRangeOptions"; }; - return ExtensionRangeOptions; - })(); + ExtensionRangeOptions.Declaration = (function() { - protobuf.FieldDescriptorProto = (function() { + /** + * Properties of a Declaration. + * @memberof google.protobuf.ExtensionRangeOptions + * @interface IDeclaration + * @property {number|null} [number] Declaration number + * @property {string|null} [fullName] Declaration fullName + * @property {string|null} [type] Declaration type + * @property {boolean|null} [reserved] Declaration reserved + * @property {boolean|null} [repeated] Declaration repeated + */ - /** - * Properties of a FieldDescriptorProto. - * @memberof google.protobuf - * @interface IFieldDescriptorProto - * @property {string|null} [name] FieldDescriptorProto name - * @property {number|null} [number] FieldDescriptorProto number - * @property {google.protobuf.FieldDescriptorProto.Label|null} [label] FieldDescriptorProto label - * @property {google.protobuf.FieldDescriptorProto.Type|null} [type] FieldDescriptorProto type - * @property {string|null} [typeName] FieldDescriptorProto typeName - * @property {string|null} [extendee] FieldDescriptorProto extendee - * @property {string|null} [defaultValue] FieldDescriptorProto defaultValue - * @property {number|null} [oneofIndex] FieldDescriptorProto oneofIndex - * @property {string|null} [jsonName] FieldDescriptorProto jsonName - * @property {google.protobuf.IFieldOptions|null} [options] FieldDescriptorProto options - * @property {boolean|null} [proto3Optional] FieldDescriptorProto proto3Optional - */ + /** + * Constructs a new Declaration. + * @memberof google.protobuf.ExtensionRangeOptions + * @classdesc Represents a Declaration. + * @implements IDeclaration + * @constructor + * @param {google.protobuf.ExtensionRangeOptions.IDeclaration=} [properties] Properties to set + */ + function Declaration(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } - /** - * Constructs a new FieldDescriptorProto. - * @memberof google.protobuf - * @classdesc Represents a FieldDescriptorProto. - * @implements IFieldDescriptorProto - * @constructor - * @param {google.protobuf.IFieldDescriptorProto=} [properties] Properties to set - */ - function FieldDescriptorProto(properties) { - if (properties) - for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) - if (properties[keys[i]] != null) - this[keys[i]] = properties[keys[i]]; - } + /** + * Declaration number. + * @member {number} number + * @memberof google.protobuf.ExtensionRangeOptions.Declaration + * @instance + */ + Declaration.prototype.number = 0; - /** - * FieldDescriptorProto name. - * @member {string} name - * @memberof google.protobuf.FieldDescriptorProto - * @instance - */ - FieldDescriptorProto.prototype.name = ""; + /** + * Declaration fullName. + * @member {string} fullName + * @memberof google.protobuf.ExtensionRangeOptions.Declaration + * @instance + */ + Declaration.prototype.fullName = ""; - /** - * FieldDescriptorProto number. - * @member {number} number - * @memberof google.protobuf.FieldDescriptorProto - * @instance - */ - FieldDescriptorProto.prototype.number = 0; + /** + * Declaration type. + * @member {string} type + * @memberof google.protobuf.ExtensionRangeOptions.Declaration + * @instance + */ + Declaration.prototype.type = ""; - /** - * FieldDescriptorProto label. - * @member {google.protobuf.FieldDescriptorProto.Label} label - * @memberof google.protobuf.FieldDescriptorProto - * @instance - */ - FieldDescriptorProto.prototype.label = 1; + /** + * Declaration reserved. + * @member {boolean} reserved + * @memberof google.protobuf.ExtensionRangeOptions.Declaration + * @instance + */ + Declaration.prototype.reserved = false; - /** - * FieldDescriptorProto type. - * @member {google.protobuf.FieldDescriptorProto.Type} type - * @memberof google.protobuf.FieldDescriptorProto - * @instance - */ - FieldDescriptorProto.prototype.type = 1; + /** + * Declaration repeated. + * @member {boolean} repeated + * @memberof google.protobuf.ExtensionRangeOptions.Declaration + * @instance + */ + Declaration.prototype.repeated = false; - /** - * FieldDescriptorProto typeName. - * @member {string} typeName - * @memberof google.protobuf.FieldDescriptorProto - * @instance - */ - FieldDescriptorProto.prototype.typeName = ""; + /** + * Creates a new Declaration instance using the specified properties. + * @function create + * @memberof google.protobuf.ExtensionRangeOptions.Declaration + * @static + * @param {google.protobuf.ExtensionRangeOptions.IDeclaration=} [properties] Properties to set + * @returns {google.protobuf.ExtensionRangeOptions.Declaration} Declaration instance + */ + Declaration.create = function create(properties) { + return new Declaration(properties); + }; - /** - * FieldDescriptorProto extendee. - * @member {string} extendee + /** + * Encodes the specified Declaration message. Does not implicitly {@link google.protobuf.ExtensionRangeOptions.Declaration.verify|verify} messages. + * @function encode + * @memberof google.protobuf.ExtensionRangeOptions.Declaration + * @static + * @param {google.protobuf.ExtensionRangeOptions.IDeclaration} message Declaration message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Declaration.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.number != null && Object.hasOwnProperty.call(message, "number")) + writer.uint32(/* id 1, wireType 0 =*/8).int32(message.number); + if (message.fullName != null && Object.hasOwnProperty.call(message, "fullName")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.fullName); + if (message.type != null && Object.hasOwnProperty.call(message, "type")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.type); + if (message.reserved != null && Object.hasOwnProperty.call(message, "reserved")) + writer.uint32(/* id 5, wireType 0 =*/40).bool(message.reserved); + if (message.repeated != null && Object.hasOwnProperty.call(message, "repeated")) + writer.uint32(/* id 6, wireType 0 =*/48).bool(message.repeated); + return writer; + }; + + /** + * Encodes the specified Declaration message, length delimited. Does not implicitly {@link google.protobuf.ExtensionRangeOptions.Declaration.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.ExtensionRangeOptions.Declaration + * @static + * @param {google.protobuf.ExtensionRangeOptions.IDeclaration} message Declaration message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Declaration.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a Declaration message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.ExtensionRangeOptions.Declaration + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.ExtensionRangeOptions.Declaration} Declaration + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Declaration.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.ExtensionRangeOptions.Declaration(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.number = reader.int32(); + break; + } + case 2: { + message.fullName = reader.string(); + break; + } + case 3: { + message.type = reader.string(); + break; + } + case 5: { + message.reserved = reader.bool(); + break; + } + case 6: { + message.repeated = reader.bool(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a Declaration message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.ExtensionRangeOptions.Declaration + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.ExtensionRangeOptions.Declaration} Declaration + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Declaration.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a Declaration message. + * @function verify + * @memberof google.protobuf.ExtensionRangeOptions.Declaration + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Declaration.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.number != null && message.hasOwnProperty("number")) + if (!$util.isInteger(message.number)) + return "number: integer expected"; + if (message.fullName != null && message.hasOwnProperty("fullName")) + if (!$util.isString(message.fullName)) + return "fullName: string expected"; + if (message.type != null && message.hasOwnProperty("type")) + if (!$util.isString(message.type)) + return "type: string expected"; + if (message.reserved != null && message.hasOwnProperty("reserved")) + if (typeof message.reserved !== "boolean") + return "reserved: boolean expected"; + if (message.repeated != null && message.hasOwnProperty("repeated")) + if (typeof message.repeated !== "boolean") + return "repeated: boolean expected"; + return null; + }; + + /** + * Creates a Declaration message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.ExtensionRangeOptions.Declaration + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.ExtensionRangeOptions.Declaration} Declaration + */ + Declaration.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.ExtensionRangeOptions.Declaration) + return object; + var message = new $root.google.protobuf.ExtensionRangeOptions.Declaration(); + if (object.number != null) + message.number = object.number | 0; + if (object.fullName != null) + message.fullName = String(object.fullName); + if (object.type != null) + message.type = String(object.type); + if (object.reserved != null) + message.reserved = Boolean(object.reserved); + if (object.repeated != null) + message.repeated = Boolean(object.repeated); + return message; + }; + + /** + * Creates a plain object from a Declaration message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.ExtensionRangeOptions.Declaration + * @static + * @param {google.protobuf.ExtensionRangeOptions.Declaration} message Declaration + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + Declaration.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.number = 0; + object.fullName = ""; + object.type = ""; + object.reserved = false; + object.repeated = false; + } + if (message.number != null && message.hasOwnProperty("number")) + object.number = message.number; + if (message.fullName != null && message.hasOwnProperty("fullName")) + object.fullName = message.fullName; + if (message.type != null && message.hasOwnProperty("type")) + object.type = message.type; + if (message.reserved != null && message.hasOwnProperty("reserved")) + object.reserved = message.reserved; + if (message.repeated != null && message.hasOwnProperty("repeated")) + object.repeated = message.repeated; + return object; + }; + + /** + * Converts this Declaration to JSON. + * @function toJSON + * @memberof google.protobuf.ExtensionRangeOptions.Declaration + * @instance + * @returns {Object.} JSON object + */ + Declaration.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for Declaration + * @function getTypeUrl + * @memberof google.protobuf.ExtensionRangeOptions.Declaration + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + Declaration.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.ExtensionRangeOptions.Declaration"; + }; + + return Declaration; + })(); + + /** + * VerificationState enum. + * @name google.protobuf.ExtensionRangeOptions.VerificationState + * @enum {number} + * @property {number} DECLARATION=0 DECLARATION value + * @property {number} UNVERIFIED=1 UNVERIFIED value + */ + ExtensionRangeOptions.VerificationState = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "DECLARATION"] = 0; + values[valuesById[1] = "UNVERIFIED"] = 1; + return values; + })(); + + return ExtensionRangeOptions; + })(); + + protobuf.FieldDescriptorProto = (function() { + + /** + * Properties of a FieldDescriptorProto. + * @memberof google.protobuf + * @interface IFieldDescriptorProto + * @property {string|null} [name] FieldDescriptorProto name + * @property {number|null} [number] FieldDescriptorProto number + * @property {google.protobuf.FieldDescriptorProto.Label|null} [label] FieldDescriptorProto label + * @property {google.protobuf.FieldDescriptorProto.Type|null} [type] FieldDescriptorProto type + * @property {string|null} [typeName] FieldDescriptorProto typeName + * @property {string|null} [extendee] FieldDescriptorProto extendee + * @property {string|null} [defaultValue] FieldDescriptorProto defaultValue + * @property {number|null} [oneofIndex] FieldDescriptorProto oneofIndex + * @property {string|null} [jsonName] FieldDescriptorProto jsonName + * @property {google.protobuf.IFieldOptions|null} [options] FieldDescriptorProto options + * @property {boolean|null} [proto3Optional] FieldDescriptorProto proto3Optional + */ + + /** + * Constructs a new FieldDescriptorProto. + * @memberof google.protobuf + * @classdesc Represents a FieldDescriptorProto. + * @implements IFieldDescriptorProto + * @constructor + * @param {google.protobuf.IFieldDescriptorProto=} [properties] Properties to set + */ + function FieldDescriptorProto(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * FieldDescriptorProto name. + * @member {string} name + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.name = ""; + + /** + * FieldDescriptorProto number. + * @member {number} number + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.number = 0; + + /** + * FieldDescriptorProto label. + * @member {google.protobuf.FieldDescriptorProto.Label} label + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.label = 1; + + /** + * FieldDescriptorProto type. + * @member {google.protobuf.FieldDescriptorProto.Type} type + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.type = 1; + + /** + * FieldDescriptorProto typeName. + * @member {string} typeName + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.typeName = ""; + + /** + * FieldDescriptorProto extendee. + * @member {string} extendee * @memberof google.protobuf.FieldDescriptorProto * @instance */ @@ -27282,6 +27989,7 @@ * @property {string|null} [phpNamespace] FileOptions phpNamespace * @property {string|null} [phpMetadataNamespace] FileOptions phpMetadataNamespace * @property {string|null} [rubyPackage] FileOptions rubyPackage + * @property {google.protobuf.IFeatureSet|null} [features] FileOptions features * @property {Array.|null} [uninterpretedOption] FileOptions uninterpretedOption * @property {Array.|null} [".google.api.resourceDefinition"] FileOptions .google.api.resourceDefinition */ @@ -27463,6 +28171,14 @@ */ FileOptions.prototype.rubyPackage = ""; + /** + * FileOptions features. + * @member {google.protobuf.IFeatureSet|null|undefined} features + * @memberof google.protobuf.FileOptions + * @instance + */ + FileOptions.prototype.features = null; + /** * FileOptions uninterpretedOption. * @member {Array.} uninterpretedOption @@ -27543,6 +28259,8 @@ writer.uint32(/* id 44, wireType 2 =*/354).string(message.phpMetadataNamespace); if (message.rubyPackage != null && Object.hasOwnProperty.call(message, "rubyPackage")) writer.uint32(/* id 45, wireType 2 =*/362).string(message.rubyPackage); + if (message.features != null && Object.hasOwnProperty.call(message, "features")) + $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 50, wireType 2 =*/402).fork()).ldelim(); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -27663,6 +28381,10 @@ message.rubyPackage = reader.string(); break; } + case 50: { + message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); + break; + } case 999: { if (!(message.uninterpretedOption && message.uninterpretedOption.length)) message.uninterpretedOption = []; @@ -27776,6 +28498,11 @@ if (message.rubyPackage != null && message.hasOwnProperty("rubyPackage")) if (!$util.isString(message.rubyPackage)) return "rubyPackage: string expected"; + if (message.features != null && message.hasOwnProperty("features")) { + var error = $root.google.protobuf.FeatureSet.verify(message.features); + if (error) + return "features." + error; + } if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { if (!Array.isArray(message.uninterpretedOption)) return "uninterpretedOption: array expected"; @@ -27867,6 +28594,11 @@ message.phpMetadataNamespace = String(object.phpMetadataNamespace); if (object.rubyPackage != null) message.rubyPackage = String(object.rubyPackage); + if (object.features != null) { + if (typeof object.features !== "object") + throw TypeError(".google.protobuf.FileOptions.features: object expected"); + message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); + } if (object.uninterpretedOption) { if (!Array.isArray(object.uninterpretedOption)) throw TypeError(".google.protobuf.FileOptions.uninterpretedOption: array expected"); @@ -27928,6 +28660,7 @@ object.phpGenericServices = false; object.phpMetadataNamespace = ""; object.rubyPackage = ""; + object.features = null; } if (message.javaPackage != null && message.hasOwnProperty("javaPackage")) object.javaPackage = message.javaPackage; @@ -27969,6 +28702,8 @@ object.phpMetadataNamespace = message.phpMetadataNamespace; if (message.rubyPackage != null && message.hasOwnProperty("rubyPackage")) object.rubyPackage = message.rubyPackage; + if (message.features != null && message.hasOwnProperty("features")) + object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -28038,6 +28773,7 @@ * @property {boolean|null} [deprecated] MessageOptions deprecated * @property {boolean|null} [mapEntry] MessageOptions mapEntry * @property {boolean|null} [deprecatedLegacyJsonFieldConflicts] MessageOptions deprecatedLegacyJsonFieldConflicts + * @property {google.protobuf.IFeatureSet|null} [features] MessageOptions features * @property {Array.|null} [uninterpretedOption] MessageOptions uninterpretedOption * @property {google.api.IResourceDescriptor|null} [".google.api.resource"] MessageOptions .google.api.resource */ @@ -28098,6 +28834,14 @@ */ MessageOptions.prototype.deprecatedLegacyJsonFieldConflicts = false; + /** + * MessageOptions features. + * @member {google.protobuf.IFeatureSet|null|undefined} features + * @memberof google.protobuf.MessageOptions + * @instance + */ + MessageOptions.prototype.features = null; + /** * MessageOptions uninterpretedOption. * @member {Array.} uninterpretedOption @@ -28148,6 +28892,8 @@ writer.uint32(/* id 7, wireType 0 =*/56).bool(message.mapEntry); if (message.deprecatedLegacyJsonFieldConflicts != null && Object.hasOwnProperty.call(message, "deprecatedLegacyJsonFieldConflicts")) writer.uint32(/* id 11, wireType 0 =*/88).bool(message.deprecatedLegacyJsonFieldConflicts); + if (message.features != null && Object.hasOwnProperty.call(message, "features")) + $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 12, wireType 2 =*/98).fork()).ldelim(); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -28207,6 +28953,10 @@ message.deprecatedLegacyJsonFieldConflicts = reader.bool(); break; } + case 12: { + message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); + break; + } case 999: { if (!(message.uninterpretedOption && message.uninterpretedOption.length)) message.uninterpretedOption = []; @@ -28267,6 +29017,11 @@ if (message.deprecatedLegacyJsonFieldConflicts != null && message.hasOwnProperty("deprecatedLegacyJsonFieldConflicts")) if (typeof message.deprecatedLegacyJsonFieldConflicts !== "boolean") return "deprecatedLegacyJsonFieldConflicts: boolean expected"; + if (message.features != null && message.hasOwnProperty("features")) { + var error = $root.google.protobuf.FeatureSet.verify(message.features); + if (error) + return "features." + error; + } if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { if (!Array.isArray(message.uninterpretedOption)) return "uninterpretedOption: array expected"; @@ -28306,6 +29061,11 @@ message.mapEntry = Boolean(object.mapEntry); if (object.deprecatedLegacyJsonFieldConflicts != null) message.deprecatedLegacyJsonFieldConflicts = Boolean(object.deprecatedLegacyJsonFieldConflicts); + if (object.features != null) { + if (typeof object.features !== "object") + throw TypeError(".google.protobuf.MessageOptions.features: object expected"); + message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); + } if (object.uninterpretedOption) { if (!Array.isArray(object.uninterpretedOption)) throw TypeError(".google.protobuf.MessageOptions.uninterpretedOption: array expected"); @@ -28345,6 +29105,7 @@ object.deprecated = false; object.mapEntry = false; object.deprecatedLegacyJsonFieldConflicts = false; + object.features = null; object[".google.api.resource"] = null; } if (message.messageSetWireFormat != null && message.hasOwnProperty("messageSetWireFormat")) @@ -28357,6 +29118,8 @@ object.mapEntry = message.mapEntry; if (message.deprecatedLegacyJsonFieldConflicts != null && message.hasOwnProperty("deprecatedLegacyJsonFieldConflicts")) object.deprecatedLegacyJsonFieldConflicts = message.deprecatedLegacyJsonFieldConflicts; + if (message.features != null && message.hasOwnProperty("features")) + object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -28411,7 +29174,9 @@ * @property {boolean|null} [weak] FieldOptions weak * @property {boolean|null} [debugRedact] FieldOptions debugRedact * @property {google.protobuf.FieldOptions.OptionRetention|null} [retention] FieldOptions retention - * @property {google.protobuf.FieldOptions.OptionTargetType|null} [target] FieldOptions target + * @property {Array.|null} [targets] FieldOptions targets + * @property {Array.|null} [editionDefaults] FieldOptions editionDefaults + * @property {google.protobuf.IFeatureSet|null} [features] FieldOptions features * @property {Array.|null} [uninterpretedOption] FieldOptions uninterpretedOption * @property {Array.|null} [".google.api.fieldBehavior"] FieldOptions .google.api.fieldBehavior * @property {google.api.IResourceReference|null} [".google.api.resourceReference"] FieldOptions .google.api.resourceReference @@ -28426,6 +29191,8 @@ * @param {google.protobuf.IFieldOptions=} [properties] Properties to set */ function FieldOptions(properties) { + this.targets = []; + this.editionDefaults = []; this.uninterpretedOption = []; this[".google.api.fieldBehavior"] = []; if (properties) @@ -28507,12 +29274,28 @@ FieldOptions.prototype.retention = 0; /** - * FieldOptions target. - * @member {google.protobuf.FieldOptions.OptionTargetType} target + * FieldOptions targets. + * @member {Array.} targets + * @memberof google.protobuf.FieldOptions + * @instance + */ + FieldOptions.prototype.targets = $util.emptyArray; + + /** + * FieldOptions editionDefaults. + * @member {Array.} editionDefaults + * @memberof google.protobuf.FieldOptions + * @instance + */ + FieldOptions.prototype.editionDefaults = $util.emptyArray; + + /** + * FieldOptions features. + * @member {google.protobuf.IFeatureSet|null|undefined} features * @memberof google.protobuf.FieldOptions * @instance */ - FieldOptions.prototype.target = 0; + FieldOptions.prototype.features = null; /** * FieldOptions uninterpretedOption. @@ -28580,8 +29363,14 @@ writer.uint32(/* id 16, wireType 0 =*/128).bool(message.debugRedact); if (message.retention != null && Object.hasOwnProperty.call(message, "retention")) writer.uint32(/* id 17, wireType 0 =*/136).int32(message.retention); - if (message.target != null && Object.hasOwnProperty.call(message, "target")) - writer.uint32(/* id 18, wireType 0 =*/144).int32(message.target); + if (message.targets != null && message.targets.length) + for (var i = 0; i < message.targets.length; ++i) + writer.uint32(/* id 19, wireType 0 =*/152).int32(message.targets[i]); + if (message.editionDefaults != null && message.editionDefaults.length) + for (var i = 0; i < message.editionDefaults.length; ++i) + $root.google.protobuf.FieldOptions.EditionDefault.encode(message.editionDefaults[i], writer.uint32(/* id 20, wireType 2 =*/162).fork()).ldelim(); + if (message.features != null && Object.hasOwnProperty.call(message, "features")) + $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 21, wireType 2 =*/170).fork()).ldelim(); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -28663,8 +29452,25 @@ message.retention = reader.int32(); break; } - case 18: { - message.target = reader.int32(); + case 19: { + if (!(message.targets && message.targets.length)) + message.targets = []; + if ((tag & 7) === 2) { + var end2 = reader.uint32() + reader.pos; + while (reader.pos < end2) + message.targets.push(reader.int32()); + } else + message.targets.push(reader.int32()); + break; + } + case 20: { + if (!(message.editionDefaults && message.editionDefaults.length)) + message.editionDefaults = []; + message.editionDefaults.push($root.google.protobuf.FieldOptions.EditionDefault.decode(reader, reader.uint32())); + break; + } + case 21: { + message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); break; } case 999: { @@ -28768,22 +29574,40 @@ case 2: break; } - if (message.target != null && message.hasOwnProperty("target")) - switch (message.target) { - default: - return "target: enum value expected"; - case 0: - case 1: - case 2: - case 3: - case 4: - case 5: - case 6: - case 7: - case 8: - case 9: - break; + if (message.targets != null && message.hasOwnProperty("targets")) { + if (!Array.isArray(message.targets)) + return "targets: array expected"; + for (var i = 0; i < message.targets.length; ++i) + switch (message.targets[i]) { + default: + return "targets: enum value[] expected"; + case 0: + case 1: + case 2: + case 3: + case 4: + case 5: + case 6: + case 7: + case 8: + case 9: + break; + } + } + if (message.editionDefaults != null && message.hasOwnProperty("editionDefaults")) { + if (!Array.isArray(message.editionDefaults)) + return "editionDefaults: array expected"; + for (var i = 0; i < message.editionDefaults.length; ++i) { + var error = $root.google.protobuf.FieldOptions.EditionDefault.verify(message.editionDefaults[i]); + if (error) + return "editionDefaults." + error; } + } + if (message.features != null && message.hasOwnProperty("features")) { + var error = $root.google.protobuf.FeatureSet.verify(message.features); + if (error) + return "features." + error; + } if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { if (!Array.isArray(message.uninterpretedOption)) return "uninterpretedOption: array expected"; @@ -28903,53 +29727,73 @@ message.retention = 2; break; } - switch (object.target) { - default: - if (typeof object.target === "number") { - message.target = object.target; - break; + if (object.targets) { + if (!Array.isArray(object.targets)) + throw TypeError(".google.protobuf.FieldOptions.targets: array expected"); + message.targets = []; + for (var i = 0; i < object.targets.length; ++i) + switch (object.targets[i]) { + default: + if (typeof object.targets[i] === "number") { + message.targets[i] = object.targets[i]; + break; + } + case "TARGET_TYPE_UNKNOWN": + case 0: + message.targets[i] = 0; + break; + case "TARGET_TYPE_FILE": + case 1: + message.targets[i] = 1; + break; + case "TARGET_TYPE_EXTENSION_RANGE": + case 2: + message.targets[i] = 2; + break; + case "TARGET_TYPE_MESSAGE": + case 3: + message.targets[i] = 3; + break; + case "TARGET_TYPE_FIELD": + case 4: + message.targets[i] = 4; + break; + case "TARGET_TYPE_ONEOF": + case 5: + message.targets[i] = 5; + break; + case "TARGET_TYPE_ENUM": + case 6: + message.targets[i] = 6; + break; + case "TARGET_TYPE_ENUM_ENTRY": + case 7: + message.targets[i] = 7; + break; + case "TARGET_TYPE_SERVICE": + case 8: + message.targets[i] = 8; + break; + case "TARGET_TYPE_METHOD": + case 9: + message.targets[i] = 9; + break; + } + } + if (object.editionDefaults) { + if (!Array.isArray(object.editionDefaults)) + throw TypeError(".google.protobuf.FieldOptions.editionDefaults: array expected"); + message.editionDefaults = []; + for (var i = 0; i < object.editionDefaults.length; ++i) { + if (typeof object.editionDefaults[i] !== "object") + throw TypeError(".google.protobuf.FieldOptions.editionDefaults: object expected"); + message.editionDefaults[i] = $root.google.protobuf.FieldOptions.EditionDefault.fromObject(object.editionDefaults[i]); } - break; - case "TARGET_TYPE_UNKNOWN": - case 0: - message.target = 0; - break; - case "TARGET_TYPE_FILE": - case 1: - message.target = 1; - break; - case "TARGET_TYPE_EXTENSION_RANGE": - case 2: - message.target = 2; - break; - case "TARGET_TYPE_MESSAGE": - case 3: - message.target = 3; - break; - case "TARGET_TYPE_FIELD": - case 4: - message.target = 4; - break; - case "TARGET_TYPE_ONEOF": - case 5: - message.target = 5; - break; - case "TARGET_TYPE_ENUM": - case 6: - message.target = 6; - break; - case "TARGET_TYPE_ENUM_ENTRY": - case 7: - message.target = 7; - break; - case "TARGET_TYPE_SERVICE": - case 8: - message.target = 8; - break; - case "TARGET_TYPE_METHOD": - case 9: - message.target = 9; - break; + } + if (object.features != null) { + if (typeof object.features !== "object") + throw TypeError(".google.protobuf.FieldOptions.features: object expected"); + message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); } if (object.uninterpretedOption) { if (!Array.isArray(object.uninterpretedOption)) @@ -29028,6 +29872,8 @@ options = {}; var object = {}; if (options.arrays || options.defaults) { + object.targets = []; + object.editionDefaults = []; object.uninterpretedOption = []; object[".google.api.fieldBehavior"] = []; } @@ -29041,7 +29887,7 @@ object.unverifiedLazy = false; object.debugRedact = false; object.retention = options.enums === String ? "RETENTION_UNKNOWN" : 0; - object.target = options.enums === String ? "TARGET_TYPE_UNKNOWN" : 0; + object.features = null; object[".google.api.resourceReference"] = null; } if (message.ctype != null && message.hasOwnProperty("ctype")) @@ -29062,8 +29908,18 @@ object.debugRedact = message.debugRedact; if (message.retention != null && message.hasOwnProperty("retention")) object.retention = options.enums === String ? $root.google.protobuf.FieldOptions.OptionRetention[message.retention] === undefined ? message.retention : $root.google.protobuf.FieldOptions.OptionRetention[message.retention] : message.retention; - if (message.target != null && message.hasOwnProperty("target")) - object.target = options.enums === String ? $root.google.protobuf.FieldOptions.OptionTargetType[message.target] === undefined ? message.target : $root.google.protobuf.FieldOptions.OptionTargetType[message.target] : message.target; + if (message.targets && message.targets.length) { + object.targets = []; + for (var j = 0; j < message.targets.length; ++j) + object.targets[j] = options.enums === String ? $root.google.protobuf.FieldOptions.OptionTargetType[message.targets[j]] === undefined ? message.targets[j] : $root.google.protobuf.FieldOptions.OptionTargetType[message.targets[j]] : message.targets[j]; + } + if (message.editionDefaults && message.editionDefaults.length) { + object.editionDefaults = []; + for (var j = 0; j < message.editionDefaults.length; ++j) + object.editionDefaults[j] = $root.google.protobuf.FieldOptions.EditionDefault.toObject(message.editionDefaults[j], options); + } + if (message.features != null && message.hasOwnProperty("features")) + object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -29183,6 +30039,233 @@ return values; })(); + FieldOptions.EditionDefault = (function() { + + /** + * Properties of an EditionDefault. + * @memberof google.protobuf.FieldOptions + * @interface IEditionDefault + * @property {string|null} [edition] EditionDefault edition + * @property {string|null} [value] EditionDefault value + */ + + /** + * Constructs a new EditionDefault. + * @memberof google.protobuf.FieldOptions + * @classdesc Represents an EditionDefault. + * @implements IEditionDefault + * @constructor + * @param {google.protobuf.FieldOptions.IEditionDefault=} [properties] Properties to set + */ + function EditionDefault(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * EditionDefault edition. + * @member {string} edition + * @memberof google.protobuf.FieldOptions.EditionDefault + * @instance + */ + EditionDefault.prototype.edition = ""; + + /** + * EditionDefault value. + * @member {string} value + * @memberof google.protobuf.FieldOptions.EditionDefault + * @instance + */ + EditionDefault.prototype.value = ""; + + /** + * Creates a new EditionDefault instance using the specified properties. + * @function create + * @memberof google.protobuf.FieldOptions.EditionDefault + * @static + * @param {google.protobuf.FieldOptions.IEditionDefault=} [properties] Properties to set + * @returns {google.protobuf.FieldOptions.EditionDefault} EditionDefault instance + */ + EditionDefault.create = function create(properties) { + return new EditionDefault(properties); + }; + + /** + * Encodes the specified EditionDefault message. Does not implicitly {@link google.protobuf.FieldOptions.EditionDefault.verify|verify} messages. + * @function encode + * @memberof google.protobuf.FieldOptions.EditionDefault + * @static + * @param {google.protobuf.FieldOptions.IEditionDefault} message EditionDefault message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + EditionDefault.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.edition != null && Object.hasOwnProperty.call(message, "edition")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.edition); + if (message.value != null && Object.hasOwnProperty.call(message, "value")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.value); + return writer; + }; + + /** + * Encodes the specified EditionDefault message, length delimited. Does not implicitly {@link google.protobuf.FieldOptions.EditionDefault.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.FieldOptions.EditionDefault + * @static + * @param {google.protobuf.FieldOptions.IEditionDefault} message EditionDefault message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + EditionDefault.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes an EditionDefault message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.FieldOptions.EditionDefault + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.FieldOptions.EditionDefault} EditionDefault + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + EditionDefault.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.FieldOptions.EditionDefault(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.edition = reader.string(); + break; + } + case 2: { + message.value = reader.string(); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes an EditionDefault message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.FieldOptions.EditionDefault + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.FieldOptions.EditionDefault} EditionDefault + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + EditionDefault.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies an EditionDefault message. + * @function verify + * @memberof google.protobuf.FieldOptions.EditionDefault + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + EditionDefault.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.edition != null && message.hasOwnProperty("edition")) + if (!$util.isString(message.edition)) + return "edition: string expected"; + if (message.value != null && message.hasOwnProperty("value")) + if (!$util.isString(message.value)) + return "value: string expected"; + return null; + }; + + /** + * Creates an EditionDefault message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.FieldOptions.EditionDefault + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.FieldOptions.EditionDefault} EditionDefault + */ + EditionDefault.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.FieldOptions.EditionDefault) + return object; + var message = new $root.google.protobuf.FieldOptions.EditionDefault(); + if (object.edition != null) + message.edition = String(object.edition); + if (object.value != null) + message.value = String(object.value); + return message; + }; + + /** + * Creates a plain object from an EditionDefault message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.FieldOptions.EditionDefault + * @static + * @param {google.protobuf.FieldOptions.EditionDefault} message EditionDefault + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + EditionDefault.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.edition = ""; + object.value = ""; + } + if (message.edition != null && message.hasOwnProperty("edition")) + object.edition = message.edition; + if (message.value != null && message.hasOwnProperty("value")) + object.value = message.value; + return object; + }; + + /** + * Converts this EditionDefault to JSON. + * @function toJSON + * @memberof google.protobuf.FieldOptions.EditionDefault + * @instance + * @returns {Object.} JSON object + */ + EditionDefault.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for EditionDefault + * @function getTypeUrl + * @memberof google.protobuf.FieldOptions.EditionDefault + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + EditionDefault.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.FieldOptions.EditionDefault"; + }; + + return EditionDefault; + })(); + return FieldOptions; })(); @@ -29192,6 +30275,7 @@ * Properties of an OneofOptions. * @memberof google.protobuf * @interface IOneofOptions + * @property {google.protobuf.IFeatureSet|null} [features] OneofOptions features * @property {Array.|null} [uninterpretedOption] OneofOptions uninterpretedOption */ @@ -29211,6 +30295,14 @@ this[keys[i]] = properties[keys[i]]; } + /** + * OneofOptions features. + * @member {google.protobuf.IFeatureSet|null|undefined} features + * @memberof google.protobuf.OneofOptions + * @instance + */ + OneofOptions.prototype.features = null; + /** * OneofOptions uninterpretedOption. * @member {Array.} uninterpretedOption @@ -29243,6 +30335,8 @@ OneofOptions.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); + if (message.features != null && Object.hasOwnProperty.call(message, "features")) + $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -29280,6 +30374,10 @@ while (reader.pos < end) { var tag = reader.uint32(); switch (tag >>> 3) { + case 1: { + message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); + break; + } case 999: { if (!(message.uninterpretedOption && message.uninterpretedOption.length)) message.uninterpretedOption = []; @@ -29321,6 +30419,11 @@ OneofOptions.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; + if (message.features != null && message.hasOwnProperty("features")) { + var error = $root.google.protobuf.FeatureSet.verify(message.features); + if (error) + return "features." + error; + } if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { if (!Array.isArray(message.uninterpretedOption)) return "uninterpretedOption: array expected"; @@ -29345,6 +30448,11 @@ if (object instanceof $root.google.protobuf.OneofOptions) return object; var message = new $root.google.protobuf.OneofOptions(); + if (object.features != null) { + if (typeof object.features !== "object") + throw TypeError(".google.protobuf.OneofOptions.features: object expected"); + message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); + } if (object.uninterpretedOption) { if (!Array.isArray(object.uninterpretedOption)) throw TypeError(".google.protobuf.OneofOptions.uninterpretedOption: array expected"); @@ -29373,6 +30481,10 @@ var object = {}; if (options.arrays || options.defaults) object.uninterpretedOption = []; + if (options.defaults) + object.features = null; + if (message.features != null && message.hasOwnProperty("features")) + object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -29419,6 +30531,7 @@ * @property {boolean|null} [allowAlias] EnumOptions allowAlias * @property {boolean|null} [deprecated] EnumOptions deprecated * @property {boolean|null} [deprecatedLegacyJsonFieldConflicts] EnumOptions deprecatedLegacyJsonFieldConflicts + * @property {google.protobuf.IFeatureSet|null} [features] EnumOptions features * @property {Array.|null} [uninterpretedOption] EnumOptions uninterpretedOption */ @@ -29462,6 +30575,14 @@ */ EnumOptions.prototype.deprecatedLegacyJsonFieldConflicts = false; + /** + * EnumOptions features. + * @member {google.protobuf.IFeatureSet|null|undefined} features + * @memberof google.protobuf.EnumOptions + * @instance + */ + EnumOptions.prototype.features = null; + /** * EnumOptions uninterpretedOption. * @member {Array.} uninterpretedOption @@ -29500,6 +30621,8 @@ writer.uint32(/* id 3, wireType 0 =*/24).bool(message.deprecated); if (message.deprecatedLegacyJsonFieldConflicts != null && Object.hasOwnProperty.call(message, "deprecatedLegacyJsonFieldConflicts")) writer.uint32(/* id 6, wireType 0 =*/48).bool(message.deprecatedLegacyJsonFieldConflicts); + if (message.features != null && Object.hasOwnProperty.call(message, "features")) + $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 7, wireType 2 =*/58).fork()).ldelim(); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -29549,6 +30672,10 @@ message.deprecatedLegacyJsonFieldConflicts = reader.bool(); break; } + case 7: { + message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); + break; + } case 999: { if (!(message.uninterpretedOption && message.uninterpretedOption.length)) message.uninterpretedOption = []; @@ -29599,6 +30726,11 @@ if (message.deprecatedLegacyJsonFieldConflicts != null && message.hasOwnProperty("deprecatedLegacyJsonFieldConflicts")) if (typeof message.deprecatedLegacyJsonFieldConflicts !== "boolean") return "deprecatedLegacyJsonFieldConflicts: boolean expected"; + if (message.features != null && message.hasOwnProperty("features")) { + var error = $root.google.protobuf.FeatureSet.verify(message.features); + if (error) + return "features." + error; + } if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { if (!Array.isArray(message.uninterpretedOption)) return "uninterpretedOption: array expected"; @@ -29629,6 +30761,11 @@ message.deprecated = Boolean(object.deprecated); if (object.deprecatedLegacyJsonFieldConflicts != null) message.deprecatedLegacyJsonFieldConflicts = Boolean(object.deprecatedLegacyJsonFieldConflicts); + if (object.features != null) { + if (typeof object.features !== "object") + throw TypeError(".google.protobuf.EnumOptions.features: object expected"); + message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); + } if (object.uninterpretedOption) { if (!Array.isArray(object.uninterpretedOption)) throw TypeError(".google.protobuf.EnumOptions.uninterpretedOption: array expected"); @@ -29661,6 +30798,7 @@ object.allowAlias = false; object.deprecated = false; object.deprecatedLegacyJsonFieldConflicts = false; + object.features = null; } if (message.allowAlias != null && message.hasOwnProperty("allowAlias")) object.allowAlias = message.allowAlias; @@ -29668,6 +30806,8 @@ object.deprecated = message.deprecated; if (message.deprecatedLegacyJsonFieldConflicts != null && message.hasOwnProperty("deprecatedLegacyJsonFieldConflicts")) object.deprecatedLegacyJsonFieldConflicts = message.deprecatedLegacyJsonFieldConflicts; + if (message.features != null && message.hasOwnProperty("features")) + object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -29712,6 +30852,8 @@ * @memberof google.protobuf * @interface IEnumValueOptions * @property {boolean|null} [deprecated] EnumValueOptions deprecated + * @property {google.protobuf.IFeatureSet|null} [features] EnumValueOptions features + * @property {boolean|null} [debugRedact] EnumValueOptions debugRedact * @property {Array.|null} [uninterpretedOption] EnumValueOptions uninterpretedOption */ @@ -29739,6 +30881,22 @@ */ EnumValueOptions.prototype.deprecated = false; + /** + * EnumValueOptions features. + * @member {google.protobuf.IFeatureSet|null|undefined} features + * @memberof google.protobuf.EnumValueOptions + * @instance + */ + EnumValueOptions.prototype.features = null; + + /** + * EnumValueOptions debugRedact. + * @member {boolean} debugRedact + * @memberof google.protobuf.EnumValueOptions + * @instance + */ + EnumValueOptions.prototype.debugRedact = false; + /** * EnumValueOptions uninterpretedOption. * @member {Array.} uninterpretedOption @@ -29773,6 +30931,10 @@ writer = $Writer.create(); if (message.deprecated != null && Object.hasOwnProperty.call(message, "deprecated")) writer.uint32(/* id 1, wireType 0 =*/8).bool(message.deprecated); + if (message.features != null && Object.hasOwnProperty.call(message, "features")) + $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.debugRedact != null && Object.hasOwnProperty.call(message, "debugRedact")) + writer.uint32(/* id 3, wireType 0 =*/24).bool(message.debugRedact); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -29814,6 +30976,14 @@ message.deprecated = reader.bool(); break; } + case 2: { + message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); + break; + } + case 3: { + message.debugRedact = reader.bool(); + break; + } case 999: { if (!(message.uninterpretedOption && message.uninterpretedOption.length)) message.uninterpretedOption = []; @@ -29858,7 +31028,15 @@ if (message.deprecated != null && message.hasOwnProperty("deprecated")) if (typeof message.deprecated !== "boolean") return "deprecated: boolean expected"; - if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { + if (message.features != null && message.hasOwnProperty("features")) { + var error = $root.google.protobuf.FeatureSet.verify(message.features); + if (error) + return "features." + error; + } + if (message.debugRedact != null && message.hasOwnProperty("debugRedact")) + if (typeof message.debugRedact !== "boolean") + return "debugRedact: boolean expected"; + if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { if (!Array.isArray(message.uninterpretedOption)) return "uninterpretedOption: array expected"; for (var i = 0; i < message.uninterpretedOption.length; ++i) { @@ -29884,6 +31062,13 @@ var message = new $root.google.protobuf.EnumValueOptions(); if (object.deprecated != null) message.deprecated = Boolean(object.deprecated); + if (object.features != null) { + if (typeof object.features !== "object") + throw TypeError(".google.protobuf.EnumValueOptions.features: object expected"); + message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); + } + if (object.debugRedact != null) + message.debugRedact = Boolean(object.debugRedact); if (object.uninterpretedOption) { if (!Array.isArray(object.uninterpretedOption)) throw TypeError(".google.protobuf.EnumValueOptions.uninterpretedOption: array expected"); @@ -29912,10 +31097,17 @@ var object = {}; if (options.arrays || options.defaults) object.uninterpretedOption = []; - if (options.defaults) + if (options.defaults) { object.deprecated = false; + object.features = null; + object.debugRedact = false; + } if (message.deprecated != null && message.hasOwnProperty("deprecated")) object.deprecated = message.deprecated; + if (message.features != null && message.hasOwnProperty("features")) + object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); + if (message.debugRedact != null && message.hasOwnProperty("debugRedact")) + object.debugRedact = message.debugRedact; if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -29959,6 +31151,7 @@ * Properties of a ServiceOptions. * @memberof google.protobuf * @interface IServiceOptions + * @property {google.protobuf.IFeatureSet|null} [features] ServiceOptions features * @property {boolean|null} [deprecated] ServiceOptions deprecated * @property {Array.|null} [uninterpretedOption] ServiceOptions uninterpretedOption * @property {string|null} [".google.api.defaultHost"] ServiceOptions .google.api.defaultHost @@ -29981,6 +31174,14 @@ this[keys[i]] = properties[keys[i]]; } + /** + * ServiceOptions features. + * @member {google.protobuf.IFeatureSet|null|undefined} features + * @memberof google.protobuf.ServiceOptions + * @instance + */ + ServiceOptions.prototype.features = null; + /** * ServiceOptions deprecated. * @member {boolean} deprecated @@ -30039,6 +31240,8 @@ writer = $Writer.create(); if (message.deprecated != null && Object.hasOwnProperty.call(message, "deprecated")) writer.uint32(/* id 33, wireType 0 =*/264).bool(message.deprecated); + if (message.features != null && Object.hasOwnProperty.call(message, "features")) + $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 34, wireType 2 =*/274).fork()).ldelim(); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -30080,6 +31283,10 @@ while (reader.pos < end) { var tag = reader.uint32(); switch (tag >>> 3) { + case 34: { + message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); + break; + } case 33: { message.deprecated = reader.bool(); break; @@ -30133,6 +31340,11 @@ ServiceOptions.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; + if (message.features != null && message.hasOwnProperty("features")) { + var error = $root.google.protobuf.FeatureSet.verify(message.features); + if (error) + return "features." + error; + } if (message.deprecated != null && message.hasOwnProperty("deprecated")) if (typeof message.deprecated !== "boolean") return "deprecated: boolean expected"; @@ -30166,6 +31378,11 @@ if (object instanceof $root.google.protobuf.ServiceOptions) return object; var message = new $root.google.protobuf.ServiceOptions(); + if (object.features != null) { + if (typeof object.features !== "object") + throw TypeError(".google.protobuf.ServiceOptions.features: object expected"); + message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); + } if (object.deprecated != null) message.deprecated = Boolean(object.deprecated); if (object.uninterpretedOption) { @@ -30202,11 +31419,14 @@ object.uninterpretedOption = []; if (options.defaults) { object.deprecated = false; + object.features = null; object[".google.api.defaultHost"] = ""; object[".google.api.oauthScopes"] = ""; } if (message.deprecated != null && message.hasOwnProperty("deprecated")) object.deprecated = message.deprecated; + if (message.features != null && message.hasOwnProperty("features")) + object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -30256,6 +31476,7 @@ * @interface IMethodOptions * @property {boolean|null} [deprecated] MethodOptions deprecated * @property {google.protobuf.MethodOptions.IdempotencyLevel|null} [idempotencyLevel] MethodOptions idempotencyLevel + * @property {google.protobuf.IFeatureSet|null} [features] MethodOptions features * @property {Array.|null} [uninterpretedOption] MethodOptions uninterpretedOption * @property {google.api.IHttpRule|null} [".google.api.http"] MethodOptions .google.api.http * @property {Array.|null} [".google.api.methodSignature"] MethodOptions .google.api.methodSignature @@ -30295,6 +31516,14 @@ */ MethodOptions.prototype.idempotencyLevel = 0; + /** + * MethodOptions features. + * @member {google.protobuf.IFeatureSet|null|undefined} features + * @memberof google.protobuf.MethodOptions + * @instance + */ + MethodOptions.prototype.features = null; + /** * MethodOptions uninterpretedOption. * @member {Array.} uninterpretedOption @@ -30355,6 +31584,8 @@ writer.uint32(/* id 33, wireType 0 =*/264).bool(message.deprecated); if (message.idempotencyLevel != null && Object.hasOwnProperty.call(message, "idempotencyLevel")) writer.uint32(/* id 34, wireType 0 =*/272).int32(message.idempotencyLevel); + if (message.features != null && Object.hasOwnProperty.call(message, "features")) + $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 35, wireType 2 =*/282).fork()).ldelim(); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -30407,6 +31638,10 @@ message.idempotencyLevel = reader.int32(); break; } + case 35: { + message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); + break; + } case 999: { if (!(message.uninterpretedOption && message.uninterpretedOption.length)) message.uninterpretedOption = []; @@ -30474,6 +31709,11 @@ case 2: break; } + if (message.features != null && message.hasOwnProperty("features")) { + var error = $root.google.protobuf.FeatureSet.verify(message.features); + if (error) + return "features." + error; + } if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { if (!Array.isArray(message.uninterpretedOption)) return "uninterpretedOption: array expected"; @@ -30537,6 +31777,11 @@ message.idempotencyLevel = 2; break; } + if (object.features != null) { + if (typeof object.features !== "object") + throw TypeError(".google.protobuf.MethodOptions.features: object expected"); + message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); + } if (object.uninterpretedOption) { if (!Array.isArray(object.uninterpretedOption)) throw TypeError(".google.protobuf.MethodOptions.uninterpretedOption: array expected"); @@ -30587,6 +31832,7 @@ if (options.defaults) { object.deprecated = false; object.idempotencyLevel = options.enums === String ? "IDEMPOTENCY_UNKNOWN" : 0; + object.features = null; object[".google.longrunning.operationInfo"] = null; object[".google.api.http"] = null; } @@ -30594,6 +31840,8 @@ object.deprecated = message.deprecated; if (message.idempotencyLevel != null && message.hasOwnProperty("idempotencyLevel")) object.idempotencyLevel = options.enums === String ? $root.google.protobuf.MethodOptions.IdempotencyLevel[message.idempotencyLevel] === undefined ? message.idempotencyLevel : $root.google.protobuf.MethodOptions.IdempotencyLevel[message.idempotencyLevel] : message.idempotencyLevel; + if (message.features != null && message.hasOwnProperty("features")) + object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -31284,6 +32532,607 @@ return UninterpretedOption; })(); + protobuf.FeatureSet = (function() { + + /** + * Properties of a FeatureSet. + * @memberof google.protobuf + * @interface IFeatureSet + * @property {google.protobuf.FeatureSet.FieldPresence|null} [fieldPresence] FeatureSet fieldPresence + * @property {google.protobuf.FeatureSet.EnumType|null} [enumType] FeatureSet enumType + * @property {google.protobuf.FeatureSet.RepeatedFieldEncoding|null} [repeatedFieldEncoding] FeatureSet repeatedFieldEncoding + * @property {google.protobuf.FeatureSet.StringFieldValidation|null} [stringFieldValidation] FeatureSet stringFieldValidation + * @property {google.protobuf.FeatureSet.MessageEncoding|null} [messageEncoding] FeatureSet messageEncoding + * @property {google.protobuf.FeatureSet.JsonFormat|null} [jsonFormat] FeatureSet jsonFormat + * @property {google.protobuf.IFeatureSet|null} [rawFeatures] FeatureSet rawFeatures + */ + + /** + * Constructs a new FeatureSet. + * @memberof google.protobuf + * @classdesc Represents a FeatureSet. + * @implements IFeatureSet + * @constructor + * @param {google.protobuf.IFeatureSet=} [properties] Properties to set + */ + function FeatureSet(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * FeatureSet fieldPresence. + * @member {google.protobuf.FeatureSet.FieldPresence} fieldPresence + * @memberof google.protobuf.FeatureSet + * @instance + */ + FeatureSet.prototype.fieldPresence = 0; + + /** + * FeatureSet enumType. + * @member {google.protobuf.FeatureSet.EnumType} enumType + * @memberof google.protobuf.FeatureSet + * @instance + */ + FeatureSet.prototype.enumType = 0; + + /** + * FeatureSet repeatedFieldEncoding. + * @member {google.protobuf.FeatureSet.RepeatedFieldEncoding} repeatedFieldEncoding + * @memberof google.protobuf.FeatureSet + * @instance + */ + FeatureSet.prototype.repeatedFieldEncoding = 0; + + /** + * FeatureSet stringFieldValidation. + * @member {google.protobuf.FeatureSet.StringFieldValidation} stringFieldValidation + * @memberof google.protobuf.FeatureSet + * @instance + */ + FeatureSet.prototype.stringFieldValidation = 0; + + /** + * FeatureSet messageEncoding. + * @member {google.protobuf.FeatureSet.MessageEncoding} messageEncoding + * @memberof google.protobuf.FeatureSet + * @instance + */ + FeatureSet.prototype.messageEncoding = 0; + + /** + * FeatureSet jsonFormat. + * @member {google.protobuf.FeatureSet.JsonFormat} jsonFormat + * @memberof google.protobuf.FeatureSet + * @instance + */ + FeatureSet.prototype.jsonFormat = 0; + + /** + * FeatureSet rawFeatures. + * @member {google.protobuf.IFeatureSet|null|undefined} rawFeatures + * @memberof google.protobuf.FeatureSet + * @instance + */ + FeatureSet.prototype.rawFeatures = null; + + /** + * Creates a new FeatureSet instance using the specified properties. + * @function create + * @memberof google.protobuf.FeatureSet + * @static + * @param {google.protobuf.IFeatureSet=} [properties] Properties to set + * @returns {google.protobuf.FeatureSet} FeatureSet instance + */ + FeatureSet.create = function create(properties) { + return new FeatureSet(properties); + }; + + /** + * Encodes the specified FeatureSet message. Does not implicitly {@link google.protobuf.FeatureSet.verify|verify} messages. + * @function encode + * @memberof google.protobuf.FeatureSet + * @static + * @param {google.protobuf.IFeatureSet} message FeatureSet message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + FeatureSet.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.fieldPresence != null && Object.hasOwnProperty.call(message, "fieldPresence")) + writer.uint32(/* id 1, wireType 0 =*/8).int32(message.fieldPresence); + if (message.enumType != null && Object.hasOwnProperty.call(message, "enumType")) + writer.uint32(/* id 2, wireType 0 =*/16).int32(message.enumType); + if (message.repeatedFieldEncoding != null && Object.hasOwnProperty.call(message, "repeatedFieldEncoding")) + writer.uint32(/* id 3, wireType 0 =*/24).int32(message.repeatedFieldEncoding); + if (message.stringFieldValidation != null && Object.hasOwnProperty.call(message, "stringFieldValidation")) + writer.uint32(/* id 4, wireType 0 =*/32).int32(message.stringFieldValidation); + if (message.messageEncoding != null && Object.hasOwnProperty.call(message, "messageEncoding")) + writer.uint32(/* id 5, wireType 0 =*/40).int32(message.messageEncoding); + if (message.jsonFormat != null && Object.hasOwnProperty.call(message, "jsonFormat")) + writer.uint32(/* id 6, wireType 0 =*/48).int32(message.jsonFormat); + if (message.rawFeatures != null && Object.hasOwnProperty.call(message, "rawFeatures")) + $root.google.protobuf.FeatureSet.encode(message.rawFeatures, writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); + return writer; + }; + + /** + * Encodes the specified FeatureSet message, length delimited. Does not implicitly {@link google.protobuf.FeatureSet.verify|verify} messages. + * @function encodeDelimited + * @memberof google.protobuf.FeatureSet + * @static + * @param {google.protobuf.IFeatureSet} message FeatureSet message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + FeatureSet.encodeDelimited = function encodeDelimited(message, writer) { + return this.encode(message, writer).ldelim(); + }; + + /** + * Decodes a FeatureSet message from the specified reader or buffer. + * @function decode + * @memberof google.protobuf.FeatureSet + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {google.protobuf.FeatureSet} FeatureSet + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + FeatureSet.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.FeatureSet(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: { + message.fieldPresence = reader.int32(); + break; + } + case 2: { + message.enumType = reader.int32(); + break; + } + case 3: { + message.repeatedFieldEncoding = reader.int32(); + break; + } + case 4: { + message.stringFieldValidation = reader.int32(); + break; + } + case 5: { + message.messageEncoding = reader.int32(); + break; + } + case 6: { + message.jsonFormat = reader.int32(); + break; + } + case 999: { + message.rawFeatures = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); + break; + } + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Decodes a FeatureSet message from the specified reader or buffer, length delimited. + * @function decodeDelimited + * @memberof google.protobuf.FeatureSet + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @returns {google.protobuf.FeatureSet} FeatureSet + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + FeatureSet.decodeDelimited = function decodeDelimited(reader) { + if (!(reader instanceof $Reader)) + reader = new $Reader(reader); + return this.decode(reader, reader.uint32()); + }; + + /** + * Verifies a FeatureSet message. + * @function verify + * @memberof google.protobuf.FeatureSet + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + FeatureSet.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.fieldPresence != null && message.hasOwnProperty("fieldPresence")) + switch (message.fieldPresence) { + default: + return "fieldPresence: enum value expected"; + case 0: + case 1: + case 2: + case 3: + break; + } + if (message.enumType != null && message.hasOwnProperty("enumType")) + switch (message.enumType) { + default: + return "enumType: enum value expected"; + case 0: + case 1: + case 2: + break; + } + if (message.repeatedFieldEncoding != null && message.hasOwnProperty("repeatedFieldEncoding")) + switch (message.repeatedFieldEncoding) { + default: + return "repeatedFieldEncoding: enum value expected"; + case 0: + case 1: + case 2: + break; + } + if (message.stringFieldValidation != null && message.hasOwnProperty("stringFieldValidation")) + switch (message.stringFieldValidation) { + default: + return "stringFieldValidation: enum value expected"; + case 0: + case 1: + case 2: + case 3: + break; + } + if (message.messageEncoding != null && message.hasOwnProperty("messageEncoding")) + switch (message.messageEncoding) { + default: + return "messageEncoding: enum value expected"; + case 0: + case 1: + case 2: + break; + } + if (message.jsonFormat != null && message.hasOwnProperty("jsonFormat")) + switch (message.jsonFormat) { + default: + return "jsonFormat: enum value expected"; + case 0: + case 1: + case 2: + break; + } + if (message.rawFeatures != null && message.hasOwnProperty("rawFeatures")) { + var error = $root.google.protobuf.FeatureSet.verify(message.rawFeatures); + if (error) + return "rawFeatures." + error; + } + return null; + }; + + /** + * Creates a FeatureSet message from a plain object. Also converts values to their respective internal types. + * @function fromObject + * @memberof google.protobuf.FeatureSet + * @static + * @param {Object.} object Plain object + * @returns {google.protobuf.FeatureSet} FeatureSet + */ + FeatureSet.fromObject = function fromObject(object) { + if (object instanceof $root.google.protobuf.FeatureSet) + return object; + var message = new $root.google.protobuf.FeatureSet(); + switch (object.fieldPresence) { + default: + if (typeof object.fieldPresence === "number") { + message.fieldPresence = object.fieldPresence; + break; + } + break; + case "FIELD_PRESENCE_UNKNOWN": + case 0: + message.fieldPresence = 0; + break; + case "EXPLICIT": + case 1: + message.fieldPresence = 1; + break; + case "IMPLICIT": + case 2: + message.fieldPresence = 2; + break; + case "LEGACY_REQUIRED": + case 3: + message.fieldPresence = 3; + break; + } + switch (object.enumType) { + default: + if (typeof object.enumType === "number") { + message.enumType = object.enumType; + break; + } + break; + case "ENUM_TYPE_UNKNOWN": + case 0: + message.enumType = 0; + break; + case "OPEN": + case 1: + message.enumType = 1; + break; + case "CLOSED": + case 2: + message.enumType = 2; + break; + } + switch (object.repeatedFieldEncoding) { + default: + if (typeof object.repeatedFieldEncoding === "number") { + message.repeatedFieldEncoding = object.repeatedFieldEncoding; + break; + } + break; + case "REPEATED_FIELD_ENCODING_UNKNOWN": + case 0: + message.repeatedFieldEncoding = 0; + break; + case "PACKED": + case 1: + message.repeatedFieldEncoding = 1; + break; + case "EXPANDED": + case 2: + message.repeatedFieldEncoding = 2; + break; + } + switch (object.stringFieldValidation) { + default: + if (typeof object.stringFieldValidation === "number") { + message.stringFieldValidation = object.stringFieldValidation; + break; + } + break; + case "STRING_FIELD_VALIDATION_UNKNOWN": + case 0: + message.stringFieldValidation = 0; + break; + case "MANDATORY": + case 1: + message.stringFieldValidation = 1; + break; + case "HINT": + case 2: + message.stringFieldValidation = 2; + break; + case "NONE": + case 3: + message.stringFieldValidation = 3; + break; + } + switch (object.messageEncoding) { + default: + if (typeof object.messageEncoding === "number") { + message.messageEncoding = object.messageEncoding; + break; + } + break; + case "MESSAGE_ENCODING_UNKNOWN": + case 0: + message.messageEncoding = 0; + break; + case "LENGTH_PREFIXED": + case 1: + message.messageEncoding = 1; + break; + case "DELIMITED": + case 2: + message.messageEncoding = 2; + break; + } + switch (object.jsonFormat) { + default: + if (typeof object.jsonFormat === "number") { + message.jsonFormat = object.jsonFormat; + break; + } + break; + case "JSON_FORMAT_UNKNOWN": + case 0: + message.jsonFormat = 0; + break; + case "ALLOW": + case 1: + message.jsonFormat = 1; + break; + case "LEGACY_BEST_EFFORT": + case 2: + message.jsonFormat = 2; + break; + } + if (object.rawFeatures != null) { + if (typeof object.rawFeatures !== "object") + throw TypeError(".google.protobuf.FeatureSet.rawFeatures: object expected"); + message.rawFeatures = $root.google.protobuf.FeatureSet.fromObject(object.rawFeatures); + } + return message; + }; + + /** + * Creates a plain object from a FeatureSet message. Also converts values to other types if specified. + * @function toObject + * @memberof google.protobuf.FeatureSet + * @static + * @param {google.protobuf.FeatureSet} message FeatureSet + * @param {$protobuf.IConversionOptions} [options] Conversion options + * @returns {Object.} Plain object + */ + FeatureSet.toObject = function toObject(message, options) { + if (!options) + options = {}; + var object = {}; + if (options.defaults) { + object.fieldPresence = options.enums === String ? "FIELD_PRESENCE_UNKNOWN" : 0; + object.enumType = options.enums === String ? "ENUM_TYPE_UNKNOWN" : 0; + object.repeatedFieldEncoding = options.enums === String ? "REPEATED_FIELD_ENCODING_UNKNOWN" : 0; + object.stringFieldValidation = options.enums === String ? "STRING_FIELD_VALIDATION_UNKNOWN" : 0; + object.messageEncoding = options.enums === String ? "MESSAGE_ENCODING_UNKNOWN" : 0; + object.jsonFormat = options.enums === String ? "JSON_FORMAT_UNKNOWN" : 0; + object.rawFeatures = null; + } + if (message.fieldPresence != null && message.hasOwnProperty("fieldPresence")) + object.fieldPresence = options.enums === String ? $root.google.protobuf.FeatureSet.FieldPresence[message.fieldPresence] === undefined ? message.fieldPresence : $root.google.protobuf.FeatureSet.FieldPresence[message.fieldPresence] : message.fieldPresence; + if (message.enumType != null && message.hasOwnProperty("enumType")) + object.enumType = options.enums === String ? $root.google.protobuf.FeatureSet.EnumType[message.enumType] === undefined ? message.enumType : $root.google.protobuf.FeatureSet.EnumType[message.enumType] : message.enumType; + if (message.repeatedFieldEncoding != null && message.hasOwnProperty("repeatedFieldEncoding")) + object.repeatedFieldEncoding = options.enums === String ? $root.google.protobuf.FeatureSet.RepeatedFieldEncoding[message.repeatedFieldEncoding] === undefined ? message.repeatedFieldEncoding : $root.google.protobuf.FeatureSet.RepeatedFieldEncoding[message.repeatedFieldEncoding] : message.repeatedFieldEncoding; + if (message.stringFieldValidation != null && message.hasOwnProperty("stringFieldValidation")) + object.stringFieldValidation = options.enums === String ? $root.google.protobuf.FeatureSet.StringFieldValidation[message.stringFieldValidation] === undefined ? message.stringFieldValidation : $root.google.protobuf.FeatureSet.StringFieldValidation[message.stringFieldValidation] : message.stringFieldValidation; + if (message.messageEncoding != null && message.hasOwnProperty("messageEncoding")) + object.messageEncoding = options.enums === String ? $root.google.protobuf.FeatureSet.MessageEncoding[message.messageEncoding] === undefined ? message.messageEncoding : $root.google.protobuf.FeatureSet.MessageEncoding[message.messageEncoding] : message.messageEncoding; + if (message.jsonFormat != null && message.hasOwnProperty("jsonFormat")) + object.jsonFormat = options.enums === String ? $root.google.protobuf.FeatureSet.JsonFormat[message.jsonFormat] === undefined ? message.jsonFormat : $root.google.protobuf.FeatureSet.JsonFormat[message.jsonFormat] : message.jsonFormat; + if (message.rawFeatures != null && message.hasOwnProperty("rawFeatures")) + object.rawFeatures = $root.google.protobuf.FeatureSet.toObject(message.rawFeatures, options); + return object; + }; + + /** + * Converts this FeatureSet to JSON. + * @function toJSON + * @memberof google.protobuf.FeatureSet + * @instance + * @returns {Object.} JSON object + */ + FeatureSet.prototype.toJSON = function toJSON() { + return this.constructor.toObject(this, $protobuf.util.toJSONOptions); + }; + + /** + * Gets the default type url for FeatureSet + * @function getTypeUrl + * @memberof google.protobuf.FeatureSet + * @static + * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") + * @returns {string} The default type url + */ + FeatureSet.getTypeUrl = function getTypeUrl(typeUrlPrefix) { + if (typeUrlPrefix === undefined) { + typeUrlPrefix = "type.googleapis.com"; + } + return typeUrlPrefix + "/google.protobuf.FeatureSet"; + }; + + /** + * FieldPresence enum. + * @name google.protobuf.FeatureSet.FieldPresence + * @enum {number} + * @property {number} FIELD_PRESENCE_UNKNOWN=0 FIELD_PRESENCE_UNKNOWN value + * @property {number} EXPLICIT=1 EXPLICIT value + * @property {number} IMPLICIT=2 IMPLICIT value + * @property {number} LEGACY_REQUIRED=3 LEGACY_REQUIRED value + */ + FeatureSet.FieldPresence = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "FIELD_PRESENCE_UNKNOWN"] = 0; + values[valuesById[1] = "EXPLICIT"] = 1; + values[valuesById[2] = "IMPLICIT"] = 2; + values[valuesById[3] = "LEGACY_REQUIRED"] = 3; + return values; + })(); + + /** + * EnumType enum. + * @name google.protobuf.FeatureSet.EnumType + * @enum {number} + * @property {number} ENUM_TYPE_UNKNOWN=0 ENUM_TYPE_UNKNOWN value + * @property {number} OPEN=1 OPEN value + * @property {number} CLOSED=2 CLOSED value + */ + FeatureSet.EnumType = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "ENUM_TYPE_UNKNOWN"] = 0; + values[valuesById[1] = "OPEN"] = 1; + values[valuesById[2] = "CLOSED"] = 2; + return values; + })(); + + /** + * RepeatedFieldEncoding enum. + * @name google.protobuf.FeatureSet.RepeatedFieldEncoding + * @enum {number} + * @property {number} REPEATED_FIELD_ENCODING_UNKNOWN=0 REPEATED_FIELD_ENCODING_UNKNOWN value + * @property {number} PACKED=1 PACKED value + * @property {number} EXPANDED=2 EXPANDED value + */ + FeatureSet.RepeatedFieldEncoding = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "REPEATED_FIELD_ENCODING_UNKNOWN"] = 0; + values[valuesById[1] = "PACKED"] = 1; + values[valuesById[2] = "EXPANDED"] = 2; + return values; + })(); + + /** + * StringFieldValidation enum. + * @name google.protobuf.FeatureSet.StringFieldValidation + * @enum {number} + * @property {number} STRING_FIELD_VALIDATION_UNKNOWN=0 STRING_FIELD_VALIDATION_UNKNOWN value + * @property {number} MANDATORY=1 MANDATORY value + * @property {number} HINT=2 HINT value + * @property {number} NONE=3 NONE value + */ + FeatureSet.StringFieldValidation = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "STRING_FIELD_VALIDATION_UNKNOWN"] = 0; + values[valuesById[1] = "MANDATORY"] = 1; + values[valuesById[2] = "HINT"] = 2; + values[valuesById[3] = "NONE"] = 3; + return values; + })(); + + /** + * MessageEncoding enum. + * @name google.protobuf.FeatureSet.MessageEncoding + * @enum {number} + * @property {number} MESSAGE_ENCODING_UNKNOWN=0 MESSAGE_ENCODING_UNKNOWN value + * @property {number} LENGTH_PREFIXED=1 LENGTH_PREFIXED value + * @property {number} DELIMITED=2 DELIMITED value + */ + FeatureSet.MessageEncoding = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "MESSAGE_ENCODING_UNKNOWN"] = 0; + values[valuesById[1] = "LENGTH_PREFIXED"] = 1; + values[valuesById[2] = "DELIMITED"] = 2; + return values; + })(); + + /** + * JsonFormat enum. + * @name google.protobuf.FeatureSet.JsonFormat + * @enum {number} + * @property {number} JSON_FORMAT_UNKNOWN=0 JSON_FORMAT_UNKNOWN value + * @property {number} ALLOW=1 ALLOW value + * @property {number} LEGACY_BEST_EFFORT=2 LEGACY_BEST_EFFORT value + */ + FeatureSet.JsonFormat = (function() { + var valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "JSON_FORMAT_UNKNOWN"] = 0; + values[valuesById[1] = "ALLOW"] = 1; + values[valuesById[2] = "LEGACY_BEST_EFFORT"] = 2; + return values; + })(); + + return FeatureSet; + })(); + protobuf.SourceCodeInfo = (function() { /** diff --git a/packages/google-cloud-edgenetwork/protos/protos.json b/packages/google-cloud-edgenetwork/protos/protos.json index 70d6a8d7c9ad..5030ec6454a3 100644 --- a/packages/google-cloud-edgenetwork/protos/protos.json +++ b/packages/google-cloud-edgenetwork/protos/protos.json @@ -2392,6 +2392,10 @@ "rule": "repeated", "type": "ClientLibrarySettings", "id": 109 + }, + "protoReferenceDocumentationUri": { + "type": "string", + "id": 110 } } }, @@ -2449,6 +2453,31 @@ "common": { "type": "CommonLanguageSettings", "id": 1 + }, + "renamedServices": { + "keyType": "string", + "type": "string", + "id": 2 + }, + "renamedResources": { + "keyType": "string", + "type": "string", + "id": 3 + }, + "ignoredResources": { + "rule": "repeated", + "type": "string", + "id": 4 + }, + "forcedNamespaceAliases": { + "rule": "repeated", + "type": "string", + "id": 5 + }, + "handwrittenSignatures": { + "rule": "repeated", + "type": "string", + "id": 6 } } }, @@ -2508,7 +2537,10 @@ "CLOUD": 1, "ADS": 2, "PHOTOS": 3, - "STREET_VIEW": 4 + "STREET_VIEW": 4, + "SHOPPING": 5, + "GEO": 6, + "GENERATIVE_AI": 7 } }, "ClientLibraryDestination": { @@ -2709,6 +2741,25 @@ "rule": "repeated", "type": "UninterpretedOption", "id": 999 + }, + "declaration": { + "rule": "repeated", + "type": "Declaration", + "id": 2, + "options": { + "retention": "RETENTION_SOURCE" + } + }, + "features": { + "type": "FeatureSet", + "id": 50 + }, + "verification": { + "type": "VerificationState", + "id": 3, + "options": { + "default": "UNVERIFIED" + } } }, "extensions": [ @@ -2716,7 +2767,45 @@ 1000, 536870911 ] - ] + ], + "nested": { + "Declaration": { + "fields": { + "number": { + "type": "int32", + "id": 1 + }, + "fullName": { + "type": "string", + "id": 2 + }, + "type": { + "type": "string", + "id": 3 + }, + "reserved": { + "type": "bool", + "id": 5 + }, + "repeated": { + "type": "bool", + "id": 6 + } + }, + "reserved": [ + [ + 4, + 4 + ] + ] + }, + "VerificationState": { + "values": { + "DECLARATION": 0, + "UNVERIFIED": 1 + } + } + } }, "FieldDescriptorProto": { "fields": { @@ -3029,6 +3118,10 @@ "type": "string", "id": 45 }, + "features": { + "type": "FeatureSet", + "id": 50 + }, "uninterpretedOption": { "rule": "repeated", "type": "UninterpretedOption", @@ -3091,6 +3184,10 @@ "deprecated": true } }, + "features": { + "type": "FeatureSet", + "id": 12 + }, "uninterpretedOption": { "rule": "repeated", "type": "UninterpretedOption", @@ -3185,9 +3282,22 @@ "type": "OptionRetention", "id": 17 }, - "target": { + "targets": { + "rule": "repeated", "type": "OptionTargetType", - "id": 18 + "id": 19, + "options": { + "packed": false + } + }, + "editionDefaults": { + "rule": "repeated", + "type": "EditionDefault", + "id": 20 + }, + "features": { + "type": "FeatureSet", + "id": 21 }, "uninterpretedOption": { "rule": "repeated", @@ -3205,6 +3315,10 @@ [ 4, 4 + ], + [ + 18, + 18 ] ], "nested": { @@ -3242,11 +3356,27 @@ "TARGET_TYPE_SERVICE": 8, "TARGET_TYPE_METHOD": 9 } + }, + "EditionDefault": { + "fields": { + "edition": { + "type": "string", + "id": 1 + }, + "value": { + "type": "string", + "id": 2 + } + } } } }, "OneofOptions": { "fields": { + "features": { + "type": "FeatureSet", + "id": 1 + }, "uninterpretedOption": { "rule": "repeated", "type": "UninterpretedOption", @@ -3280,6 +3410,10 @@ "deprecated": true } }, + "features": { + "type": "FeatureSet", + "id": 7 + }, "uninterpretedOption": { "rule": "repeated", "type": "UninterpretedOption", @@ -3308,6 +3442,17 @@ "default": false } }, + "features": { + "type": "FeatureSet", + "id": 2 + }, + "debugRedact": { + "type": "bool", + "id": 3, + "options": { + "default": false + } + }, "uninterpretedOption": { "rule": "repeated", "type": "UninterpretedOption", @@ -3323,6 +3468,10 @@ }, "ServiceOptions": { "fields": { + "features": { + "type": "FeatureSet", + "id": 34 + }, "deprecated": { "type": "bool", "id": 33, @@ -3359,6 +3508,10 @@ "default": "IDEMPOTENCY_UNKNOWN" } }, + "features": { + "type": "FeatureSet", + "id": 35 + }, "uninterpretedOption": { "rule": "repeated", "type": "UninterpretedOption", @@ -3430,6 +3583,137 @@ } } }, + "FeatureSet": { + "fields": { + "fieldPresence": { + "type": "FieldPresence", + "id": 1, + "options": { + "retention": "RETENTION_RUNTIME", + "targets": "TARGET_TYPE_FILE", + "edition_defaults.edition": "2023", + "edition_defaults.value": "EXPLICIT" + } + }, + "enumType": { + "type": "EnumType", + "id": 2, + "options": { + "retention": "RETENTION_RUNTIME", + "targets": "TARGET_TYPE_FILE", + "edition_defaults.edition": "2023", + "edition_defaults.value": "OPEN" + } + }, + "repeatedFieldEncoding": { + "type": "RepeatedFieldEncoding", + "id": 3, + "options": { + "retention": "RETENTION_RUNTIME", + "targets": "TARGET_TYPE_FILE", + "edition_defaults.edition": "2023", + "edition_defaults.value": "PACKED" + } + }, + "stringFieldValidation": { + "type": "StringFieldValidation", + "id": 4, + "options": { + "retention": "RETENTION_RUNTIME", + "targets": "TARGET_TYPE_FILE", + "edition_defaults.edition": "2023", + "edition_defaults.value": "MANDATORY" + } + }, + "messageEncoding": { + "type": "MessageEncoding", + "id": 5, + "options": { + "retention": "RETENTION_RUNTIME", + "targets": "TARGET_TYPE_FILE", + "edition_defaults.edition": "2023", + "edition_defaults.value": "LENGTH_PREFIXED" + } + }, + "jsonFormat": { + "type": "JsonFormat", + "id": 6, + "options": { + "retention": "RETENTION_RUNTIME", + "targets": "TARGET_TYPE_FILE", + "edition_defaults.edition": "2023", + "edition_defaults.value": "ALLOW" + } + }, + "rawFeatures": { + "type": "FeatureSet", + "id": 999, + "options": { + "targets": "TARGET_TYPE_UNKNOWN" + } + } + }, + "extensions": [ + [ + 1000, + 1000 + ], + [ + 1001, + 1001 + ], + [ + 9995, + 9999 + ] + ], + "nested": { + "FieldPresence": { + "values": { + "FIELD_PRESENCE_UNKNOWN": 0, + "EXPLICIT": 1, + "IMPLICIT": 2, + "LEGACY_REQUIRED": 3 + } + }, + "EnumType": { + "values": { + "ENUM_TYPE_UNKNOWN": 0, + "OPEN": 1, + "CLOSED": 2 + } + }, + "RepeatedFieldEncoding": { + "values": { + "REPEATED_FIELD_ENCODING_UNKNOWN": 0, + "PACKED": 1, + "EXPANDED": 2 + } + }, + "StringFieldValidation": { + "values": { + "STRING_FIELD_VALIDATION_UNKNOWN": 0, + "MANDATORY": 1, + "HINT": 2, + "NONE": 3 + } + }, + "MessageEncoding": { + "values": { + "MESSAGE_ENCODING_UNKNOWN": 0, + "LENGTH_PREFIXED": 1, + "DELIMITED": 2 + } + }, + "JsonFormat": { + "values": { + "JSON_FORMAT_UNKNOWN": 0, + "ALLOW": 1, + "LEGACY_BEST_EFFORT": 2 + } + } + } + }, "SourceCodeInfo": { "fields": { "location": { @@ -3567,7 +3851,7 @@ "options": { "cc_enable_arenas": true, "csharp_namespace": "Google.LongRunning", - "go_package": "google.golang.org/genproto/googleapis/longrunning;longrunning", + "go_package": "cloud.google.com/go/longrunning/autogen/longrunningpb;longrunningpb", "java_multiple_files": true, "java_outer_classname": "OperationsProto", "java_package": "com.google.longrunning", diff --git a/packages/google-cloud-edgenetwork/samples/quickstart.js b/packages/google-cloud-edgenetwork/samples/quickstart.js index 0a57d77c8e2d..8316861d6439 100644 --- a/packages/google-cloud-edgenetwork/samples/quickstart.js +++ b/packages/google-cloud-edgenetwork/samples/quickstart.js @@ -27,26 +27,9 @@ function main(parent) { * TODO(developer): Uncomment these variables before running the sample. */ /** - * Required. Parent value for ListRoutersRequest + * Required. Parent value for ListZonesRequest */ - // const parent = 'abc123' - /** - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - */ - // const pageSize = 1234 - /** - * A token identifying a page of results the server should return. - */ - // const pageToken = 'abc123' - /** - * Filtering results - */ - // const filter = 'abc123' - /** - * Hint for how to order the results - */ - // const orderBy = 'abc123' + // const parent = 'projects/your-project/locations/your-location' // Imports the Edgenetwork library const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; @@ -54,20 +37,20 @@ function main(parent) { // Instantiates a client const edgenetworkClient = new EdgeNetworkClient(); - async function callListRouters() { + async function callListZones() { // Construct request const request = { parent, }; // Run request - const iterable = await edgenetworkClient.listRoutersAsync(request); + const iterable = await edgenetworkClient.listZonesAsync(request); for await (const response of iterable) { console.log(response); } } - callListRouters(); + callListZones(); // [END edgenetwork_quickstart] } diff --git a/packages/google-cloud-edgenetwork/samples/test/quickstart.js b/packages/google-cloud-edgenetwork/samples/test/quickstart.js index 6df3e5cc5e04..e3403ec24a00 100644 --- a/packages/google-cloud-edgenetwork/samples/test/quickstart.js +++ b/packages/google-cloud-edgenetwork/samples/test/quickstart.js @@ -1,4 +1,4 @@ -// Copyright 2022 Google LLC +// Copyright 2023 Google LLC // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -18,8 +18,8 @@ const assert = require('assert'); const path = require('path'); const cp = require('child_process'); const {describe, it, before} = require('mocha'); -const {Client} = require('@google-cloud/edgenetwork').v1; -const edgenetworkClient = new Client(); +const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; +const edgenetworkClient = new EdgeNetworkClient(); const execSync = cmd => cp.execSync(cmd, {encoding: 'utf-8'}); From b4907056f7d066084bdeff43de14011758ae2987 Mon Sep 17 00:00:00 2001 From: Owl Bot Date: Thu, 9 Nov 2023 23:38:19 +0000 Subject: [PATCH 7/7] =?UTF-8?q?=F0=9F=A6=89=20Updates=20from=20OwlBot=20po?= =?UTF-8?q?st-processor?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit See https://github.com/googleapis/repo-automation-bots/blob/main/packages/owl-bot/README.md --- packages/google-cloud-edgenetwork/README.md | 27 +- .../protos/protos.d.ts | 540 +---- .../google-cloud-edgenetwork/protos/protos.js | 2135 ++--------------- .../protos/protos.json | 294 +-- 4 files changed, 158 insertions(+), 2838 deletions(-) diff --git a/packages/google-cloud-edgenetwork/README.md b/packages/google-cloud-edgenetwork/README.md index d93e8cd5eb46..587165981148 100644 --- a/packages/google-cloud-edgenetwork/README.md +++ b/packages/google-cloud-edgenetwork/README.md @@ -64,26 +64,9 @@ npm install @google-cloud/edgenetwork * TODO(developer): Uncomment these variables before running the sample. */ /** - * Required. Parent value for ListRoutersRequest + * Required. Parent value for ListZonesRequest */ -// const parent = 'abc123' -/** - * Requested page size. Server may return fewer items than requested. - * If unspecified, server will pick an appropriate default. - */ -// const pageSize = 1234 -/** - * A token identifying a page of results the server should return. - */ -// const pageToken = 'abc123' -/** - * Filtering results - */ -// const filter = 'abc123' -/** - * Hint for how to order the results - */ -// const orderBy = 'abc123' +// const parent = 'projects/your-project/locations/your-location' // Imports the Edgenetwork library const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; @@ -91,20 +74,20 @@ const {EdgeNetworkClient} = require('@google-cloud/edgenetwork').v1; // Instantiates a client const edgenetworkClient = new EdgeNetworkClient(); -async function callListRouters() { +async function callListZones() { // Construct request const request = { parent, }; // Run request - const iterable = await edgenetworkClient.listRoutersAsync(request); + const iterable = await edgenetworkClient.listZonesAsync(request); for await (const response of iterable) { console.log(response); } } -callListRouters(); +callListZones(); ``` diff --git a/packages/google-cloud-edgenetwork/protos/protos.d.ts b/packages/google-cloud-edgenetwork/protos/protos.d.ts index 0687a6accfc7..1d1e21f82264 100644 --- a/packages/google-cloud-edgenetwork/protos/protos.d.ts +++ b/packages/google-cloud-edgenetwork/protos/protos.d.ts @@ -8043,9 +8043,6 @@ export namespace google { /** Publishing librarySettings */ librarySettings?: (google.api.IClientLibrarySettings[]|null); - - /** Publishing protoReferenceDocumentationUri */ - protoReferenceDocumentationUri?: (string|null); } /** Represents a Publishing. */ @@ -8084,9 +8081,6 @@ export namespace google { /** Publishing librarySettings. */ public librarySettings: google.api.IClientLibrarySettings[]; - /** Publishing protoReferenceDocumentationUri. */ - public protoReferenceDocumentationUri: string; - /** * Creates a new Publishing instance using the specified properties. * @param [properties] Properties to set @@ -8667,21 +8661,6 @@ export namespace google { /** DotnetSettings common */ common?: (google.api.ICommonLanguageSettings|null); - - /** DotnetSettings renamedServices */ - renamedServices?: ({ [k: string]: string }|null); - - /** DotnetSettings renamedResources */ - renamedResources?: ({ [k: string]: string }|null); - - /** DotnetSettings ignoredResources */ - ignoredResources?: (string[]|null); - - /** DotnetSettings forcedNamespaceAliases */ - forcedNamespaceAliases?: (string[]|null); - - /** DotnetSettings handwrittenSignatures */ - handwrittenSignatures?: (string[]|null); } /** Represents a DotnetSettings. */ @@ -8696,21 +8675,6 @@ export namespace google { /** DotnetSettings common. */ public common?: (google.api.ICommonLanguageSettings|null); - /** DotnetSettings renamedServices. */ - public renamedServices: { [k: string]: string }; - - /** DotnetSettings renamedResources. */ - public renamedResources: { [k: string]: string }; - - /** DotnetSettings ignoredResources. */ - public ignoredResources: string[]; - - /** DotnetSettings forcedNamespaceAliases. */ - public forcedNamespaceAliases: string[]; - - /** DotnetSettings handwrittenSignatures. */ - public handwrittenSignatures: string[]; - /** * Creates a new DotnetSettings instance using the specified properties. * @param [properties] Properties to set @@ -9210,10 +9174,7 @@ export namespace google { CLOUD = 1, ADS = 2, PHOTOS = 3, - STREET_VIEW = 4, - SHOPPING = 5, - GEO = 6, - GENERATIVE_AI = 7 + STREET_VIEW = 4 } /** ClientLibraryDestination enum. */ @@ -9876,15 +9837,6 @@ export namespace google { /** ExtensionRangeOptions uninterpretedOption */ uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); - - /** ExtensionRangeOptions declaration */ - declaration?: (google.protobuf.ExtensionRangeOptions.IDeclaration[]|null); - - /** ExtensionRangeOptions features */ - features?: (google.protobuf.IFeatureSet|null); - - /** ExtensionRangeOptions verification */ - verification?: (google.protobuf.ExtensionRangeOptions.VerificationState|keyof typeof google.protobuf.ExtensionRangeOptions.VerificationState|null); } /** Represents an ExtensionRangeOptions. */ @@ -9899,15 +9851,6 @@ export namespace google { /** ExtensionRangeOptions uninterpretedOption. */ public uninterpretedOption: google.protobuf.IUninterpretedOption[]; - /** ExtensionRangeOptions declaration. */ - public declaration: google.protobuf.ExtensionRangeOptions.IDeclaration[]; - - /** ExtensionRangeOptions features. */ - public features?: (google.protobuf.IFeatureSet|null); - - /** ExtensionRangeOptions verification. */ - public verification: (google.protobuf.ExtensionRangeOptions.VerificationState|keyof typeof google.protobuf.ExtensionRangeOptions.VerificationState); - /** * Creates a new ExtensionRangeOptions instance using the specified properties. * @param [properties] Properties to set @@ -9986,136 +9929,6 @@ export namespace google { public static getTypeUrl(typeUrlPrefix?: string): string; } - namespace ExtensionRangeOptions { - - /** Properties of a Declaration. */ - interface IDeclaration { - - /** Declaration number */ - number?: (number|null); - - /** Declaration fullName */ - fullName?: (string|null); - - /** Declaration type */ - type?: (string|null); - - /** Declaration reserved */ - reserved?: (boolean|null); - - /** Declaration repeated */ - repeated?: (boolean|null); - } - - /** Represents a Declaration. */ - class Declaration implements IDeclaration { - - /** - * Constructs a new Declaration. - * @param [properties] Properties to set - */ - constructor(properties?: google.protobuf.ExtensionRangeOptions.IDeclaration); - - /** Declaration number. */ - public number: number; - - /** Declaration fullName. */ - public fullName: string; - - /** Declaration type. */ - public type: string; - - /** Declaration reserved. */ - public reserved: boolean; - - /** Declaration repeated. */ - public repeated: boolean; - - /** - * Creates a new Declaration instance using the specified properties. - * @param [properties] Properties to set - * @returns Declaration instance - */ - public static create(properties?: google.protobuf.ExtensionRangeOptions.IDeclaration): google.protobuf.ExtensionRangeOptions.Declaration; - - /** - * Encodes the specified Declaration message. Does not implicitly {@link google.protobuf.ExtensionRangeOptions.Declaration.verify|verify} messages. - * @param message Declaration message or plain object to encode - * @param [writer] Writer to encode to - * @returns Writer - */ - public static encode(message: google.protobuf.ExtensionRangeOptions.IDeclaration, writer?: $protobuf.Writer): $protobuf.Writer; - - /** - * Encodes the specified Declaration message, length delimited. Does not implicitly {@link google.protobuf.ExtensionRangeOptions.Declaration.verify|verify} messages. - * @param message Declaration message or plain object to encode - * @param [writer] Writer to encode to - * @returns Writer - */ - public static encodeDelimited(message: google.protobuf.ExtensionRangeOptions.IDeclaration, writer?: $protobuf.Writer): $protobuf.Writer; - - /** - * Decodes a Declaration message from the specified reader or buffer. - * @param reader Reader or buffer to decode from - * @param [length] Message length if known beforehand - * @returns Declaration - * @throws {Error} If the payload is not a reader or valid buffer - * @throws {$protobuf.util.ProtocolError} If required fields are missing - */ - public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.ExtensionRangeOptions.Declaration; - - /** - * Decodes a Declaration message from the specified reader or buffer, length delimited. - * @param reader Reader or buffer to decode from - * @returns Declaration - * @throws {Error} If the payload is not a reader or valid buffer - * @throws {$protobuf.util.ProtocolError} If required fields are missing - */ - public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.ExtensionRangeOptions.Declaration; - - /** - * Verifies a Declaration message. - * @param message Plain object to verify - * @returns `null` if valid, otherwise the reason why it is not - */ - public static verify(message: { [k: string]: any }): (string|null); - - /** - * Creates a Declaration message from a plain object. Also converts values to their respective internal types. - * @param object Plain object - * @returns Declaration - */ - public static fromObject(object: { [k: string]: any }): google.protobuf.ExtensionRangeOptions.Declaration; - - /** - * Creates a plain object from a Declaration message. Also converts values to other types if specified. - * @param message Declaration - * @param [options] Conversion options - * @returns Plain object - */ - public static toObject(message: google.protobuf.ExtensionRangeOptions.Declaration, options?: $protobuf.IConversionOptions): { [k: string]: any }; - - /** - * Converts this Declaration to JSON. - * @returns JSON object - */ - public toJSON(): { [k: string]: any }; - - /** - * Gets the default type url for Declaration - * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") - * @returns The default type url - */ - public static getTypeUrl(typeUrlPrefix?: string): string; - } - - /** VerificationState enum. */ - enum VerificationState { - DECLARATION = 0, - UNVERIFIED = 1 - } - } - /** Properties of a FieldDescriptorProto. */ interface IFieldDescriptorProto { @@ -11043,9 +10856,6 @@ export namespace google { /** FileOptions rubyPackage */ rubyPackage?: (string|null); - /** FileOptions features */ - features?: (google.protobuf.IFeatureSet|null); - /** FileOptions uninterpretedOption */ uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); @@ -11122,9 +10932,6 @@ export namespace google { /** FileOptions rubyPackage. */ public rubyPackage: string; - /** FileOptions features. */ - public features?: (google.protobuf.IFeatureSet|null); - /** FileOptions uninterpretedOption. */ public uninterpretedOption: google.protobuf.IUninterpretedOption[]; @@ -11234,9 +11041,6 @@ export namespace google { /** MessageOptions deprecatedLegacyJsonFieldConflicts */ deprecatedLegacyJsonFieldConflicts?: (boolean|null); - /** MessageOptions features */ - features?: (google.protobuf.IFeatureSet|null); - /** MessageOptions uninterpretedOption */ uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); @@ -11268,9 +11072,6 @@ export namespace google { /** MessageOptions deprecatedLegacyJsonFieldConflicts. */ public deprecatedLegacyJsonFieldConflicts: boolean; - /** MessageOptions features. */ - public features?: (google.protobuf.IFeatureSet|null); - /** MessageOptions uninterpretedOption. */ public uninterpretedOption: google.protobuf.IUninterpretedOption[]; @@ -11382,14 +11183,8 @@ export namespace google { /** FieldOptions retention */ retention?: (google.protobuf.FieldOptions.OptionRetention|keyof typeof google.protobuf.FieldOptions.OptionRetention|null); - /** FieldOptions targets */ - targets?: (google.protobuf.FieldOptions.OptionTargetType[]|null); - - /** FieldOptions editionDefaults */ - editionDefaults?: (google.protobuf.FieldOptions.IEditionDefault[]|null); - - /** FieldOptions features */ - features?: (google.protobuf.IFeatureSet|null); + /** FieldOptions target */ + target?: (google.protobuf.FieldOptions.OptionTargetType|keyof typeof google.protobuf.FieldOptions.OptionTargetType|null); /** FieldOptions uninterpretedOption */ uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); @@ -11437,14 +11232,8 @@ export namespace google { /** FieldOptions retention. */ public retention: (google.protobuf.FieldOptions.OptionRetention|keyof typeof google.protobuf.FieldOptions.OptionRetention); - /** FieldOptions targets. */ - public targets: google.protobuf.FieldOptions.OptionTargetType[]; - - /** FieldOptions editionDefaults. */ - public editionDefaults: google.protobuf.FieldOptions.IEditionDefault[]; - - /** FieldOptions features. */ - public features?: (google.protobuf.IFeatureSet|null); + /** FieldOptions target. */ + public target: (google.protobuf.FieldOptions.OptionTargetType|keyof typeof google.protobuf.FieldOptions.OptionTargetType); /** FieldOptions uninterpretedOption. */ public uninterpretedOption: google.protobuf.IUninterpretedOption[]; @@ -11563,117 +11352,11 @@ export namespace google { TARGET_TYPE_SERVICE = 8, TARGET_TYPE_METHOD = 9 } - - /** Properties of an EditionDefault. */ - interface IEditionDefault { - - /** EditionDefault edition */ - edition?: (string|null); - - /** EditionDefault value */ - value?: (string|null); - } - - /** Represents an EditionDefault. */ - class EditionDefault implements IEditionDefault { - - /** - * Constructs a new EditionDefault. - * @param [properties] Properties to set - */ - constructor(properties?: google.protobuf.FieldOptions.IEditionDefault); - - /** EditionDefault edition. */ - public edition: string; - - /** EditionDefault value. */ - public value: string; - - /** - * Creates a new EditionDefault instance using the specified properties. - * @param [properties] Properties to set - * @returns EditionDefault instance - */ - public static create(properties?: google.protobuf.FieldOptions.IEditionDefault): google.protobuf.FieldOptions.EditionDefault; - - /** - * Encodes the specified EditionDefault message. Does not implicitly {@link google.protobuf.FieldOptions.EditionDefault.verify|verify} messages. - * @param message EditionDefault message or plain object to encode - * @param [writer] Writer to encode to - * @returns Writer - */ - public static encode(message: google.protobuf.FieldOptions.IEditionDefault, writer?: $protobuf.Writer): $protobuf.Writer; - - /** - * Encodes the specified EditionDefault message, length delimited. Does not implicitly {@link google.protobuf.FieldOptions.EditionDefault.verify|verify} messages. - * @param message EditionDefault message or plain object to encode - * @param [writer] Writer to encode to - * @returns Writer - */ - public static encodeDelimited(message: google.protobuf.FieldOptions.IEditionDefault, writer?: $protobuf.Writer): $protobuf.Writer; - - /** - * Decodes an EditionDefault message from the specified reader or buffer. - * @param reader Reader or buffer to decode from - * @param [length] Message length if known beforehand - * @returns EditionDefault - * @throws {Error} If the payload is not a reader or valid buffer - * @throws {$protobuf.util.ProtocolError} If required fields are missing - */ - public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.FieldOptions.EditionDefault; - - /** - * Decodes an EditionDefault message from the specified reader or buffer, length delimited. - * @param reader Reader or buffer to decode from - * @returns EditionDefault - * @throws {Error} If the payload is not a reader or valid buffer - * @throws {$protobuf.util.ProtocolError} If required fields are missing - */ - public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.FieldOptions.EditionDefault; - - /** - * Verifies an EditionDefault message. - * @param message Plain object to verify - * @returns `null` if valid, otherwise the reason why it is not - */ - public static verify(message: { [k: string]: any }): (string|null); - - /** - * Creates an EditionDefault message from a plain object. Also converts values to their respective internal types. - * @param object Plain object - * @returns EditionDefault - */ - public static fromObject(object: { [k: string]: any }): google.protobuf.FieldOptions.EditionDefault; - - /** - * Creates a plain object from an EditionDefault message. Also converts values to other types if specified. - * @param message EditionDefault - * @param [options] Conversion options - * @returns Plain object - */ - public static toObject(message: google.protobuf.FieldOptions.EditionDefault, options?: $protobuf.IConversionOptions): { [k: string]: any }; - - /** - * Converts this EditionDefault to JSON. - * @returns JSON object - */ - public toJSON(): { [k: string]: any }; - - /** - * Gets the default type url for EditionDefault - * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") - * @returns The default type url - */ - public static getTypeUrl(typeUrlPrefix?: string): string; - } } /** Properties of an OneofOptions. */ interface IOneofOptions { - /** OneofOptions features */ - features?: (google.protobuf.IFeatureSet|null); - /** OneofOptions uninterpretedOption */ uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); } @@ -11687,9 +11370,6 @@ export namespace google { */ constructor(properties?: google.protobuf.IOneofOptions); - /** OneofOptions features. */ - public features?: (google.protobuf.IFeatureSet|null); - /** OneofOptions uninterpretedOption. */ public uninterpretedOption: google.protobuf.IUninterpretedOption[]; @@ -11783,9 +11463,6 @@ export namespace google { /** EnumOptions deprecatedLegacyJsonFieldConflicts */ deprecatedLegacyJsonFieldConflicts?: (boolean|null); - /** EnumOptions features */ - features?: (google.protobuf.IFeatureSet|null); - /** EnumOptions uninterpretedOption */ uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); } @@ -11808,9 +11485,6 @@ export namespace google { /** EnumOptions deprecatedLegacyJsonFieldConflicts. */ public deprecatedLegacyJsonFieldConflicts: boolean; - /** EnumOptions features. */ - public features?: (google.protobuf.IFeatureSet|null); - /** EnumOptions uninterpretedOption. */ public uninterpretedOption: google.protobuf.IUninterpretedOption[]; @@ -11898,12 +11572,6 @@ export namespace google { /** EnumValueOptions deprecated */ deprecated?: (boolean|null); - /** EnumValueOptions features */ - features?: (google.protobuf.IFeatureSet|null); - - /** EnumValueOptions debugRedact */ - debugRedact?: (boolean|null); - /** EnumValueOptions uninterpretedOption */ uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); } @@ -11920,12 +11588,6 @@ export namespace google { /** EnumValueOptions deprecated. */ public deprecated: boolean; - /** EnumValueOptions features. */ - public features?: (google.protobuf.IFeatureSet|null); - - /** EnumValueOptions debugRedact. */ - public debugRedact: boolean; - /** EnumValueOptions uninterpretedOption. */ public uninterpretedOption: google.protobuf.IUninterpretedOption[]; @@ -12010,9 +11672,6 @@ export namespace google { /** Properties of a ServiceOptions. */ interface IServiceOptions { - /** ServiceOptions features */ - features?: (google.protobuf.IFeatureSet|null); - /** ServiceOptions deprecated */ deprecated?: (boolean|null); @@ -12035,9 +11694,6 @@ export namespace google { */ constructor(properties?: google.protobuf.IServiceOptions); - /** ServiceOptions features. */ - public features?: (google.protobuf.IFeatureSet|null); - /** ServiceOptions deprecated. */ public deprecated: boolean; @@ -12131,9 +11787,6 @@ export namespace google { /** MethodOptions idempotencyLevel */ idempotencyLevel?: (google.protobuf.MethodOptions.IdempotencyLevel|keyof typeof google.protobuf.MethodOptions.IdempotencyLevel|null); - /** MethodOptions features */ - features?: (google.protobuf.IFeatureSet|null); - /** MethodOptions uninterpretedOption */ uninterpretedOption?: (google.protobuf.IUninterpretedOption[]|null); @@ -12162,9 +11815,6 @@ export namespace google { /** MethodOptions idempotencyLevel. */ public idempotencyLevel: (google.protobuf.MethodOptions.IdempotencyLevel|keyof typeof google.protobuf.MethodOptions.IdempotencyLevel); - /** MethodOptions features. */ - public features?: (google.protobuf.IFeatureSet|null); - /** MethodOptions uninterpretedOption. */ public uninterpretedOption: google.protobuf.IUninterpretedOption[]; @@ -12495,186 +12145,6 @@ export namespace google { } } - /** Properties of a FeatureSet. */ - interface IFeatureSet { - - /** FeatureSet fieldPresence */ - fieldPresence?: (google.protobuf.FeatureSet.FieldPresence|keyof typeof google.protobuf.FeatureSet.FieldPresence|null); - - /** FeatureSet enumType */ - enumType?: (google.protobuf.FeatureSet.EnumType|keyof typeof google.protobuf.FeatureSet.EnumType|null); - - /** FeatureSet repeatedFieldEncoding */ - repeatedFieldEncoding?: (google.protobuf.FeatureSet.RepeatedFieldEncoding|keyof typeof google.protobuf.FeatureSet.RepeatedFieldEncoding|null); - - /** FeatureSet stringFieldValidation */ - stringFieldValidation?: (google.protobuf.FeatureSet.StringFieldValidation|keyof typeof google.protobuf.FeatureSet.StringFieldValidation|null); - - /** FeatureSet messageEncoding */ - messageEncoding?: (google.protobuf.FeatureSet.MessageEncoding|keyof typeof google.protobuf.FeatureSet.MessageEncoding|null); - - /** FeatureSet jsonFormat */ - jsonFormat?: (google.protobuf.FeatureSet.JsonFormat|keyof typeof google.protobuf.FeatureSet.JsonFormat|null); - - /** FeatureSet rawFeatures */ - rawFeatures?: (google.protobuf.IFeatureSet|null); - } - - /** Represents a FeatureSet. */ - class FeatureSet implements IFeatureSet { - - /** - * Constructs a new FeatureSet. - * @param [properties] Properties to set - */ - constructor(properties?: google.protobuf.IFeatureSet); - - /** FeatureSet fieldPresence. */ - public fieldPresence: (google.protobuf.FeatureSet.FieldPresence|keyof typeof google.protobuf.FeatureSet.FieldPresence); - - /** FeatureSet enumType. */ - public enumType: (google.protobuf.FeatureSet.EnumType|keyof typeof google.protobuf.FeatureSet.EnumType); - - /** FeatureSet repeatedFieldEncoding. */ - public repeatedFieldEncoding: (google.protobuf.FeatureSet.RepeatedFieldEncoding|keyof typeof google.protobuf.FeatureSet.RepeatedFieldEncoding); - - /** FeatureSet stringFieldValidation. */ - public stringFieldValidation: (google.protobuf.FeatureSet.StringFieldValidation|keyof typeof google.protobuf.FeatureSet.StringFieldValidation); - - /** FeatureSet messageEncoding. */ - public messageEncoding: (google.protobuf.FeatureSet.MessageEncoding|keyof typeof google.protobuf.FeatureSet.MessageEncoding); - - /** FeatureSet jsonFormat. */ - public jsonFormat: (google.protobuf.FeatureSet.JsonFormat|keyof typeof google.protobuf.FeatureSet.JsonFormat); - - /** FeatureSet rawFeatures. */ - public rawFeatures?: (google.protobuf.IFeatureSet|null); - - /** - * Creates a new FeatureSet instance using the specified properties. - * @param [properties] Properties to set - * @returns FeatureSet instance - */ - public static create(properties?: google.protobuf.IFeatureSet): google.protobuf.FeatureSet; - - /** - * Encodes the specified FeatureSet message. Does not implicitly {@link google.protobuf.FeatureSet.verify|verify} messages. - * @param message FeatureSet message or plain object to encode - * @param [writer] Writer to encode to - * @returns Writer - */ - public static encode(message: google.protobuf.IFeatureSet, writer?: $protobuf.Writer): $protobuf.Writer; - - /** - * Encodes the specified FeatureSet message, length delimited. Does not implicitly {@link google.protobuf.FeatureSet.verify|verify} messages. - * @param message FeatureSet message or plain object to encode - * @param [writer] Writer to encode to - * @returns Writer - */ - public static encodeDelimited(message: google.protobuf.IFeatureSet, writer?: $protobuf.Writer): $protobuf.Writer; - - /** - * Decodes a FeatureSet message from the specified reader or buffer. - * @param reader Reader or buffer to decode from - * @param [length] Message length if known beforehand - * @returns FeatureSet - * @throws {Error} If the payload is not a reader or valid buffer - * @throws {$protobuf.util.ProtocolError} If required fields are missing - */ - public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): google.protobuf.FeatureSet; - - /** - * Decodes a FeatureSet message from the specified reader or buffer, length delimited. - * @param reader Reader or buffer to decode from - * @returns FeatureSet - * @throws {Error} If the payload is not a reader or valid buffer - * @throws {$protobuf.util.ProtocolError} If required fields are missing - */ - public static decodeDelimited(reader: ($protobuf.Reader|Uint8Array)): google.protobuf.FeatureSet; - - /** - * Verifies a FeatureSet message. - * @param message Plain object to verify - * @returns `null` if valid, otherwise the reason why it is not - */ - public static verify(message: { [k: string]: any }): (string|null); - - /** - * Creates a FeatureSet message from a plain object. Also converts values to their respective internal types. - * @param object Plain object - * @returns FeatureSet - */ - public static fromObject(object: { [k: string]: any }): google.protobuf.FeatureSet; - - /** - * Creates a plain object from a FeatureSet message. Also converts values to other types if specified. - * @param message FeatureSet - * @param [options] Conversion options - * @returns Plain object - */ - public static toObject(message: google.protobuf.FeatureSet, options?: $protobuf.IConversionOptions): { [k: string]: any }; - - /** - * Converts this FeatureSet to JSON. - * @returns JSON object - */ - public toJSON(): { [k: string]: any }; - - /** - * Gets the default type url for FeatureSet - * @param [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") - * @returns The default type url - */ - public static getTypeUrl(typeUrlPrefix?: string): string; - } - - namespace FeatureSet { - - /** FieldPresence enum. */ - enum FieldPresence { - FIELD_PRESENCE_UNKNOWN = 0, - EXPLICIT = 1, - IMPLICIT = 2, - LEGACY_REQUIRED = 3 - } - - /** EnumType enum. */ - enum EnumType { - ENUM_TYPE_UNKNOWN = 0, - OPEN = 1, - CLOSED = 2 - } - - /** RepeatedFieldEncoding enum. */ - enum RepeatedFieldEncoding { - REPEATED_FIELD_ENCODING_UNKNOWN = 0, - PACKED = 1, - EXPANDED = 2 - } - - /** StringFieldValidation enum. */ - enum StringFieldValidation { - STRING_FIELD_VALIDATION_UNKNOWN = 0, - MANDATORY = 1, - HINT = 2, - NONE = 3 - } - - /** MessageEncoding enum. */ - enum MessageEncoding { - MESSAGE_ENCODING_UNKNOWN = 0, - LENGTH_PREFIXED = 1, - DELIMITED = 2 - } - - /** JsonFormat enum. */ - enum JsonFormat { - JSON_FORMAT_UNKNOWN = 0, - ALLOW = 1, - LEGACY_BEST_EFFORT = 2 - } - } - /** Properties of a SourceCodeInfo. */ interface ISourceCodeInfo { diff --git a/packages/google-cloud-edgenetwork/protos/protos.js b/packages/google-cloud-edgenetwork/protos/protos.js index b405c3a211c4..9fb7a9007736 100644 --- a/packages/google-cloud-edgenetwork/protos/protos.js +++ b/packages/google-cloud-edgenetwork/protos/protos.js @@ -20003,7 +20003,6 @@ * @property {string|null} [docTagPrefix] Publishing docTagPrefix * @property {google.api.ClientLibraryOrganization|null} [organization] Publishing organization * @property {Array.|null} [librarySettings] Publishing librarySettings - * @property {string|null} [protoReferenceDocumentationUri] Publishing protoReferenceDocumentationUri */ /** @@ -20096,14 +20095,6 @@ */ Publishing.prototype.librarySettings = $util.emptyArray; - /** - * Publishing protoReferenceDocumentationUri. - * @member {string} protoReferenceDocumentationUri - * @memberof google.api.Publishing - * @instance - */ - Publishing.prototype.protoReferenceDocumentationUri = ""; - /** * Creates a new Publishing instance using the specified properties. * @function create @@ -20149,8 +20140,6 @@ if (message.librarySettings != null && message.librarySettings.length) for (var i = 0; i < message.librarySettings.length; ++i) $root.google.api.ClientLibrarySettings.encode(message.librarySettings[i], writer.uint32(/* id 109, wireType 2 =*/874).fork()).ldelim(); - if (message.protoReferenceDocumentationUri != null && Object.hasOwnProperty.call(message, "protoReferenceDocumentationUri")) - writer.uint32(/* id 110, wireType 2 =*/882).string(message.protoReferenceDocumentationUri); return writer; }; @@ -20227,10 +20216,6 @@ message.librarySettings.push($root.google.api.ClientLibrarySettings.decode(reader, reader.uint32())); break; } - case 110: { - message.protoReferenceDocumentationUri = reader.string(); - break; - } default: reader.skipType(tag & 7); break; @@ -20306,9 +20291,6 @@ case 2: case 3: case 4: - case 5: - case 6: - case 7: break; } if (message.librarySettings != null && message.hasOwnProperty("librarySettings")) { @@ -20320,9 +20302,6 @@ return "librarySettings." + error; } } - if (message.protoReferenceDocumentationUri != null && message.hasOwnProperty("protoReferenceDocumentationUri")) - if (!$util.isString(message.protoReferenceDocumentationUri)) - return "protoReferenceDocumentationUri: string expected"; return null; }; @@ -20392,18 +20371,6 @@ case 4: message.organization = 4; break; - case "SHOPPING": - case 5: - message.organization = 5; - break; - case "GEO": - case 6: - message.organization = 6; - break; - case "GENERATIVE_AI": - case 7: - message.organization = 7; - break; } if (object.librarySettings) { if (!Array.isArray(object.librarySettings)) @@ -20415,8 +20382,6 @@ message.librarySettings[i] = $root.google.api.ClientLibrarySettings.fromObject(object.librarySettings[i]); } } - if (object.protoReferenceDocumentationUri != null) - message.protoReferenceDocumentationUri = String(object.protoReferenceDocumentationUri); return message; }; @@ -20445,7 +20410,6 @@ object.githubLabel = ""; object.docTagPrefix = ""; object.organization = options.enums === String ? "CLIENT_LIBRARY_ORGANIZATION_UNSPECIFIED" : 0; - object.protoReferenceDocumentationUri = ""; } if (message.methodSettings && message.methodSettings.length) { object.methodSettings = []; @@ -20474,8 +20438,6 @@ for (var j = 0; j < message.librarySettings.length; ++j) object.librarySettings[j] = $root.google.api.ClientLibrarySettings.toObject(message.librarySettings[j], options); } - if (message.protoReferenceDocumentationUri != null && message.hasOwnProperty("protoReferenceDocumentationUri")) - object.protoReferenceDocumentationUri = message.protoReferenceDocumentationUri; return object; }; @@ -21638,11 +21600,6 @@ * @memberof google.api * @interface IDotnetSettings * @property {google.api.ICommonLanguageSettings|null} [common] DotnetSettings common - * @property {Object.|null} [renamedServices] DotnetSettings renamedServices - * @property {Object.|null} [renamedResources] DotnetSettings renamedResources - * @property {Array.|null} [ignoredResources] DotnetSettings ignoredResources - * @property {Array.|null} [forcedNamespaceAliases] DotnetSettings forcedNamespaceAliases - * @property {Array.|null} [handwrittenSignatures] DotnetSettings handwrittenSignatures */ /** @@ -21654,11 +21611,6 @@ * @param {google.api.IDotnetSettings=} [properties] Properties to set */ function DotnetSettings(properties) { - this.renamedServices = {}; - this.renamedResources = {}; - this.ignoredResources = []; - this.forcedNamespaceAliases = []; - this.handwrittenSignatures = []; if (properties) for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -21673,46 +21625,6 @@ */ DotnetSettings.prototype.common = null; - /** - * DotnetSettings renamedServices. - * @member {Object.} renamedServices - * @memberof google.api.DotnetSettings - * @instance - */ - DotnetSettings.prototype.renamedServices = $util.emptyObject; - - /** - * DotnetSettings renamedResources. - * @member {Object.} renamedResources - * @memberof google.api.DotnetSettings - * @instance - */ - DotnetSettings.prototype.renamedResources = $util.emptyObject; - - /** - * DotnetSettings ignoredResources. - * @member {Array.} ignoredResources - * @memberof google.api.DotnetSettings - * @instance - */ - DotnetSettings.prototype.ignoredResources = $util.emptyArray; - - /** - * DotnetSettings forcedNamespaceAliases. - * @member {Array.} forcedNamespaceAliases - * @memberof google.api.DotnetSettings - * @instance - */ - DotnetSettings.prototype.forcedNamespaceAliases = $util.emptyArray; - - /** - * DotnetSettings handwrittenSignatures. - * @member {Array.} handwrittenSignatures - * @memberof google.api.DotnetSettings - * @instance - */ - DotnetSettings.prototype.handwrittenSignatures = $util.emptyArray; - /** * Creates a new DotnetSettings instance using the specified properties. * @function create @@ -21739,21 +21651,6 @@ writer = $Writer.create(); if (message.common != null && Object.hasOwnProperty.call(message, "common")) $root.google.api.CommonLanguageSettings.encode(message.common, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); - if (message.renamedServices != null && Object.hasOwnProperty.call(message, "renamedServices")) - for (var keys = Object.keys(message.renamedServices), i = 0; i < keys.length; ++i) - writer.uint32(/* id 2, wireType 2 =*/18).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]).uint32(/* id 2, wireType 2 =*/18).string(message.renamedServices[keys[i]]).ldelim(); - if (message.renamedResources != null && Object.hasOwnProperty.call(message, "renamedResources")) - for (var keys = Object.keys(message.renamedResources), i = 0; i < keys.length; ++i) - writer.uint32(/* id 3, wireType 2 =*/26).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]).uint32(/* id 2, wireType 2 =*/18).string(message.renamedResources[keys[i]]).ldelim(); - if (message.ignoredResources != null && message.ignoredResources.length) - for (var i = 0; i < message.ignoredResources.length; ++i) - writer.uint32(/* id 4, wireType 2 =*/34).string(message.ignoredResources[i]); - if (message.forcedNamespaceAliases != null && message.forcedNamespaceAliases.length) - for (var i = 0; i < message.forcedNamespaceAliases.length; ++i) - writer.uint32(/* id 5, wireType 2 =*/42).string(message.forcedNamespaceAliases[i]); - if (message.handwrittenSignatures != null && message.handwrittenSignatures.length) - for (var i = 0; i < message.handwrittenSignatures.length; ++i) - writer.uint32(/* id 6, wireType 2 =*/50).string(message.handwrittenSignatures[i]); return writer; }; @@ -21784,7 +21681,7 @@ DotnetSettings.decode = function decode(reader, length) { if (!(reader instanceof $Reader)) reader = $Reader.create(reader); - var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.DotnetSettings(), key, value; + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.api.DotnetSettings(); while (reader.pos < end) { var tag = reader.uint32(); switch (tag >>> 3) { @@ -21792,70 +21689,6 @@ message.common = $root.google.api.CommonLanguageSettings.decode(reader, reader.uint32()); break; } - case 2: { - if (message.renamedServices === $util.emptyObject) - message.renamedServices = {}; - var end2 = reader.uint32() + reader.pos; - key = ""; - value = ""; - while (reader.pos < end2) { - var tag2 = reader.uint32(); - switch (tag2 >>> 3) { - case 1: - key = reader.string(); - break; - case 2: - value = reader.string(); - break; - default: - reader.skipType(tag2 & 7); - break; - } - } - message.renamedServices[key] = value; - break; - } - case 3: { - if (message.renamedResources === $util.emptyObject) - message.renamedResources = {}; - var end2 = reader.uint32() + reader.pos; - key = ""; - value = ""; - while (reader.pos < end2) { - var tag2 = reader.uint32(); - switch (tag2 >>> 3) { - case 1: - key = reader.string(); - break; - case 2: - value = reader.string(); - break; - default: - reader.skipType(tag2 & 7); - break; - } - } - message.renamedResources[key] = value; - break; - } - case 4: { - if (!(message.ignoredResources && message.ignoredResources.length)) - message.ignoredResources = []; - message.ignoredResources.push(reader.string()); - break; - } - case 5: { - if (!(message.forcedNamespaceAliases && message.forcedNamespaceAliases.length)) - message.forcedNamespaceAliases = []; - message.forcedNamespaceAliases.push(reader.string()); - break; - } - case 6: { - if (!(message.handwrittenSignatures && message.handwrittenSignatures.length)) - message.handwrittenSignatures = []; - message.handwrittenSignatures.push(reader.string()); - break; - } default: reader.skipType(tag & 7); break; @@ -21896,43 +21729,6 @@ if (error) return "common." + error; } - if (message.renamedServices != null && message.hasOwnProperty("renamedServices")) { - if (!$util.isObject(message.renamedServices)) - return "renamedServices: object expected"; - var key = Object.keys(message.renamedServices); - for (var i = 0; i < key.length; ++i) - if (!$util.isString(message.renamedServices[key[i]])) - return "renamedServices: string{k:string} expected"; - } - if (message.renamedResources != null && message.hasOwnProperty("renamedResources")) { - if (!$util.isObject(message.renamedResources)) - return "renamedResources: object expected"; - var key = Object.keys(message.renamedResources); - for (var i = 0; i < key.length; ++i) - if (!$util.isString(message.renamedResources[key[i]])) - return "renamedResources: string{k:string} expected"; - } - if (message.ignoredResources != null && message.hasOwnProperty("ignoredResources")) { - if (!Array.isArray(message.ignoredResources)) - return "ignoredResources: array expected"; - for (var i = 0; i < message.ignoredResources.length; ++i) - if (!$util.isString(message.ignoredResources[i])) - return "ignoredResources: string[] expected"; - } - if (message.forcedNamespaceAliases != null && message.hasOwnProperty("forcedNamespaceAliases")) { - if (!Array.isArray(message.forcedNamespaceAliases)) - return "forcedNamespaceAliases: array expected"; - for (var i = 0; i < message.forcedNamespaceAliases.length; ++i) - if (!$util.isString(message.forcedNamespaceAliases[i])) - return "forcedNamespaceAliases: string[] expected"; - } - if (message.handwrittenSignatures != null && message.hasOwnProperty("handwrittenSignatures")) { - if (!Array.isArray(message.handwrittenSignatures)) - return "handwrittenSignatures: array expected"; - for (var i = 0; i < message.handwrittenSignatures.length; ++i) - if (!$util.isString(message.handwrittenSignatures[i])) - return "handwrittenSignatures: string[] expected"; - } return null; }; @@ -21953,41 +21749,6 @@ throw TypeError(".google.api.DotnetSettings.common: object expected"); message.common = $root.google.api.CommonLanguageSettings.fromObject(object.common); } - if (object.renamedServices) { - if (typeof object.renamedServices !== "object") - throw TypeError(".google.api.DotnetSettings.renamedServices: object expected"); - message.renamedServices = {}; - for (var keys = Object.keys(object.renamedServices), i = 0; i < keys.length; ++i) - message.renamedServices[keys[i]] = String(object.renamedServices[keys[i]]); - } - if (object.renamedResources) { - if (typeof object.renamedResources !== "object") - throw TypeError(".google.api.DotnetSettings.renamedResources: object expected"); - message.renamedResources = {}; - for (var keys = Object.keys(object.renamedResources), i = 0; i < keys.length; ++i) - message.renamedResources[keys[i]] = String(object.renamedResources[keys[i]]); - } - if (object.ignoredResources) { - if (!Array.isArray(object.ignoredResources)) - throw TypeError(".google.api.DotnetSettings.ignoredResources: array expected"); - message.ignoredResources = []; - for (var i = 0; i < object.ignoredResources.length; ++i) - message.ignoredResources[i] = String(object.ignoredResources[i]); - } - if (object.forcedNamespaceAliases) { - if (!Array.isArray(object.forcedNamespaceAliases)) - throw TypeError(".google.api.DotnetSettings.forcedNamespaceAliases: array expected"); - message.forcedNamespaceAliases = []; - for (var i = 0; i < object.forcedNamespaceAliases.length; ++i) - message.forcedNamespaceAliases[i] = String(object.forcedNamespaceAliases[i]); - } - if (object.handwrittenSignatures) { - if (!Array.isArray(object.handwrittenSignatures)) - throw TypeError(".google.api.DotnetSettings.handwrittenSignatures: array expected"); - message.handwrittenSignatures = []; - for (var i = 0; i < object.handwrittenSignatures.length; ++i) - message.handwrittenSignatures[i] = String(object.handwrittenSignatures[i]); - } return message; }; @@ -22004,45 +21765,10 @@ if (!options) options = {}; var object = {}; - if (options.arrays || options.defaults) { - object.ignoredResources = []; - object.forcedNamespaceAliases = []; - object.handwrittenSignatures = []; - } - if (options.objects || options.defaults) { - object.renamedServices = {}; - object.renamedResources = {}; - } if (options.defaults) object.common = null; if (message.common != null && message.hasOwnProperty("common")) object.common = $root.google.api.CommonLanguageSettings.toObject(message.common, options); - var keys2; - if (message.renamedServices && (keys2 = Object.keys(message.renamedServices)).length) { - object.renamedServices = {}; - for (var j = 0; j < keys2.length; ++j) - object.renamedServices[keys2[j]] = message.renamedServices[keys2[j]]; - } - if (message.renamedResources && (keys2 = Object.keys(message.renamedResources)).length) { - object.renamedResources = {}; - for (var j = 0; j < keys2.length; ++j) - object.renamedResources[keys2[j]] = message.renamedResources[keys2[j]]; - } - if (message.ignoredResources && message.ignoredResources.length) { - object.ignoredResources = []; - for (var j = 0; j < message.ignoredResources.length; ++j) - object.ignoredResources[j] = message.ignoredResources[j]; - } - if (message.forcedNamespaceAliases && message.forcedNamespaceAliases.length) { - object.forcedNamespaceAliases = []; - for (var j = 0; j < message.forcedNamespaceAliases.length; ++j) - object.forcedNamespaceAliases[j] = message.forcedNamespaceAliases[j]; - } - if (message.handwrittenSignatures && message.handwrittenSignatures.length) { - object.handwrittenSignatures = []; - for (var j = 0; j < message.handwrittenSignatures.length; ++j) - object.handwrittenSignatures[j] = message.handwrittenSignatures[j]; - } return object; }; @@ -23020,9 +22746,6 @@ * @property {number} ADS=2 ADS value * @property {number} PHOTOS=3 PHOTOS value * @property {number} STREET_VIEW=4 STREET_VIEW value - * @property {number} SHOPPING=5 SHOPPING value - * @property {number} GEO=6 GEO value - * @property {number} GENERATIVE_AI=7 GENERATIVE_AI value */ api.ClientLibraryOrganization = (function() { var valuesById = {}, values = Object.create(valuesById); @@ -23031,9 +22754,6 @@ values[valuesById[2] = "ADS"] = 2; values[valuesById[3] = "PHOTOS"] = 3; values[valuesById[4] = "STREET_VIEW"] = 4; - values[valuesById[5] = "SHOPPING"] = 5; - values[valuesById[6] = "GEO"] = 6; - values[valuesById[7] = "GENERATIVE_AI"] = 7; return values; })(); @@ -25019,9 +24739,6 @@ * @memberof google.protobuf * @interface IExtensionRangeOptions * @property {Array.|null} [uninterpretedOption] ExtensionRangeOptions uninterpretedOption - * @property {Array.|null} [declaration] ExtensionRangeOptions declaration - * @property {google.protobuf.IFeatureSet|null} [features] ExtensionRangeOptions features - * @property {google.protobuf.ExtensionRangeOptions.VerificationState|null} [verification] ExtensionRangeOptions verification */ /** @@ -25034,7 +24751,6 @@ */ function ExtensionRangeOptions(properties) { this.uninterpretedOption = []; - this.declaration = []; if (properties) for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -25049,30 +24765,6 @@ */ ExtensionRangeOptions.prototype.uninterpretedOption = $util.emptyArray; - /** - * ExtensionRangeOptions declaration. - * @member {Array.} declaration - * @memberof google.protobuf.ExtensionRangeOptions - * @instance - */ - ExtensionRangeOptions.prototype.declaration = $util.emptyArray; - - /** - * ExtensionRangeOptions features. - * @member {google.protobuf.IFeatureSet|null|undefined} features - * @memberof google.protobuf.ExtensionRangeOptions - * @instance - */ - ExtensionRangeOptions.prototype.features = null; - - /** - * ExtensionRangeOptions verification. - * @member {google.protobuf.ExtensionRangeOptions.VerificationState} verification - * @memberof google.protobuf.ExtensionRangeOptions - * @instance - */ - ExtensionRangeOptions.prototype.verification = 1; - /** * Creates a new ExtensionRangeOptions instance using the specified properties. * @function create @@ -25097,13 +24789,6 @@ ExtensionRangeOptions.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.declaration != null && message.declaration.length) - for (var i = 0; i < message.declaration.length; ++i) - $root.google.protobuf.ExtensionRangeOptions.Declaration.encode(message.declaration[i], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); - if (message.verification != null && Object.hasOwnProperty.call(message, "verification")) - writer.uint32(/* id 3, wireType 0 =*/24).int32(message.verification); - if (message.features != null && Object.hasOwnProperty.call(message, "features")) - $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 50, wireType 2 =*/402).fork()).ldelim(); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -25147,20 +24832,6 @@ message.uninterpretedOption.push($root.google.protobuf.UninterpretedOption.decode(reader, reader.uint32())); break; } - case 2: { - if (!(message.declaration && message.declaration.length)) - message.declaration = []; - message.declaration.push($root.google.protobuf.ExtensionRangeOptions.Declaration.decode(reader, reader.uint32())); - break; - } - case 50: { - message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); - break; - } - case 3: { - message.verification = reader.int32(); - break; - } default: reader.skipType(tag & 7); break; @@ -25205,28 +24876,6 @@ return "uninterpretedOption." + error; } } - if (message.declaration != null && message.hasOwnProperty("declaration")) { - if (!Array.isArray(message.declaration)) - return "declaration: array expected"; - for (var i = 0; i < message.declaration.length; ++i) { - var error = $root.google.protobuf.ExtensionRangeOptions.Declaration.verify(message.declaration[i]); - if (error) - return "declaration." + error; - } - } - if (message.features != null && message.hasOwnProperty("features")) { - var error = $root.google.protobuf.FeatureSet.verify(message.features); - if (error) - return "features." + error; - } - if (message.verification != null && message.hasOwnProperty("verification")) - switch (message.verification) { - default: - return "verification: enum value expected"; - case 0: - case 1: - break; - } return null; }; @@ -25252,37 +24901,6 @@ message.uninterpretedOption[i] = $root.google.protobuf.UninterpretedOption.fromObject(object.uninterpretedOption[i]); } } - if (object.declaration) { - if (!Array.isArray(object.declaration)) - throw TypeError(".google.protobuf.ExtensionRangeOptions.declaration: array expected"); - message.declaration = []; - for (var i = 0; i < object.declaration.length; ++i) { - if (typeof object.declaration[i] !== "object") - throw TypeError(".google.protobuf.ExtensionRangeOptions.declaration: object expected"); - message.declaration[i] = $root.google.protobuf.ExtensionRangeOptions.Declaration.fromObject(object.declaration[i]); - } - } - if (object.features != null) { - if (typeof object.features !== "object") - throw TypeError(".google.protobuf.ExtensionRangeOptions.features: object expected"); - message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); - } - switch (object.verification) { - case "DECLARATION": - case 0: - message.verification = 0; - break; - default: - if (typeof object.verification === "number") { - message.verification = object.verification; - break; - } - break; - case "UNVERIFIED": - case 1: - message.verification = 1; - break; - } return message; }; @@ -25299,23 +24917,8 @@ if (!options) options = {}; var object = {}; - if (options.arrays || options.defaults) { - object.declaration = []; + if (options.arrays || options.defaults) object.uninterpretedOption = []; - } - if (options.defaults) { - object.verification = options.enums === String ? "UNVERIFIED" : 1; - object.features = null; - } - if (message.declaration && message.declaration.length) { - object.declaration = []; - for (var j = 0; j < message.declaration.length; ++j) - object.declaration[j] = $root.google.protobuf.ExtensionRangeOptions.Declaration.toObject(message.declaration[j], options); - } - if (message.verification != null && message.hasOwnProperty("verification")) - object.verification = options.enums === String ? $root.google.protobuf.ExtensionRangeOptions.VerificationState[message.verification] === undefined ? message.verification : $root.google.protobuf.ExtensionRangeOptions.VerificationState[message.verification] : message.verification; - if (message.features != null && message.hasOwnProperty("features")) - object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -25350,392 +24953,82 @@ return typeUrlPrefix + "/google.protobuf.ExtensionRangeOptions"; }; - ExtensionRangeOptions.Declaration = (function() { + return ExtensionRangeOptions; + })(); - /** - * Properties of a Declaration. - * @memberof google.protobuf.ExtensionRangeOptions - * @interface IDeclaration - * @property {number|null} [number] Declaration number - * @property {string|null} [fullName] Declaration fullName - * @property {string|null} [type] Declaration type - * @property {boolean|null} [reserved] Declaration reserved - * @property {boolean|null} [repeated] Declaration repeated - */ + protobuf.FieldDescriptorProto = (function() { - /** - * Constructs a new Declaration. - * @memberof google.protobuf.ExtensionRangeOptions - * @classdesc Represents a Declaration. - * @implements IDeclaration - * @constructor - * @param {google.protobuf.ExtensionRangeOptions.IDeclaration=} [properties] Properties to set - */ - function Declaration(properties) { - if (properties) - for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) - if (properties[keys[i]] != null) - this[keys[i]] = properties[keys[i]]; - } + /** + * Properties of a FieldDescriptorProto. + * @memberof google.protobuf + * @interface IFieldDescriptorProto + * @property {string|null} [name] FieldDescriptorProto name + * @property {number|null} [number] FieldDescriptorProto number + * @property {google.protobuf.FieldDescriptorProto.Label|null} [label] FieldDescriptorProto label + * @property {google.protobuf.FieldDescriptorProto.Type|null} [type] FieldDescriptorProto type + * @property {string|null} [typeName] FieldDescriptorProto typeName + * @property {string|null} [extendee] FieldDescriptorProto extendee + * @property {string|null} [defaultValue] FieldDescriptorProto defaultValue + * @property {number|null} [oneofIndex] FieldDescriptorProto oneofIndex + * @property {string|null} [jsonName] FieldDescriptorProto jsonName + * @property {google.protobuf.IFieldOptions|null} [options] FieldDescriptorProto options + * @property {boolean|null} [proto3Optional] FieldDescriptorProto proto3Optional + */ - /** - * Declaration number. - * @member {number} number - * @memberof google.protobuf.ExtensionRangeOptions.Declaration - * @instance - */ - Declaration.prototype.number = 0; + /** + * Constructs a new FieldDescriptorProto. + * @memberof google.protobuf + * @classdesc Represents a FieldDescriptorProto. + * @implements IFieldDescriptorProto + * @constructor + * @param {google.protobuf.IFieldDescriptorProto=} [properties] Properties to set + */ + function FieldDescriptorProto(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } - /** - * Declaration fullName. - * @member {string} fullName - * @memberof google.protobuf.ExtensionRangeOptions.Declaration - * @instance - */ - Declaration.prototype.fullName = ""; + /** + * FieldDescriptorProto name. + * @member {string} name + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.name = ""; - /** - * Declaration type. - * @member {string} type - * @memberof google.protobuf.ExtensionRangeOptions.Declaration - * @instance - */ - Declaration.prototype.type = ""; + /** + * FieldDescriptorProto number. + * @member {number} number + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.number = 0; - /** - * Declaration reserved. - * @member {boolean} reserved - * @memberof google.protobuf.ExtensionRangeOptions.Declaration - * @instance - */ - Declaration.prototype.reserved = false; + /** + * FieldDescriptorProto label. + * @member {google.protobuf.FieldDescriptorProto.Label} label + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.label = 1; - /** - * Declaration repeated. - * @member {boolean} repeated - * @memberof google.protobuf.ExtensionRangeOptions.Declaration - * @instance - */ - Declaration.prototype.repeated = false; + /** + * FieldDescriptorProto type. + * @member {google.protobuf.FieldDescriptorProto.Type} type + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.type = 1; - /** - * Creates a new Declaration instance using the specified properties. - * @function create - * @memberof google.protobuf.ExtensionRangeOptions.Declaration - * @static - * @param {google.protobuf.ExtensionRangeOptions.IDeclaration=} [properties] Properties to set - * @returns {google.protobuf.ExtensionRangeOptions.Declaration} Declaration instance - */ - Declaration.create = function create(properties) { - return new Declaration(properties); - }; - - /** - * Encodes the specified Declaration message. Does not implicitly {@link google.protobuf.ExtensionRangeOptions.Declaration.verify|verify} messages. - * @function encode - * @memberof google.protobuf.ExtensionRangeOptions.Declaration - * @static - * @param {google.protobuf.ExtensionRangeOptions.IDeclaration} message Declaration message or plain object to encode - * @param {$protobuf.Writer} [writer] Writer to encode to - * @returns {$protobuf.Writer} Writer - */ - Declaration.encode = function encode(message, writer) { - if (!writer) - writer = $Writer.create(); - if (message.number != null && Object.hasOwnProperty.call(message, "number")) - writer.uint32(/* id 1, wireType 0 =*/8).int32(message.number); - if (message.fullName != null && Object.hasOwnProperty.call(message, "fullName")) - writer.uint32(/* id 2, wireType 2 =*/18).string(message.fullName); - if (message.type != null && Object.hasOwnProperty.call(message, "type")) - writer.uint32(/* id 3, wireType 2 =*/26).string(message.type); - if (message.reserved != null && Object.hasOwnProperty.call(message, "reserved")) - writer.uint32(/* id 5, wireType 0 =*/40).bool(message.reserved); - if (message.repeated != null && Object.hasOwnProperty.call(message, "repeated")) - writer.uint32(/* id 6, wireType 0 =*/48).bool(message.repeated); - return writer; - }; - - /** - * Encodes the specified Declaration message, length delimited. Does not implicitly {@link google.protobuf.ExtensionRangeOptions.Declaration.verify|verify} messages. - * @function encodeDelimited - * @memberof google.protobuf.ExtensionRangeOptions.Declaration - * @static - * @param {google.protobuf.ExtensionRangeOptions.IDeclaration} message Declaration message or plain object to encode - * @param {$protobuf.Writer} [writer] Writer to encode to - * @returns {$protobuf.Writer} Writer - */ - Declaration.encodeDelimited = function encodeDelimited(message, writer) { - return this.encode(message, writer).ldelim(); - }; - - /** - * Decodes a Declaration message from the specified reader or buffer. - * @function decode - * @memberof google.protobuf.ExtensionRangeOptions.Declaration - * @static - * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from - * @param {number} [length] Message length if known beforehand - * @returns {google.protobuf.ExtensionRangeOptions.Declaration} Declaration - * @throws {Error} If the payload is not a reader or valid buffer - * @throws {$protobuf.util.ProtocolError} If required fields are missing - */ - Declaration.decode = function decode(reader, length) { - if (!(reader instanceof $Reader)) - reader = $Reader.create(reader); - var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.ExtensionRangeOptions.Declaration(); - while (reader.pos < end) { - var tag = reader.uint32(); - switch (tag >>> 3) { - case 1: { - message.number = reader.int32(); - break; - } - case 2: { - message.fullName = reader.string(); - break; - } - case 3: { - message.type = reader.string(); - break; - } - case 5: { - message.reserved = reader.bool(); - break; - } - case 6: { - message.repeated = reader.bool(); - break; - } - default: - reader.skipType(tag & 7); - break; - } - } - return message; - }; - - /** - * Decodes a Declaration message from the specified reader or buffer, length delimited. - * @function decodeDelimited - * @memberof google.protobuf.ExtensionRangeOptions.Declaration - * @static - * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from - * @returns {google.protobuf.ExtensionRangeOptions.Declaration} Declaration - * @throws {Error} If the payload is not a reader or valid buffer - * @throws {$protobuf.util.ProtocolError} If required fields are missing - */ - Declaration.decodeDelimited = function decodeDelimited(reader) { - if (!(reader instanceof $Reader)) - reader = new $Reader(reader); - return this.decode(reader, reader.uint32()); - }; - - /** - * Verifies a Declaration message. - * @function verify - * @memberof google.protobuf.ExtensionRangeOptions.Declaration - * @static - * @param {Object.} message Plain object to verify - * @returns {string|null} `null` if valid, otherwise the reason why it is not - */ - Declaration.verify = function verify(message) { - if (typeof message !== "object" || message === null) - return "object expected"; - if (message.number != null && message.hasOwnProperty("number")) - if (!$util.isInteger(message.number)) - return "number: integer expected"; - if (message.fullName != null && message.hasOwnProperty("fullName")) - if (!$util.isString(message.fullName)) - return "fullName: string expected"; - if (message.type != null && message.hasOwnProperty("type")) - if (!$util.isString(message.type)) - return "type: string expected"; - if (message.reserved != null && message.hasOwnProperty("reserved")) - if (typeof message.reserved !== "boolean") - return "reserved: boolean expected"; - if (message.repeated != null && message.hasOwnProperty("repeated")) - if (typeof message.repeated !== "boolean") - return "repeated: boolean expected"; - return null; - }; - - /** - * Creates a Declaration message from a plain object. Also converts values to their respective internal types. - * @function fromObject - * @memberof google.protobuf.ExtensionRangeOptions.Declaration - * @static - * @param {Object.} object Plain object - * @returns {google.protobuf.ExtensionRangeOptions.Declaration} Declaration - */ - Declaration.fromObject = function fromObject(object) { - if (object instanceof $root.google.protobuf.ExtensionRangeOptions.Declaration) - return object; - var message = new $root.google.protobuf.ExtensionRangeOptions.Declaration(); - if (object.number != null) - message.number = object.number | 0; - if (object.fullName != null) - message.fullName = String(object.fullName); - if (object.type != null) - message.type = String(object.type); - if (object.reserved != null) - message.reserved = Boolean(object.reserved); - if (object.repeated != null) - message.repeated = Boolean(object.repeated); - return message; - }; - - /** - * Creates a plain object from a Declaration message. Also converts values to other types if specified. - * @function toObject - * @memberof google.protobuf.ExtensionRangeOptions.Declaration - * @static - * @param {google.protobuf.ExtensionRangeOptions.Declaration} message Declaration - * @param {$protobuf.IConversionOptions} [options] Conversion options - * @returns {Object.} Plain object - */ - Declaration.toObject = function toObject(message, options) { - if (!options) - options = {}; - var object = {}; - if (options.defaults) { - object.number = 0; - object.fullName = ""; - object.type = ""; - object.reserved = false; - object.repeated = false; - } - if (message.number != null && message.hasOwnProperty("number")) - object.number = message.number; - if (message.fullName != null && message.hasOwnProperty("fullName")) - object.fullName = message.fullName; - if (message.type != null && message.hasOwnProperty("type")) - object.type = message.type; - if (message.reserved != null && message.hasOwnProperty("reserved")) - object.reserved = message.reserved; - if (message.repeated != null && message.hasOwnProperty("repeated")) - object.repeated = message.repeated; - return object; - }; - - /** - * Converts this Declaration to JSON. - * @function toJSON - * @memberof google.protobuf.ExtensionRangeOptions.Declaration - * @instance - * @returns {Object.} JSON object - */ - Declaration.prototype.toJSON = function toJSON() { - return this.constructor.toObject(this, $protobuf.util.toJSONOptions); - }; - - /** - * Gets the default type url for Declaration - * @function getTypeUrl - * @memberof google.protobuf.ExtensionRangeOptions.Declaration - * @static - * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") - * @returns {string} The default type url - */ - Declaration.getTypeUrl = function getTypeUrl(typeUrlPrefix) { - if (typeUrlPrefix === undefined) { - typeUrlPrefix = "type.googleapis.com"; - } - return typeUrlPrefix + "/google.protobuf.ExtensionRangeOptions.Declaration"; - }; - - return Declaration; - })(); - - /** - * VerificationState enum. - * @name google.protobuf.ExtensionRangeOptions.VerificationState - * @enum {number} - * @property {number} DECLARATION=0 DECLARATION value - * @property {number} UNVERIFIED=1 UNVERIFIED value - */ - ExtensionRangeOptions.VerificationState = (function() { - var valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "DECLARATION"] = 0; - values[valuesById[1] = "UNVERIFIED"] = 1; - return values; - })(); - - return ExtensionRangeOptions; - })(); - - protobuf.FieldDescriptorProto = (function() { - - /** - * Properties of a FieldDescriptorProto. - * @memberof google.protobuf - * @interface IFieldDescriptorProto - * @property {string|null} [name] FieldDescriptorProto name - * @property {number|null} [number] FieldDescriptorProto number - * @property {google.protobuf.FieldDescriptorProto.Label|null} [label] FieldDescriptorProto label - * @property {google.protobuf.FieldDescriptorProto.Type|null} [type] FieldDescriptorProto type - * @property {string|null} [typeName] FieldDescriptorProto typeName - * @property {string|null} [extendee] FieldDescriptorProto extendee - * @property {string|null} [defaultValue] FieldDescriptorProto defaultValue - * @property {number|null} [oneofIndex] FieldDescriptorProto oneofIndex - * @property {string|null} [jsonName] FieldDescriptorProto jsonName - * @property {google.protobuf.IFieldOptions|null} [options] FieldDescriptorProto options - * @property {boolean|null} [proto3Optional] FieldDescriptorProto proto3Optional - */ - - /** - * Constructs a new FieldDescriptorProto. - * @memberof google.protobuf - * @classdesc Represents a FieldDescriptorProto. - * @implements IFieldDescriptorProto - * @constructor - * @param {google.protobuf.IFieldDescriptorProto=} [properties] Properties to set - */ - function FieldDescriptorProto(properties) { - if (properties) - for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) - if (properties[keys[i]] != null) - this[keys[i]] = properties[keys[i]]; - } - - /** - * FieldDescriptorProto name. - * @member {string} name - * @memberof google.protobuf.FieldDescriptorProto - * @instance - */ - FieldDescriptorProto.prototype.name = ""; - - /** - * FieldDescriptorProto number. - * @member {number} number - * @memberof google.protobuf.FieldDescriptorProto - * @instance - */ - FieldDescriptorProto.prototype.number = 0; - - /** - * FieldDescriptorProto label. - * @member {google.protobuf.FieldDescriptorProto.Label} label - * @memberof google.protobuf.FieldDescriptorProto - * @instance - */ - FieldDescriptorProto.prototype.label = 1; - - /** - * FieldDescriptorProto type. - * @member {google.protobuf.FieldDescriptorProto.Type} type - * @memberof google.protobuf.FieldDescriptorProto - * @instance - */ - FieldDescriptorProto.prototype.type = 1; - - /** - * FieldDescriptorProto typeName. - * @member {string} typeName - * @memberof google.protobuf.FieldDescriptorProto - * @instance - */ - FieldDescriptorProto.prototype.typeName = ""; + /** + * FieldDescriptorProto typeName. + * @member {string} typeName + * @memberof google.protobuf.FieldDescriptorProto + * @instance + */ + FieldDescriptorProto.prototype.typeName = ""; /** * FieldDescriptorProto extendee. @@ -27989,7 +27282,6 @@ * @property {string|null} [phpNamespace] FileOptions phpNamespace * @property {string|null} [phpMetadataNamespace] FileOptions phpMetadataNamespace * @property {string|null} [rubyPackage] FileOptions rubyPackage - * @property {google.protobuf.IFeatureSet|null} [features] FileOptions features * @property {Array.|null} [uninterpretedOption] FileOptions uninterpretedOption * @property {Array.|null} [".google.api.resourceDefinition"] FileOptions .google.api.resourceDefinition */ @@ -28171,14 +27463,6 @@ */ FileOptions.prototype.rubyPackage = ""; - /** - * FileOptions features. - * @member {google.protobuf.IFeatureSet|null|undefined} features - * @memberof google.protobuf.FileOptions - * @instance - */ - FileOptions.prototype.features = null; - /** * FileOptions uninterpretedOption. * @member {Array.} uninterpretedOption @@ -28259,8 +27543,6 @@ writer.uint32(/* id 44, wireType 2 =*/354).string(message.phpMetadataNamespace); if (message.rubyPackage != null && Object.hasOwnProperty.call(message, "rubyPackage")) writer.uint32(/* id 45, wireType 2 =*/362).string(message.rubyPackage); - if (message.features != null && Object.hasOwnProperty.call(message, "features")) - $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 50, wireType 2 =*/402).fork()).ldelim(); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -28381,10 +27663,6 @@ message.rubyPackage = reader.string(); break; } - case 50: { - message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); - break; - } case 999: { if (!(message.uninterpretedOption && message.uninterpretedOption.length)) message.uninterpretedOption = []; @@ -28498,11 +27776,6 @@ if (message.rubyPackage != null && message.hasOwnProperty("rubyPackage")) if (!$util.isString(message.rubyPackage)) return "rubyPackage: string expected"; - if (message.features != null && message.hasOwnProperty("features")) { - var error = $root.google.protobuf.FeatureSet.verify(message.features); - if (error) - return "features." + error; - } if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { if (!Array.isArray(message.uninterpretedOption)) return "uninterpretedOption: array expected"; @@ -28594,11 +27867,6 @@ message.phpMetadataNamespace = String(object.phpMetadataNamespace); if (object.rubyPackage != null) message.rubyPackage = String(object.rubyPackage); - if (object.features != null) { - if (typeof object.features !== "object") - throw TypeError(".google.protobuf.FileOptions.features: object expected"); - message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); - } if (object.uninterpretedOption) { if (!Array.isArray(object.uninterpretedOption)) throw TypeError(".google.protobuf.FileOptions.uninterpretedOption: array expected"); @@ -28660,7 +27928,6 @@ object.phpGenericServices = false; object.phpMetadataNamespace = ""; object.rubyPackage = ""; - object.features = null; } if (message.javaPackage != null && message.hasOwnProperty("javaPackage")) object.javaPackage = message.javaPackage; @@ -28702,8 +27969,6 @@ object.phpMetadataNamespace = message.phpMetadataNamespace; if (message.rubyPackage != null && message.hasOwnProperty("rubyPackage")) object.rubyPackage = message.rubyPackage; - if (message.features != null && message.hasOwnProperty("features")) - object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -28773,7 +28038,6 @@ * @property {boolean|null} [deprecated] MessageOptions deprecated * @property {boolean|null} [mapEntry] MessageOptions mapEntry * @property {boolean|null} [deprecatedLegacyJsonFieldConflicts] MessageOptions deprecatedLegacyJsonFieldConflicts - * @property {google.protobuf.IFeatureSet|null} [features] MessageOptions features * @property {Array.|null} [uninterpretedOption] MessageOptions uninterpretedOption * @property {google.api.IResourceDescriptor|null} [".google.api.resource"] MessageOptions .google.api.resource */ @@ -28834,14 +28098,6 @@ */ MessageOptions.prototype.deprecatedLegacyJsonFieldConflicts = false; - /** - * MessageOptions features. - * @member {google.protobuf.IFeatureSet|null|undefined} features - * @memberof google.protobuf.MessageOptions - * @instance - */ - MessageOptions.prototype.features = null; - /** * MessageOptions uninterpretedOption. * @member {Array.} uninterpretedOption @@ -28892,8 +28148,6 @@ writer.uint32(/* id 7, wireType 0 =*/56).bool(message.mapEntry); if (message.deprecatedLegacyJsonFieldConflicts != null && Object.hasOwnProperty.call(message, "deprecatedLegacyJsonFieldConflicts")) writer.uint32(/* id 11, wireType 0 =*/88).bool(message.deprecatedLegacyJsonFieldConflicts); - if (message.features != null && Object.hasOwnProperty.call(message, "features")) - $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 12, wireType 2 =*/98).fork()).ldelim(); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -28953,10 +28207,6 @@ message.deprecatedLegacyJsonFieldConflicts = reader.bool(); break; } - case 12: { - message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); - break; - } case 999: { if (!(message.uninterpretedOption && message.uninterpretedOption.length)) message.uninterpretedOption = []; @@ -29017,11 +28267,6 @@ if (message.deprecatedLegacyJsonFieldConflicts != null && message.hasOwnProperty("deprecatedLegacyJsonFieldConflicts")) if (typeof message.deprecatedLegacyJsonFieldConflicts !== "boolean") return "deprecatedLegacyJsonFieldConflicts: boolean expected"; - if (message.features != null && message.hasOwnProperty("features")) { - var error = $root.google.protobuf.FeatureSet.verify(message.features); - if (error) - return "features." + error; - } if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { if (!Array.isArray(message.uninterpretedOption)) return "uninterpretedOption: array expected"; @@ -29061,11 +28306,6 @@ message.mapEntry = Boolean(object.mapEntry); if (object.deprecatedLegacyJsonFieldConflicts != null) message.deprecatedLegacyJsonFieldConflicts = Boolean(object.deprecatedLegacyJsonFieldConflicts); - if (object.features != null) { - if (typeof object.features !== "object") - throw TypeError(".google.protobuf.MessageOptions.features: object expected"); - message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); - } if (object.uninterpretedOption) { if (!Array.isArray(object.uninterpretedOption)) throw TypeError(".google.protobuf.MessageOptions.uninterpretedOption: array expected"); @@ -29105,7 +28345,6 @@ object.deprecated = false; object.mapEntry = false; object.deprecatedLegacyJsonFieldConflicts = false; - object.features = null; object[".google.api.resource"] = null; } if (message.messageSetWireFormat != null && message.hasOwnProperty("messageSetWireFormat")) @@ -29118,8 +28357,6 @@ object.mapEntry = message.mapEntry; if (message.deprecatedLegacyJsonFieldConflicts != null && message.hasOwnProperty("deprecatedLegacyJsonFieldConflicts")) object.deprecatedLegacyJsonFieldConflicts = message.deprecatedLegacyJsonFieldConflicts; - if (message.features != null && message.hasOwnProperty("features")) - object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -29174,9 +28411,7 @@ * @property {boolean|null} [weak] FieldOptions weak * @property {boolean|null} [debugRedact] FieldOptions debugRedact * @property {google.protobuf.FieldOptions.OptionRetention|null} [retention] FieldOptions retention - * @property {Array.|null} [targets] FieldOptions targets - * @property {Array.|null} [editionDefaults] FieldOptions editionDefaults - * @property {google.protobuf.IFeatureSet|null} [features] FieldOptions features + * @property {google.protobuf.FieldOptions.OptionTargetType|null} [target] FieldOptions target * @property {Array.|null} [uninterpretedOption] FieldOptions uninterpretedOption * @property {Array.|null} [".google.api.fieldBehavior"] FieldOptions .google.api.fieldBehavior * @property {google.api.IResourceReference|null} [".google.api.resourceReference"] FieldOptions .google.api.resourceReference @@ -29191,8 +28426,6 @@ * @param {google.protobuf.IFieldOptions=} [properties] Properties to set */ function FieldOptions(properties) { - this.targets = []; - this.editionDefaults = []; this.uninterpretedOption = []; this[".google.api.fieldBehavior"] = []; if (properties) @@ -29274,28 +28507,12 @@ FieldOptions.prototype.retention = 0; /** - * FieldOptions targets. - * @member {Array.} targets - * @memberof google.protobuf.FieldOptions - * @instance - */ - FieldOptions.prototype.targets = $util.emptyArray; - - /** - * FieldOptions editionDefaults. - * @member {Array.} editionDefaults - * @memberof google.protobuf.FieldOptions - * @instance - */ - FieldOptions.prototype.editionDefaults = $util.emptyArray; - - /** - * FieldOptions features. - * @member {google.protobuf.IFeatureSet|null|undefined} features + * FieldOptions target. + * @member {google.protobuf.FieldOptions.OptionTargetType} target * @memberof google.protobuf.FieldOptions * @instance */ - FieldOptions.prototype.features = null; + FieldOptions.prototype.target = 0; /** * FieldOptions uninterpretedOption. @@ -29363,14 +28580,8 @@ writer.uint32(/* id 16, wireType 0 =*/128).bool(message.debugRedact); if (message.retention != null && Object.hasOwnProperty.call(message, "retention")) writer.uint32(/* id 17, wireType 0 =*/136).int32(message.retention); - if (message.targets != null && message.targets.length) - for (var i = 0; i < message.targets.length; ++i) - writer.uint32(/* id 19, wireType 0 =*/152).int32(message.targets[i]); - if (message.editionDefaults != null && message.editionDefaults.length) - for (var i = 0; i < message.editionDefaults.length; ++i) - $root.google.protobuf.FieldOptions.EditionDefault.encode(message.editionDefaults[i], writer.uint32(/* id 20, wireType 2 =*/162).fork()).ldelim(); - if (message.features != null && Object.hasOwnProperty.call(message, "features")) - $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 21, wireType 2 =*/170).fork()).ldelim(); + if (message.target != null && Object.hasOwnProperty.call(message, "target")) + writer.uint32(/* id 18, wireType 0 =*/144).int32(message.target); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -29452,25 +28663,8 @@ message.retention = reader.int32(); break; } - case 19: { - if (!(message.targets && message.targets.length)) - message.targets = []; - if ((tag & 7) === 2) { - var end2 = reader.uint32() + reader.pos; - while (reader.pos < end2) - message.targets.push(reader.int32()); - } else - message.targets.push(reader.int32()); - break; - } - case 20: { - if (!(message.editionDefaults && message.editionDefaults.length)) - message.editionDefaults = []; - message.editionDefaults.push($root.google.protobuf.FieldOptions.EditionDefault.decode(reader, reader.uint32())); - break; - } - case 21: { - message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); + case 18: { + message.target = reader.int32(); break; } case 999: { @@ -29574,40 +28768,22 @@ case 2: break; } - if (message.targets != null && message.hasOwnProperty("targets")) { - if (!Array.isArray(message.targets)) - return "targets: array expected"; - for (var i = 0; i < message.targets.length; ++i) - switch (message.targets[i]) { - default: - return "targets: enum value[] expected"; - case 0: - case 1: - case 2: - case 3: - case 4: - case 5: - case 6: - case 7: - case 8: - case 9: - break; - } - } - if (message.editionDefaults != null && message.hasOwnProperty("editionDefaults")) { - if (!Array.isArray(message.editionDefaults)) - return "editionDefaults: array expected"; - for (var i = 0; i < message.editionDefaults.length; ++i) { - var error = $root.google.protobuf.FieldOptions.EditionDefault.verify(message.editionDefaults[i]); - if (error) - return "editionDefaults." + error; + if (message.target != null && message.hasOwnProperty("target")) + switch (message.target) { + default: + return "target: enum value expected"; + case 0: + case 1: + case 2: + case 3: + case 4: + case 5: + case 6: + case 7: + case 8: + case 9: + break; } - } - if (message.features != null && message.hasOwnProperty("features")) { - var error = $root.google.protobuf.FeatureSet.verify(message.features); - if (error) - return "features." + error; - } if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { if (!Array.isArray(message.uninterpretedOption)) return "uninterpretedOption: array expected"; @@ -29727,73 +28903,53 @@ message.retention = 2; break; } - if (object.targets) { - if (!Array.isArray(object.targets)) - throw TypeError(".google.protobuf.FieldOptions.targets: array expected"); - message.targets = []; - for (var i = 0; i < object.targets.length; ++i) - switch (object.targets[i]) { - default: - if (typeof object.targets[i] === "number") { - message.targets[i] = object.targets[i]; - break; - } - case "TARGET_TYPE_UNKNOWN": - case 0: - message.targets[i] = 0; - break; - case "TARGET_TYPE_FILE": - case 1: - message.targets[i] = 1; - break; - case "TARGET_TYPE_EXTENSION_RANGE": - case 2: - message.targets[i] = 2; - break; - case "TARGET_TYPE_MESSAGE": - case 3: - message.targets[i] = 3; - break; - case "TARGET_TYPE_FIELD": - case 4: - message.targets[i] = 4; - break; - case "TARGET_TYPE_ONEOF": - case 5: - message.targets[i] = 5; - break; - case "TARGET_TYPE_ENUM": - case 6: - message.targets[i] = 6; - break; - case "TARGET_TYPE_ENUM_ENTRY": - case 7: - message.targets[i] = 7; - break; - case "TARGET_TYPE_SERVICE": - case 8: - message.targets[i] = 8; - break; - case "TARGET_TYPE_METHOD": - case 9: - message.targets[i] = 9; - break; - } - } - if (object.editionDefaults) { - if (!Array.isArray(object.editionDefaults)) - throw TypeError(".google.protobuf.FieldOptions.editionDefaults: array expected"); - message.editionDefaults = []; - for (var i = 0; i < object.editionDefaults.length; ++i) { - if (typeof object.editionDefaults[i] !== "object") - throw TypeError(".google.protobuf.FieldOptions.editionDefaults: object expected"); - message.editionDefaults[i] = $root.google.protobuf.FieldOptions.EditionDefault.fromObject(object.editionDefaults[i]); + switch (object.target) { + default: + if (typeof object.target === "number") { + message.target = object.target; + break; } - } - if (object.features != null) { - if (typeof object.features !== "object") - throw TypeError(".google.protobuf.FieldOptions.features: object expected"); - message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); + break; + case "TARGET_TYPE_UNKNOWN": + case 0: + message.target = 0; + break; + case "TARGET_TYPE_FILE": + case 1: + message.target = 1; + break; + case "TARGET_TYPE_EXTENSION_RANGE": + case 2: + message.target = 2; + break; + case "TARGET_TYPE_MESSAGE": + case 3: + message.target = 3; + break; + case "TARGET_TYPE_FIELD": + case 4: + message.target = 4; + break; + case "TARGET_TYPE_ONEOF": + case 5: + message.target = 5; + break; + case "TARGET_TYPE_ENUM": + case 6: + message.target = 6; + break; + case "TARGET_TYPE_ENUM_ENTRY": + case 7: + message.target = 7; + break; + case "TARGET_TYPE_SERVICE": + case 8: + message.target = 8; + break; + case "TARGET_TYPE_METHOD": + case 9: + message.target = 9; + break; } if (object.uninterpretedOption) { if (!Array.isArray(object.uninterpretedOption)) @@ -29872,8 +29028,6 @@ options = {}; var object = {}; if (options.arrays || options.defaults) { - object.targets = []; - object.editionDefaults = []; object.uninterpretedOption = []; object[".google.api.fieldBehavior"] = []; } @@ -29887,7 +29041,7 @@ object.unverifiedLazy = false; object.debugRedact = false; object.retention = options.enums === String ? "RETENTION_UNKNOWN" : 0; - object.features = null; + object.target = options.enums === String ? "TARGET_TYPE_UNKNOWN" : 0; object[".google.api.resourceReference"] = null; } if (message.ctype != null && message.hasOwnProperty("ctype")) @@ -29908,18 +29062,8 @@ object.debugRedact = message.debugRedact; if (message.retention != null && message.hasOwnProperty("retention")) object.retention = options.enums === String ? $root.google.protobuf.FieldOptions.OptionRetention[message.retention] === undefined ? message.retention : $root.google.protobuf.FieldOptions.OptionRetention[message.retention] : message.retention; - if (message.targets && message.targets.length) { - object.targets = []; - for (var j = 0; j < message.targets.length; ++j) - object.targets[j] = options.enums === String ? $root.google.protobuf.FieldOptions.OptionTargetType[message.targets[j]] === undefined ? message.targets[j] : $root.google.protobuf.FieldOptions.OptionTargetType[message.targets[j]] : message.targets[j]; - } - if (message.editionDefaults && message.editionDefaults.length) { - object.editionDefaults = []; - for (var j = 0; j < message.editionDefaults.length; ++j) - object.editionDefaults[j] = $root.google.protobuf.FieldOptions.EditionDefault.toObject(message.editionDefaults[j], options); - } - if (message.features != null && message.hasOwnProperty("features")) - object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); + if (message.target != null && message.hasOwnProperty("target")) + object.target = options.enums === String ? $root.google.protobuf.FieldOptions.OptionTargetType[message.target] === undefined ? message.target : $root.google.protobuf.FieldOptions.OptionTargetType[message.target] : message.target; if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -30039,233 +29183,6 @@ return values; })(); - FieldOptions.EditionDefault = (function() { - - /** - * Properties of an EditionDefault. - * @memberof google.protobuf.FieldOptions - * @interface IEditionDefault - * @property {string|null} [edition] EditionDefault edition - * @property {string|null} [value] EditionDefault value - */ - - /** - * Constructs a new EditionDefault. - * @memberof google.protobuf.FieldOptions - * @classdesc Represents an EditionDefault. - * @implements IEditionDefault - * @constructor - * @param {google.protobuf.FieldOptions.IEditionDefault=} [properties] Properties to set - */ - function EditionDefault(properties) { - if (properties) - for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) - if (properties[keys[i]] != null) - this[keys[i]] = properties[keys[i]]; - } - - /** - * EditionDefault edition. - * @member {string} edition - * @memberof google.protobuf.FieldOptions.EditionDefault - * @instance - */ - EditionDefault.prototype.edition = ""; - - /** - * EditionDefault value. - * @member {string} value - * @memberof google.protobuf.FieldOptions.EditionDefault - * @instance - */ - EditionDefault.prototype.value = ""; - - /** - * Creates a new EditionDefault instance using the specified properties. - * @function create - * @memberof google.protobuf.FieldOptions.EditionDefault - * @static - * @param {google.protobuf.FieldOptions.IEditionDefault=} [properties] Properties to set - * @returns {google.protobuf.FieldOptions.EditionDefault} EditionDefault instance - */ - EditionDefault.create = function create(properties) { - return new EditionDefault(properties); - }; - - /** - * Encodes the specified EditionDefault message. Does not implicitly {@link google.protobuf.FieldOptions.EditionDefault.verify|verify} messages. - * @function encode - * @memberof google.protobuf.FieldOptions.EditionDefault - * @static - * @param {google.protobuf.FieldOptions.IEditionDefault} message EditionDefault message or plain object to encode - * @param {$protobuf.Writer} [writer] Writer to encode to - * @returns {$protobuf.Writer} Writer - */ - EditionDefault.encode = function encode(message, writer) { - if (!writer) - writer = $Writer.create(); - if (message.edition != null && Object.hasOwnProperty.call(message, "edition")) - writer.uint32(/* id 1, wireType 2 =*/10).string(message.edition); - if (message.value != null && Object.hasOwnProperty.call(message, "value")) - writer.uint32(/* id 2, wireType 2 =*/18).string(message.value); - return writer; - }; - - /** - * Encodes the specified EditionDefault message, length delimited. Does not implicitly {@link google.protobuf.FieldOptions.EditionDefault.verify|verify} messages. - * @function encodeDelimited - * @memberof google.protobuf.FieldOptions.EditionDefault - * @static - * @param {google.protobuf.FieldOptions.IEditionDefault} message EditionDefault message or plain object to encode - * @param {$protobuf.Writer} [writer] Writer to encode to - * @returns {$protobuf.Writer} Writer - */ - EditionDefault.encodeDelimited = function encodeDelimited(message, writer) { - return this.encode(message, writer).ldelim(); - }; - - /** - * Decodes an EditionDefault message from the specified reader or buffer. - * @function decode - * @memberof google.protobuf.FieldOptions.EditionDefault - * @static - * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from - * @param {number} [length] Message length if known beforehand - * @returns {google.protobuf.FieldOptions.EditionDefault} EditionDefault - * @throws {Error} If the payload is not a reader or valid buffer - * @throws {$protobuf.util.ProtocolError} If required fields are missing - */ - EditionDefault.decode = function decode(reader, length) { - if (!(reader instanceof $Reader)) - reader = $Reader.create(reader); - var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.FieldOptions.EditionDefault(); - while (reader.pos < end) { - var tag = reader.uint32(); - switch (tag >>> 3) { - case 1: { - message.edition = reader.string(); - break; - } - case 2: { - message.value = reader.string(); - break; - } - default: - reader.skipType(tag & 7); - break; - } - } - return message; - }; - - /** - * Decodes an EditionDefault message from the specified reader or buffer, length delimited. - * @function decodeDelimited - * @memberof google.protobuf.FieldOptions.EditionDefault - * @static - * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from - * @returns {google.protobuf.FieldOptions.EditionDefault} EditionDefault - * @throws {Error} If the payload is not a reader or valid buffer - * @throws {$protobuf.util.ProtocolError} If required fields are missing - */ - EditionDefault.decodeDelimited = function decodeDelimited(reader) { - if (!(reader instanceof $Reader)) - reader = new $Reader(reader); - return this.decode(reader, reader.uint32()); - }; - - /** - * Verifies an EditionDefault message. - * @function verify - * @memberof google.protobuf.FieldOptions.EditionDefault - * @static - * @param {Object.} message Plain object to verify - * @returns {string|null} `null` if valid, otherwise the reason why it is not - */ - EditionDefault.verify = function verify(message) { - if (typeof message !== "object" || message === null) - return "object expected"; - if (message.edition != null && message.hasOwnProperty("edition")) - if (!$util.isString(message.edition)) - return "edition: string expected"; - if (message.value != null && message.hasOwnProperty("value")) - if (!$util.isString(message.value)) - return "value: string expected"; - return null; - }; - - /** - * Creates an EditionDefault message from a plain object. Also converts values to their respective internal types. - * @function fromObject - * @memberof google.protobuf.FieldOptions.EditionDefault - * @static - * @param {Object.} object Plain object - * @returns {google.protobuf.FieldOptions.EditionDefault} EditionDefault - */ - EditionDefault.fromObject = function fromObject(object) { - if (object instanceof $root.google.protobuf.FieldOptions.EditionDefault) - return object; - var message = new $root.google.protobuf.FieldOptions.EditionDefault(); - if (object.edition != null) - message.edition = String(object.edition); - if (object.value != null) - message.value = String(object.value); - return message; - }; - - /** - * Creates a plain object from an EditionDefault message. Also converts values to other types if specified. - * @function toObject - * @memberof google.protobuf.FieldOptions.EditionDefault - * @static - * @param {google.protobuf.FieldOptions.EditionDefault} message EditionDefault - * @param {$protobuf.IConversionOptions} [options] Conversion options - * @returns {Object.} Plain object - */ - EditionDefault.toObject = function toObject(message, options) { - if (!options) - options = {}; - var object = {}; - if (options.defaults) { - object.edition = ""; - object.value = ""; - } - if (message.edition != null && message.hasOwnProperty("edition")) - object.edition = message.edition; - if (message.value != null && message.hasOwnProperty("value")) - object.value = message.value; - return object; - }; - - /** - * Converts this EditionDefault to JSON. - * @function toJSON - * @memberof google.protobuf.FieldOptions.EditionDefault - * @instance - * @returns {Object.} JSON object - */ - EditionDefault.prototype.toJSON = function toJSON() { - return this.constructor.toObject(this, $protobuf.util.toJSONOptions); - }; - - /** - * Gets the default type url for EditionDefault - * @function getTypeUrl - * @memberof google.protobuf.FieldOptions.EditionDefault - * @static - * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") - * @returns {string} The default type url - */ - EditionDefault.getTypeUrl = function getTypeUrl(typeUrlPrefix) { - if (typeUrlPrefix === undefined) { - typeUrlPrefix = "type.googleapis.com"; - } - return typeUrlPrefix + "/google.protobuf.FieldOptions.EditionDefault"; - }; - - return EditionDefault; - })(); - return FieldOptions; })(); @@ -30275,7 +29192,6 @@ * Properties of an OneofOptions. * @memberof google.protobuf * @interface IOneofOptions - * @property {google.protobuf.IFeatureSet|null} [features] OneofOptions features * @property {Array.|null} [uninterpretedOption] OneofOptions uninterpretedOption */ @@ -30295,14 +29211,6 @@ this[keys[i]] = properties[keys[i]]; } - /** - * OneofOptions features. - * @member {google.protobuf.IFeatureSet|null|undefined} features - * @memberof google.protobuf.OneofOptions - * @instance - */ - OneofOptions.prototype.features = null; - /** * OneofOptions uninterpretedOption. * @member {Array.} uninterpretedOption @@ -30335,8 +29243,6 @@ OneofOptions.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.features != null && Object.hasOwnProperty.call(message, "features")) - $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -30374,10 +29280,6 @@ while (reader.pos < end) { var tag = reader.uint32(); switch (tag >>> 3) { - case 1: { - message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); - break; - } case 999: { if (!(message.uninterpretedOption && message.uninterpretedOption.length)) message.uninterpretedOption = []; @@ -30419,11 +29321,6 @@ OneofOptions.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.features != null && message.hasOwnProperty("features")) { - var error = $root.google.protobuf.FeatureSet.verify(message.features); - if (error) - return "features." + error; - } if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { if (!Array.isArray(message.uninterpretedOption)) return "uninterpretedOption: array expected"; @@ -30448,11 +29345,6 @@ if (object instanceof $root.google.protobuf.OneofOptions) return object; var message = new $root.google.protobuf.OneofOptions(); - if (object.features != null) { - if (typeof object.features !== "object") - throw TypeError(".google.protobuf.OneofOptions.features: object expected"); - message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); - } if (object.uninterpretedOption) { if (!Array.isArray(object.uninterpretedOption)) throw TypeError(".google.protobuf.OneofOptions.uninterpretedOption: array expected"); @@ -30481,10 +29373,6 @@ var object = {}; if (options.arrays || options.defaults) object.uninterpretedOption = []; - if (options.defaults) - object.features = null; - if (message.features != null && message.hasOwnProperty("features")) - object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -30531,7 +29419,6 @@ * @property {boolean|null} [allowAlias] EnumOptions allowAlias * @property {boolean|null} [deprecated] EnumOptions deprecated * @property {boolean|null} [deprecatedLegacyJsonFieldConflicts] EnumOptions deprecatedLegacyJsonFieldConflicts - * @property {google.protobuf.IFeatureSet|null} [features] EnumOptions features * @property {Array.|null} [uninterpretedOption] EnumOptions uninterpretedOption */ @@ -30575,14 +29462,6 @@ */ EnumOptions.prototype.deprecatedLegacyJsonFieldConflicts = false; - /** - * EnumOptions features. - * @member {google.protobuf.IFeatureSet|null|undefined} features - * @memberof google.protobuf.EnumOptions - * @instance - */ - EnumOptions.prototype.features = null; - /** * EnumOptions uninterpretedOption. * @member {Array.} uninterpretedOption @@ -30621,8 +29500,6 @@ writer.uint32(/* id 3, wireType 0 =*/24).bool(message.deprecated); if (message.deprecatedLegacyJsonFieldConflicts != null && Object.hasOwnProperty.call(message, "deprecatedLegacyJsonFieldConflicts")) writer.uint32(/* id 6, wireType 0 =*/48).bool(message.deprecatedLegacyJsonFieldConflicts); - if (message.features != null && Object.hasOwnProperty.call(message, "features")) - $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 7, wireType 2 =*/58).fork()).ldelim(); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -30672,10 +29549,6 @@ message.deprecatedLegacyJsonFieldConflicts = reader.bool(); break; } - case 7: { - message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); - break; - } case 999: { if (!(message.uninterpretedOption && message.uninterpretedOption.length)) message.uninterpretedOption = []; @@ -30726,11 +29599,6 @@ if (message.deprecatedLegacyJsonFieldConflicts != null && message.hasOwnProperty("deprecatedLegacyJsonFieldConflicts")) if (typeof message.deprecatedLegacyJsonFieldConflicts !== "boolean") return "deprecatedLegacyJsonFieldConflicts: boolean expected"; - if (message.features != null && message.hasOwnProperty("features")) { - var error = $root.google.protobuf.FeatureSet.verify(message.features); - if (error) - return "features." + error; - } if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { if (!Array.isArray(message.uninterpretedOption)) return "uninterpretedOption: array expected"; @@ -30761,11 +29629,6 @@ message.deprecated = Boolean(object.deprecated); if (object.deprecatedLegacyJsonFieldConflicts != null) message.deprecatedLegacyJsonFieldConflicts = Boolean(object.deprecatedLegacyJsonFieldConflicts); - if (object.features != null) { - if (typeof object.features !== "object") - throw TypeError(".google.protobuf.EnumOptions.features: object expected"); - message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); - } if (object.uninterpretedOption) { if (!Array.isArray(object.uninterpretedOption)) throw TypeError(".google.protobuf.EnumOptions.uninterpretedOption: array expected"); @@ -30798,7 +29661,6 @@ object.allowAlias = false; object.deprecated = false; object.deprecatedLegacyJsonFieldConflicts = false; - object.features = null; } if (message.allowAlias != null && message.hasOwnProperty("allowAlias")) object.allowAlias = message.allowAlias; @@ -30806,8 +29668,6 @@ object.deprecated = message.deprecated; if (message.deprecatedLegacyJsonFieldConflicts != null && message.hasOwnProperty("deprecatedLegacyJsonFieldConflicts")) object.deprecatedLegacyJsonFieldConflicts = message.deprecatedLegacyJsonFieldConflicts; - if (message.features != null && message.hasOwnProperty("features")) - object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -30852,8 +29712,6 @@ * @memberof google.protobuf * @interface IEnumValueOptions * @property {boolean|null} [deprecated] EnumValueOptions deprecated - * @property {google.protobuf.IFeatureSet|null} [features] EnumValueOptions features - * @property {boolean|null} [debugRedact] EnumValueOptions debugRedact * @property {Array.|null} [uninterpretedOption] EnumValueOptions uninterpretedOption */ @@ -30881,22 +29739,6 @@ */ EnumValueOptions.prototype.deprecated = false; - /** - * EnumValueOptions features. - * @member {google.protobuf.IFeatureSet|null|undefined} features - * @memberof google.protobuf.EnumValueOptions - * @instance - */ - EnumValueOptions.prototype.features = null; - - /** - * EnumValueOptions debugRedact. - * @member {boolean} debugRedact - * @memberof google.protobuf.EnumValueOptions - * @instance - */ - EnumValueOptions.prototype.debugRedact = false; - /** * EnumValueOptions uninterpretedOption. * @member {Array.} uninterpretedOption @@ -30931,10 +29773,6 @@ writer = $Writer.create(); if (message.deprecated != null && Object.hasOwnProperty.call(message, "deprecated")) writer.uint32(/* id 1, wireType 0 =*/8).bool(message.deprecated); - if (message.features != null && Object.hasOwnProperty.call(message, "features")) - $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); - if (message.debugRedact != null && Object.hasOwnProperty.call(message, "debugRedact")) - writer.uint32(/* id 3, wireType 0 =*/24).bool(message.debugRedact); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -30976,14 +29814,6 @@ message.deprecated = reader.bool(); break; } - case 2: { - message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); - break; - } - case 3: { - message.debugRedact = reader.bool(); - break; - } case 999: { if (!(message.uninterpretedOption && message.uninterpretedOption.length)) message.uninterpretedOption = []; @@ -31028,14 +29858,6 @@ if (message.deprecated != null && message.hasOwnProperty("deprecated")) if (typeof message.deprecated !== "boolean") return "deprecated: boolean expected"; - if (message.features != null && message.hasOwnProperty("features")) { - var error = $root.google.protobuf.FeatureSet.verify(message.features); - if (error) - return "features." + error; - } - if (message.debugRedact != null && message.hasOwnProperty("debugRedact")) - if (typeof message.debugRedact !== "boolean") - return "debugRedact: boolean expected"; if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { if (!Array.isArray(message.uninterpretedOption)) return "uninterpretedOption: array expected"; @@ -31062,13 +29884,6 @@ var message = new $root.google.protobuf.EnumValueOptions(); if (object.deprecated != null) message.deprecated = Boolean(object.deprecated); - if (object.features != null) { - if (typeof object.features !== "object") - throw TypeError(".google.protobuf.EnumValueOptions.features: object expected"); - message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); - } - if (object.debugRedact != null) - message.debugRedact = Boolean(object.debugRedact); if (object.uninterpretedOption) { if (!Array.isArray(object.uninterpretedOption)) throw TypeError(".google.protobuf.EnumValueOptions.uninterpretedOption: array expected"); @@ -31097,17 +29912,10 @@ var object = {}; if (options.arrays || options.defaults) object.uninterpretedOption = []; - if (options.defaults) { + if (options.defaults) object.deprecated = false; - object.features = null; - object.debugRedact = false; - } if (message.deprecated != null && message.hasOwnProperty("deprecated")) object.deprecated = message.deprecated; - if (message.features != null && message.hasOwnProperty("features")) - object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); - if (message.debugRedact != null && message.hasOwnProperty("debugRedact")) - object.debugRedact = message.debugRedact; if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -31151,7 +29959,6 @@ * Properties of a ServiceOptions. * @memberof google.protobuf * @interface IServiceOptions - * @property {google.protobuf.IFeatureSet|null} [features] ServiceOptions features * @property {boolean|null} [deprecated] ServiceOptions deprecated * @property {Array.|null} [uninterpretedOption] ServiceOptions uninterpretedOption * @property {string|null} [".google.api.defaultHost"] ServiceOptions .google.api.defaultHost @@ -31174,14 +29981,6 @@ this[keys[i]] = properties[keys[i]]; } - /** - * ServiceOptions features. - * @member {google.protobuf.IFeatureSet|null|undefined} features - * @memberof google.protobuf.ServiceOptions - * @instance - */ - ServiceOptions.prototype.features = null; - /** * ServiceOptions deprecated. * @member {boolean} deprecated @@ -31240,8 +30039,6 @@ writer = $Writer.create(); if (message.deprecated != null && Object.hasOwnProperty.call(message, "deprecated")) writer.uint32(/* id 33, wireType 0 =*/264).bool(message.deprecated); - if (message.features != null && Object.hasOwnProperty.call(message, "features")) - $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 34, wireType 2 =*/274).fork()).ldelim(); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -31283,10 +30080,6 @@ while (reader.pos < end) { var tag = reader.uint32(); switch (tag >>> 3) { - case 34: { - message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); - break; - } case 33: { message.deprecated = reader.bool(); break; @@ -31340,11 +30133,6 @@ ServiceOptions.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.features != null && message.hasOwnProperty("features")) { - var error = $root.google.protobuf.FeatureSet.verify(message.features); - if (error) - return "features." + error; - } if (message.deprecated != null && message.hasOwnProperty("deprecated")) if (typeof message.deprecated !== "boolean") return "deprecated: boolean expected"; @@ -31378,11 +30166,6 @@ if (object instanceof $root.google.protobuf.ServiceOptions) return object; var message = new $root.google.protobuf.ServiceOptions(); - if (object.features != null) { - if (typeof object.features !== "object") - throw TypeError(".google.protobuf.ServiceOptions.features: object expected"); - message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); - } if (object.deprecated != null) message.deprecated = Boolean(object.deprecated); if (object.uninterpretedOption) { @@ -31419,14 +30202,11 @@ object.uninterpretedOption = []; if (options.defaults) { object.deprecated = false; - object.features = null; object[".google.api.defaultHost"] = ""; object[".google.api.oauthScopes"] = ""; } if (message.deprecated != null && message.hasOwnProperty("deprecated")) object.deprecated = message.deprecated; - if (message.features != null && message.hasOwnProperty("features")) - object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -31476,7 +30256,6 @@ * @interface IMethodOptions * @property {boolean|null} [deprecated] MethodOptions deprecated * @property {google.protobuf.MethodOptions.IdempotencyLevel|null} [idempotencyLevel] MethodOptions idempotencyLevel - * @property {google.protobuf.IFeatureSet|null} [features] MethodOptions features * @property {Array.|null} [uninterpretedOption] MethodOptions uninterpretedOption * @property {google.api.IHttpRule|null} [".google.api.http"] MethodOptions .google.api.http * @property {Array.|null} [".google.api.methodSignature"] MethodOptions .google.api.methodSignature @@ -31516,14 +30295,6 @@ */ MethodOptions.prototype.idempotencyLevel = 0; - /** - * MethodOptions features. - * @member {google.protobuf.IFeatureSet|null|undefined} features - * @memberof google.protobuf.MethodOptions - * @instance - */ - MethodOptions.prototype.features = null; - /** * MethodOptions uninterpretedOption. * @member {Array.} uninterpretedOption @@ -31584,8 +30355,6 @@ writer.uint32(/* id 33, wireType 0 =*/264).bool(message.deprecated); if (message.idempotencyLevel != null && Object.hasOwnProperty.call(message, "idempotencyLevel")) writer.uint32(/* id 34, wireType 0 =*/272).int32(message.idempotencyLevel); - if (message.features != null && Object.hasOwnProperty.call(message, "features")) - $root.google.protobuf.FeatureSet.encode(message.features, writer.uint32(/* id 35, wireType 2 =*/282).fork()).ldelim(); if (message.uninterpretedOption != null && message.uninterpretedOption.length) for (var i = 0; i < message.uninterpretedOption.length; ++i) $root.google.protobuf.UninterpretedOption.encode(message.uninterpretedOption[i], writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); @@ -31638,10 +30407,6 @@ message.idempotencyLevel = reader.int32(); break; } - case 35: { - message.features = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); - break; - } case 999: { if (!(message.uninterpretedOption && message.uninterpretedOption.length)) message.uninterpretedOption = []; @@ -31709,11 +30474,6 @@ case 2: break; } - if (message.features != null && message.hasOwnProperty("features")) { - var error = $root.google.protobuf.FeatureSet.verify(message.features); - if (error) - return "features." + error; - } if (message.uninterpretedOption != null && message.hasOwnProperty("uninterpretedOption")) { if (!Array.isArray(message.uninterpretedOption)) return "uninterpretedOption: array expected"; @@ -31777,11 +30537,6 @@ message.idempotencyLevel = 2; break; } - if (object.features != null) { - if (typeof object.features !== "object") - throw TypeError(".google.protobuf.MethodOptions.features: object expected"); - message.features = $root.google.protobuf.FeatureSet.fromObject(object.features); - } if (object.uninterpretedOption) { if (!Array.isArray(object.uninterpretedOption)) throw TypeError(".google.protobuf.MethodOptions.uninterpretedOption: array expected"); @@ -31832,7 +30587,6 @@ if (options.defaults) { object.deprecated = false; object.idempotencyLevel = options.enums === String ? "IDEMPOTENCY_UNKNOWN" : 0; - object.features = null; object[".google.longrunning.operationInfo"] = null; object[".google.api.http"] = null; } @@ -31840,8 +30594,6 @@ object.deprecated = message.deprecated; if (message.idempotencyLevel != null && message.hasOwnProperty("idempotencyLevel")) object.idempotencyLevel = options.enums === String ? $root.google.protobuf.MethodOptions.IdempotencyLevel[message.idempotencyLevel] === undefined ? message.idempotencyLevel : $root.google.protobuf.MethodOptions.IdempotencyLevel[message.idempotencyLevel] : message.idempotencyLevel; - if (message.features != null && message.hasOwnProperty("features")) - object.features = $root.google.protobuf.FeatureSet.toObject(message.features, options); if (message.uninterpretedOption && message.uninterpretedOption.length) { object.uninterpretedOption = []; for (var j = 0; j < message.uninterpretedOption.length; ++j) @@ -32532,607 +31284,6 @@ return UninterpretedOption; })(); - protobuf.FeatureSet = (function() { - - /** - * Properties of a FeatureSet. - * @memberof google.protobuf - * @interface IFeatureSet - * @property {google.protobuf.FeatureSet.FieldPresence|null} [fieldPresence] FeatureSet fieldPresence - * @property {google.protobuf.FeatureSet.EnumType|null} [enumType] FeatureSet enumType - * @property {google.protobuf.FeatureSet.RepeatedFieldEncoding|null} [repeatedFieldEncoding] FeatureSet repeatedFieldEncoding - * @property {google.protobuf.FeatureSet.StringFieldValidation|null} [stringFieldValidation] FeatureSet stringFieldValidation - * @property {google.protobuf.FeatureSet.MessageEncoding|null} [messageEncoding] FeatureSet messageEncoding - * @property {google.protobuf.FeatureSet.JsonFormat|null} [jsonFormat] FeatureSet jsonFormat - * @property {google.protobuf.IFeatureSet|null} [rawFeatures] FeatureSet rawFeatures - */ - - /** - * Constructs a new FeatureSet. - * @memberof google.protobuf - * @classdesc Represents a FeatureSet. - * @implements IFeatureSet - * @constructor - * @param {google.protobuf.IFeatureSet=} [properties] Properties to set - */ - function FeatureSet(properties) { - if (properties) - for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) - if (properties[keys[i]] != null) - this[keys[i]] = properties[keys[i]]; - } - - /** - * FeatureSet fieldPresence. - * @member {google.protobuf.FeatureSet.FieldPresence} fieldPresence - * @memberof google.protobuf.FeatureSet - * @instance - */ - FeatureSet.prototype.fieldPresence = 0; - - /** - * FeatureSet enumType. - * @member {google.protobuf.FeatureSet.EnumType} enumType - * @memberof google.protobuf.FeatureSet - * @instance - */ - FeatureSet.prototype.enumType = 0; - - /** - * FeatureSet repeatedFieldEncoding. - * @member {google.protobuf.FeatureSet.RepeatedFieldEncoding} repeatedFieldEncoding - * @memberof google.protobuf.FeatureSet - * @instance - */ - FeatureSet.prototype.repeatedFieldEncoding = 0; - - /** - * FeatureSet stringFieldValidation. - * @member {google.protobuf.FeatureSet.StringFieldValidation} stringFieldValidation - * @memberof google.protobuf.FeatureSet - * @instance - */ - FeatureSet.prototype.stringFieldValidation = 0; - - /** - * FeatureSet messageEncoding. - * @member {google.protobuf.FeatureSet.MessageEncoding} messageEncoding - * @memberof google.protobuf.FeatureSet - * @instance - */ - FeatureSet.prototype.messageEncoding = 0; - - /** - * FeatureSet jsonFormat. - * @member {google.protobuf.FeatureSet.JsonFormat} jsonFormat - * @memberof google.protobuf.FeatureSet - * @instance - */ - FeatureSet.prototype.jsonFormat = 0; - - /** - * FeatureSet rawFeatures. - * @member {google.protobuf.IFeatureSet|null|undefined} rawFeatures - * @memberof google.protobuf.FeatureSet - * @instance - */ - FeatureSet.prototype.rawFeatures = null; - - /** - * Creates a new FeatureSet instance using the specified properties. - * @function create - * @memberof google.protobuf.FeatureSet - * @static - * @param {google.protobuf.IFeatureSet=} [properties] Properties to set - * @returns {google.protobuf.FeatureSet} FeatureSet instance - */ - FeatureSet.create = function create(properties) { - return new FeatureSet(properties); - }; - - /** - * Encodes the specified FeatureSet message. Does not implicitly {@link google.protobuf.FeatureSet.verify|verify} messages. - * @function encode - * @memberof google.protobuf.FeatureSet - * @static - * @param {google.protobuf.IFeatureSet} message FeatureSet message or plain object to encode - * @param {$protobuf.Writer} [writer] Writer to encode to - * @returns {$protobuf.Writer} Writer - */ - FeatureSet.encode = function encode(message, writer) { - if (!writer) - writer = $Writer.create(); - if (message.fieldPresence != null && Object.hasOwnProperty.call(message, "fieldPresence")) - writer.uint32(/* id 1, wireType 0 =*/8).int32(message.fieldPresence); - if (message.enumType != null && Object.hasOwnProperty.call(message, "enumType")) - writer.uint32(/* id 2, wireType 0 =*/16).int32(message.enumType); - if (message.repeatedFieldEncoding != null && Object.hasOwnProperty.call(message, "repeatedFieldEncoding")) - writer.uint32(/* id 3, wireType 0 =*/24).int32(message.repeatedFieldEncoding); - if (message.stringFieldValidation != null && Object.hasOwnProperty.call(message, "stringFieldValidation")) - writer.uint32(/* id 4, wireType 0 =*/32).int32(message.stringFieldValidation); - if (message.messageEncoding != null && Object.hasOwnProperty.call(message, "messageEncoding")) - writer.uint32(/* id 5, wireType 0 =*/40).int32(message.messageEncoding); - if (message.jsonFormat != null && Object.hasOwnProperty.call(message, "jsonFormat")) - writer.uint32(/* id 6, wireType 0 =*/48).int32(message.jsonFormat); - if (message.rawFeatures != null && Object.hasOwnProperty.call(message, "rawFeatures")) - $root.google.protobuf.FeatureSet.encode(message.rawFeatures, writer.uint32(/* id 999, wireType 2 =*/7994).fork()).ldelim(); - return writer; - }; - - /** - * Encodes the specified FeatureSet message, length delimited. Does not implicitly {@link google.protobuf.FeatureSet.verify|verify} messages. - * @function encodeDelimited - * @memberof google.protobuf.FeatureSet - * @static - * @param {google.protobuf.IFeatureSet} message FeatureSet message or plain object to encode - * @param {$protobuf.Writer} [writer] Writer to encode to - * @returns {$protobuf.Writer} Writer - */ - FeatureSet.encodeDelimited = function encodeDelimited(message, writer) { - return this.encode(message, writer).ldelim(); - }; - - /** - * Decodes a FeatureSet message from the specified reader or buffer. - * @function decode - * @memberof google.protobuf.FeatureSet - * @static - * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from - * @param {number} [length] Message length if known beforehand - * @returns {google.protobuf.FeatureSet} FeatureSet - * @throws {Error} If the payload is not a reader or valid buffer - * @throws {$protobuf.util.ProtocolError} If required fields are missing - */ - FeatureSet.decode = function decode(reader, length) { - if (!(reader instanceof $Reader)) - reader = $Reader.create(reader); - var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.FeatureSet(); - while (reader.pos < end) { - var tag = reader.uint32(); - switch (tag >>> 3) { - case 1: { - message.fieldPresence = reader.int32(); - break; - } - case 2: { - message.enumType = reader.int32(); - break; - } - case 3: { - message.repeatedFieldEncoding = reader.int32(); - break; - } - case 4: { - message.stringFieldValidation = reader.int32(); - break; - } - case 5: { - message.messageEncoding = reader.int32(); - break; - } - case 6: { - message.jsonFormat = reader.int32(); - break; - } - case 999: { - message.rawFeatures = $root.google.protobuf.FeatureSet.decode(reader, reader.uint32()); - break; - } - default: - reader.skipType(tag & 7); - break; - } - } - return message; - }; - - /** - * Decodes a FeatureSet message from the specified reader or buffer, length delimited. - * @function decodeDelimited - * @memberof google.protobuf.FeatureSet - * @static - * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from - * @returns {google.protobuf.FeatureSet} FeatureSet - * @throws {Error} If the payload is not a reader or valid buffer - * @throws {$protobuf.util.ProtocolError} If required fields are missing - */ - FeatureSet.decodeDelimited = function decodeDelimited(reader) { - if (!(reader instanceof $Reader)) - reader = new $Reader(reader); - return this.decode(reader, reader.uint32()); - }; - - /** - * Verifies a FeatureSet message. - * @function verify - * @memberof google.protobuf.FeatureSet - * @static - * @param {Object.} message Plain object to verify - * @returns {string|null} `null` if valid, otherwise the reason why it is not - */ - FeatureSet.verify = function verify(message) { - if (typeof message !== "object" || message === null) - return "object expected"; - if (message.fieldPresence != null && message.hasOwnProperty("fieldPresence")) - switch (message.fieldPresence) { - default: - return "fieldPresence: enum value expected"; - case 0: - case 1: - case 2: - case 3: - break; - } - if (message.enumType != null && message.hasOwnProperty("enumType")) - switch (message.enumType) { - default: - return "enumType: enum value expected"; - case 0: - case 1: - case 2: - break; - } - if (message.repeatedFieldEncoding != null && message.hasOwnProperty("repeatedFieldEncoding")) - switch (message.repeatedFieldEncoding) { - default: - return "repeatedFieldEncoding: enum value expected"; - case 0: - case 1: - case 2: - break; - } - if (message.stringFieldValidation != null && message.hasOwnProperty("stringFieldValidation")) - switch (message.stringFieldValidation) { - default: - return "stringFieldValidation: enum value expected"; - case 0: - case 1: - case 2: - case 3: - break; - } - if (message.messageEncoding != null && message.hasOwnProperty("messageEncoding")) - switch (message.messageEncoding) { - default: - return "messageEncoding: enum value expected"; - case 0: - case 1: - case 2: - break; - } - if (message.jsonFormat != null && message.hasOwnProperty("jsonFormat")) - switch (message.jsonFormat) { - default: - return "jsonFormat: enum value expected"; - case 0: - case 1: - case 2: - break; - } - if (message.rawFeatures != null && message.hasOwnProperty("rawFeatures")) { - var error = $root.google.protobuf.FeatureSet.verify(message.rawFeatures); - if (error) - return "rawFeatures." + error; - } - return null; - }; - - /** - * Creates a FeatureSet message from a plain object. Also converts values to their respective internal types. - * @function fromObject - * @memberof google.protobuf.FeatureSet - * @static - * @param {Object.} object Plain object - * @returns {google.protobuf.FeatureSet} FeatureSet - */ - FeatureSet.fromObject = function fromObject(object) { - if (object instanceof $root.google.protobuf.FeatureSet) - return object; - var message = new $root.google.protobuf.FeatureSet(); - switch (object.fieldPresence) { - default: - if (typeof object.fieldPresence === "number") { - message.fieldPresence = object.fieldPresence; - break; - } - break; - case "FIELD_PRESENCE_UNKNOWN": - case 0: - message.fieldPresence = 0; - break; - case "EXPLICIT": - case 1: - message.fieldPresence = 1; - break; - case "IMPLICIT": - case 2: - message.fieldPresence = 2; - break; - case "LEGACY_REQUIRED": - case 3: - message.fieldPresence = 3; - break; - } - switch (object.enumType) { - default: - if (typeof object.enumType === "number") { - message.enumType = object.enumType; - break; - } - break; - case "ENUM_TYPE_UNKNOWN": - case 0: - message.enumType = 0; - break; - case "OPEN": - case 1: - message.enumType = 1; - break; - case "CLOSED": - case 2: - message.enumType = 2; - break; - } - switch (object.repeatedFieldEncoding) { - default: - if (typeof object.repeatedFieldEncoding === "number") { - message.repeatedFieldEncoding = object.repeatedFieldEncoding; - break; - } - break; - case "REPEATED_FIELD_ENCODING_UNKNOWN": - case 0: - message.repeatedFieldEncoding = 0; - break; - case "PACKED": - case 1: - message.repeatedFieldEncoding = 1; - break; - case "EXPANDED": - case 2: - message.repeatedFieldEncoding = 2; - break; - } - switch (object.stringFieldValidation) { - default: - if (typeof object.stringFieldValidation === "number") { - message.stringFieldValidation = object.stringFieldValidation; - break; - } - break; - case "STRING_FIELD_VALIDATION_UNKNOWN": - case 0: - message.stringFieldValidation = 0; - break; - case "MANDATORY": - case 1: - message.stringFieldValidation = 1; - break; - case "HINT": - case 2: - message.stringFieldValidation = 2; - break; - case "NONE": - case 3: - message.stringFieldValidation = 3; - break; - } - switch (object.messageEncoding) { - default: - if (typeof object.messageEncoding === "number") { - message.messageEncoding = object.messageEncoding; - break; - } - break; - case "MESSAGE_ENCODING_UNKNOWN": - case 0: - message.messageEncoding = 0; - break; - case "LENGTH_PREFIXED": - case 1: - message.messageEncoding = 1; - break; - case "DELIMITED": - case 2: - message.messageEncoding = 2; - break; - } - switch (object.jsonFormat) { - default: - if (typeof object.jsonFormat === "number") { - message.jsonFormat = object.jsonFormat; - break; - } - break; - case "JSON_FORMAT_UNKNOWN": - case 0: - message.jsonFormat = 0; - break; - case "ALLOW": - case 1: - message.jsonFormat = 1; - break; - case "LEGACY_BEST_EFFORT": - case 2: - message.jsonFormat = 2; - break; - } - if (object.rawFeatures != null) { - if (typeof object.rawFeatures !== "object") - throw TypeError(".google.protobuf.FeatureSet.rawFeatures: object expected"); - message.rawFeatures = $root.google.protobuf.FeatureSet.fromObject(object.rawFeatures); - } - return message; - }; - - /** - * Creates a plain object from a FeatureSet message. Also converts values to other types if specified. - * @function toObject - * @memberof google.protobuf.FeatureSet - * @static - * @param {google.protobuf.FeatureSet} message FeatureSet - * @param {$protobuf.IConversionOptions} [options] Conversion options - * @returns {Object.} Plain object - */ - FeatureSet.toObject = function toObject(message, options) { - if (!options) - options = {}; - var object = {}; - if (options.defaults) { - object.fieldPresence = options.enums === String ? "FIELD_PRESENCE_UNKNOWN" : 0; - object.enumType = options.enums === String ? "ENUM_TYPE_UNKNOWN" : 0; - object.repeatedFieldEncoding = options.enums === String ? "REPEATED_FIELD_ENCODING_UNKNOWN" : 0; - object.stringFieldValidation = options.enums === String ? "STRING_FIELD_VALIDATION_UNKNOWN" : 0; - object.messageEncoding = options.enums === String ? "MESSAGE_ENCODING_UNKNOWN" : 0; - object.jsonFormat = options.enums === String ? "JSON_FORMAT_UNKNOWN" : 0; - object.rawFeatures = null; - } - if (message.fieldPresence != null && message.hasOwnProperty("fieldPresence")) - object.fieldPresence = options.enums === String ? $root.google.protobuf.FeatureSet.FieldPresence[message.fieldPresence] === undefined ? message.fieldPresence : $root.google.protobuf.FeatureSet.FieldPresence[message.fieldPresence] : message.fieldPresence; - if (message.enumType != null && message.hasOwnProperty("enumType")) - object.enumType = options.enums === String ? $root.google.protobuf.FeatureSet.EnumType[message.enumType] === undefined ? message.enumType : $root.google.protobuf.FeatureSet.EnumType[message.enumType] : message.enumType; - if (message.repeatedFieldEncoding != null && message.hasOwnProperty("repeatedFieldEncoding")) - object.repeatedFieldEncoding = options.enums === String ? $root.google.protobuf.FeatureSet.RepeatedFieldEncoding[message.repeatedFieldEncoding] === undefined ? message.repeatedFieldEncoding : $root.google.protobuf.FeatureSet.RepeatedFieldEncoding[message.repeatedFieldEncoding] : message.repeatedFieldEncoding; - if (message.stringFieldValidation != null && message.hasOwnProperty("stringFieldValidation")) - object.stringFieldValidation = options.enums === String ? $root.google.protobuf.FeatureSet.StringFieldValidation[message.stringFieldValidation] === undefined ? message.stringFieldValidation : $root.google.protobuf.FeatureSet.StringFieldValidation[message.stringFieldValidation] : message.stringFieldValidation; - if (message.messageEncoding != null && message.hasOwnProperty("messageEncoding")) - object.messageEncoding = options.enums === String ? $root.google.protobuf.FeatureSet.MessageEncoding[message.messageEncoding] === undefined ? message.messageEncoding : $root.google.protobuf.FeatureSet.MessageEncoding[message.messageEncoding] : message.messageEncoding; - if (message.jsonFormat != null && message.hasOwnProperty("jsonFormat")) - object.jsonFormat = options.enums === String ? $root.google.protobuf.FeatureSet.JsonFormat[message.jsonFormat] === undefined ? message.jsonFormat : $root.google.protobuf.FeatureSet.JsonFormat[message.jsonFormat] : message.jsonFormat; - if (message.rawFeatures != null && message.hasOwnProperty("rawFeatures")) - object.rawFeatures = $root.google.protobuf.FeatureSet.toObject(message.rawFeatures, options); - return object; - }; - - /** - * Converts this FeatureSet to JSON. - * @function toJSON - * @memberof google.protobuf.FeatureSet - * @instance - * @returns {Object.} JSON object - */ - FeatureSet.prototype.toJSON = function toJSON() { - return this.constructor.toObject(this, $protobuf.util.toJSONOptions); - }; - - /** - * Gets the default type url for FeatureSet - * @function getTypeUrl - * @memberof google.protobuf.FeatureSet - * @static - * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") - * @returns {string} The default type url - */ - FeatureSet.getTypeUrl = function getTypeUrl(typeUrlPrefix) { - if (typeUrlPrefix === undefined) { - typeUrlPrefix = "type.googleapis.com"; - } - return typeUrlPrefix + "/google.protobuf.FeatureSet"; - }; - - /** - * FieldPresence enum. - * @name google.protobuf.FeatureSet.FieldPresence - * @enum {number} - * @property {number} FIELD_PRESENCE_UNKNOWN=0 FIELD_PRESENCE_UNKNOWN value - * @property {number} EXPLICIT=1 EXPLICIT value - * @property {number} IMPLICIT=2 IMPLICIT value - * @property {number} LEGACY_REQUIRED=3 LEGACY_REQUIRED value - */ - FeatureSet.FieldPresence = (function() { - var valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "FIELD_PRESENCE_UNKNOWN"] = 0; - values[valuesById[1] = "EXPLICIT"] = 1; - values[valuesById[2] = "IMPLICIT"] = 2; - values[valuesById[3] = "LEGACY_REQUIRED"] = 3; - return values; - })(); - - /** - * EnumType enum. - * @name google.protobuf.FeatureSet.EnumType - * @enum {number} - * @property {number} ENUM_TYPE_UNKNOWN=0 ENUM_TYPE_UNKNOWN value - * @property {number} OPEN=1 OPEN value - * @property {number} CLOSED=2 CLOSED value - */ - FeatureSet.EnumType = (function() { - var valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "ENUM_TYPE_UNKNOWN"] = 0; - values[valuesById[1] = "OPEN"] = 1; - values[valuesById[2] = "CLOSED"] = 2; - return values; - })(); - - /** - * RepeatedFieldEncoding enum. - * @name google.protobuf.FeatureSet.RepeatedFieldEncoding - * @enum {number} - * @property {number} REPEATED_FIELD_ENCODING_UNKNOWN=0 REPEATED_FIELD_ENCODING_UNKNOWN value - * @property {number} PACKED=1 PACKED value - * @property {number} EXPANDED=2 EXPANDED value - */ - FeatureSet.RepeatedFieldEncoding = (function() { - var valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "REPEATED_FIELD_ENCODING_UNKNOWN"] = 0; - values[valuesById[1] = "PACKED"] = 1; - values[valuesById[2] = "EXPANDED"] = 2; - return values; - })(); - - /** - * StringFieldValidation enum. - * @name google.protobuf.FeatureSet.StringFieldValidation - * @enum {number} - * @property {number} STRING_FIELD_VALIDATION_UNKNOWN=0 STRING_FIELD_VALIDATION_UNKNOWN value - * @property {number} MANDATORY=1 MANDATORY value - * @property {number} HINT=2 HINT value - * @property {number} NONE=3 NONE value - */ - FeatureSet.StringFieldValidation = (function() { - var valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "STRING_FIELD_VALIDATION_UNKNOWN"] = 0; - values[valuesById[1] = "MANDATORY"] = 1; - values[valuesById[2] = "HINT"] = 2; - values[valuesById[3] = "NONE"] = 3; - return values; - })(); - - /** - * MessageEncoding enum. - * @name google.protobuf.FeatureSet.MessageEncoding - * @enum {number} - * @property {number} MESSAGE_ENCODING_UNKNOWN=0 MESSAGE_ENCODING_UNKNOWN value - * @property {number} LENGTH_PREFIXED=1 LENGTH_PREFIXED value - * @property {number} DELIMITED=2 DELIMITED value - */ - FeatureSet.MessageEncoding = (function() { - var valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "MESSAGE_ENCODING_UNKNOWN"] = 0; - values[valuesById[1] = "LENGTH_PREFIXED"] = 1; - values[valuesById[2] = "DELIMITED"] = 2; - return values; - })(); - - /** - * JsonFormat enum. - * @name google.protobuf.FeatureSet.JsonFormat - * @enum {number} - * @property {number} JSON_FORMAT_UNKNOWN=0 JSON_FORMAT_UNKNOWN value - * @property {number} ALLOW=1 ALLOW value - * @property {number} LEGACY_BEST_EFFORT=2 LEGACY_BEST_EFFORT value - */ - FeatureSet.JsonFormat = (function() { - var valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "JSON_FORMAT_UNKNOWN"] = 0; - values[valuesById[1] = "ALLOW"] = 1; - values[valuesById[2] = "LEGACY_BEST_EFFORT"] = 2; - return values; - })(); - - return FeatureSet; - })(); - protobuf.SourceCodeInfo = (function() { /** diff --git a/packages/google-cloud-edgenetwork/protos/protos.json b/packages/google-cloud-edgenetwork/protos/protos.json index 5030ec6454a3..70d6a8d7c9ad 100644 --- a/packages/google-cloud-edgenetwork/protos/protos.json +++ b/packages/google-cloud-edgenetwork/protos/protos.json @@ -2392,10 +2392,6 @@ "rule": "repeated", "type": "ClientLibrarySettings", "id": 109 - }, - "protoReferenceDocumentationUri": { - "type": "string", - "id": 110 } } }, @@ -2453,31 +2449,6 @@ "common": { "type": "CommonLanguageSettings", "id": 1 - }, - "renamedServices": { - "keyType": "string", - "type": "string", - "id": 2 - }, - "renamedResources": { - "keyType": "string", - "type": "string", - "id": 3 - }, - "ignoredResources": { - "rule": "repeated", - "type": "string", - "id": 4 - }, - "forcedNamespaceAliases": { - "rule": "repeated", - "type": "string", - "id": 5 - }, - "handwrittenSignatures": { - "rule": "repeated", - "type": "string", - "id": 6 } } }, @@ -2537,10 +2508,7 @@ "CLOUD": 1, "ADS": 2, "PHOTOS": 3, - "STREET_VIEW": 4, - "SHOPPING": 5, - "GEO": 6, - "GENERATIVE_AI": 7 + "STREET_VIEW": 4 } }, "ClientLibraryDestination": { @@ -2741,25 +2709,6 @@ "rule": "repeated", "type": "UninterpretedOption", "id": 999 - }, - "declaration": { - "rule": "repeated", - "type": "Declaration", - "id": 2, - "options": { - "retention": "RETENTION_SOURCE" - } - }, - "features": { - "type": "FeatureSet", - "id": 50 - }, - "verification": { - "type": "VerificationState", - "id": 3, - "options": { - "default": "UNVERIFIED" - } } }, "extensions": [ @@ -2767,45 +2716,7 @@ 1000, 536870911 ] - ], - "nested": { - "Declaration": { - "fields": { - "number": { - "type": "int32", - "id": 1 - }, - "fullName": { - "type": "string", - "id": 2 - }, - "type": { - "type": "string", - "id": 3 - }, - "reserved": { - "type": "bool", - "id": 5 - }, - "repeated": { - "type": "bool", - "id": 6 - } - }, - "reserved": [ - [ - 4, - 4 - ] - ] - }, - "VerificationState": { - "values": { - "DECLARATION": 0, - "UNVERIFIED": 1 - } - } - } + ] }, "FieldDescriptorProto": { "fields": { @@ -3118,10 +3029,6 @@ "type": "string", "id": 45 }, - "features": { - "type": "FeatureSet", - "id": 50 - }, "uninterpretedOption": { "rule": "repeated", "type": "UninterpretedOption", @@ -3184,10 +3091,6 @@ "deprecated": true } }, - "features": { - "type": "FeatureSet", - "id": 12 - }, "uninterpretedOption": { "rule": "repeated", "type": "UninterpretedOption", @@ -3282,22 +3185,9 @@ "type": "OptionRetention", "id": 17 }, - "targets": { - "rule": "repeated", + "target": { "type": "OptionTargetType", - "id": 19, - "options": { - "packed": false - } - }, - "editionDefaults": { - "rule": "repeated", - "type": "EditionDefault", - "id": 20 - }, - "features": { - "type": "FeatureSet", - "id": 21 + "id": 18 }, "uninterpretedOption": { "rule": "repeated", @@ -3315,10 +3205,6 @@ [ 4, 4 - ], - [ - 18, - 18 ] ], "nested": { @@ -3356,27 +3242,11 @@ "TARGET_TYPE_SERVICE": 8, "TARGET_TYPE_METHOD": 9 } - }, - "EditionDefault": { - "fields": { - "edition": { - "type": "string", - "id": 1 - }, - "value": { - "type": "string", - "id": 2 - } - } } } }, "OneofOptions": { "fields": { - "features": { - "type": "FeatureSet", - "id": 1 - }, "uninterpretedOption": { "rule": "repeated", "type": "UninterpretedOption", @@ -3410,10 +3280,6 @@ "deprecated": true } }, - "features": { - "type": "FeatureSet", - "id": 7 - }, "uninterpretedOption": { "rule": "repeated", "type": "UninterpretedOption", @@ -3442,17 +3308,6 @@ "default": false } }, - "features": { - "type": "FeatureSet", - "id": 2 - }, - "debugRedact": { - "type": "bool", - "id": 3, - "options": { - "default": false - } - }, "uninterpretedOption": { "rule": "repeated", "type": "UninterpretedOption", @@ -3468,10 +3323,6 @@ }, "ServiceOptions": { "fields": { - "features": { - "type": "FeatureSet", - "id": 34 - }, "deprecated": { "type": "bool", "id": 33, @@ -3508,10 +3359,6 @@ "default": "IDEMPOTENCY_UNKNOWN" } }, - "features": { - "type": "FeatureSet", - "id": 35 - }, "uninterpretedOption": { "rule": "repeated", "type": "UninterpretedOption", @@ -3583,137 +3430,6 @@ } } }, - "FeatureSet": { - "fields": { - "fieldPresence": { - "type": "FieldPresence", - "id": 1, - "options": { - "retention": "RETENTION_RUNTIME", - "targets": "TARGET_TYPE_FILE", - "edition_defaults.edition": "2023", - "edition_defaults.value": "EXPLICIT" - } - }, - "enumType": { - "type": "EnumType", - "id": 2, - "options": { - "retention": "RETENTION_RUNTIME", - "targets": "TARGET_TYPE_FILE", - "edition_defaults.edition": "2023", - "edition_defaults.value": "OPEN" - } - }, - "repeatedFieldEncoding": { - "type": "RepeatedFieldEncoding", - "id": 3, - "options": { - "retention": "RETENTION_RUNTIME", - "targets": "TARGET_TYPE_FILE", - "edition_defaults.edition": "2023", - "edition_defaults.value": "PACKED" - } - }, - "stringFieldValidation": { - "type": "StringFieldValidation", - "id": 4, - "options": { - "retention": "RETENTION_RUNTIME", - "targets": "TARGET_TYPE_FILE", - "edition_defaults.edition": "2023", - "edition_defaults.value": "MANDATORY" - } - }, - "messageEncoding": { - "type": "MessageEncoding", - "id": 5, - "options": { - "retention": "RETENTION_RUNTIME", - "targets": "TARGET_TYPE_FILE", - "edition_defaults.edition": "2023", - "edition_defaults.value": "LENGTH_PREFIXED" - } - }, - "jsonFormat": { - "type": "JsonFormat", - "id": 6, - "options": { - "retention": "RETENTION_RUNTIME", - "targets": "TARGET_TYPE_FILE", - "edition_defaults.edition": "2023", - "edition_defaults.value": "ALLOW" - } - }, - "rawFeatures": { - "type": "FeatureSet", - "id": 999, - "options": { - "targets": "TARGET_TYPE_UNKNOWN" - } - } - }, - "extensions": [ - [ - 1000, - 1000 - ], - [ - 1001, - 1001 - ], - [ - 9995, - 9999 - ] - ], - "nested": { - "FieldPresence": { - "values": { - "FIELD_PRESENCE_UNKNOWN": 0, - "EXPLICIT": 1, - "IMPLICIT": 2, - "LEGACY_REQUIRED": 3 - } - }, - "EnumType": { - "values": { - "ENUM_TYPE_UNKNOWN": 0, - "OPEN": 1, - "CLOSED": 2 - } - }, - "RepeatedFieldEncoding": { - "values": { - "REPEATED_FIELD_ENCODING_UNKNOWN": 0, - "PACKED": 1, - "EXPANDED": 2 - } - }, - "StringFieldValidation": { - "values": { - "STRING_FIELD_VALIDATION_UNKNOWN": 0, - "MANDATORY": 1, - "HINT": 2, - "NONE": 3 - } - }, - "MessageEncoding": { - "values": { - "MESSAGE_ENCODING_UNKNOWN": 0, - "LENGTH_PREFIXED": 1, - "DELIMITED": 2 - } - }, - "JsonFormat": { - "values": { - "JSON_FORMAT_UNKNOWN": 0, - "ALLOW": 1, - "LEGACY_BEST_EFFORT": 2 - } - } - } - }, "SourceCodeInfo": { "fields": { "location": { @@ -3851,7 +3567,7 @@ "options": { "cc_enable_arenas": true, "csharp_namespace": "Google.LongRunning", - "go_package": "cloud.google.com/go/longrunning/autogen/longrunningpb;longrunningpb", + "go_package": "google.golang.org/genproto/googleapis/longrunning;longrunning", "java_multiple_files": true, "java_outer_classname": "OperationsProto", "java_package": "com.google.longrunning",