chore: Update discovery artifacts (#1195)

* chore(accesscontextmanager): update the api
* chore(adexchangebuyer2): update the api
* chore(admin): update the api
* chore(alertcenter): update the api
* chore(analyticsadmin): update the api
* chore(analyticsdata): update the api
* chore(androidmanagement): update the api
* chore(apigateway): update the api
* chore(apigee): update the api
* chore(appengine): update the api
* chore(area120tables): update the api
* chore(artifactregistry): update the api
* chore(bigquery): update the api
* chore(bigqueryconnection): update the api
* chore(bigqueryreservation): update the api
* chore(billingbudgets): update the api
* chore(binaryauthorization): update the api
* chore(blogger): update the api
* chore(calendar): update the api
* chore(chat): update the api
* chore(cloudasset): update the api
* chore(cloudbuild): update the api
* chore(cloudfunctions): update the api
* chore(cloudidentity): update the api
* chore(cloudkms): update the api
* chore(cloudresourcemanager): update the api
* chore(cloudscheduler): update the api
* chore(cloudtasks): update the api
* chore(composer): update the api
* chore(compute): update the api
* chore(container): update the api
* chore(containeranalysis): update the api
* chore(content): update the api
* chore(datacatalog): update the api
* chore(dataflow): update the api
* chore(datafusion): update the api
* chore(datamigration): update the api
* chore(dataproc): update the api
* chore(deploymentmanager): update the api
* chore(dialogflow): update the api
* chore(displayvideo): update the api
* chore(dlp): update the api
* chore(dns): update the api
* chore(documentai): update the api
* chore(eventarc): update the api
* chore(file): update the api
* chore(firebaseml): update the api
* chore(games): update the api
* chore(gameservices): update the api
* chore(genomics): update the api
* chore(healthcare): update the api
* chore(homegraph): update the api
* chore(iam): update the api
* chore(iap): update the api
* chore(jobs): update the api
* chore(lifesciences): update the api
* chore(localservices): update the api
* chore(managedidentities): update the api
* chore(manufacturers): update the api
* chore(memcache): update the api
* chore(ml): update the api
* chore(monitoring): update the api
* chore(notebooks): update the api
* chore(osconfig): update the api
* chore(pagespeedonline): update the api
* chore(people): update the api
* chore(privateca): update the api
* chore(prod_tt_sasportal): update the api
* chore(pubsub): update the api
* chore(pubsublite): update the api
* chore(recommender): update the api
* chore(remotebuildexecution): update the api
* chore(reseller): update the api
* chore(run): update the api
* chore(safebrowsing): update the api
* chore(sasportal): update the api
* chore(searchconsole): update the api
* chore(secretmanager): update the api
* chore(securitycenter): update the api
* chore(serviceconsumermanagement): update the api
* chore(servicecontrol): update the api
* chore(servicenetworking): update the api
* chore(serviceusage): update the api
* chore(sheets): update the api
* chore(slides): update the api
* chore(spanner): update the api
* chore(speech): update the api
* chore(sqladmin): update the api
* chore(storage): update the api
* chore(storagetransfer): update the api
* chore(sts): update the api
* chore(tagmanager): update the api
* chore(testing): update the api
* chore(toolresults): update the api
* chore(transcoder): update the api
* chore(vectortile): update the api
* chore(videointelligence): update the api
* chore(vision): update the api
* chore(webmasters): update the api
* chore(workflowexecutions): update the api
* chore(youtube): update the api
diff --git a/googleapiclient/discovery_cache/documents/prod_tt_sasportal.v1alpha1.json b/googleapiclient/discovery_cache/documents/prod_tt_sasportal.v1alpha1.json
index 3a392f9..0fadeac 100644
--- a/googleapiclient/discovery_cache/documents/prod_tt_sasportal.v1alpha1.json
+++ b/googleapiclient/discovery_cache/documents/prod_tt_sasportal.v1alpha1.json
@@ -1,2907 +1,3349 @@
 {
-  "schemas": {
-    "SasPortalEmpty": {
-      "id": "SasPortalEmpty",
-      "properties": {},
-      "type": "object",
-      "description": "A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); } The JSON representation for `Empty` is empty JSON object `{}`."
-    },
-    "SasPortalOperation": {
-      "properties": {
-        "name": {
-          "description": "The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`.",
-          "type": "string"
-        },
-        "done": {
-          "type": "boolean",
-          "description": "If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available."
-        },
-        "response": {
-          "additionalProperties": {
-            "type": "any",
-            "description": "Properties of the object. Contains field @type with type URL."
-          },
-          "description": "The normal response of the operation in case of success. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.",
-          "type": "object"
-        },
-        "metadata": {
-          "type": "object",
-          "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any.",
-          "additionalProperties": {
-            "type": "any",
-            "description": "Properties of the object. Contains field @type with type URL."
-          }
-        },
-        "error": {
-          "description": "The error result of the operation in case of failure or cancellation.",
-          "$ref": "SasPortalStatus"
+    "auth": {
+        "oauth2": {
+            "scopes": {
+                "https://www.googleapis.com/auth/userinfo.email": {
+                    "description": "View your email address"
+                }
+            }
         }
-      },
-      "type": "object",
-      "description": "This resource represents a long-running operation that is the result of a network API call.",
-      "id": "SasPortalOperation"
     },
-    "SasPortalTestPermissionsResponse": {
-      "description": "Response message for `TestPermissions` method.",
-      "type": "object",
-      "id": "SasPortalTestPermissionsResponse",
-      "properties": {
-        "permissions": {
-          "type": "array",
-          "items": {
-            "type": "string"
-          },
-          "description": "A set of permissions that the caller is allowed."
-        }
-      }
+    "basePath": "",
+    "baseUrl": "https://prod-tt-sasportal.googleapis.com/",
+    "batchPath": "batch",
+    "canonicalName": "SAS Portal Testing",
+    "description": "",
+    "discoveryVersion": "v1",
+    "documentationLink": "https://developers.google.com/spectrum-access-system/",
+    "fullyEncodeReservedExpansion": true,
+    "icons": {
+        "x16": "http://www.google.com/images/icons/product/search-16.gif",
+        "x32": "http://www.google.com/images/icons/product/search-32.gif"
     },
-    "SasPortalBulkCreateDeviceResponse": {
-      "type": "object",
-      "id": "SasPortalBulkCreateDeviceResponse",
-      "properties": {
-        "devices": {
-          "items": {
-            "$ref": "SasPortalDevice"
-          },
-          "description": "Required. The devices that were imported.",
-          "type": "array"
-        }
-      },
-      "description": "Response for BulkCreateDevice method."
-    },
-    "SasPortalBulkCreateDeviceRequest": {
-      "type": "object",
-      "description": "Request for BulkCreateDevice method.",
-      "id": "SasPortalBulkCreateDeviceRequest",
-      "properties": {
-        "csv": {
-          "description": "Required. A csv with each row representing a [device]. Each row must conform to the regulations described on CreateDeviceRequest's device field.",
-          "type": "string"
-        }
-      }
-    },
-    "SasPortalUpdateSignedDeviceRequest": {
-      "properties": {
-        "encodedDevice": {
-          "type": "string",
-          "format": "byte",
-          "description": "Required. The JSON Web Token signed using a CPI private key. Payload must be the JSON encoding of the device. The user_id field must be set."
-        },
-        "installerId": {
-          "type": "string",
-          "description": "Required. Unique installer ID (CPI ID) from the Certified Professional Installers database."
-        }
-      },
-      "type": "object",
-      "description": "Request for UpdateSignedDevice method.",
-      "id": "SasPortalUpdateSignedDeviceRequest"
-    },
-    "SasPortalListNodesResponse": {
-      "id": "SasPortalListNodesResponse",
-      "properties": {
-        "nodes": {
-          "type": "array",
-          "description": "The nodes that match the request.",
-          "items": {
-            "$ref": "SasPortalNode"
-          }
-        },
-        "nextPageToken": {
-          "description": "A pagination token returned from a previous call to ListNodes method that indicates from where listing should continue. If the field is missing or empty, it means there is no more nodes.",
-          "type": "string"
-        }
-      },
-      "description": "Response for ListNodes method.",
-      "type": "object"
-    },
-    "SasPortalTestPermissionsRequest": {
-      "properties": {
-        "resource": {
-          "description": "Required. The resource for which the permissions are being requested.",
-          "type": "string"
-        },
-        "permissions": {
-          "description": "The set of permissions to check for the `resource`.",
-          "type": "array",
-          "items": {
-            "type": "string"
-          }
-        }
-      },
-      "description": "Request message for `TestPermissions` method.",
-      "type": "object",
-      "id": "SasPortalTestPermissionsRequest"
-    },
-    "SasPortalDevice": {
-      "type": "object",
-      "properties": {
-        "activeConfig": {
-          "description": "Output only. Current configuration of the device as registered to the SAS.",
-          "$ref": "SasPortalDeviceConfig"
-        },
-        "grants": {
-          "items": {
-            "$ref": "SasPortalDeviceGrant"
-          },
-          "description": "Output only. Grants held by the device.",
-          "type": "array"
-        },
-        "name": {
-          "description": "Output only. The resource path name.",
-          "type": "string"
-        },
-        "displayName": {
-          "description": "Device display name.",
-          "type": "string"
-        },
-        "serialNumber": {
-          "description": "A serial number assigned to the device by the device manufacturer.",
-          "type": "string"
-        },
-        "preloadedConfig": {
-          "description": "Configuration of the device, as specified via SAS Portal API.",
-          "$ref": "SasPortalDeviceConfig"
-        },
-        "deviceMetadata": {
-          "$ref": "SasPortalDeviceMetadata",
-          "description": "Device parameters that can be overridden by both SAS Portal and SAS registration requests."
-        },
-        "fccId": {
-          "description": "The FCC identifier of the device.",
-          "type": "string"
-        },
-        "state": {
-          "enumDescriptions": [
-            "Unspecified state.",
-            "Device created in the SAS Portal, however, not yet registered with SAS.",
-            "Device registered with SAS.",
-            "Device de-registered with SAS."
-          ],
-          "enum": [
-            "DEVICE_STATE_UNSPECIFIED",
-            "RESERVED",
-            "REGISTERED",
-            "DEREGISTERED"
-          ],
-          "type": "string",
-          "description": "Output only. Device state."
-        }
-      },
-      "id": "SasPortalDevice"
-    },
-    "SasPortalMoveDeploymentRequest": {
-      "type": "object",
-      "description": "Request for MoveDeployment method.",
-      "id": "SasPortalMoveDeploymentRequest",
-      "properties": {
-        "destination": {
-          "type": "string",
-          "description": "Required. The name of the new parent resource Node or Customer to reparent the deployment under."
-        }
-      }
-    },
-    "SasPortalDeviceAirInterface": {
-      "description": "Information about the device's air interface.",
-      "properties": {
-        "supportedSpec": {
-          "type": "string",
-          "description": "This field is related to the radioTechnology field and provides the air interface specification that the CBSD is compliant with at the time of registration. Optional"
-        },
-        "radioTechnology": {
-          "type": "string",
-          "enumDescriptions": [
-            "",
-            "",
-            "",
-            "",
-            "",
-            "",
-            "",
-            "",
-            ""
-          ],
-          "description": "This field specifies the radio access technology that is used for the CBSD. Conditional",
-          "enum": [
-            "RADIO_TECHNOLOGY_UNSPECIFIED",
-            "E_UTRA",
-            "CAMBIUM_NETWORKS",
-            "FOUR_G_BBW_SAA_1",
-            "NR",
-            "DOODLE_CBRS",
-            "CW",
-            "REDLINE",
-            "TARANA_WIRELESS"
-          ]
-        }
-      },
-      "id": "SasPortalDeviceAirInterface",
-      "type": "object"
-    },
-    "SasPortalNode": {
-      "id": "SasPortalNode",
-      "type": "object",
-      "properties": {
-        "displayName": {
-          "type": "string",
-          "description": "The node's display name."
-        },
-        "name": {
-          "type": "string",
-          "description": "Output only. Resource name."
-        },
-        "sasUserIds": {
-          "items": {
-            "type": "string"
-          },
-          "description": "User ids used by the devices belonging to this node.",
-          "type": "array"
-        }
-      },
-      "description": "The Node."
-    },
-    "SasPortalDeviceConfig": {
-      "properties": {
-        "state": {
-          "enumDescriptions": [
-            "",
-            "",
-            ""
-          ],
-          "type": "string",
-          "description": "State of the configuration.",
-          "enum": [
-            "DEVICE_CONFIG_STATE_UNSPECIFIED",
-            "DRAFT",
-            "FINAL"
-          ]
-        },
-        "callSign": {
-          "description": "The call sign of the device operator.",
-          "type": "string"
-        },
-        "measurementCapabilities": {
-          "description": "Measurement reporting capabilities of the device.",
-          "items": {
+    "id": "prod_tt_sasportal:v1alpha1",
+    "kind": "discovery#restDescription",
+    "mtlsRootUrl": "https://prod-tt-sasportal.mtls.googleapis.com/",
+    "name": "prod_tt_sasportal",
+    "ownerDomain": "google.com",
+    "ownerName": "Google",
+    "parameters": {
+        "$.xgafv": {
+            "description": "V1 error format.",
             "enum": [
-              "MEASUREMENT_CAPABILITY_UNSPECIFIED",
-              "MEASUREMENT_CAPABILITY_RECEIVED_POWER_WITH_GRANT",
-              "MEASUREMENT_CAPABILITY_RECEIVED_POWER_WITHOUT_GRANT"
+                "1",
+                "2"
             ],
-            "type": "string",
             "enumDescriptions": [
-              "",
-              "",
-              ""
-            ]
-          },
-          "type": "array"
-        },
-        "isSigned": {
-          "type": "boolean",
-          "description": "Output-only. Whether the configuration has been signed by a CPI."
-        },
-        "userId": {
-          "type": "string",
-          "description": "The identifier of a device user."
-        },
-        "category": {
-          "enum": [
-            "DEVICE_CATEGORY_UNSPECIFIED",
-            "DEVICE_CATEGORY_A",
-            "DEVICE_CATEGORY_B"
-          ],
-          "enumDescriptions": [
-            "Unspecified device category.",
-            "Category A.",
-            "Category B."
-          ],
-          "description": "FCC category of the device.",
-          "type": "string"
-        },
-        "updateTime": {
-          "format": "google-datetime",
-          "description": "Output-only. The last time the device configuration was edited.",
-          "type": "string"
-        },
-        "model": {
-          "description": "Information about this device model.",
-          "$ref": "SasPortalDeviceModel"
-        },
-        "installationParams": {
-          "$ref": "SasPortalInstallationParams",
-          "description": "Installation parameters for the device."
-        },
-        "airInterface": {
-          "description": "Information about this device's air interface.",
-          "$ref": "SasPortalDeviceAirInterface"
-        }
-      },
-      "type": "object",
-      "description": "Information about the device configuration.",
-      "id": "SasPortalDeviceConfig"
-    },
-    "SasPortalDeviceGrant": {
-      "id": "SasPortalDeviceGrant",
-      "description": "Device grant. It is an authorization provided by the Spectrum Access System to a device to transmit using specified operating parameters after a successful heartbeat by the device.",
-      "type": "object",
-      "properties": {
-        "moveList": {
-          "type": "array",
-          "description": "The DPA move lists on which this grant appears.",
-          "items": {
-            "$ref": "SasPortalDpaMoveList"
-          }
-        },
-        "channelType": {
-          "type": "string",
-          "enumDescriptions": [
-            "",
-            "",
-            ""
-          ],
-          "description": "Type of channel used.",
-          "enum": [
-            "CHANNEL_TYPE_UNSPECIFIED",
-            "CHANNEL_TYPE_GAA",
-            "CHANNEL_TYPE_PAL"
-          ]
-        },
-        "frequencyRange": {
-          "description": "The transmission frequency range.",
-          "$ref": "SasPortalFrequencyRange"
-        },
-        "suspensionReason": {
-          "items": {
+                "v1 error format",
+                "v2 error format"
+            ],
+            "location": "query",
             "type": "string"
-          },
-          "type": "array",
-          "description": "If the grant is suspended, the reason(s) for suspension."
         },
-        "expireTime": {
-          "description": "The expiration time of the grant.",
-          "format": "google-datetime",
-          "type": "string"
-        },
-        "grantId": {
-          "description": "Grant Id.",
-          "type": "string"
-        },
-        "state": {
-          "enum": [
-            "GRANT_STATE_UNSPECIFIED",
-            "GRANT_STATE_GRANTED",
-            "GRANT_STATE_TERMINATED",
-            "GRANT_STATE_SUSPENDED",
-            "GRANT_STATE_AUTHORIZED",
-            "GRANT_STATE_EXPIRED"
-          ],
-          "enumDescriptions": [
-            "",
-            "The grant has been granted but the device is not heartbeating on it.",
-            "The grant has been terminated by the SAS.",
-            "The grant has been suspended by the SAS.",
-            "The device is currently transmitting.",
-            "The grant has expired."
-          ],
-          "description": "State of the grant.",
-          "type": "string"
-        },
-        "maxEirp": {
-          "type": "number",
-          "format": "double",
-          "description": "Maximum Equivalent Isotropically Radiated Power (EIRP) permitted by the grant. The maximum EIRP is in units of dBm/MHz. The value of maxEirp represents the average (RMS) EIRP that would be measured by the procedure defined in FCC part 96.41(e)(3)."
-        }
-      }
-    },
-    "SasPortalGenerateSecretRequest": {
-      "id": "SasPortalGenerateSecretRequest",
-      "properties": {},
-      "type": "object",
-      "description": "Request for GenerateSecret method] [spectrum.sas.portal.v1alpha1.DeviceManager.GenerateSecret]."
-    },
-    "SasPortalSetPolicyRequest": {
-      "type": "object",
-      "description": "Request message for `SetPolicy` method.",
-      "properties": {
-        "policy": {
-          "$ref": "SasPortalPolicy",
-          "description": "Required. The policy to be applied to the `resource`."
-        },
-        "resource": {
-          "description": "Required. The resource for which the policy is being specified. This policy replaces any existing policy.",
-          "type": "string"
-        }
-      },
-      "id": "SasPortalSetPolicyRequest"
-    },
-    "SasPortalCustomer": {
-      "type": "object",
-      "description": "Entity representing a SAS customer.",
-      "properties": {
-        "sasUserIds": {
-          "items": {
+        "access_token": {
+            "description": "OAuth access token.",
+            "location": "query",
             "type": "string"
-          },
-          "type": "array",
-          "description": "User IDs used by the devices belonging to this customer."
         },
-        "name": {
-          "type": "string",
-          "description": "Output only. Resource name of the customer."
+        "alt": {
+            "default": "json",
+            "description": "Data format for response.",
+            "enum": [
+                "json",
+                "media",
+                "proto"
+            ],
+            "enumDescriptions": [
+                "Responses with Content-Type of application/json",
+                "Media download with context-dependent Content-Type",
+                "Responses with Content-Type of application/x-protobuf"
+            ],
+            "location": "query",
+            "type": "string"
         },
-        "displayName": {
-          "type": "string",
-          "description": "Required. Name of the organization that the customer entity represents."
-        }
-      },
-      "id": "SasPortalCustomer"
-    },
-    "SasPortalValidateInstallerRequest": {
-      "id": "SasPortalValidateInstallerRequest",
-      "properties": {
-        "installerId": {
-          "description": "Required. Unique installer id (cpiId) from the Certified Professional Installers database.",
-          "type": "string"
+        "callback": {
+            "description": "JSONP",
+            "location": "query",
+            "type": "string"
         },
-        "secret": {
-          "description": "Required. Secret returned by the GenerateSecret method.",
-          "type": "string"
+        "fields": {
+            "description": "Selector specifying which fields to include in a partial response.",
+            "location": "query",
+            "type": "string"
         },
-        "encodedSecret": {
-          "type": "string",
-          "description": "Required. JSON Web Token signed using a CPI private key. Payload must include a \"secret\" claim whose value is the secret."
-        }
-      },
-      "type": "object",
-      "description": "Request for ValidateInstaller method."
-    },
-    "SasPortalSignDeviceRequest": {
-      "type": "object",
-      "id": "SasPortalSignDeviceRequest",
-      "properties": {
-        "device": {
-          "description": "Required. The device to sign. The device fields name, fcc_id and serial_number must be set. The user_id field must be set.",
-          "$ref": "SasPortalDevice"
-        }
-      },
-      "description": "Request for SignDevice method."
-    },
-    "SasPortalFrequencyRange": {
-      "id": "SasPortalFrequencyRange",
-      "type": "object",
-      "description": "Frequency range from `low_frequency` to `high_frequency`.",
-      "properties": {
-        "highFrequencyMhz": {
-          "type": "number",
-          "format": "double",
-          "description": "The highest frequency of the frequency range in MHz."
+        "key": {
+            "description": "API key. Your API key identifies your project and provides you with API access, quota, and reports. Required unless you provide an OAuth 2.0 token.",
+            "location": "query",
+            "type": "string"
         },
-        "lowFrequencyMhz": {
-          "format": "double",
-          "description": "The lowest frequency of the frequency range in MHz.",
-          "type": "number"
-        }
-      }
-    },
-    "SasPortalMoveDeviceRequest": {
-      "type": "object",
-      "description": "Request for MoveDevice method.",
-      "properties": {
-        "destination": {
-          "type": "string",
-          "description": "Required. The name of the new parent resource (Node or Customer) to reparent the device under."
-        }
-      },
-      "id": "SasPortalMoveDeviceRequest"
-    },
-    "SasPortalDpaMoveList": {
-      "description": "An entry in a DPA's move list.",
-      "type": "object",
-      "properties": {
-        "frequencyRange": {
-          "description": "The frequency range that the move list affects.",
-          "$ref": "SasPortalFrequencyRange"
+        "oauth_token": {
+            "description": "OAuth 2.0 token for the current user.",
+            "location": "query",
+            "type": "string"
         },
-        "dpaId": {
-          "description": "The ID of the DPA.",
-          "type": "string"
+        "prettyPrint": {
+            "default": "true",
+            "description": "Returns response with indentations and line breaks.",
+            "location": "query",
+            "type": "boolean"
+        },
+        "quotaUser": {
+            "description": "Available to use for quota purposes for server-side applications. Can be any arbitrary string assigned to a user, but should not exceed 40 characters.",
+            "location": "query",
+            "type": "string"
+        },
+        "uploadType": {
+            "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\").",
+            "location": "query",
+            "type": "string"
+        },
+        "upload_protocol": {
+            "description": "Upload protocol for media (e.g. \"raw\", \"multipart\").",
+            "location": "query",
+            "type": "string"
         }
-      },
-      "id": "SasPortalDpaMoveList"
     },
-    "SasPortalValidateInstallerResponse": {
-      "type": "object",
-      "id": "SasPortalValidateInstallerResponse",
-      "description": "Response for ValidateInstaller method] [spectrum.sas.portal.v1alpha1.DeviceManager.ValidateInstaller].",
-      "properties": {}
-    },
-    "SasPortalGenerateSecretResponse": {
-      "type": "object",
-      "description": "Response for GenerateSecret method.",
-      "properties": {
-        "secret": {
-          "description": "The secret generated by the string and used by [ValidateInstaller] method.",
-          "type": "string"
-        }
-      },
-      "id": "SasPortalGenerateSecretResponse"
-    },
-    "SasPortalListCustomersResponse": {
-      "type": "object",
-      "properties": {
+    "protocol": "rest",
+    "resources": {
         "customers": {
-          "items": {
-            "$ref": "SasPortalCustomer"
-          },
-          "description": "The list of customers that match the request.",
-          "type": "array"
+            "methods": {
+                "get": {
+                    "description": "Returns a requested customer.",
+                    "flatPath": "v1alpha1/customers/{customersId}",
+                    "httpMethod": "GET",
+                    "id": "prod_tt_sasportal.customers.get",
+                    "parameterOrder": [
+                        "name"
+                    ],
+                    "parameters": {
+                        "name": {
+                            "description": "Required. The name of the customer.",
+                            "location": "path",
+                            "pattern": "^customers/[^/]+$",
+                            "required": true,
+                            "type": "string"
+                        }
+                    },
+                    "path": "v1alpha1/{+name}",
+                    "response": {
+                        "$ref": "SasPortalCustomer"
+                    },
+                    "scopes": [
+                        "https://www.googleapis.com/auth/userinfo.email"
+                    ]
+                },
+                "list": {
+                    "description": "Returns a list of requested customers.",
+                    "flatPath": "v1alpha1/customers",
+                    "httpMethod": "GET",
+                    "id": "prod_tt_sasportal.customers.list",
+                    "parameterOrder": [],
+                    "parameters": {
+                        "pageSize": {
+                            "description": "The maximum number of customers to return in the response.",
+                            "format": "int32",
+                            "location": "query",
+                            "type": "integer"
+                        },
+                        "pageToken": {
+                            "description": "A pagination token returned from a previous call to ListCustomers that indicates where this listing should continue from.",
+                            "location": "query",
+                            "type": "string"
+                        }
+                    },
+                    "path": "v1alpha1/customers",
+                    "response": {
+                        "$ref": "SasPortalListCustomersResponse"
+                    },
+                    "scopes": [
+                        "https://www.googleapis.com/auth/userinfo.email"
+                    ]
+                },
+                "patch": {
+                    "description": "Updates an existing customer.",
+                    "flatPath": "v1alpha1/customers/{customersId}",
+                    "httpMethod": "PATCH",
+                    "id": "prod_tt_sasportal.customers.patch",
+                    "parameterOrder": [
+                        "name"
+                    ],
+                    "parameters": {
+                        "name": {
+                            "description": "Output only. Resource name of the customer.",
+                            "location": "path",
+                            "pattern": "^customers/[^/]+$",
+                            "required": true,
+                            "type": "string"
+                        },
+                        "updateMask": {
+                            "description": "Fields to be updated.",
+                            "format": "google-fieldmask",
+                            "location": "query",
+                            "type": "string"
+                        }
+                    },
+                    "path": "v1alpha1/{+name}",
+                    "request": {
+                        "$ref": "SasPortalCustomer"
+                    },
+                    "response": {
+                        "$ref": "SasPortalCustomer"
+                    },
+                    "scopes": [
+                        "https://www.googleapis.com/auth/userinfo.email"
+                    ]
+                }
+            },
+            "resources": {
+                "deployments": {
+                    "methods": {
+                        "create": {
+                            "description": "Creates a new deployment.",
+                            "flatPath": "v1alpha1/customers/{customersId}/deployments",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.customers.deployments.create",
+                            "parameterOrder": [
+                                "parent"
+                            ],
+                            "parameters": {
+                                "parent": {
+                                    "description": "Required. The parent resource name where the deployment is to be created.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+parent}/deployments",
+                            "request": {
+                                "$ref": "SasPortalDeployment"
+                            },
+                            "response": {
+                                "$ref": "SasPortalDeployment"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "delete": {
+                            "description": "Deletes a deployment.",
+                            "flatPath": "v1alpha1/customers/{customersId}/deployments/{deploymentsId}",
+                            "httpMethod": "DELETE",
+                            "id": "prod_tt_sasportal.customers.deployments.delete",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the deployment.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+/deployments/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "response": {
+                                "$ref": "SasPortalEmpty"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "get": {
+                            "description": "Returns a requested deployment.",
+                            "flatPath": "v1alpha1/customers/{customersId}/deployments/{deploymentsId}",
+                            "httpMethod": "GET",
+                            "id": "prod_tt_sasportal.customers.deployments.get",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the deployment.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+/deployments/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "response": {
+                                "$ref": "SasPortalDeployment"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "list": {
+                            "description": "Lists deployments.",
+                            "flatPath": "v1alpha1/customers/{customersId}/deployments",
+                            "httpMethod": "GET",
+                            "id": "prod_tt_sasportal.customers.deployments.list",
+                            "parameterOrder": [
+                                "parent"
+                            ],
+                            "parameters": {
+                                "filter": {
+                                    "description": "The filter expression. The filter should have the following format: \"DIRECT_CHILDREN\" or format: \"direct_children\". The filter is case insensitive. If empty, then no deployments are filtered.",
+                                    "location": "query",
+                                    "type": "string"
+                                },
+                                "pageSize": {
+                                    "description": "The maximum number of deployments to return in the response.",
+                                    "format": "int32",
+                                    "location": "query",
+                                    "type": "integer"
+                                },
+                                "pageToken": {
+                                    "description": "A pagination token returned from a previous call to ListDeployments that indicates where this listing should continue from.",
+                                    "location": "query",
+                                    "type": "string"
+                                },
+                                "parent": {
+                                    "description": "Required. The parent resource name, for example, \"nodes/1\", customer/1/nodes/2.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+parent}/deployments",
+                            "response": {
+                                "$ref": "SasPortalListDeploymentsResponse"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "move": {
+                            "description": "Moves a deployment under another node or customer.",
+                            "flatPath": "v1alpha1/customers/{customersId}/deployments/{deploymentsId}:move",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.customers.deployments.move",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the deployment to move.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+/deployments/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}:move",
+                            "request": {
+                                "$ref": "SasPortalMoveDeploymentRequest"
+                            },
+                            "response": {
+                                "$ref": "SasPortalOperation"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "patch": {
+                            "description": "Updates an existing deployment.",
+                            "flatPath": "v1alpha1/customers/{customersId}/deployments/{deploymentsId}",
+                            "httpMethod": "PATCH",
+                            "id": "prod_tt_sasportal.customers.deployments.patch",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Output only. Resource name.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+/deployments/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                },
+                                "updateMask": {
+                                    "description": "Fields to be updated.",
+                                    "format": "google-fieldmask",
+                                    "location": "query",
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "request": {
+                                "$ref": "SasPortalDeployment"
+                            },
+                            "response": {
+                                "$ref": "SasPortalDeployment"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        }
+                    },
+                    "resources": {
+                        "devices": {
+                            "methods": {
+                                "create": {
+                                    "description": "Creates a device under a node or customer.",
+                                    "flatPath": "v1alpha1/customers/{customersId}/deployments/{deploymentsId}/devices",
+                                    "httpMethod": "POST",
+                                    "id": "prod_tt_sasportal.customers.deployments.devices.create",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "parent": {
+                                            "description": "Required. The name of the parent resource.",
+                                            "location": "path",
+                                            "pattern": "^customers/[^/]+/deployments/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/devices",
+                                    "request": {
+                                        "$ref": "SasPortalDevice"
+                                    },
+                                    "response": {
+                                        "$ref": "SasPortalDevice"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                },
+                                "createSigned": {
+                                    "description": "Creates a signed device under a node or customer.",
+                                    "flatPath": "v1alpha1/customers/{customersId}/deployments/{deploymentsId}/devices:createSigned",
+                                    "httpMethod": "POST",
+                                    "id": "prod_tt_sasportal.customers.deployments.devices.createSigned",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "parent": {
+                                            "description": "Required. The name of the parent resource.",
+                                            "location": "path",
+                                            "pattern": "^customers/[^/]+/deployments/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/devices:createSigned",
+                                    "request": {
+                                        "$ref": "SasPortalCreateSignedDeviceRequest"
+                                    },
+                                    "response": {
+                                        "$ref": "SasPortalDevice"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                },
+                                "list": {
+                                    "description": "Lists devices under a node or customer.",
+                                    "flatPath": "v1alpha1/customers/{customersId}/deployments/{deploymentsId}/devices",
+                                    "httpMethod": "GET",
+                                    "id": "prod_tt_sasportal.customers.deployments.devices.list",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "filter": {
+                                            "description": "The filter expression. The filter should have one of the following formats: \"sn=123454\" or \"display_name=MyDevice\". sn corresponds to serial number of the device. The filter is case insensitive.",
+                                            "location": "query",
+                                            "type": "string"
+                                        },
+                                        "pageSize": {
+                                            "description": "The maximum number of devices to return in the response. If empty or zero, all devices will be listed. Must be in the range [0, 1000].",
+                                            "format": "int32",
+                                            "location": "query",
+                                            "type": "integer"
+                                        },
+                                        "pageToken": {
+                                            "description": "A pagination token returned from a previous call to ListDevices that indicates where this listing should continue from.",
+                                            "location": "query",
+                                            "type": "string"
+                                        },
+                                        "parent": {
+                                            "description": "Required. The name of the parent resource.",
+                                            "location": "path",
+                                            "pattern": "^customers/[^/]+/deployments/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/devices",
+                                    "response": {
+                                        "$ref": "SasPortalListDevicesResponse"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                }
+                            }
+                        }
+                    }
+                },
+                "devices": {
+                    "methods": {
+                        "create": {
+                            "description": "Creates a device under a node or customer.",
+                            "flatPath": "v1alpha1/customers/{customersId}/devices",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.customers.devices.create",
+                            "parameterOrder": [
+                                "parent"
+                            ],
+                            "parameters": {
+                                "parent": {
+                                    "description": "Required. The name of the parent resource.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+parent}/devices",
+                            "request": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "response": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "createSigned": {
+                            "description": "Creates a signed device under a node or customer.",
+                            "flatPath": "v1alpha1/customers/{customersId}/devices:createSigned",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.customers.devices.createSigned",
+                            "parameterOrder": [
+                                "parent"
+                            ],
+                            "parameters": {
+                                "parent": {
+                                    "description": "Required. The name of the parent resource.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+parent}/devices:createSigned",
+                            "request": {
+                                "$ref": "SasPortalCreateSignedDeviceRequest"
+                            },
+                            "response": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "delete": {
+                            "description": "Deletes a device.",
+                            "flatPath": "v1alpha1/customers/{customersId}/devices/{devicesId}",
+                            "httpMethod": "DELETE",
+                            "id": "prod_tt_sasportal.customers.devices.delete",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the device.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "response": {
+                                "$ref": "SasPortalEmpty"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "get": {
+                            "description": "Gets details about a device.",
+                            "flatPath": "v1alpha1/customers/{customersId}/devices/{devicesId}",
+                            "httpMethod": "GET",
+                            "id": "prod_tt_sasportal.customers.devices.get",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the device.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "response": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "list": {
+                            "description": "Lists devices under a node or customer.",
+                            "flatPath": "v1alpha1/customers/{customersId}/devices",
+                            "httpMethod": "GET",
+                            "id": "prod_tt_sasportal.customers.devices.list",
+                            "parameterOrder": [
+                                "parent"
+                            ],
+                            "parameters": {
+                                "filter": {
+                                    "description": "The filter expression. The filter should have one of the following formats: \"sn=123454\" or \"display_name=MyDevice\". sn corresponds to serial number of the device. The filter is case insensitive.",
+                                    "location": "query",
+                                    "type": "string"
+                                },
+                                "pageSize": {
+                                    "description": "The maximum number of devices to return in the response. If empty or zero, all devices will be listed. Must be in the range [0, 1000].",
+                                    "format": "int32",
+                                    "location": "query",
+                                    "type": "integer"
+                                },
+                                "pageToken": {
+                                    "description": "A pagination token returned from a previous call to ListDevices that indicates where this listing should continue from.",
+                                    "location": "query",
+                                    "type": "string"
+                                },
+                                "parent": {
+                                    "description": "Required. The name of the parent resource.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+parent}/devices",
+                            "response": {
+                                "$ref": "SasPortalListDevicesResponse"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "move": {
+                            "description": "Moves a device under another node or customer.",
+                            "flatPath": "v1alpha1/customers/{customersId}/devices/{devicesId}:move",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.customers.devices.move",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the device to move.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}:move",
+                            "request": {
+                                "$ref": "SasPortalMoveDeviceRequest"
+                            },
+                            "response": {
+                                "$ref": "SasPortalOperation"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "patch": {
+                            "description": "Updates a device.",
+                            "flatPath": "v1alpha1/customers/{customersId}/devices/{devicesId}",
+                            "httpMethod": "PATCH",
+                            "id": "prod_tt_sasportal.customers.devices.patch",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Output only. The resource path name.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                },
+                                "updateMask": {
+                                    "description": "Fields to be updated.",
+                                    "format": "google-fieldmask",
+                                    "location": "query",
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "request": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "response": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "signDevice": {
+                            "description": "Signs a device.",
+                            "flatPath": "v1alpha1/customers/{customersId}/devices/{devicesId}:signDevice",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.customers.devices.signDevice",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Output only. The resource path name.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}:signDevice",
+                            "request": {
+                                "$ref": "SasPortalSignDeviceRequest"
+                            },
+                            "response": {
+                                "$ref": "SasPortalEmpty"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "updateSigned": {
+                            "description": "Updates a signed device.",
+                            "flatPath": "v1alpha1/customers/{customersId}/devices/{devicesId}:updateSigned",
+                            "httpMethod": "PATCH",
+                            "id": "prod_tt_sasportal.customers.devices.updateSigned",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the device to update.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}:updateSigned",
+                            "request": {
+                                "$ref": "SasPortalUpdateSignedDeviceRequest"
+                            },
+                            "response": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        }
+                    }
+                },
+                "nodes": {
+                    "methods": {
+                        "create": {
+                            "description": "Creates a new node.",
+                            "flatPath": "v1alpha1/customers/{customersId}/nodes",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.customers.nodes.create",
+                            "parameterOrder": [
+                                "parent"
+                            ],
+                            "parameters": {
+                                "parent": {
+                                    "description": "Required. The parent resource name where the node is to be created.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+parent}/nodes",
+                            "request": {
+                                "$ref": "SasPortalNode"
+                            },
+                            "response": {
+                                "$ref": "SasPortalNode"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "delete": {
+                            "description": "Deletes a node.",
+                            "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}",
+                            "httpMethod": "DELETE",
+                            "id": "prod_tt_sasportal.customers.nodes.delete",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the node.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+/nodes/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "response": {
+                                "$ref": "SasPortalEmpty"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "get": {
+                            "description": "Returns a requested node.",
+                            "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}",
+                            "httpMethod": "GET",
+                            "id": "prod_tt_sasportal.customers.nodes.get",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the node.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+/nodes/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "response": {
+                                "$ref": "SasPortalNode"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "list": {
+                            "description": "Lists nodes.",
+                            "flatPath": "v1alpha1/customers/{customersId}/nodes",
+                            "httpMethod": "GET",
+                            "id": "prod_tt_sasportal.customers.nodes.list",
+                            "parameterOrder": [
+                                "parent"
+                            ],
+                            "parameters": {
+                                "filter": {
+                                    "description": "The filter expression. The filter should have the following format: \"DIRECT_CHILDREN\" or format: \"direct_children\". The filter is case insensitive. If empty, then no nodes are filtered.",
+                                    "location": "query",
+                                    "type": "string"
+                                },
+                                "pageSize": {
+                                    "description": "The maximum number of nodes to return in the response.",
+                                    "format": "int32",
+                                    "location": "query",
+                                    "type": "integer"
+                                },
+                                "pageToken": {
+                                    "description": "A pagination token returned from a previous call to ListNodes that indicates where this listing should continue from.",
+                                    "location": "query",
+                                    "type": "string"
+                                },
+                                "parent": {
+                                    "description": "Required. The parent resource name, for example, \"nodes/1\".",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+parent}/nodes",
+                            "response": {
+                                "$ref": "SasPortalListNodesResponse"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "move": {
+                            "description": "Moves a node under another node or customer.",
+                            "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}:move",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.customers.nodes.move",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the node to move.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+/nodes/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}:move",
+                            "request": {
+                                "$ref": "SasPortalMoveNodeRequest"
+                            },
+                            "response": {
+                                "$ref": "SasPortalOperation"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "patch": {
+                            "description": "Updates an existing node.",
+                            "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}",
+                            "httpMethod": "PATCH",
+                            "id": "prod_tt_sasportal.customers.nodes.patch",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Output only. Resource name.",
+                                    "location": "path",
+                                    "pattern": "^customers/[^/]+/nodes/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                },
+                                "updateMask": {
+                                    "description": "Fields to be updated.",
+                                    "format": "google-fieldmask",
+                                    "location": "query",
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "request": {
+                                "$ref": "SasPortalNode"
+                            },
+                            "response": {
+                                "$ref": "SasPortalNode"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        }
+                    },
+                    "resources": {
+                        "deployments": {
+                            "methods": {
+                                "create": {
+                                    "description": "Creates a new deployment.",
+                                    "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}/deployments",
+                                    "httpMethod": "POST",
+                                    "id": "prod_tt_sasportal.customers.nodes.deployments.create",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "parent": {
+                                            "description": "Required. The parent resource name where the deployment is to be created.",
+                                            "location": "path",
+                                            "pattern": "^customers/[^/]+/nodes/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/deployments",
+                                    "request": {
+                                        "$ref": "SasPortalDeployment"
+                                    },
+                                    "response": {
+                                        "$ref": "SasPortalDeployment"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                },
+                                "list": {
+                                    "description": "Lists deployments.",
+                                    "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}/deployments",
+                                    "httpMethod": "GET",
+                                    "id": "prod_tt_sasportal.customers.nodes.deployments.list",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "filter": {
+                                            "description": "The filter expression. The filter should have the following format: \"DIRECT_CHILDREN\" or format: \"direct_children\". The filter is case insensitive. If empty, then no deployments are filtered.",
+                                            "location": "query",
+                                            "type": "string"
+                                        },
+                                        "pageSize": {
+                                            "description": "The maximum number of deployments to return in the response.",
+                                            "format": "int32",
+                                            "location": "query",
+                                            "type": "integer"
+                                        },
+                                        "pageToken": {
+                                            "description": "A pagination token returned from a previous call to ListDeployments that indicates where this listing should continue from.",
+                                            "location": "query",
+                                            "type": "string"
+                                        },
+                                        "parent": {
+                                            "description": "Required. The parent resource name, for example, \"nodes/1\", customer/1/nodes/2.",
+                                            "location": "path",
+                                            "pattern": "^customers/[^/]+/nodes/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/deployments",
+                                    "response": {
+                                        "$ref": "SasPortalListDeploymentsResponse"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                }
+                            }
+                        },
+                        "devices": {
+                            "methods": {
+                                "create": {
+                                    "description": "Creates a device under a node or customer.",
+                                    "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}/devices",
+                                    "httpMethod": "POST",
+                                    "id": "prod_tt_sasportal.customers.nodes.devices.create",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "parent": {
+                                            "description": "Required. The name of the parent resource.",
+                                            "location": "path",
+                                            "pattern": "^customers/[^/]+/nodes/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/devices",
+                                    "request": {
+                                        "$ref": "SasPortalDevice"
+                                    },
+                                    "response": {
+                                        "$ref": "SasPortalDevice"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                },
+                                "createSigned": {
+                                    "description": "Creates a signed device under a node or customer.",
+                                    "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}/devices:createSigned",
+                                    "httpMethod": "POST",
+                                    "id": "prod_tt_sasportal.customers.nodes.devices.createSigned",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "parent": {
+                                            "description": "Required. The name of the parent resource.",
+                                            "location": "path",
+                                            "pattern": "^customers/[^/]+/nodes/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/devices:createSigned",
+                                    "request": {
+                                        "$ref": "SasPortalCreateSignedDeviceRequest"
+                                    },
+                                    "response": {
+                                        "$ref": "SasPortalDevice"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                },
+                                "list": {
+                                    "description": "Lists devices under a node or customer.",
+                                    "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}/devices",
+                                    "httpMethod": "GET",
+                                    "id": "prod_tt_sasportal.customers.nodes.devices.list",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "filter": {
+                                            "description": "The filter expression. The filter should have one of the following formats: \"sn=123454\" or \"display_name=MyDevice\". sn corresponds to serial number of the device. The filter is case insensitive.",
+                                            "location": "query",
+                                            "type": "string"
+                                        },
+                                        "pageSize": {
+                                            "description": "The maximum number of devices to return in the response. If empty or zero, all devices will be listed. Must be in the range [0, 1000].",
+                                            "format": "int32",
+                                            "location": "query",
+                                            "type": "integer"
+                                        },
+                                        "pageToken": {
+                                            "description": "A pagination token returned from a previous call to ListDevices that indicates where this listing should continue from.",
+                                            "location": "query",
+                                            "type": "string"
+                                        },
+                                        "parent": {
+                                            "description": "Required. The name of the parent resource.",
+                                            "location": "path",
+                                            "pattern": "^customers/[^/]+/nodes/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/devices",
+                                    "response": {
+                                        "$ref": "SasPortalListDevicesResponse"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                }
+                            }
+                        },
+                        "nodes": {
+                            "methods": {
+                                "create": {
+                                    "description": "Creates a new node.",
+                                    "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}/nodes",
+                                    "httpMethod": "POST",
+                                    "id": "prod_tt_sasportal.customers.nodes.nodes.create",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "parent": {
+                                            "description": "Required. The parent resource name where the node is to be created.",
+                                            "location": "path",
+                                            "pattern": "^customers/[^/]+/nodes/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/nodes",
+                                    "request": {
+                                        "$ref": "SasPortalNode"
+                                    },
+                                    "response": {
+                                        "$ref": "SasPortalNode"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                },
+                                "list": {
+                                    "description": "Lists nodes.",
+                                    "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}/nodes",
+                                    "httpMethod": "GET",
+                                    "id": "prod_tt_sasportal.customers.nodes.nodes.list",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "filter": {
+                                            "description": "The filter expression. The filter should have the following format: \"DIRECT_CHILDREN\" or format: \"direct_children\". The filter is case insensitive. If empty, then no nodes are filtered.",
+                                            "location": "query",
+                                            "type": "string"
+                                        },
+                                        "pageSize": {
+                                            "description": "The maximum number of nodes to return in the response.",
+                                            "format": "int32",
+                                            "location": "query",
+                                            "type": "integer"
+                                        },
+                                        "pageToken": {
+                                            "description": "A pagination token returned from a previous call to ListNodes that indicates where this listing should continue from.",
+                                            "location": "query",
+                                            "type": "string"
+                                        },
+                                        "parent": {
+                                            "description": "Required. The parent resource name, for example, \"nodes/1\".",
+                                            "location": "path",
+                                            "pattern": "^customers/[^/]+/nodes/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/nodes",
+                                    "response": {
+                                        "$ref": "SasPortalListNodesResponse"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                }
+                            }
+                        }
+                    }
+                }
+            }
         },
-        "nextPageToken": {
-          "type": "string",
-          "description": "A pagination token returned from a previous call to ListCustomers method that indicates from where listing should continue. If the field is missing or empty, it means there are no more customers."
+        "deployments": {
+            "methods": {
+                "get": {
+                    "description": "Returns a requested deployment.",
+                    "flatPath": "v1alpha1/deployments/{deploymentsId}",
+                    "httpMethod": "GET",
+                    "id": "prod_tt_sasportal.deployments.get",
+                    "parameterOrder": [
+                        "name"
+                    ],
+                    "parameters": {
+                        "name": {
+                            "description": "Required. The name of the deployment.",
+                            "location": "path",
+                            "pattern": "^deployments/[^/]+$",
+                            "required": true,
+                            "type": "string"
+                        }
+                    },
+                    "path": "v1alpha1/{+name}",
+                    "response": {
+                        "$ref": "SasPortalDeployment"
+                    },
+                    "scopes": [
+                        "https://www.googleapis.com/auth/userinfo.email"
+                    ]
+                }
+            },
+            "resources": {
+                "devices": {
+                    "methods": {
+                        "delete": {
+                            "description": "Deletes a device.",
+                            "flatPath": "v1alpha1/deployments/{deploymentsId}/devices/{devicesId}",
+                            "httpMethod": "DELETE",
+                            "id": "prod_tt_sasportal.deployments.devices.delete",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the device.",
+                                    "location": "path",
+                                    "pattern": "^deployments/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "response": {
+                                "$ref": "SasPortalEmpty"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "get": {
+                            "description": "Gets details about a device.",
+                            "flatPath": "v1alpha1/deployments/{deploymentsId}/devices/{devicesId}",
+                            "httpMethod": "GET",
+                            "id": "prod_tt_sasportal.deployments.devices.get",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the device.",
+                                    "location": "path",
+                                    "pattern": "^deployments/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "response": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "move": {
+                            "description": "Moves a device under another node or customer.",
+                            "flatPath": "v1alpha1/deployments/{deploymentsId}/devices/{devicesId}:move",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.deployments.devices.move",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the device to move.",
+                                    "location": "path",
+                                    "pattern": "^deployments/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}:move",
+                            "request": {
+                                "$ref": "SasPortalMoveDeviceRequest"
+                            },
+                            "response": {
+                                "$ref": "SasPortalOperation"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "patch": {
+                            "description": "Updates a device.",
+                            "flatPath": "v1alpha1/deployments/{deploymentsId}/devices/{devicesId}",
+                            "httpMethod": "PATCH",
+                            "id": "prod_tt_sasportal.deployments.devices.patch",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Output only. The resource path name.",
+                                    "location": "path",
+                                    "pattern": "^deployments/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                },
+                                "updateMask": {
+                                    "description": "Fields to be updated.",
+                                    "format": "google-fieldmask",
+                                    "location": "query",
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "request": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "response": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "signDevice": {
+                            "description": "Signs a device.",
+                            "flatPath": "v1alpha1/deployments/{deploymentsId}/devices/{devicesId}:signDevice",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.deployments.devices.signDevice",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Output only. The resource path name.",
+                                    "location": "path",
+                                    "pattern": "^deployments/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}:signDevice",
+                            "request": {
+                                "$ref": "SasPortalSignDeviceRequest"
+                            },
+                            "response": {
+                                "$ref": "SasPortalEmpty"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "updateSigned": {
+                            "description": "Updates a signed device.",
+                            "flatPath": "v1alpha1/deployments/{deploymentsId}/devices/{devicesId}:updateSigned",
+                            "httpMethod": "PATCH",
+                            "id": "prod_tt_sasportal.deployments.devices.updateSigned",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the device to update.",
+                                    "location": "path",
+                                    "pattern": "^deployments/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}:updateSigned",
+                            "request": {
+                                "$ref": "SasPortalUpdateSignedDeviceRequest"
+                            },
+                            "response": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        }
+                    }
+                }
+            }
+        },
+        "installer": {
+            "methods": {
+                "generateSecret": {
+                    "description": "Generates a secret to be used with the ValidateInstaller.",
+                    "flatPath": "v1alpha1/installer:generateSecret",
+                    "httpMethod": "POST",
+                    "id": "prod_tt_sasportal.installer.generateSecret",
+                    "parameterOrder": [],
+                    "parameters": {},
+                    "path": "v1alpha1/installer:generateSecret",
+                    "request": {
+                        "$ref": "SasPortalGenerateSecretRequest"
+                    },
+                    "response": {
+                        "$ref": "SasPortalGenerateSecretResponse"
+                    },
+                    "scopes": [
+                        "https://www.googleapis.com/auth/userinfo.email"
+                    ]
+                },
+                "validate": {
+                    "description": "Validates the identity of a Certified Professional Installer (CPI).",
+                    "flatPath": "v1alpha1/installer:validate",
+                    "httpMethod": "POST",
+                    "id": "prod_tt_sasportal.installer.validate",
+                    "parameterOrder": [],
+                    "parameters": {},
+                    "path": "v1alpha1/installer:validate",
+                    "request": {
+                        "$ref": "SasPortalValidateInstallerRequest"
+                    },
+                    "response": {
+                        "$ref": "SasPortalValidateInstallerResponse"
+                    },
+                    "scopes": [
+                        "https://www.googleapis.com/auth/userinfo.email"
+                    ]
+                }
+            }
+        },
+        "nodes": {
+            "methods": {
+                "get": {
+                    "description": "Returns a requested node.",
+                    "flatPath": "v1alpha1/nodes/{nodesId}",
+                    "httpMethod": "GET",
+                    "id": "prod_tt_sasportal.nodes.get",
+                    "parameterOrder": [
+                        "name"
+                    ],
+                    "parameters": {
+                        "name": {
+                            "description": "Required. The name of the node.",
+                            "location": "path",
+                            "pattern": "^nodes/[^/]+$",
+                            "required": true,
+                            "type": "string"
+                        }
+                    },
+                    "path": "v1alpha1/{+name}",
+                    "response": {
+                        "$ref": "SasPortalNode"
+                    },
+                    "scopes": [
+                        "https://www.googleapis.com/auth/userinfo.email"
+                    ]
+                }
+            },
+            "resources": {
+                "deployments": {
+                    "methods": {
+                        "delete": {
+                            "description": "Deletes a deployment.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/deployments/{deploymentsId}",
+                            "httpMethod": "DELETE",
+                            "id": "prod_tt_sasportal.nodes.deployments.delete",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the deployment.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+/deployments/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "response": {
+                                "$ref": "SasPortalEmpty"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "get": {
+                            "description": "Returns a requested deployment.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/deployments/{deploymentsId}",
+                            "httpMethod": "GET",
+                            "id": "prod_tt_sasportal.nodes.deployments.get",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the deployment.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+/deployments/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "response": {
+                                "$ref": "SasPortalDeployment"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "list": {
+                            "description": "Lists deployments.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/deployments",
+                            "httpMethod": "GET",
+                            "id": "prod_tt_sasportal.nodes.deployments.list",
+                            "parameterOrder": [
+                                "parent"
+                            ],
+                            "parameters": {
+                                "filter": {
+                                    "description": "The filter expression. The filter should have the following format: \"DIRECT_CHILDREN\" or format: \"direct_children\". The filter is case insensitive. If empty, then no deployments are filtered.",
+                                    "location": "query",
+                                    "type": "string"
+                                },
+                                "pageSize": {
+                                    "description": "The maximum number of deployments to return in the response.",
+                                    "format": "int32",
+                                    "location": "query",
+                                    "type": "integer"
+                                },
+                                "pageToken": {
+                                    "description": "A pagination token returned from a previous call to ListDeployments that indicates where this listing should continue from.",
+                                    "location": "query",
+                                    "type": "string"
+                                },
+                                "parent": {
+                                    "description": "Required. The parent resource name, for example, \"nodes/1\", customer/1/nodes/2.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+parent}/deployments",
+                            "response": {
+                                "$ref": "SasPortalListDeploymentsResponse"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "move": {
+                            "description": "Moves a deployment under another node or customer.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/deployments/{deploymentsId}:move",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.nodes.deployments.move",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the deployment to move.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+/deployments/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}:move",
+                            "request": {
+                                "$ref": "SasPortalMoveDeploymentRequest"
+                            },
+                            "response": {
+                                "$ref": "SasPortalOperation"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "patch": {
+                            "description": "Updates an existing deployment.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/deployments/{deploymentsId}",
+                            "httpMethod": "PATCH",
+                            "id": "prod_tt_sasportal.nodes.deployments.patch",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Output only. Resource name.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+/deployments/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                },
+                                "updateMask": {
+                                    "description": "Fields to be updated.",
+                                    "format": "google-fieldmask",
+                                    "location": "query",
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "request": {
+                                "$ref": "SasPortalDeployment"
+                            },
+                            "response": {
+                                "$ref": "SasPortalDeployment"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        }
+                    },
+                    "resources": {
+                        "devices": {
+                            "methods": {
+                                "create": {
+                                    "description": "Creates a device under a node or customer.",
+                                    "flatPath": "v1alpha1/nodes/{nodesId}/deployments/{deploymentsId}/devices",
+                                    "httpMethod": "POST",
+                                    "id": "prod_tt_sasportal.nodes.deployments.devices.create",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "parent": {
+                                            "description": "Required. The name of the parent resource.",
+                                            "location": "path",
+                                            "pattern": "^nodes/[^/]+/deployments/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/devices",
+                                    "request": {
+                                        "$ref": "SasPortalDevice"
+                                    },
+                                    "response": {
+                                        "$ref": "SasPortalDevice"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                },
+                                "createSigned": {
+                                    "description": "Creates a signed device under a node or customer.",
+                                    "flatPath": "v1alpha1/nodes/{nodesId}/deployments/{deploymentsId}/devices:createSigned",
+                                    "httpMethod": "POST",
+                                    "id": "prod_tt_sasportal.nodes.deployments.devices.createSigned",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "parent": {
+                                            "description": "Required. The name of the parent resource.",
+                                            "location": "path",
+                                            "pattern": "^nodes/[^/]+/deployments/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/devices:createSigned",
+                                    "request": {
+                                        "$ref": "SasPortalCreateSignedDeviceRequest"
+                                    },
+                                    "response": {
+                                        "$ref": "SasPortalDevice"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                },
+                                "list": {
+                                    "description": "Lists devices under a node or customer.",
+                                    "flatPath": "v1alpha1/nodes/{nodesId}/deployments/{deploymentsId}/devices",
+                                    "httpMethod": "GET",
+                                    "id": "prod_tt_sasportal.nodes.deployments.devices.list",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "filter": {
+                                            "description": "The filter expression. The filter should have one of the following formats: \"sn=123454\" or \"display_name=MyDevice\". sn corresponds to serial number of the device. The filter is case insensitive.",
+                                            "location": "query",
+                                            "type": "string"
+                                        },
+                                        "pageSize": {
+                                            "description": "The maximum number of devices to return in the response. If empty or zero, all devices will be listed. Must be in the range [0, 1000].",
+                                            "format": "int32",
+                                            "location": "query",
+                                            "type": "integer"
+                                        },
+                                        "pageToken": {
+                                            "description": "A pagination token returned from a previous call to ListDevices that indicates where this listing should continue from.",
+                                            "location": "query",
+                                            "type": "string"
+                                        },
+                                        "parent": {
+                                            "description": "Required. The name of the parent resource.",
+                                            "location": "path",
+                                            "pattern": "^nodes/[^/]+/deployments/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/devices",
+                                    "response": {
+                                        "$ref": "SasPortalListDevicesResponse"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                }
+                            }
+                        }
+                    }
+                },
+                "devices": {
+                    "methods": {
+                        "create": {
+                            "description": "Creates a device under a node or customer.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/devices",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.nodes.devices.create",
+                            "parameterOrder": [
+                                "parent"
+                            ],
+                            "parameters": {
+                                "parent": {
+                                    "description": "Required. The name of the parent resource.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+parent}/devices",
+                            "request": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "response": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "createSigned": {
+                            "description": "Creates a signed device under a node or customer.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/devices:createSigned",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.nodes.devices.createSigned",
+                            "parameterOrder": [
+                                "parent"
+                            ],
+                            "parameters": {
+                                "parent": {
+                                    "description": "Required. The name of the parent resource.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+parent}/devices:createSigned",
+                            "request": {
+                                "$ref": "SasPortalCreateSignedDeviceRequest"
+                            },
+                            "response": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "delete": {
+                            "description": "Deletes a device.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/devices/{devicesId}",
+                            "httpMethod": "DELETE",
+                            "id": "prod_tt_sasportal.nodes.devices.delete",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the device.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "response": {
+                                "$ref": "SasPortalEmpty"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "get": {
+                            "description": "Gets details about a device.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/devices/{devicesId}",
+                            "httpMethod": "GET",
+                            "id": "prod_tt_sasportal.nodes.devices.get",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the device.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "response": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "list": {
+                            "description": "Lists devices under a node or customer.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/devices",
+                            "httpMethod": "GET",
+                            "id": "prod_tt_sasportal.nodes.devices.list",
+                            "parameterOrder": [
+                                "parent"
+                            ],
+                            "parameters": {
+                                "filter": {
+                                    "description": "The filter expression. The filter should have one of the following formats: \"sn=123454\" or \"display_name=MyDevice\". sn corresponds to serial number of the device. The filter is case insensitive.",
+                                    "location": "query",
+                                    "type": "string"
+                                },
+                                "pageSize": {
+                                    "description": "The maximum number of devices to return in the response. If empty or zero, all devices will be listed. Must be in the range [0, 1000].",
+                                    "format": "int32",
+                                    "location": "query",
+                                    "type": "integer"
+                                },
+                                "pageToken": {
+                                    "description": "A pagination token returned from a previous call to ListDevices that indicates where this listing should continue from.",
+                                    "location": "query",
+                                    "type": "string"
+                                },
+                                "parent": {
+                                    "description": "Required. The name of the parent resource.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+parent}/devices",
+                            "response": {
+                                "$ref": "SasPortalListDevicesResponse"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "move": {
+                            "description": "Moves a device under another node or customer.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/devices/{devicesId}:move",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.nodes.devices.move",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the device to move.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}:move",
+                            "request": {
+                                "$ref": "SasPortalMoveDeviceRequest"
+                            },
+                            "response": {
+                                "$ref": "SasPortalOperation"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "patch": {
+                            "description": "Updates a device.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/devices/{devicesId}",
+                            "httpMethod": "PATCH",
+                            "id": "prod_tt_sasportal.nodes.devices.patch",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Output only. The resource path name.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                },
+                                "updateMask": {
+                                    "description": "Fields to be updated.",
+                                    "format": "google-fieldmask",
+                                    "location": "query",
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "request": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "response": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "signDevice": {
+                            "description": "Signs a device.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/devices/{devicesId}:signDevice",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.nodes.devices.signDevice",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Output only. The resource path name.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}:signDevice",
+                            "request": {
+                                "$ref": "SasPortalSignDeviceRequest"
+                            },
+                            "response": {
+                                "$ref": "SasPortalEmpty"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "updateSigned": {
+                            "description": "Updates a signed device.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/devices/{devicesId}:updateSigned",
+                            "httpMethod": "PATCH",
+                            "id": "prod_tt_sasportal.nodes.devices.updateSigned",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the device to update.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+/devices/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}:updateSigned",
+                            "request": {
+                                "$ref": "SasPortalUpdateSignedDeviceRequest"
+                            },
+                            "response": {
+                                "$ref": "SasPortalDevice"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        }
+                    }
+                },
+                "nodes": {
+                    "methods": {
+                        "create": {
+                            "description": "Creates a new node.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/nodes",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.nodes.nodes.create",
+                            "parameterOrder": [
+                                "parent"
+                            ],
+                            "parameters": {
+                                "parent": {
+                                    "description": "Required. The parent resource name where the node is to be created.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+parent}/nodes",
+                            "request": {
+                                "$ref": "SasPortalNode"
+                            },
+                            "response": {
+                                "$ref": "SasPortalNode"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "delete": {
+                            "description": "Deletes a node.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}",
+                            "httpMethod": "DELETE",
+                            "id": "prod_tt_sasportal.nodes.nodes.delete",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the node.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+/nodes/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "response": {
+                                "$ref": "SasPortalEmpty"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "get": {
+                            "description": "Returns a requested node.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}",
+                            "httpMethod": "GET",
+                            "id": "prod_tt_sasportal.nodes.nodes.get",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the node.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+/nodes/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "response": {
+                                "$ref": "SasPortalNode"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "list": {
+                            "description": "Lists nodes.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/nodes",
+                            "httpMethod": "GET",
+                            "id": "prod_tt_sasportal.nodes.nodes.list",
+                            "parameterOrder": [
+                                "parent"
+                            ],
+                            "parameters": {
+                                "filter": {
+                                    "description": "The filter expression. The filter should have the following format: \"DIRECT_CHILDREN\" or format: \"direct_children\". The filter is case insensitive. If empty, then no nodes are filtered.",
+                                    "location": "query",
+                                    "type": "string"
+                                },
+                                "pageSize": {
+                                    "description": "The maximum number of nodes to return in the response.",
+                                    "format": "int32",
+                                    "location": "query",
+                                    "type": "integer"
+                                },
+                                "pageToken": {
+                                    "description": "A pagination token returned from a previous call to ListNodes that indicates where this listing should continue from.",
+                                    "location": "query",
+                                    "type": "string"
+                                },
+                                "parent": {
+                                    "description": "Required. The parent resource name, for example, \"nodes/1\".",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+parent}/nodes",
+                            "response": {
+                                "$ref": "SasPortalListNodesResponse"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "move": {
+                            "description": "Moves a node under another node or customer.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}:move",
+                            "httpMethod": "POST",
+                            "id": "prod_tt_sasportal.nodes.nodes.move",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Required. The name of the node to move.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+/nodes/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}:move",
+                            "request": {
+                                "$ref": "SasPortalMoveNodeRequest"
+                            },
+                            "response": {
+                                "$ref": "SasPortalOperation"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        },
+                        "patch": {
+                            "description": "Updates an existing node.",
+                            "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}",
+                            "httpMethod": "PATCH",
+                            "id": "prod_tt_sasportal.nodes.nodes.patch",
+                            "parameterOrder": [
+                                "name"
+                            ],
+                            "parameters": {
+                                "name": {
+                                    "description": "Output only. Resource name.",
+                                    "location": "path",
+                                    "pattern": "^nodes/[^/]+/nodes/[^/]+$",
+                                    "required": true,
+                                    "type": "string"
+                                },
+                                "updateMask": {
+                                    "description": "Fields to be updated.",
+                                    "format": "google-fieldmask",
+                                    "location": "query",
+                                    "type": "string"
+                                }
+                            },
+                            "path": "v1alpha1/{+name}",
+                            "request": {
+                                "$ref": "SasPortalNode"
+                            },
+                            "response": {
+                                "$ref": "SasPortalNode"
+                            },
+                            "scopes": [
+                                "https://www.googleapis.com/auth/userinfo.email"
+                            ]
+                        }
+                    },
+                    "resources": {
+                        "deployments": {
+                            "methods": {
+                                "create": {
+                                    "description": "Creates a new deployment.",
+                                    "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}/deployments",
+                                    "httpMethod": "POST",
+                                    "id": "prod_tt_sasportal.nodes.nodes.deployments.create",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "parent": {
+                                            "description": "Required. The parent resource name where the deployment is to be created.",
+                                            "location": "path",
+                                            "pattern": "^nodes/[^/]+/nodes/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/deployments",
+                                    "request": {
+                                        "$ref": "SasPortalDeployment"
+                                    },
+                                    "response": {
+                                        "$ref": "SasPortalDeployment"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                },
+                                "list": {
+                                    "description": "Lists deployments.",
+                                    "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}/deployments",
+                                    "httpMethod": "GET",
+                                    "id": "prod_tt_sasportal.nodes.nodes.deployments.list",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "filter": {
+                                            "description": "The filter expression. The filter should have the following format: \"DIRECT_CHILDREN\" or format: \"direct_children\". The filter is case insensitive. If empty, then no deployments are filtered.",
+                                            "location": "query",
+                                            "type": "string"
+                                        },
+                                        "pageSize": {
+                                            "description": "The maximum number of deployments to return in the response.",
+                                            "format": "int32",
+                                            "location": "query",
+                                            "type": "integer"
+                                        },
+                                        "pageToken": {
+                                            "description": "A pagination token returned from a previous call to ListDeployments that indicates where this listing should continue from.",
+                                            "location": "query",
+                                            "type": "string"
+                                        },
+                                        "parent": {
+                                            "description": "Required. The parent resource name, for example, \"nodes/1\", customer/1/nodes/2.",
+                                            "location": "path",
+                                            "pattern": "^nodes/[^/]+/nodes/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/deployments",
+                                    "response": {
+                                        "$ref": "SasPortalListDeploymentsResponse"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                }
+                            }
+                        },
+                        "devices": {
+                            "methods": {
+                                "create": {
+                                    "description": "Creates a device under a node or customer.",
+                                    "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}/devices",
+                                    "httpMethod": "POST",
+                                    "id": "prod_tt_sasportal.nodes.nodes.devices.create",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "parent": {
+                                            "description": "Required. The name of the parent resource.",
+                                            "location": "path",
+                                            "pattern": "^nodes/[^/]+/nodes/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/devices",
+                                    "request": {
+                                        "$ref": "SasPortalDevice"
+                                    },
+                                    "response": {
+                                        "$ref": "SasPortalDevice"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                },
+                                "createSigned": {
+                                    "description": "Creates a signed device under a node or customer.",
+                                    "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}/devices:createSigned",
+                                    "httpMethod": "POST",
+                                    "id": "prod_tt_sasportal.nodes.nodes.devices.createSigned",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "parent": {
+                                            "description": "Required. The name of the parent resource.",
+                                            "location": "path",
+                                            "pattern": "^nodes/[^/]+/nodes/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/devices:createSigned",
+                                    "request": {
+                                        "$ref": "SasPortalCreateSignedDeviceRequest"
+                                    },
+                                    "response": {
+                                        "$ref": "SasPortalDevice"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                },
+                                "list": {
+                                    "description": "Lists devices under a node or customer.",
+                                    "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}/devices",
+                                    "httpMethod": "GET",
+                                    "id": "prod_tt_sasportal.nodes.nodes.devices.list",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "filter": {
+                                            "description": "The filter expression. The filter should have one of the following formats: \"sn=123454\" or \"display_name=MyDevice\". sn corresponds to serial number of the device. The filter is case insensitive.",
+                                            "location": "query",
+                                            "type": "string"
+                                        },
+                                        "pageSize": {
+                                            "description": "The maximum number of devices to return in the response. If empty or zero, all devices will be listed. Must be in the range [0, 1000].",
+                                            "format": "int32",
+                                            "location": "query",
+                                            "type": "integer"
+                                        },
+                                        "pageToken": {
+                                            "description": "A pagination token returned from a previous call to ListDevices that indicates where this listing should continue from.",
+                                            "location": "query",
+                                            "type": "string"
+                                        },
+                                        "parent": {
+                                            "description": "Required. The name of the parent resource.",
+                                            "location": "path",
+                                            "pattern": "^nodes/[^/]+/nodes/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/devices",
+                                    "response": {
+                                        "$ref": "SasPortalListDevicesResponse"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                }
+                            }
+                        },
+                        "nodes": {
+                            "methods": {
+                                "create": {
+                                    "description": "Creates a new node.",
+                                    "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}/nodes",
+                                    "httpMethod": "POST",
+                                    "id": "prod_tt_sasportal.nodes.nodes.nodes.create",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "parent": {
+                                            "description": "Required. The parent resource name where the node is to be created.",
+                                            "location": "path",
+                                            "pattern": "^nodes/[^/]+/nodes/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/nodes",
+                                    "request": {
+                                        "$ref": "SasPortalNode"
+                                    },
+                                    "response": {
+                                        "$ref": "SasPortalNode"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                },
+                                "list": {
+                                    "description": "Lists nodes.",
+                                    "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}/nodes",
+                                    "httpMethod": "GET",
+                                    "id": "prod_tt_sasportal.nodes.nodes.nodes.list",
+                                    "parameterOrder": [
+                                        "parent"
+                                    ],
+                                    "parameters": {
+                                        "filter": {
+                                            "description": "The filter expression. The filter should have the following format: \"DIRECT_CHILDREN\" or format: \"direct_children\". The filter is case insensitive. If empty, then no nodes are filtered.",
+                                            "location": "query",
+                                            "type": "string"
+                                        },
+                                        "pageSize": {
+                                            "description": "The maximum number of nodes to return in the response.",
+                                            "format": "int32",
+                                            "location": "query",
+                                            "type": "integer"
+                                        },
+                                        "pageToken": {
+                                            "description": "A pagination token returned from a previous call to ListNodes that indicates where this listing should continue from.",
+                                            "location": "query",
+                                            "type": "string"
+                                        },
+                                        "parent": {
+                                            "description": "Required. The parent resource name, for example, \"nodes/1\".",
+                                            "location": "path",
+                                            "pattern": "^nodes/[^/]+/nodes/[^/]+$",
+                                            "required": true,
+                                            "type": "string"
+                                        }
+                                    },
+                                    "path": "v1alpha1/{+parent}/nodes",
+                                    "response": {
+                                        "$ref": "SasPortalListNodesResponse"
+                                    },
+                                    "scopes": [
+                                        "https://www.googleapis.com/auth/userinfo.email"
+                                    ]
+                                }
+                            }
+                        }
+                    }
+                }
+            }
+        },
+        "policies": {
+            "methods": {
+                "get": {
+                    "description": "Gets the access control policy for a resource. Returns an empty policy if the resource exists and does not have a policy set.",
+                    "flatPath": "v1alpha1/policies:get",
+                    "httpMethod": "POST",
+                    "id": "prod_tt_sasportal.policies.get",
+                    "parameterOrder": [],
+                    "parameters": {},
+                    "path": "v1alpha1/policies:get",
+                    "request": {
+                        "$ref": "SasPortalGetPolicyRequest"
+                    },
+                    "response": {
+                        "$ref": "SasPortalPolicy"
+                    },
+                    "scopes": [
+                        "https://www.googleapis.com/auth/userinfo.email"
+                    ]
+                },
+                "set": {
+                    "description": "Sets the access control policy on the specified resource. Replaces any existing policy.",
+                    "flatPath": "v1alpha1/policies:set",
+                    "httpMethod": "POST",
+                    "id": "prod_tt_sasportal.policies.set",
+                    "parameterOrder": [],
+                    "parameters": {},
+                    "path": "v1alpha1/policies:set",
+                    "request": {
+                        "$ref": "SasPortalSetPolicyRequest"
+                    },
+                    "response": {
+                        "$ref": "SasPortalPolicy"
+                    },
+                    "scopes": [
+                        "https://www.googleapis.com/auth/userinfo.email"
+                    ]
+                },
+                "test": {
+                    "description": "Returns permissions that a caller has on the specified resource.",
+                    "flatPath": "v1alpha1/policies:test",
+                    "httpMethod": "POST",
+                    "id": "prod_tt_sasportal.policies.test",
+                    "parameterOrder": [],
+                    "parameters": {},
+                    "path": "v1alpha1/policies:test",
+                    "request": {
+                        "$ref": "SasPortalTestPermissionsRequest"
+                    },
+                    "response": {
+                        "$ref": "SasPortalTestPermissionsResponse"
+                    },
+                    "scopes": [
+                        "https://www.googleapis.com/auth/userinfo.email"
+                    ]
+                }
+            }
         }
-      },
-      "id": "SasPortalListCustomersResponse",
-      "description": "Response for `ListCustomers`."
     },
-    "SasPortalCreateSignedDeviceRequest": {
-      "type": "object",
-      "id": "SasPortalCreateSignedDeviceRequest",
-      "description": "Request for CreateSignedDevice method.",
-      "properties": {
-        "encodedDevice": {
-          "format": "byte",
-          "description": "Required. JSON Web Token signed using a CPI private key. Payload must be the JSON encoding of the [Device]. The user_id field must be set.",
-          "type": "string"
-        },
-        "installerId": {
-          "description": "Required. Unique installer id (cpiId) from the Certified Professional Installers database.",
-          "type": "string"
-        }
-      }
-    },
-    "SasPortalAssignment": {
-      "description": "Associates `members` with a `role`.",
-      "type": "object",
-      "id": "SasPortalAssignment",
-      "properties": {
-        "members": {
-          "description": "The identities the role is assigned to. It can have the following values: * `{user_email}`: An email address that represents a specific Google account. For example: `alice@gmail.com`. * `{group_email}`: An email address that represents a Google group. For example, `viewers@gmail.com`.",
-          "type": "array",
-          "items": {
-            "type": "string"
-          }
-        },
-        "role": {
-          "type": "string",
-          "description": "Required. Role that is assigned to `members`."
-        }
-      }
-    },
-    "SasPortalDeviceMetadata": {
-      "id": "SasPortalDeviceMetadata",
-      "properties": {},
-      "description": "Device data overridable by both SAS Portal and registration requests.",
-      "type": "object"
-    },
-    "SasPortalPolicy": {
-      "description": "Defines an access control policy to the resources.",
-      "type": "object",
-      "properties": {
-        "etag": {
-          "description": "The [etag] is used for optimistic concurrency control as a way to help prevent simultaneous updates of a policy from overwriting each other. It is strongly suggested that systems make use of the [etag] in the read-modify-write cycle to perform policy updates in order to avoid race conditions: An [etag] is returned in the response to [GetPolicy], and systems are expected to put that etag in the request to [SetPolicy] to ensure that their change will be applied to the same version of the policy. If no [etag] is provided in the call to [SetPolicy], then the existing policy is overwritten blindly.",
-          "format": "byte",
-          "type": "string"
-        },
-        "assignments": {
-          "type": "array",
-          "items": {
-            "$ref": "SasPortalAssignment"
-          }
-        }
-      },
-      "id": "SasPortalPolicy"
-    },
-    "SasPortalInstallationParams": {
-      "properties": {
-        "verticalAccuracy": {
-          "type": "number",
-          "description": "A positive number in meters to indicate accuracy of the device antenna vertical location. This optional parameter should only be present if its value is less than the FCC requirement of 3 meters.",
-          "format": "double"
-        },
-        "indoorDeployment": {
-          "description": "Whether the device antenna is indoor or not. True: indoor. False: outdoor.",
-          "type": "boolean"
-        },
-        "antennaBeamwidth": {
-          "description": "3-dB antenna beamwidth of the antenna in the horizontal-plane in degrees. This parameter is an unsigned integer having a value between 0 and 360 (degrees) inclusive; it is optional for Category A devices and conditional for Category B devices.",
-          "type": "integer",
-          "format": "int32"
-        },
-        "antennaAzimuth": {
-          "type": "integer",
-          "format": "int32",
-          "description": "Boresight direction of the horizontal plane of the antenna in degrees with respect to true north. The value of this parameter is an integer with a value between 0 and 359 inclusive. A value of 0 degrees means true north; a value of 90 degrees means east. This parameter is optional for Category A devices and conditional for Category B devices."
-        },
-        "antennaGain": {
-          "description": "Peak antenna gain in dBi. This parameter is an integer with a value between -127 and +128 (dBi) inclusive.",
-          "type": "integer",
-          "format": "int32"
-        },
-        "eirpCapability": {
-          "type": "integer",
-          "format": "int32",
-          "description": "This parameter is the maximum device EIRP in units of dBm/10MHz and is an integer with a value between -127 and +47 (dBm/10 MHz) inclusive. If not included, SAS interprets it as maximum allowable EIRP in units of dBm/10MHz for device category."
-        },
-        "longitude": {
-          "description": "Longitude of the device antenna location. in degrees relative to the WGS 84 datum. The allowed range is from -180.000000 to +180.000000. Positive values represent longitudes east of the prime meridian; negative values west of the prime meridian.",
-          "type": "number",
-          "format": "double"
-        },
-        "antennaDowntilt": {
-          "type": "integer",
-          "format": "int32",
-          "description": "Antenna downtilt in degrees and is an integer with a value between -90 and +90 inclusive; a negative value means the antenna is tilted up (above horizontal). This parameter is optional for Category A devices and conditional for Category B devices."
-        },
-        "horizontalAccuracy": {
-          "description": "A positive number in meters to indicate accuracy of the device antenna horizontal location. This optional parameter should only be present if its value is less than the FCC requirement of 50 meters.",
-          "type": "number",
-          "format": "double"
-        },
-        "latitude": {
-          "description": "Latitude of the device antenna location in degrees relative to the WGS 84 datum. The allowed range is from -90.000000 to +90.000000. Positive values represent latitudes north of the equator; negative values south of the equator.",
-          "type": "number",
-          "format": "double"
-        },
-        "heightType": {
-          "type": "string",
-          "description": "Specifies how the height is measured.",
-          "enum": [
-            "HEIGHT_TYPE_UNSPECIFIED",
-            "HEIGHT_TYPE_AGL",
-            "HEIGHT_TYPE_AMSL"
-          ],
-          "enumDescriptions": [
-            "Unspecified height type.",
-            "AGL height is measured relative to the ground level.",
-            "AMSL height is measured relative to the mean sea level."
-          ]
-        },
-        "cpeCbsdIndication": {
-          "description": "If present, this parameter specifies whether the CBSD is a CPE-CBSD or not.",
-          "type": "boolean"
-        },
-        "antennaModel": {
-          "type": "string",
-          "description": "If an external antenna is used, the antenna model is optionally provided in this field. The string has a maximum length of 128 octets."
-        },
-        "height": {
-          "type": "number",
-          "description": "Device antenna height in meters. When the heightType parameter value is \"AGL\", the antenna height should be given relative to ground level. When the heightType parameter value is \"AMSL\", it is given with respect to WGS84 datum.",
-          "format": "double"
-        }
-      },
-      "type": "object",
-      "id": "SasPortalInstallationParams",
-      "description": "Information about the device installation parameters."
-    },
-    "SasPortalStatus": {
-      "description": "The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors).",
-      "type": "object",
-      "properties": {
-        "code": {
-          "description": "The status code, which should be an enum value of google.rpc.Code.",
-          "format": "int32",
-          "type": "integer"
-        },
-        "message": {
-          "type": "string",
-          "description": "A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client."
-        },
-        "details": {
-          "items": {
-            "additionalProperties": {
-              "description": "Properties of the object. Contains field @type with type URL.",
-              "type": "any"
+    "revision": "20210209",
+    "rootUrl": "https://prod-tt-sasportal.googleapis.com/",
+    "schemas": {
+        "SasPortalAssignment": {
+            "description": "Associates `members` with a `role`.",
+            "id": "SasPortalAssignment",
+            "properties": {
+                "members": {
+                    "description": "The identities the role is assigned to. It can have the following values: * `{user_email}`: An email address that represents a specific Google account. For example: `alice@gmail.com`. * `{group_email}`: An email address that represents a Google group. For example, `viewers@gmail.com`.",
+                    "items": {
+                        "type": "string"
+                    },
+                    "type": "array"
+                },
+                "role": {
+                    "description": "Required. Role that is assigned to `members`.",
+                    "type": "string"
+                }
             },
             "type": "object"
-          },
-          "type": "array",
-          "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use."
+        },
+        "SasPortalCreateSignedDeviceRequest": {
+            "description": "Request for CreateSignedDevice.",
+            "id": "SasPortalCreateSignedDeviceRequest",
+            "properties": {
+                "encodedDevice": {
+                    "description": "Required. JSON Web Token signed using a CPI private key. Payload must be the JSON encoding of the device. The user_id field must be set.",
+                    "format": "byte",
+                    "type": "string"
+                },
+                "installerId": {
+                    "description": "Required. Unique installer id (CPI ID) from the Certified Professional Installers database.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalCustomer": {
+            "description": "Entity representing a SAS customer.",
+            "id": "SasPortalCustomer",
+            "properties": {
+                "displayName": {
+                    "description": "Required. Name of the organization that the customer entity represents.",
+                    "type": "string"
+                },
+                "name": {
+                    "description": "Output only. Resource name of the customer.",
+                    "type": "string"
+                },
+                "sasUserIds": {
+                    "description": "User IDs used by the devices belonging to this customer.",
+                    "items": {
+                        "type": "string"
+                    },
+                    "type": "array"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalDeployment": {
+            "description": "The Deployment.",
+            "id": "SasPortalDeployment",
+            "properties": {
+                "allowedBillingModes": {
+                    "description": "The allowed billing modes under this deployment.",
+                    "items": {
+                        "enum": [
+                            "BILLING_MODE_UNSPECIFIED",
+                            "MOBILE",
+                            "FIXED_WIRELESS"
+                        ],
+                        "enumDescriptions": [
+                            "Billing mode has not been specified.",
+                            "Price is based on category of CBSD: Category A, Category B registered with SAS.",
+                            "Price is based on type of CBSD: Base station or CPE."
+                        ],
+                        "type": "string"
+                    },
+                    "type": "array"
+                },
+                "defaultBillingMode": {
+                    "description": "Default billing mode for the deployment and devices under it.",
+                    "enum": [
+                        "BILLING_MODE_UNSPECIFIED",
+                        "MOBILE",
+                        "FIXED_WIRELESS"
+                    ],
+                    "enumDescriptions": [
+                        "Billing mode has not been specified.",
+                        "Price is based on category of CBSD: Category A, Category B registered with SAS.",
+                        "Price is based on type of CBSD: Base station or CPE."
+                    ],
+                    "type": "string"
+                },
+                "displayName": {
+                    "description": "The deployment's display name.",
+                    "type": "string"
+                },
+                "name": {
+                    "description": "Output only. Resource name.",
+                    "readOnly": true,
+                    "type": "string"
+                },
+                "sasUserIds": {
+                    "description": "User ID used by the devices belonging to this deployment. Each deployment should be associated with one unique user ID.",
+                    "items": {
+                        "type": "string"
+                    },
+                    "type": "array"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalDevice": {
+            "id": "SasPortalDevice",
+            "properties": {
+                "activeConfig": {
+                    "$ref": "SasPortalDeviceConfig",
+                    "description": "Output only. Current configuration of the device as registered to the SAS."
+                },
+                "deviceMetadata": {
+                    "$ref": "SasPortalDeviceMetadata",
+                    "description": "Device parameters that can be overridden by both SAS Portal and SAS registration requests."
+                },
+                "displayName": {
+                    "description": "Device display name.",
+                    "type": "string"
+                },
+                "fccId": {
+                    "description": "The FCC identifier of the device.",
+                    "type": "string"
+                },
+                "grantRangeAllowlists": {
+                    "description": "Only ranges within the allowlists are available for new grants.",
+                    "items": {
+                        "$ref": "SasPortalFrequencyRange"
+                    },
+                    "type": "array"
+                },
+                "grants": {
+                    "description": "Output only. Grants held by the device.",
+                    "items": {
+                        "$ref": "SasPortalDeviceGrant"
+                    },
+                    "type": "array"
+                },
+                "name": {
+                    "description": "Output only. The resource path name.",
+                    "type": "string"
+                },
+                "preloadedConfig": {
+                    "$ref": "SasPortalDeviceConfig",
+                    "description": "Configuration of the device, as specified via SAS Portal API."
+                },
+                "serialNumber": {
+                    "description": "A serial number assigned to the device by the device manufacturer.",
+                    "type": "string"
+                },
+                "state": {
+                    "description": "Output only. Device state.",
+                    "enum": [
+                        "DEVICE_STATE_UNSPECIFIED",
+                        "RESERVED",
+                        "REGISTERED",
+                        "DEREGISTERED"
+                    ],
+                    "enumDescriptions": [
+                        "Unspecified state.",
+                        "Device created in the SAS Portal, however, not yet registered with SAS.",
+                        "Device registered with SAS.",
+                        "Device de-registered with SAS."
+                    ],
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalDeviceAirInterface": {
+            "description": "Information about the device's air interface.",
+            "id": "SasPortalDeviceAirInterface",
+            "properties": {
+                "radioTechnology": {
+                    "description": "Conditional. This field specifies the radio access technology that is used for the CBSD.",
+                    "enum": [
+                        "RADIO_TECHNOLOGY_UNSPECIFIED",
+                        "E_UTRA",
+                        "CAMBIUM_NETWORKS",
+                        "FOUR_G_BBW_SAA_1",
+                        "NR",
+                        "DOODLE_CBRS",
+                        "CW",
+                        "REDLINE",
+                        "TARANA_WIRELESS"
+                    ],
+                    "enumDescriptions": [
+                        "",
+                        "",
+                        "",
+                        "",
+                        "",
+                        "",
+                        "",
+                        "",
+                        ""
+                    ],
+                    "type": "string"
+                },
+                "supportedSpec": {
+                    "description": "Optional. This field is related to the `radioTechnology` and provides the air interface specification that the CBSD is compliant with at the time of registration.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalDeviceConfig": {
+            "description": "Information about the device configuration.",
+            "id": "SasPortalDeviceConfig",
+            "properties": {
+                "airInterface": {
+                    "$ref": "SasPortalDeviceAirInterface",
+                    "description": "Information about this device's air interface."
+                },
+                "callSign": {
+                    "description": "The call sign of the device operator.",
+                    "type": "string"
+                },
+                "category": {
+                    "description": "FCC category of the device.",
+                    "enum": [
+                        "DEVICE_CATEGORY_UNSPECIFIED",
+                        "DEVICE_CATEGORY_A",
+                        "DEVICE_CATEGORY_B"
+                    ],
+                    "enumDescriptions": [
+                        "Unspecified device category.",
+                        "Category A.",
+                        "Category B."
+                    ],
+                    "type": "string"
+                },
+                "installationParams": {
+                    "$ref": "SasPortalInstallationParams",
+                    "description": "Installation parameters for the device."
+                },
+                "isSigned": {
+                    "description": "Output only. Whether the configuration has been signed by a CPI.",
+                    "type": "boolean"
+                },
+                "measurementCapabilities": {
+                    "description": "Measurement reporting capabilities of the device.",
+                    "items": {
+                        "enum": [
+                            "MEASUREMENT_CAPABILITY_UNSPECIFIED",
+                            "MEASUREMENT_CAPABILITY_RECEIVED_POWER_WITH_GRANT",
+                            "MEASUREMENT_CAPABILITY_RECEIVED_POWER_WITHOUT_GRANT"
+                        ],
+                        "enumDescriptions": [
+                            "",
+                            "",
+                            ""
+                        ],
+                        "type": "string"
+                    },
+                    "type": "array"
+                },
+                "model": {
+                    "$ref": "SasPortalDeviceModel",
+                    "description": "Information about this device model."
+                },
+                "state": {
+                    "description": "State of the configuration.",
+                    "enum": [
+                        "DEVICE_CONFIG_STATE_UNSPECIFIED",
+                        "DRAFT",
+                        "FINAL"
+                    ],
+                    "enumDescriptions": [
+                        "",
+                        "",
+                        ""
+                    ],
+                    "type": "string"
+                },
+                "updateTime": {
+                    "description": "Output only. The last time the device configuration was edited.",
+                    "format": "google-datetime",
+                    "type": "string"
+                },
+                "userId": {
+                    "description": "The identifier of a device user.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalDeviceGrant": {
+            "description": "Device grant. It is an authorization provided by the Spectrum Access System to a device to transmit using specified operating parameters after a successful heartbeat by the device.",
+            "id": "SasPortalDeviceGrant",
+            "properties": {
+                "channelType": {
+                    "description": "Type of channel used.",
+                    "enum": [
+                        "CHANNEL_TYPE_UNSPECIFIED",
+                        "CHANNEL_TYPE_GAA",
+                        "CHANNEL_TYPE_PAL"
+                    ],
+                    "enumDescriptions": [
+                        "",
+                        "",
+                        ""
+                    ],
+                    "type": "string"
+                },
+                "expireTime": {
+                    "description": "The expiration time of the grant.",
+                    "format": "google-datetime",
+                    "type": "string"
+                },
+                "frequencyRange": {
+                    "$ref": "SasPortalFrequencyRange",
+                    "description": "The transmission frequency range."
+                },
+                "grantId": {
+                    "description": "Grant Id.",
+                    "type": "string"
+                },
+                "maxEirp": {
+                    "description": "Maximum Equivalent Isotropically Radiated Power (EIRP) permitted by the grant. The maximum EIRP is in units of dBm/MHz. The value of `maxEirp` represents the average (RMS) EIRP that would be measured by the procedure defined in FCC part 96.41(e)(3).",
+                    "format": "double",
+                    "type": "number"
+                },
+                "moveList": {
+                    "description": "The DPA move lists on which this grant appears.",
+                    "items": {
+                        "$ref": "SasPortalDpaMoveList"
+                    },
+                    "type": "array"
+                },
+                "state": {
+                    "description": "State of the grant.",
+                    "enum": [
+                        "GRANT_STATE_UNSPECIFIED",
+                        "GRANT_STATE_GRANTED",
+                        "GRANT_STATE_TERMINATED",
+                        "GRANT_STATE_SUSPENDED",
+                        "GRANT_STATE_AUTHORIZED",
+                        "GRANT_STATE_EXPIRED"
+                    ],
+                    "enumDescriptions": [
+                        "",
+                        "The grant has been granted but the device is not heartbeating on it.",
+                        "The grant has been terminated by the SAS.",
+                        "The grant has been suspended by the SAS.",
+                        "The device is currently transmitting.",
+                        "The grant has expired."
+                    ],
+                    "type": "string"
+                },
+                "suspensionReason": {
+                    "description": "If the grant is suspended, the reason(s) for suspension.",
+                    "items": {
+                        "type": "string"
+                    },
+                    "type": "array"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalDeviceMetadata": {
+            "description": "Device data overridable by both SAS Portal and registration requests.",
+            "id": "SasPortalDeviceMetadata",
+            "properties": {},
+            "type": "object"
+        },
+        "SasPortalDeviceModel": {
+            "description": "Information about the model of the device.",
+            "id": "SasPortalDeviceModel",
+            "properties": {
+                "firmwareVersion": {
+                    "description": "The firmware version of the device.",
+                    "type": "string"
+                },
+                "hardwareVersion": {
+                    "description": "The hardware version of the device.",
+                    "type": "string"
+                },
+                "name": {
+                    "description": "The name of the device model.",
+                    "type": "string"
+                },
+                "softwareVersion": {
+                    "description": "The software version of the device.",
+                    "type": "string"
+                },
+                "vendor": {
+                    "description": "The name of the device vendor.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalDpaMoveList": {
+            "description": "An entry in a DPA's move list.",
+            "id": "SasPortalDpaMoveList",
+            "properties": {
+                "dpaId": {
+                    "description": "The ID of the DPA.",
+                    "type": "string"
+                },
+                "frequencyRange": {
+                    "$ref": "SasPortalFrequencyRange",
+                    "description": "The frequency range that the move list affects."
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalEmpty": {
+            "description": "A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); } The JSON representation for `Empty` is empty JSON object `{}`.",
+            "id": "SasPortalEmpty",
+            "properties": {},
+            "type": "object"
+        },
+        "SasPortalFrequencyRange": {
+            "description": "Frequency range from `low_frequency` to `high_frequency`.",
+            "id": "SasPortalFrequencyRange",
+            "properties": {
+                "highFrequencyMhz": {
+                    "description": "The highest frequency of the frequency range in MHz.",
+                    "format": "double",
+                    "type": "number"
+                },
+                "lowFrequencyMhz": {
+                    "description": "The lowest frequency of the frequency range in MHz.",
+                    "format": "double",
+                    "type": "number"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalGenerateSecretRequest": {
+            "description": "Request for GenerateSecret.",
+            "id": "SasPortalGenerateSecretRequest",
+            "properties": {},
+            "type": "object"
+        },
+        "SasPortalGenerateSecretResponse": {
+            "description": "Response for GenerateSecret.",
+            "id": "SasPortalGenerateSecretResponse",
+            "properties": {
+                "secret": {
+                    "description": "The secret generated by the string and used by ValidateInstaller.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalGetPolicyRequest": {
+            "description": "Request message for `GetPolicy` method.",
+            "id": "SasPortalGetPolicyRequest",
+            "properties": {
+                "resource": {
+                    "description": "Required. The resource for which the policy is being requested.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalInstallationParams": {
+            "description": "Information about the device installation parameters.",
+            "id": "SasPortalInstallationParams",
+            "properties": {
+                "antennaAzimuth": {
+                    "description": "Boresight direction of the horizontal plane of the antenna in degrees with respect to true north. The value of this parameter is an integer with a value between 0 and 359 inclusive. A value of 0 degrees means true north; a value of 90 degrees means east. This parameter is optional for Category A devices and conditional for Category B devices.",
+                    "format": "int32",
+                    "type": "integer"
+                },
+                "antennaBeamwidth": {
+                    "description": "3-dB antenna beamwidth of the antenna in the horizontal-plane in degrees. This parameter is an unsigned integer having a value between 0 and 360 (degrees) inclusive; it is optional for Category A devices and conditional for Category B devices.",
+                    "format": "int32",
+                    "type": "integer"
+                },
+                "antennaDowntilt": {
+                    "description": "Antenna downtilt in degrees and is an integer with a value between -90 and +90 inclusive; a negative value means the antenna is tilted up (above horizontal). This parameter is optional for Category A devices and conditional for Category B devices.",
+                    "format": "int32",
+                    "type": "integer"
+                },
+                "antennaGain": {
+                    "description": "Peak antenna gain in dBi. This parameter is an integer with a value between -127 and +128 (dBi) inclusive.",
+                    "format": "int32",
+                    "type": "integer"
+                },
+                "antennaModel": {
+                    "description": "If an external antenna is used, the antenna model is optionally provided in this field. The string has a maximum length of 128 octets.",
+                    "type": "string"
+                },
+                "cpeCbsdIndication": {
+                    "description": "If present, this parameter specifies whether the CBSD is a CPE-CBSD or not.",
+                    "type": "boolean"
+                },
+                "eirpCapability": {
+                    "description": "This parameter is the maximum device EIRP in units of dBm/10MHz and is an integer with a value between -127 and +47 (dBm/10 MHz) inclusive. If not included, SAS interprets it as maximum allowable EIRP in units of dBm/10MHz for device category.",
+                    "format": "int32",
+                    "type": "integer"
+                },
+                "height": {
+                    "description": "Device antenna height in meters. When the `heightType` parameter value is \"AGL\", the antenna height should be given relative to ground level. When the `heightType` parameter value is \"AMSL\", it is given with respect to WGS84 datum.",
+                    "format": "double",
+                    "type": "number"
+                },
+                "heightType": {
+                    "description": "Specifies how the height is measured.",
+                    "enum": [
+                        "HEIGHT_TYPE_UNSPECIFIED",
+                        "HEIGHT_TYPE_AGL",
+                        "HEIGHT_TYPE_AMSL"
+                    ],
+                    "enumDescriptions": [
+                        "Unspecified height type.",
+                        "AGL height is measured relative to the ground level.",
+                        "AMSL height is measured relative to the mean sea level."
+                    ],
+                    "type": "string"
+                },
+                "horizontalAccuracy": {
+                    "description": "A positive number in meters to indicate accuracy of the device antenna horizontal location. This optional parameter should only be present if its value is less than the FCC requirement of 50 meters.",
+                    "format": "double",
+                    "type": "number"
+                },
+                "indoorDeployment": {
+                    "description": "Whether the device antenna is indoor or not. `true`: indoor. `false`: outdoor.",
+                    "type": "boolean"
+                },
+                "latitude": {
+                    "description": "Latitude of the device antenna location in degrees relative to the WGS 84 datum. The allowed range is from -90.000000 to +90.000000. Positive values represent latitudes north of the equator; negative values south of the equator.",
+                    "format": "double",
+                    "type": "number"
+                },
+                "longitude": {
+                    "description": "Longitude of the device antenna location in degrees relative to the WGS 84 datum. The allowed range is from -180.000000 to +180.000000. Positive values represent longitudes east of the prime meridian; negative values west of the prime meridian.",
+                    "format": "double",
+                    "type": "number"
+                },
+                "verticalAccuracy": {
+                    "description": "A positive number in meters to indicate accuracy of the device antenna vertical location. This optional parameter should only be present if its value is less than the FCC requirement of 3 meters.",
+                    "format": "double",
+                    "type": "number"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalListCustomersResponse": {
+            "description": "Response for `ListCustomers`.",
+            "id": "SasPortalListCustomersResponse",
+            "properties": {
+                "customers": {
+                    "description": "The list of customers that match the request.",
+                    "items": {
+                        "$ref": "SasPortalCustomer"
+                    },
+                    "type": "array"
+                },
+                "nextPageToken": {
+                    "description": "A pagination token returned from a previous call to ListCustomers that indicates from where listing should continue. If the field is missing or empty, it means there are no more customers.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalListDeploymentsResponse": {
+            "description": "Response for ListDeployments.",
+            "id": "SasPortalListDeploymentsResponse",
+            "properties": {
+                "deployments": {
+                    "description": "The deployments that match the request.",
+                    "items": {
+                        "$ref": "SasPortalDeployment"
+                    },
+                    "type": "array"
+                },
+                "nextPageToken": {
+                    "description": "A pagination token returned from a previous call to ListDeployments that indicates from where listing should continue. If the field is missing or empty, it means there are no more deployments.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalListDevicesResponse": {
+            "description": "Response for ListDevices.",
+            "id": "SasPortalListDevicesResponse",
+            "properties": {
+                "devices": {
+                    "description": "The devices that match the request.",
+                    "items": {
+                        "$ref": "SasPortalDevice"
+                    },
+                    "type": "array"
+                },
+                "nextPageToken": {
+                    "description": "A pagination token returned from a previous call to ListDevices that indicates from where listing should continue. If the field is missing or empty, it means there is no more devices.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalListNodesResponse": {
+            "description": "Response for ListNodes.",
+            "id": "SasPortalListNodesResponse",
+            "properties": {
+                "nextPageToken": {
+                    "description": "A pagination token returned from a previous call to ListNodes that indicates from where listing should continue. If the field is missing or empty, it means there is no more nodes.",
+                    "type": "string"
+                },
+                "nodes": {
+                    "description": "The nodes that match the request.",
+                    "items": {
+                        "$ref": "SasPortalNode"
+                    },
+                    "type": "array"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalMoveDeploymentRequest": {
+            "description": "Request for MoveDeployment.",
+            "id": "SasPortalMoveDeploymentRequest",
+            "properties": {
+                "destination": {
+                    "description": "Required. The name of the new parent resource node or customer to reparent the deployment under.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalMoveDeviceRequest": {
+            "description": "Request for MoveDevice.",
+            "id": "SasPortalMoveDeviceRequest",
+            "properties": {
+                "destination": {
+                    "description": "Required. The name of the new parent resource node or customer to reparent the device under.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalMoveNodeRequest": {
+            "description": "Request for MoveNode.",
+            "id": "SasPortalMoveNodeRequest",
+            "properties": {
+                "destination": {
+                    "description": "Required. The name of the new parent resource node or customer to reparent the node under.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalNode": {
+            "description": "The Node.",
+            "id": "SasPortalNode",
+            "properties": {
+                "displayName": {
+                    "description": "The node's display name.",
+                    "type": "string"
+                },
+                "name": {
+                    "description": "Output only. Resource name.",
+                    "type": "string"
+                },
+                "sasUserIds": {
+                    "description": "User ids used by the devices belonging to this node.",
+                    "items": {
+                        "type": "string"
+                    },
+                    "type": "array"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalOperation": {
+            "description": "This resource represents a long-running operation that is the result of a network API call.",
+            "id": "SasPortalOperation",
+            "properties": {
+                "done": {
+                    "description": "If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available.",
+                    "type": "boolean"
+                },
+                "error": {
+                    "$ref": "SasPortalStatus",
+                    "description": "The error result of the operation in case of failure or cancellation."
+                },
+                "metadata": {
+                    "additionalProperties": {
+                        "description": "Properties of the object. Contains field @type with type URL.",
+                        "type": "any"
+                    },
+                    "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any.",
+                    "type": "object"
+                },
+                "name": {
+                    "description": "The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`.",
+                    "type": "string"
+                },
+                "response": {
+                    "additionalProperties": {
+                        "description": "Properties of the object. Contains field @type with type URL.",
+                        "type": "any"
+                    },
+                    "description": "The normal response of the operation in case of success. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.",
+                    "type": "object"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalPolicy": {
+            "description": "Defines an access control policy to the resources.",
+            "id": "SasPortalPolicy",
+            "properties": {
+                "assignments": {
+                    "description": "List of assignments",
+                    "items": {
+                        "$ref": "SasPortalAssignment"
+                    },
+                    "type": "array"
+                },
+                "etag": {
+                    "description": "The etag is used for optimistic concurrency control as a way to help prevent simultaneous updates of a policy from overwriting each other. It is strongly suggested that systems make use of the etag in the read-modify-write cycle to perform policy updates in order to avoid race conditions: An etag is returned in the response to GetPolicy, and systems are expected to put that etag in the request to SetPolicy to ensure that their change will be applied to the same version of the policy. If no etag is provided in the call to GetPolicy, then the existing policy is overwritten blindly.",
+                    "format": "byte",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalSetPolicyRequest": {
+            "description": "Request message for `SetPolicy` method.",
+            "id": "SasPortalSetPolicyRequest",
+            "properties": {
+                "policy": {
+                    "$ref": "SasPortalPolicy",
+                    "description": "Required. The policy to be applied to the `resource`."
+                },
+                "resource": {
+                    "description": "Required. The resource for which the policy is being specified. This policy replaces any existing policy.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalSignDeviceRequest": {
+            "description": "Request for SignDevice.",
+            "id": "SasPortalSignDeviceRequest",
+            "properties": {
+                "device": {
+                    "$ref": "SasPortalDevice",
+                    "description": "Required. The device to sign. The device fields name, fcc_id and serial_number must be set. The user_id field must be set."
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalStatus": {
+            "description": "The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors).",
+            "id": "SasPortalStatus",
+            "properties": {
+                "code": {
+                    "description": "The status code, which should be an enum value of google.rpc.Code.",
+                    "format": "int32",
+                    "type": "integer"
+                },
+                "details": {
+                    "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.",
+                    "items": {
+                        "additionalProperties": {
+                            "description": "Properties of the object. Contains field @type with type URL.",
+                            "type": "any"
+                        },
+                        "type": "object"
+                    },
+                    "type": "array"
+                },
+                "message": {
+                    "description": "A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalTestPermissionsRequest": {
+            "description": "Request message for `TestPermissions` method.",
+            "id": "SasPortalTestPermissionsRequest",
+            "properties": {
+                "permissions": {
+                    "description": "The set of permissions to check for the `resource`.",
+                    "items": {
+                        "type": "string"
+                    },
+                    "type": "array"
+                },
+                "resource": {
+                    "description": "Required. The resource for which the permissions are being requested.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalTestPermissionsResponse": {
+            "description": "Response message for `TestPermissions` method.",
+            "id": "SasPortalTestPermissionsResponse",
+            "properties": {
+                "permissions": {
+                    "description": "A set of permissions that the caller is allowed.",
+                    "items": {
+                        "type": "string"
+                    },
+                    "type": "array"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalUpdateSignedDeviceRequest": {
+            "description": "Request for UpdateSignedDevice.",
+            "id": "SasPortalUpdateSignedDeviceRequest",
+            "properties": {
+                "encodedDevice": {
+                    "description": "Required. The JSON Web Token signed using a CPI private key. Payload must be the JSON encoding of the device. The user_id field must be set.",
+                    "format": "byte",
+                    "type": "string"
+                },
+                "installerId": {
+                    "description": "Required. Unique installer ID (CPI ID) from the Certified Professional Installers database.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalValidateInstallerRequest": {
+            "description": "Request for ValidateInstaller.",
+            "id": "SasPortalValidateInstallerRequest",
+            "properties": {
+                "encodedSecret": {
+                    "description": "Required. JSON Web Token signed using a CPI private key. Payload must include a \"secret\" claim whose value is the secret.",
+                    "type": "string"
+                },
+                "installerId": {
+                    "description": "Required. Unique installer id (CPI ID) from the Certified Professional Installers database.",
+                    "type": "string"
+                },
+                "secret": {
+                    "description": "Required. Secret returned by the GenerateSecret.",
+                    "type": "string"
+                }
+            },
+            "type": "object"
+        },
+        "SasPortalValidateInstallerResponse": {
+            "description": "Response for ValidateInstaller.",
+            "id": "SasPortalValidateInstallerResponse",
+            "properties": {},
+            "type": "object"
         }
-      },
-      "id": "SasPortalStatus"
     },
-    "SasPortalListDevicesResponse": {
-      "properties": {
-        "nextPageToken": {
-          "description": "A pagination token returned from a previous call to ListDevices method that indicates from where listing should continue. If the field is missing or empty, it means there is no more devices.",
-          "type": "string"
-        },
-        "devices": {
-          "items": {
-            "$ref": "SasPortalDevice"
-          },
-          "type": "array",
-          "description": "The devices that match the request."
-        }
-      },
-      "type": "object",
-      "id": "SasPortalListDevicesResponse",
-      "description": "Response for ListDevices method."
-    },
-    "SasPortalGetPolicyRequest": {
-      "type": "object",
-      "id": "SasPortalGetPolicyRequest",
-      "properties": {
-        "resource": {
-          "type": "string",
-          "description": "Required. The resource for which the policy is being requested."
-        }
-      },
-      "description": "Request message for `GetPolicy` method."
-    },
-    "SasPortalDeviceModel": {
-      "type": "object",
-      "properties": {
-        "softwareVersion": {
-          "description": "The software version of the device.",
-          "type": "string"
-        },
-        "name": {
-          "type": "string",
-          "description": "The name of the device model."
-        },
-        "firmwareVersion": {
-          "description": "The firmware version of the device.",
-          "type": "string"
-        },
-        "hardwareVersion": {
-          "description": "The hardware version of the device.",
-          "type": "string"
-        },
-        "vendor": {
-          "description": "The name of the device vendor.",
-          "type": "string"
-        }
-      },
-      "description": "Information about the model of the device.",
-      "id": "SasPortalDeviceModel"
-    },
-    "SasPortalMoveNodeRequest": {
-      "description": "Request for MoveNode method.",
-      "type": "object",
-      "properties": {
-        "destination": {
-          "description": "Required. The name of the new parent resource node or Customer) to reparent the node under.",
-          "type": "string"
-        }
-      },
-      "id": "SasPortalMoveNodeRequest"
-    }
-  },
-  "description": "",
-  "batchPath": "batch",
-  "version": "v1alpha1",
-  "mtlsRootUrl": "https://prod-tt-sasportal.mtls.googleapis.com/",
-  "version_module": true,
-  "id": "prod_tt_sasportal:v1alpha1",
-  "baseUrl": "https://prod-tt-sasportal.googleapis.com/",
-  "protocol": "rest",
-  "parameters": {
-    "alt": {
-      "enumDescriptions": [
-        "Responses with Content-Type of application/json",
-        "Media download with context-dependent Content-Type",
-        "Responses with Content-Type of application/x-protobuf"
-      ],
-      "type": "string",
-      "enum": [
-        "json",
-        "media",
-        "proto"
-      ],
-      "location": "query",
-      "description": "Data format for response.",
-      "default": "json"
-    },
-    "$.xgafv": {
-      "description": "V1 error format.",
-      "enumDescriptions": [
-        "v1 error format",
-        "v2 error format"
-      ],
-      "enum": [
-        "1",
-        "2"
-      ],
-      "location": "query",
-      "type": "string"
-    },
-    "access_token": {
-      "type": "string",
-      "description": "OAuth access token.",
-      "location": "query"
-    },
-    "upload_protocol": {
-      "location": "query",
-      "type": "string",
-      "description": "Upload protocol for media (e.g. \"raw\", \"multipart\")."
-    },
-    "prettyPrint": {
-      "type": "boolean",
-      "location": "query",
-      "description": "Returns response with indentations and line breaks.",
-      "default": "true"
-    },
-    "fields": {
-      "type": "string",
-      "description": "Selector specifying which fields to include in a partial response.",
-      "location": "query"
-    },
-    "oauth_token": {
-      "description": "OAuth 2.0 token for the current user.",
-      "type": "string",
-      "location": "query"
-    },
-    "key": {
-      "type": "string",
-      "location": "query",
-      "description": "API key. Your API key identifies your project and provides you with API access, quota, and reports. Required unless you provide an OAuth 2.0 token."
-    },
-    "callback": {
-      "location": "query",
-      "description": "JSONP",
-      "type": "string"
-    },
-    "uploadType": {
-      "location": "query",
-      "type": "string",
-      "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\")."
-    },
-    "quotaUser": {
-      "location": "query",
-      "type": "string",
-      "description": "Available to use for quota purposes for server-side applications. Can be any arbitrary string assigned to a user, but should not exceed 40 characters."
-    }
-  },
-  "resources": {
-    "nodes": {
-      "resources": {
-        "devices": {
-          "methods": {
-            "signDevice": {
-              "id": "prod_tt_sasportal.nodes.devices.signDevice",
-              "request": {
-                "$ref": "SasPortalSignDeviceRequest"
-              },
-              "parameters": {
-                "name": {
-                  "pattern": "^nodes/[^/]+/devices/[^/]+$",
-                  "description": "Output only. The resource path name.",
-                  "type": "string",
-                  "required": true,
-                  "location": "path"
-                }
-              },
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "parameterOrder": [
-                "name"
-              ],
-              "httpMethod": "POST",
-              "path": "v1alpha1/{+name}:signDevice",
-              "flatPath": "v1alpha1/nodes/{nodesId}/devices/{devicesId}:signDevice",
-              "description": "Signs a device.",
-              "response": {
-                "$ref": "SasPortalEmpty"
-              }
-            },
-            "list": {
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "id": "prod_tt_sasportal.nodes.devices.list",
-              "httpMethod": "GET",
-              "path": "v1alpha1/{+parent}/devices",
-              "parameters": {
-                "parent": {
-                  "pattern": "^nodes/[^/]+$",
-                  "location": "path",
-                  "description": "Required. The name of the parent resource.",
-                  "required": true,
-                  "type": "string"
-                },
-                "filter": {
-                  "type": "string",
-                  "location": "query",
-                  "description": "The filter expression. The filter should have one of the following formats: \"sn=123454\" or \"display_name=MyDevice\". sn corresponds to serial_number of the device. The filter is case insensitive."
-                },
-                "pageSize": {
-                  "format": "int32",
-                  "type": "integer",
-                  "location": "query",
-                  "description": "The maximum number of devices to return in the response. If empty or zero, all devices will be listed. Must be in the range [0, 1000]."
-                },
-                "pageToken": {
-                  "type": "string",
-                  "location": "query",
-                  "description": "A pagination token returned from a previous call to ListDevices that indicates where this listing should continue from."
-                }
-              },
-              "flatPath": "v1alpha1/nodes/{nodesId}/devices",
-              "response": {
-                "$ref": "SasPortalListDevicesResponse"
-              },
-              "parameterOrder": [
-                "parent"
-              ],
-              "description": "Lists devices under a node or customer."
-            },
-            "move": {
-              "parameters": {
-                "name": {
-                  "required": true,
-                  "type": "string",
-                  "description": "Required. The name of the device to move.",
-                  "location": "path",
-                  "pattern": "^nodes/[^/]+/devices/[^/]+$"
-                }
-              },
-              "response": {
-                "$ref": "SasPortalOperation"
-              },
-              "path": "v1alpha1/{+name}:move",
-              "parameterOrder": [
-                "name"
-              ],
-              "id": "prod_tt_sasportal.nodes.devices.move",
-              "httpMethod": "POST",
-              "request": {
-                "$ref": "SasPortalMoveDeviceRequest"
-              },
-              "description": "Moves a device under another node or customer.",
-              "flatPath": "v1alpha1/nodes/{nodesId}/devices/{devicesId}:move",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ]
-            },
-            "updateSigned": {
-              "parameterOrder": [
-                "name"
-              ],
-              "description": "Updates a signed device.",
-              "parameters": {
-                "name": {
-                  "type": "string",
-                  "location": "path",
-                  "description": "Required. The name of the device to update.",
-                  "pattern": "^nodes/[^/]+/devices/[^/]+$",
-                  "required": true
-                }
-              },
-              "path": "v1alpha1/{+name}:updateSigned",
-              "request": {
-                "$ref": "SasPortalUpdateSignedDeviceRequest"
-              },
-              "flatPath": "v1alpha1/nodes/{nodesId}/devices/{devicesId}:updateSigned",
-              "response": {
-                "$ref": "SasPortalDevice"
-              },
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "id": "prod_tt_sasportal.nodes.devices.updateSigned",
-              "httpMethod": "PATCH"
-            },
-            "patch": {
-              "parameters": {
-                "name": {
-                  "required": true,
-                  "pattern": "^nodes/[^/]+/devices/[^/]+$",
-                  "description": "Output only. The resource path name.",
-                  "type": "string",
-                  "location": "path"
-                },
-                "updateMask": {
-                  "location": "query",
-                  "description": "Fields to be updated.",
-                  "format": "google-fieldmask",
-                  "type": "string"
-                }
-              },
-              "path": "v1alpha1/{+name}",
-              "parameterOrder": [
-                "name"
-              ],
-              "response": {
-                "$ref": "SasPortalDevice"
-              },
-              "flatPath": "v1alpha1/nodes/{nodesId}/devices/{devicesId}",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "description": "Updates a device.",
-              "id": "prod_tt_sasportal.nodes.devices.patch",
-              "httpMethod": "PATCH",
-              "request": {
-                "$ref": "SasPortalDevice"
-              }
-            },
-            "createSigned": {
-              "response": {
-                "$ref": "SasPortalDevice"
-              },
-              "id": "prod_tt_sasportal.nodes.devices.createSigned",
-              "httpMethod": "POST",
-              "request": {
-                "$ref": "SasPortalCreateSignedDeviceRequest"
-              },
-              "path": "v1alpha1/{+parent}/devices:createSigned",
-              "parameterOrder": [
-                "parent"
-              ],
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "flatPath": "v1alpha1/nodes/{nodesId}/devices:createSigned",
-              "description": "Creates a signed device under a node or customer.",
-              "parameters": {
-                "parent": {
-                  "required": true,
-                  "pattern": "^nodes/[^/]+$",
-                  "location": "path",
-                  "type": "string",
-                  "description": "Required. The name of the parent resource."
-                }
-              }
-            },
-            "bulk": {
-              "flatPath": "v1alpha1/nodes/{nodesId}/devices:bulk",
-              "id": "prod_tt_sasportal.nodes.devices.bulk",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "parameters": {
-                "parent": {
-                  "required": true,
-                  "type": "string",
-                  "location": "path",
-                  "pattern": "^nodes/[^/]+$",
-                  "description": "Required. The name of the parent resource."
-                }
-              },
-              "parameterOrder": [
-                "parent"
-              ],
-              "request": {
-                "$ref": "SasPortalBulkCreateDeviceRequest"
-              },
-              "description": "Creates a device under a node or customer. Returned devices are unordered.",
-              "response": {
-                "$ref": "SasPortalBulkCreateDeviceResponse"
-              },
-              "httpMethod": "POST",
-              "path": "v1alpha1/{+parent}/devices:bulk"
-            },
-            "create": {
-              "parameters": {
-                "parent": {
-                  "pattern": "^nodes/[^/]+$",
-                  "description": "Required. The name of the parent resource.",
-                  "location": "path",
-                  "required": true,
-                  "type": "string"
-                }
-              },
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "flatPath": "v1alpha1/nodes/{nodesId}/devices",
-              "request": {
-                "$ref": "SasPortalDevice"
-              },
-              "description": "Creates a device under a node or customer.",
-              "path": "v1alpha1/{+parent}/devices",
-              "parameterOrder": [
-                "parent"
-              ],
-              "id": "prod_tt_sasportal.nodes.devices.create",
-              "response": {
-                "$ref": "SasPortalDevice"
-              },
-              "httpMethod": "POST"
-            },
-            "get": {
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "parameterOrder": [
-                "name"
-              ],
-              "parameters": {
-                "name": {
-                  "location": "path",
-                  "description": "Required. The name of the device.",
-                  "type": "string",
-                  "required": true,
-                  "pattern": "^nodes/[^/]+/devices/[^/]+$"
-                }
-              },
-              "httpMethod": "GET",
-              "flatPath": "v1alpha1/nodes/{nodesId}/devices/{devicesId}",
-              "response": {
-                "$ref": "SasPortalDevice"
-              },
-              "description": "Gets details about a device.",
-              "id": "prod_tt_sasportal.nodes.devices.get",
-              "path": "v1alpha1/{+name}"
-            },
-            "delete": {
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "flatPath": "v1alpha1/nodes/{nodesId}/devices/{devicesId}",
-              "parameters": {
-                "name": {
-                  "type": "string",
-                  "pattern": "^nodes/[^/]+/devices/[^/]+$",
-                  "location": "path",
-                  "required": true,
-                  "description": "Required. The name of the device."
-                }
-              },
-              "description": "Deletes a device.",
-              "id": "prod_tt_sasportal.nodes.devices.delete",
-              "response": {
-                "$ref": "SasPortalEmpty"
-              },
-              "path": "v1alpha1/{+name}",
-              "parameterOrder": [
-                "name"
-              ],
-              "httpMethod": "DELETE"
-            }
-          }
-        },
-        "nodes": {
-          "methods": {
-            "delete": {
-              "httpMethod": "DELETE",
-              "response": {
-                "$ref": "SasPortalEmpty"
-              },
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "path": "v1alpha1/{+name}",
-              "description": "Deletes a node.",
-              "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}",
-              "parameterOrder": [
-                "name"
-              ],
-              "id": "prod_tt_sasportal.nodes.nodes.delete",
-              "parameters": {
-                "name": {
-                  "pattern": "^nodes/[^/]+/nodes/[^/]+$",
-                  "type": "string",
-                  "description": "Required. The name of the node.",
-                  "required": true,
-                  "location": "path"
-                }
-              }
-            },
-            "create": {
-              "parameterOrder": [
-                "parent"
-              ],
-              "parameters": {
-                "parent": {
-                  "required": true,
-                  "location": "path",
-                  "description": "Required. The parent resource name where the node is to be created.",
-                  "type": "string",
-                  "pattern": "^nodes/[^/]+$"
-                }
-              },
-              "response": {
-                "$ref": "SasPortalNode"
-              },
-              "flatPath": "v1alpha1/nodes/{nodesId}/nodes",
-              "path": "v1alpha1/{+parent}/nodes",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "request": {
-                "$ref": "SasPortalNode"
-              },
-              "httpMethod": "POST",
-              "id": "prod_tt_sasportal.nodes.nodes.create",
-              "description": "Creates a new node."
-            },
-            "get": {
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "description": "Returns a requested node.",
-              "parameterOrder": [
-                "name"
-              ],
-              "parameters": {
-                "name": {
-                  "type": "string",
-                  "required": true,
-                  "pattern": "^nodes/[^/]+/nodes/[^/]+$",
-                  "description": "Required. The name of the node.",
-                  "location": "path"
-                }
-              },
-              "path": "v1alpha1/{+name}",
-              "id": "prod_tt_sasportal.nodes.nodes.get",
-              "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}",
-              "response": {
-                "$ref": "SasPortalNode"
-              },
-              "httpMethod": "GET"
-            },
-            "move": {
-              "request": {
-                "$ref": "SasPortalMoveNodeRequest"
-              },
-              "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}:move",
-              "httpMethod": "POST",
-              "id": "prod_tt_sasportal.nodes.nodes.move",
-              "parameters": {
-                "name": {
-                  "pattern": "^nodes/[^/]+/nodes/[^/]+$",
-                  "description": "Required. The name of the node to move.",
-                  "location": "path",
-                  "type": "string",
-                  "required": true
-                }
-              },
-              "response": {
-                "$ref": "SasPortalOperation"
-              },
-              "description": "Moves a node under another node or customer.",
-              "parameterOrder": [
-                "name"
-              ],
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "path": "v1alpha1/{+name}:move"
-            },
-            "list": {
-              "httpMethod": "GET",
-              "parameters": {
-                "pageSize": {
-                  "description": "The maximum number of nodes to return in the response.",
-                  "type": "integer",
-                  "format": "int32",
-                  "location": "query"
-                },
-                "pageToken": {
-                  "location": "query",
-                  "type": "string",
-                  "description": "A pagination token returned from a previous call to ListNodes method that indicates where this listing should continue from."
-                },
-                "parent": {
-                  "type": "string",
-                  "description": "Required. The parent resource name, for example, \"nodes/1\".",
-                  "required": true,
-                  "pattern": "^nodes/[^/]+$",
-                  "location": "path"
-                }
-              },
-              "flatPath": "v1alpha1/nodes/{nodesId}/nodes",
-              "id": "prod_tt_sasportal.nodes.nodes.list",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "description": "Lists nodes.",
-              "path": "v1alpha1/{+parent}/nodes",
-              "response": {
-                "$ref": "SasPortalListNodesResponse"
-              },
-              "parameterOrder": [
-                "parent"
-              ]
-            },
-            "patch": {
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "response": {
-                "$ref": "SasPortalNode"
-              },
-              "description": "Updates an existing node.",
-              "request": {
-                "$ref": "SasPortalNode"
-              },
-              "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}",
-              "parameters": {
-                "name": {
-                  "pattern": "^nodes/[^/]+/nodes/[^/]+$",
-                  "description": "Output only. Resource name.",
-                  "type": "string",
-                  "required": true,
-                  "location": "path"
-                },
-                "updateMask": {
-                  "format": "google-fieldmask",
-                  "location": "query",
-                  "type": "string",
-                  "description": "Fields to be updated."
-                }
-              },
-              "path": "v1alpha1/{+name}",
-              "httpMethod": "PATCH",
-              "id": "prod_tt_sasportal.nodes.nodes.patch",
-              "parameterOrder": [
-                "name"
-              ]
-            }
-          },
-          "resources": {
-            "nodes": {
-              "methods": {
-                "list": {
-                  "description": "Lists nodes.",
-                  "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}/nodes",
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "path": "v1alpha1/{+parent}/nodes",
-                  "id": "prod_tt_sasportal.nodes.nodes.nodes.list",
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ],
-                  "parameters": {
-                    "pageSize": {
-                      "type": "integer",
-                      "description": "The maximum number of nodes to return in the response.",
-                      "format": "int32",
-                      "location": "query"
-                    },
-                    "parent": {
-                      "description": "Required. The parent resource name, for example, \"nodes/1\".",
-                      "pattern": "^nodes/[^/]+/nodes/[^/]+$",
-                      "required": true,
-                      "location": "path",
-                      "type": "string"
-                    },
-                    "pageToken": {
-                      "description": "A pagination token returned from a previous call to ListNodes method that indicates where this listing should continue from.",
-                      "type": "string",
-                      "location": "query"
-                    }
-                  },
-                  "httpMethod": "GET",
-                  "response": {
-                    "$ref": "SasPortalListNodesResponse"
-                  }
-                },
-                "create": {
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ],
-                  "path": "v1alpha1/{+parent}/nodes",
-                  "description": "Creates a new node.",
-                  "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}/nodes",
-                  "parameters": {
-                    "parent": {
-                      "description": "Required. The parent resource name where the node is to be created.",
-                      "pattern": "^nodes/[^/]+/nodes/[^/]+$",
-                      "required": true,
-                      "location": "path",
-                      "type": "string"
-                    }
-                  },
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "response": {
-                    "$ref": "SasPortalNode"
-                  },
-                  "httpMethod": "POST",
-                  "id": "prod_tt_sasportal.nodes.nodes.nodes.create",
-                  "request": {
-                    "$ref": "SasPortalNode"
-                  }
-                }
-              }
-            },
-            "devices": {
-              "methods": {
-                "create": {
-                  "request": {
-                    "$ref": "SasPortalDevice"
-                  },
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "parameters": {
-                    "parent": {
-                      "pattern": "^nodes/[^/]+/nodes/[^/]+$",
-                      "description": "Required. The name of the parent resource.",
-                      "required": true,
-                      "location": "path",
-                      "type": "string"
-                    }
-                  },
-                  "httpMethod": "POST",
-                  "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}/devices",
-                  "path": "v1alpha1/{+parent}/devices",
-                  "response": {
-                    "$ref": "SasPortalDevice"
-                  },
-                  "description": "Creates a device under a node or customer.",
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ],
-                  "id": "prod_tt_sasportal.nodes.nodes.devices.create"
-                },
-                "createSigned": {
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ],
-                  "parameters": {
-                    "parent": {
-                      "description": "Required. The name of the parent resource.",
-                      "type": "string",
-                      "pattern": "^nodes/[^/]+/nodes/[^/]+$",
-                      "required": true,
-                      "location": "path"
-                    }
-                  },
-                  "path": "v1alpha1/{+parent}/devices:createSigned",
-                  "httpMethod": "POST",
-                  "description": "Creates a signed device under a node or customer.",
-                  "request": {
-                    "$ref": "SasPortalCreateSignedDeviceRequest"
-                  },
-                  "response": {
-                    "$ref": "SasPortalDevice"
-                  },
-                  "id": "prod_tt_sasportal.nodes.nodes.devices.createSigned",
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}/devices:createSigned"
-                },
-                "bulk": {
-                  "response": {
-                    "$ref": "SasPortalBulkCreateDeviceResponse"
-                  },
-                  "id": "prod_tt_sasportal.nodes.nodes.devices.bulk",
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ],
-                  "httpMethod": "POST",
-                  "description": "Creates a device under a node or customer. Returned devices are unordered.",
-                  "request": {
-                    "$ref": "SasPortalBulkCreateDeviceRequest"
-                  },
-                  "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}/devices:bulk",
-                  "path": "v1alpha1/{+parent}/devices:bulk",
-                  "parameters": {
-                    "parent": {
-                      "location": "path",
-                      "type": "string",
-                      "description": "Required. The name of the parent resource.",
-                      "pattern": "^nodes/[^/]+/nodes/[^/]+$",
-                      "required": true
-                    }
-                  },
-                  "parameterOrder": [
-                    "parent"
-                  ]
-                },
-                "list": {
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ],
-                  "response": {
-                    "$ref": "SasPortalListDevicesResponse"
-                  },
-                  "httpMethod": "GET",
-                  "description": "Lists devices under a node or customer.",
-                  "parameters": {
-                    "filter": {
-                      "location": "query",
-                      "description": "The filter expression. The filter should have one of the following formats: \"sn=123454\" or \"display_name=MyDevice\". sn corresponds to serial_number of the device. The filter is case insensitive.",
-                      "type": "string"
-                    },
-                    "parent": {
-                      "description": "Required. The name of the parent resource.",
-                      "type": "string",
-                      "location": "path",
-                      "pattern": "^nodes/[^/]+/nodes/[^/]+$",
-                      "required": true
-                    },
-                    "pageToken": {
-                      "location": "query",
-                      "description": "A pagination token returned from a previous call to ListDevices that indicates where this listing should continue from.",
-                      "type": "string"
-                    },
-                    "pageSize": {
-                      "format": "int32",
-                      "type": "integer",
-                      "description": "The maximum number of devices to return in the response. If empty or zero, all devices will be listed. Must be in the range [0, 1000].",
-                      "location": "query"
-                    }
-                  },
-                  "id": "prod_tt_sasportal.nodes.nodes.devices.list",
-                  "flatPath": "v1alpha1/nodes/{nodesId}/nodes/{nodesId1}/devices",
-                  "path": "v1alpha1/{+parent}/devices",
-                  "parameterOrder": [
-                    "parent"
-                  ]
-                }
-              }
-            }
-          }
-        },
-        "deployments": {
-          "methods": {
-            "move": {
-              "path": "v1alpha1/{+name}:move",
-              "description": "Moves a deployment under another node or customer.",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "httpMethod": "POST",
-              "id": "prod_tt_sasportal.nodes.deployments.move",
-              "request": {
-                "$ref": "SasPortalMoveDeploymentRequest"
-              },
-              "parameterOrder": [
-                "name"
-              ],
-              "parameters": {
-                "name": {
-                  "location": "path",
-                  "type": "string",
-                  "required": true,
-                  "description": "Required. The name of the deployment to move.",
-                  "pattern": "^nodes/[^/]+/deployments/[^/]+$"
-                }
-              },
-              "response": {
-                "$ref": "SasPortalOperation"
-              },
-              "flatPath": "v1alpha1/nodes/{nodesId}/deployments/{deploymentsId}:move"
-            }
-          },
-          "resources": {
-            "devices": {
-              "methods": {
-                "list": {
-                  "description": "Lists devices under a node or customer.",
-                  "httpMethod": "GET",
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ],
-                  "parameters": {
-                    "pageToken": {
-                      "location": "query",
-                      "type": "string",
-                      "description": "A pagination token returned from a previous call to ListDevices that indicates where this listing should continue from."
-                    },
-                    "pageSize": {
-                      "format": "int32",
-                      "description": "The maximum number of devices to return in the response. If empty or zero, all devices will be listed. Must be in the range [0, 1000].",
-                      "type": "integer",
-                      "location": "query"
-                    },
-                    "parent": {
-                      "description": "Required. The name of the parent resource.",
-                      "required": true,
-                      "location": "path",
-                      "pattern": "^nodes/[^/]+/deployments/[^/]+$",
-                      "type": "string"
-                    },
-                    "filter": {
-                      "description": "The filter expression. The filter should have one of the following formats: \"sn=123454\" or \"display_name=MyDevice\". sn corresponds to serial_number of the device. The filter is case insensitive.",
-                      "type": "string",
-                      "location": "query"
-                    }
-                  },
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "path": "v1alpha1/{+parent}/devices",
-                  "response": {
-                    "$ref": "SasPortalListDevicesResponse"
-                  },
-                  "id": "prod_tt_sasportal.nodes.deployments.devices.list",
-                  "flatPath": "v1alpha1/nodes/{nodesId}/deployments/{deploymentsId}/devices"
-                },
-                "create": {
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ],
-                  "path": "v1alpha1/{+parent}/devices",
-                  "request": {
-                    "$ref": "SasPortalDevice"
-                  },
-                  "description": "Creates a device under a node or customer.",
-                  "id": "prod_tt_sasportal.nodes.deployments.devices.create",
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "parameters": {
-                    "parent": {
-                      "type": "string",
-                      "location": "path",
-                      "required": true,
-                      "description": "Required. The name of the parent resource.",
-                      "pattern": "^nodes/[^/]+/deployments/[^/]+$"
-                    }
-                  },
-                  "flatPath": "v1alpha1/nodes/{nodesId}/deployments/{deploymentsId}/devices",
-                  "response": {
-                    "$ref": "SasPortalDevice"
-                  },
-                  "httpMethod": "POST"
-                },
-                "createSigned": {
-                  "httpMethod": "POST",
-                  "request": {
-                    "$ref": "SasPortalCreateSignedDeviceRequest"
-                  },
-                  "description": "Creates a signed device under a node or customer.",
-                  "id": "prod_tt_sasportal.nodes.deployments.devices.createSigned",
-                  "parameters": {
-                    "parent": {
-                      "type": "string",
-                      "location": "path",
-                      "pattern": "^nodes/[^/]+/deployments/[^/]+$",
-                      "description": "Required. The name of the parent resource.",
-                      "required": true
-                    }
-                  },
-                  "flatPath": "v1alpha1/nodes/{nodesId}/deployments/{deploymentsId}/devices:createSigned",
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "path": "v1alpha1/{+parent}/devices:createSigned",
-                  "response": {
-                    "$ref": "SasPortalDevice"
-                  },
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ]
-                }
-              }
-            }
-          }
-        }
-      },
-      "methods": {
-        "get": {
-          "path": "v1alpha1/{+name}",
-          "httpMethod": "GET",
-          "id": "prod_tt_sasportal.nodes.get",
-          "description": "Returns a requested node.",
-          "flatPath": "v1alpha1/nodes/{nodesId}",
-          "scopes": [
-            "https://www.googleapis.com/auth/userinfo.email"
-          ],
-          "parameterOrder": [
-            "name"
-          ],
-          "response": {
-            "$ref": "SasPortalNode"
-          },
-          "parameters": {
-            "name": {
-              "description": "Required. The name of the node.",
-              "pattern": "^nodes/[^/]+$",
-              "required": true,
-              "location": "path",
-              "type": "string"
-            }
-          }
-        }
-      }
-    },
-    "policies": {
-      "methods": {
-        "get": {
-          "httpMethod": "POST",
-          "id": "prod_tt_sasportal.policies.get",
-          "description": "Gets the access control policy for a resource. Returns an empty policy if the resource exists and does not have a policy set.",
-          "request": {
-            "$ref": "SasPortalGetPolicyRequest"
-          },
-          "scopes": [
-            "https://www.googleapis.com/auth/userinfo.email"
-          ],
-          "flatPath": "v1alpha1/policies:get",
-          "response": {
-            "$ref": "SasPortalPolicy"
-          },
-          "path": "v1alpha1/policies:get",
-          "parameters": {},
-          "parameterOrder": []
-        },
-        "test": {
-          "scopes": [
-            "https://www.googleapis.com/auth/userinfo.email"
-          ],
-          "parameterOrder": [],
-          "request": {
-            "$ref": "SasPortalTestPermissionsRequest"
-          },
-          "httpMethod": "POST",
-          "parameters": {},
-          "description": "Returns permissions that a caller has on the specified resource.",
-          "response": {
-            "$ref": "SasPortalTestPermissionsResponse"
-          },
-          "id": "prod_tt_sasportal.policies.test",
-          "flatPath": "v1alpha1/policies:test",
-          "path": "v1alpha1/policies:test"
-        },
-        "set": {
-          "parameters": {},
-          "parameterOrder": [],
-          "httpMethod": "POST",
-          "flatPath": "v1alpha1/policies:set",
-          "id": "prod_tt_sasportal.policies.set",
-          "request": {
-            "$ref": "SasPortalSetPolicyRequest"
-          },
-          "path": "v1alpha1/policies:set",
-          "response": {
-            "$ref": "SasPortalPolicy"
-          },
-          "scopes": [
-            "https://www.googleapis.com/auth/userinfo.email"
-          ],
-          "description": "Sets the access control policy on the specified resource. Replaces any existing policy."
-        }
-      }
-    },
-    "customers": {
-      "methods": {
-        "patch": {
-          "response": {
-            "$ref": "SasPortalCustomer"
-          },
-          "description": "Updates an existing customer.",
-          "id": "prod_tt_sasportal.customers.patch",
-          "httpMethod": "PATCH",
-          "scopes": [
-            "https://www.googleapis.com/auth/userinfo.email"
-          ],
-          "parameters": {
-            "updateMask": {
-              "type": "string",
-              "format": "google-fieldmask",
-              "description": "Fields to be updated.",
-              "location": "query"
-            },
-            "name": {
-              "location": "path",
-              "type": "string",
-              "description": "Output only. Resource name of the customer.",
-              "pattern": "^customers/[^/]+$",
-              "required": true
-            }
-          },
-          "parameterOrder": [
-            "name"
-          ],
-          "request": {
-            "$ref": "SasPortalCustomer"
-          },
-          "flatPath": "v1alpha1/customers/{customersId}",
-          "path": "v1alpha1/{+name}"
-        },
-        "get": {
-          "parameterOrder": [
-            "name"
-          ],
-          "flatPath": "v1alpha1/customers/{customersId}",
-          "scopes": [
-            "https://www.googleapis.com/auth/userinfo.email"
-          ],
-          "httpMethod": "GET",
-          "description": "Returns a requested customer.",
-          "response": {
-            "$ref": "SasPortalCustomer"
-          },
-          "parameters": {
-            "name": {
-              "location": "path",
-              "type": "string",
-              "required": true,
-              "description": "Required. The name of the customer.",
-              "pattern": "^customers/[^/]+$"
-            }
-          },
-          "path": "v1alpha1/{+name}",
-          "id": "prod_tt_sasportal.customers.get"
-        },
-        "list": {
-          "response": {
-            "$ref": "SasPortalListCustomersResponse"
-          },
-          "parameterOrder": [],
-          "id": "prod_tt_sasportal.customers.list",
-          "scopes": [
-            "https://www.googleapis.com/auth/userinfo.email"
-          ],
-          "path": "v1alpha1/customers",
-          "httpMethod": "GET",
-          "parameters": {
-            "pageSize": {
-              "description": "The maximum number of customers to return in the response.",
-              "location": "query",
-              "format": "int32",
-              "type": "integer"
-            },
-            "pageToken": {
-              "description": "A pagination token returned from a previous call to ListCustomers method that indicates where this listing should continue from.",
-              "type": "string",
-              "location": "query"
-            }
-          },
-          "description": "Returns a list of requested customers.",
-          "flatPath": "v1alpha1/customers"
-        }
-      },
-      "resources": {
-        "devices": {
-          "methods": {
-            "delete": {
-              "flatPath": "v1alpha1/customers/{customersId}/devices/{devicesId}",
-              "description": "Deletes a device.",
-              "id": "prod_tt_sasportal.customers.devices.delete",
-              "httpMethod": "DELETE",
-              "parameters": {
-                "name": {
-                  "type": "string",
-                  "pattern": "^customers/[^/]+/devices/[^/]+$",
-                  "required": true,
-                  "description": "Required. The name of the device.",
-                  "location": "path"
-                }
-              },
-              "path": "v1alpha1/{+name}",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "response": {
-                "$ref": "SasPortalEmpty"
-              },
-              "parameterOrder": [
-                "name"
-              ]
-            },
-            "updateSigned": {
-              "path": "v1alpha1/{+name}:updateSigned",
-              "parameterOrder": [
-                "name"
-              ],
-              "request": {
-                "$ref": "SasPortalUpdateSignedDeviceRequest"
-              },
-              "httpMethod": "PATCH",
-              "description": "Updates a signed device.",
-              "id": "prod_tt_sasportal.customers.devices.updateSigned",
-              "flatPath": "v1alpha1/customers/{customersId}/devices/{devicesId}:updateSigned",
-              "response": {
-                "$ref": "SasPortalDevice"
-              },
-              "parameters": {
-                "name": {
-                  "location": "path",
-                  "required": true,
-                  "pattern": "^customers/[^/]+/devices/[^/]+$",
-                  "description": "Required. The name of the device to update.",
-                  "type": "string"
-                }
-              },
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ]
-            },
-            "move": {
-              "id": "prod_tt_sasportal.customers.devices.move",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "description": "Moves a device under another node or customer.",
-              "path": "v1alpha1/{+name}:move",
-              "response": {
-                "$ref": "SasPortalOperation"
-              },
-              "parameterOrder": [
-                "name"
-              ],
-              "flatPath": "v1alpha1/customers/{customersId}/devices/{devicesId}:move",
-              "request": {
-                "$ref": "SasPortalMoveDeviceRequest"
-              },
-              "parameters": {
-                "name": {
-                  "type": "string",
-                  "location": "path",
-                  "description": "Required. The name of the device to move.",
-                  "required": true,
-                  "pattern": "^customers/[^/]+/devices/[^/]+$"
-                }
-              },
-              "httpMethod": "POST"
-            },
-            "list": {
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "description": "Lists devices under a node or customer.",
-              "response": {
-                "$ref": "SasPortalListDevicesResponse"
-              },
-              "path": "v1alpha1/{+parent}/devices",
-              "parameterOrder": [
-                "parent"
-              ],
-              "flatPath": "v1alpha1/customers/{customersId}/devices",
-              "httpMethod": "GET",
-              "parameters": {
-                "pageSize": {
-                  "description": "The maximum number of devices to return in the response. If empty or zero, all devices will be listed. Must be in the range [0, 1000].",
-                  "type": "integer",
-                  "location": "query",
-                  "format": "int32"
-                },
-                "filter": {
-                  "location": "query",
-                  "type": "string",
-                  "description": "The filter expression. The filter should have one of the following formats: \"sn=123454\" or \"display_name=MyDevice\". sn corresponds to serial_number of the device. The filter is case insensitive."
-                },
-                "parent": {
-                  "description": "Required. The name of the parent resource.",
-                  "pattern": "^customers/[^/]+$",
-                  "type": "string",
-                  "required": true,
-                  "location": "path"
-                },
-                "pageToken": {
-                  "description": "A pagination token returned from a previous call to ListDevices that indicates where this listing should continue from.",
-                  "location": "query",
-                  "type": "string"
-                }
-              },
-              "id": "prod_tt_sasportal.customers.devices.list"
-            },
-            "bulk": {
-              "response": {
-                "$ref": "SasPortalBulkCreateDeviceResponse"
-              },
-              "flatPath": "v1alpha1/customers/{customersId}/devices:bulk",
-              "request": {
-                "$ref": "SasPortalBulkCreateDeviceRequest"
-              },
-              "path": "v1alpha1/{+parent}/devices:bulk",
-              "httpMethod": "POST",
-              "description": "Creates a device under a node or customer. Returned devices are unordered.",
-              "id": "prod_tt_sasportal.customers.devices.bulk",
-              "parameters": {
-                "parent": {
-                  "description": "Required. The name of the parent resource.",
-                  "pattern": "^customers/[^/]+$",
-                  "required": true,
-                  "type": "string",
-                  "location": "path"
-                }
-              },
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "parameterOrder": [
-                "parent"
-              ]
-            },
-            "createSigned": {
-              "parameters": {
-                "parent": {
-                  "type": "string",
-                  "location": "path",
-                  "pattern": "^customers/[^/]+$",
-                  "description": "Required. The name of the parent resource.",
-                  "required": true
-                }
-              },
-              "parameterOrder": [
-                "parent"
-              ],
-              "description": "Creates a signed device under a node or customer.",
-              "id": "prod_tt_sasportal.customers.devices.createSigned",
-              "httpMethod": "POST",
-              "path": "v1alpha1/{+parent}/devices:createSigned",
-              "request": {
-                "$ref": "SasPortalCreateSignedDeviceRequest"
-              },
-              "response": {
-                "$ref": "SasPortalDevice"
-              },
-              "flatPath": "v1alpha1/customers/{customersId}/devices:createSigned",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ]
-            },
-            "create": {
-              "parameterOrder": [
-                "parent"
-              ],
-              "httpMethod": "POST",
-              "path": "v1alpha1/{+parent}/devices",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "flatPath": "v1alpha1/customers/{customersId}/devices",
-              "description": "Creates a device under a node or customer.",
-              "response": {
-                "$ref": "SasPortalDevice"
-              },
-              "parameters": {
-                "parent": {
-                  "type": "string",
-                  "required": true,
-                  "location": "path",
-                  "description": "Required. The name of the parent resource.",
-                  "pattern": "^customers/[^/]+$"
-                }
-              },
-              "id": "prod_tt_sasportal.customers.devices.create",
-              "request": {
-                "$ref": "SasPortalDevice"
-              }
-            },
-            "patch": {
-              "description": "Updates a device.",
-              "id": "prod_tt_sasportal.customers.devices.patch",
-              "httpMethod": "PATCH",
-              "path": "v1alpha1/{+name}",
-              "request": {
-                "$ref": "SasPortalDevice"
-              },
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "response": {
-                "$ref": "SasPortalDevice"
-              },
-              "flatPath": "v1alpha1/customers/{customersId}/devices/{devicesId}",
-              "parameters": {
-                "name": {
-                  "pattern": "^customers/[^/]+/devices/[^/]+$",
-                  "type": "string",
-                  "location": "path",
-                  "description": "Output only. The resource path name.",
-                  "required": true
-                },
-                "updateMask": {
-                  "type": "string",
-                  "format": "google-fieldmask",
-                  "description": "Fields to be updated.",
-                  "location": "query"
-                }
-              },
-              "parameterOrder": [
-                "name"
-              ]
-            },
-            "get": {
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "flatPath": "v1alpha1/customers/{customersId}/devices/{devicesId}",
-              "id": "prod_tt_sasportal.customers.devices.get",
-              "parameters": {
-                "name": {
-                  "location": "path",
-                  "required": true,
-                  "description": "Required. The name of the device.",
-                  "pattern": "^customers/[^/]+/devices/[^/]+$",
-                  "type": "string"
-                }
-              },
-              "parameterOrder": [
-                "name"
-              ],
-              "httpMethod": "GET",
-              "path": "v1alpha1/{+name}",
-              "description": "Gets details about a device.",
-              "response": {
-                "$ref": "SasPortalDevice"
-              }
-            },
-            "signDevice": {
-              "httpMethod": "POST",
-              "parameters": {
-                "name": {
-                  "required": true,
-                  "location": "path",
-                  "description": "Output only. The resource path name.",
-                  "pattern": "^customers/[^/]+/devices/[^/]+$",
-                  "type": "string"
-                }
-              },
-              "description": "Signs a device.",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "request": {
-                "$ref": "SasPortalSignDeviceRequest"
-              },
-              "flatPath": "v1alpha1/customers/{customersId}/devices/{devicesId}:signDevice",
-              "path": "v1alpha1/{+name}:signDevice",
-              "parameterOrder": [
-                "name"
-              ],
-              "id": "prod_tt_sasportal.customers.devices.signDevice",
-              "response": {
-                "$ref": "SasPortalEmpty"
-              }
-            }
-          }
-        },
-        "deployments": {
-          "methods": {
-            "move": {
-              "parameters": {
-                "name": {
-                  "description": "Required. The name of the deployment to move.",
-                  "pattern": "^customers/[^/]+/deployments/[^/]+$",
-                  "required": true,
-                  "type": "string",
-                  "location": "path"
-                }
-              },
-              "response": {
-                "$ref": "SasPortalOperation"
-              },
-              "description": "Moves a deployment under another node or customer.",
-              "httpMethod": "POST",
-              "path": "v1alpha1/{+name}:move",
-              "flatPath": "v1alpha1/customers/{customersId}/deployments/{deploymentsId}:move",
-              "parameterOrder": [
-                "name"
-              ],
-              "id": "prod_tt_sasportal.customers.deployments.move",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "request": {
-                "$ref": "SasPortalMoveDeploymentRequest"
-              }
-            }
-          },
-          "resources": {
-            "devices": {
-              "methods": {
-                "create": {
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ],
-                  "httpMethod": "POST",
-                  "request": {
-                    "$ref": "SasPortalDevice"
-                  },
-                  "response": {
-                    "$ref": "SasPortalDevice"
-                  },
-                  "description": "Creates a device under a node or customer.",
-                  "parameters": {
-                    "parent": {
-                      "type": "string",
-                      "description": "Required. The name of the parent resource.",
-                      "location": "path",
-                      "required": true,
-                      "pattern": "^customers/[^/]+/deployments/[^/]+$"
-                    }
-                  },
-                  "id": "prod_tt_sasportal.customers.deployments.devices.create",
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "flatPath": "v1alpha1/customers/{customersId}/deployments/{deploymentsId}/devices",
-                  "path": "v1alpha1/{+parent}/devices"
-                },
-                "list": {
-                  "id": "prod_tt_sasportal.customers.deployments.devices.list",
-                  "description": "Lists devices under a node or customer.",
-                  "response": {
-                    "$ref": "SasPortalListDevicesResponse"
-                  },
-                  "flatPath": "v1alpha1/customers/{customersId}/deployments/{deploymentsId}/devices",
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ],
-                  "parameters": {
-                    "pageToken": {
-                      "description": "A pagination token returned from a previous call to ListDevices that indicates where this listing should continue from.",
-                      "location": "query",
-                      "type": "string"
-                    },
-                    "filter": {
-                      "description": "The filter expression. The filter should have one of the following formats: \"sn=123454\" or \"display_name=MyDevice\". sn corresponds to serial_number of the device. The filter is case insensitive.",
-                      "location": "query",
-                      "type": "string"
-                    },
-                    "pageSize": {
-                      "type": "integer",
-                      "format": "int32",
-                      "location": "query",
-                      "description": "The maximum number of devices to return in the response. If empty or zero, all devices will be listed. Must be in the range [0, 1000]."
-                    },
-                    "parent": {
-                      "type": "string",
-                      "description": "Required. The name of the parent resource.",
-                      "required": true,
-                      "pattern": "^customers/[^/]+/deployments/[^/]+$",
-                      "location": "path"
-                    }
-                  },
-                  "httpMethod": "GET",
-                  "path": "v1alpha1/{+parent}/devices"
-                },
-                "createSigned": {
-                  "request": {
-                    "$ref": "SasPortalCreateSignedDeviceRequest"
-                  },
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "response": {
-                    "$ref": "SasPortalDevice"
-                  },
-                  "httpMethod": "POST",
-                  "parameters": {
-                    "parent": {
-                      "location": "path",
-                      "description": "Required. The name of the parent resource.",
-                      "pattern": "^customers/[^/]+/deployments/[^/]+$",
-                      "required": true,
-                      "type": "string"
-                    }
-                  },
-                  "id": "prod_tt_sasportal.customers.deployments.devices.createSigned",
-                  "path": "v1alpha1/{+parent}/devices:createSigned",
-                  "description": "Creates a signed device under a node or customer.",
-                  "flatPath": "v1alpha1/customers/{customersId}/deployments/{deploymentsId}/devices:createSigned",
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ]
-                }
-              }
-            }
-          }
-        },
-        "nodes": {
-          "methods": {
-            "patch": {
-              "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}",
-              "response": {
-                "$ref": "SasPortalNode"
-              },
-              "request": {
-                "$ref": "SasPortalNode"
-              },
-              "description": "Updates an existing node.",
-              "parameters": {
-                "name": {
-                  "description": "Output only. Resource name.",
-                  "pattern": "^customers/[^/]+/nodes/[^/]+$",
-                  "location": "path",
-                  "type": "string",
-                  "required": true
-                },
-                "updateMask": {
-                  "location": "query",
-                  "description": "Fields to be updated.",
-                  "format": "google-fieldmask",
-                  "type": "string"
-                }
-              },
-              "path": "v1alpha1/{+name}",
-              "httpMethod": "PATCH",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "parameterOrder": [
-                "name"
-              ],
-              "id": "prod_tt_sasportal.customers.nodes.patch"
-            },
-            "delete": {
-              "id": "prod_tt_sasportal.customers.nodes.delete",
-              "httpMethod": "DELETE",
-              "parameters": {
-                "name": {
-                  "location": "path",
-                  "description": "Required. The name of the node.",
-                  "pattern": "^customers/[^/]+/nodes/[^/]+$",
-                  "required": true,
-                  "type": "string"
-                }
-              },
-              "path": "v1alpha1/{+name}",
-              "description": "Deletes a node.",
-              "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}",
-              "parameterOrder": [
-                "name"
-              ],
-              "response": {
-                "$ref": "SasPortalEmpty"
-              },
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ]
-            },
-            "list": {
-              "response": {
-                "$ref": "SasPortalListNodesResponse"
-              },
-              "description": "Lists nodes.",
-              "flatPath": "v1alpha1/customers/{customersId}/nodes",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "id": "prod_tt_sasportal.customers.nodes.list",
-              "path": "v1alpha1/{+parent}/nodes",
-              "httpMethod": "GET",
-              "parameterOrder": [
-                "parent"
-              ],
-              "parameters": {
-                "pageSize": {
-                  "description": "The maximum number of nodes to return in the response.",
-                  "format": "int32",
-                  "location": "query",
-                  "type": "integer"
-                },
-                "pageToken": {
-                  "type": "string",
-                  "location": "query",
-                  "description": "A pagination token returned from a previous call to ListNodes method that indicates where this listing should continue from."
-                },
-                "parent": {
-                  "type": "string",
-                  "pattern": "^customers/[^/]+$",
-                  "description": "Required. The parent resource name, for example, \"nodes/1\".",
-                  "required": true,
-                  "location": "path"
-                }
-              }
-            },
-            "create": {
-              "parameters": {
-                "parent": {
-                  "location": "path",
-                  "type": "string",
-                  "description": "Required. The parent resource name where the node is to be created.",
-                  "pattern": "^customers/[^/]+$",
-                  "required": true
-                }
-              },
-              "flatPath": "v1alpha1/customers/{customersId}/nodes",
-              "path": "v1alpha1/{+parent}/nodes",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "description": "Creates a new node.",
-              "response": {
-                "$ref": "SasPortalNode"
-              },
-              "httpMethod": "POST",
-              "id": "prod_tt_sasportal.customers.nodes.create",
-              "parameterOrder": [
-                "parent"
-              ],
-              "request": {
-                "$ref": "SasPortalNode"
-              }
-            },
-            "get": {
-              "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "httpMethod": "GET",
-              "parameterOrder": [
-                "name"
-              ],
-              "description": "Returns a requested node.",
-              "path": "v1alpha1/{+name}",
-              "id": "prod_tt_sasportal.customers.nodes.get",
-              "response": {
-                "$ref": "SasPortalNode"
-              },
-              "parameters": {
-                "name": {
-                  "location": "path",
-                  "type": "string",
-                  "pattern": "^customers/[^/]+/nodes/[^/]+$",
-                  "description": "Required. The name of the node.",
-                  "required": true
-                }
-              }
-            },
-            "move": {
-              "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}:move",
-              "response": {
-                "$ref": "SasPortalOperation"
-              },
-              "path": "v1alpha1/{+name}:move",
-              "parameterOrder": [
-                "name"
-              ],
-              "httpMethod": "POST",
-              "request": {
-                "$ref": "SasPortalMoveNodeRequest"
-              },
-              "id": "prod_tt_sasportal.customers.nodes.move",
-              "parameters": {
-                "name": {
-                  "description": "Required. The name of the node to move.",
-                  "required": true,
-                  "pattern": "^customers/[^/]+/nodes/[^/]+$",
-                  "location": "path",
-                  "type": "string"
-                }
-              },
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "description": "Moves a node under another node or customer."
-            }
-          },
-          "resources": {
-            "nodes": {
-              "methods": {
-                "list": {
-                  "parameters": {
-                    "pageSize": {
-                      "type": "integer",
-                      "location": "query",
-                      "format": "int32",
-                      "description": "The maximum number of nodes to return in the response."
-                    },
-                    "parent": {
-                      "pattern": "^customers/[^/]+/nodes/[^/]+$",
-                      "location": "path",
-                      "type": "string",
-                      "description": "Required. The parent resource name, for example, \"nodes/1\".",
-                      "required": true
-                    },
-                    "pageToken": {
-                      "location": "query",
-                      "description": "A pagination token returned from a previous call to ListNodes method that indicates where this listing should continue from.",
-                      "type": "string"
-                    }
-                  },
-                  "id": "prod_tt_sasportal.customers.nodes.nodes.list",
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ],
-                  "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}/nodes",
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "httpMethod": "GET",
-                  "path": "v1alpha1/{+parent}/nodes",
-                  "response": {
-                    "$ref": "SasPortalListNodesResponse"
-                  },
-                  "description": "Lists nodes."
-                },
-                "create": {
-                  "httpMethod": "POST",
-                  "response": {
-                    "$ref": "SasPortalNode"
-                  },
-                  "description": "Creates a new node.",
-                  "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}/nodes",
-                  "parameters": {
-                    "parent": {
-                      "location": "path",
-                      "pattern": "^customers/[^/]+/nodes/[^/]+$",
-                      "type": "string",
-                      "required": true,
-                      "description": "Required. The parent resource name where the node is to be created."
-                    }
-                  },
-                  "request": {
-                    "$ref": "SasPortalNode"
-                  },
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ],
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "path": "v1alpha1/{+parent}/nodes",
-                  "id": "prod_tt_sasportal.customers.nodes.nodes.create"
-                }
-              }
-            },
-            "devices": {
-              "methods": {
-                "list": {
-                  "parameters": {
-                    "filter": {
-                      "type": "string",
-                      "description": "The filter expression. The filter should have one of the following formats: \"sn=123454\" or \"display_name=MyDevice\". sn corresponds to serial_number of the device. The filter is case insensitive.",
-                      "location": "query"
-                    },
-                    "parent": {
-                      "type": "string",
-                      "description": "Required. The name of the parent resource.",
-                      "required": true,
-                      "location": "path",
-                      "pattern": "^customers/[^/]+/nodes/[^/]+$"
-                    },
-                    "pageSize": {
-                      "location": "query",
-                      "format": "int32",
-                      "type": "integer",
-                      "description": "The maximum number of devices to return in the response. If empty or zero, all devices will be listed. Must be in the range [0, 1000]."
-                    },
-                    "pageToken": {
-                      "location": "query",
-                      "description": "A pagination token returned from a previous call to ListDevices that indicates where this listing should continue from.",
-                      "type": "string"
-                    }
-                  },
-                  "path": "v1alpha1/{+parent}/devices",
-                  "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}/devices",
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "description": "Lists devices under a node or customer.",
-                  "httpMethod": "GET",
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ],
-                  "response": {
-                    "$ref": "SasPortalListDevicesResponse"
-                  },
-                  "id": "prod_tt_sasportal.customers.nodes.devices.list"
-                },
-                "createSigned": {
-                  "description": "Creates a signed device under a node or customer.",
-                  "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}/devices:createSigned",
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ],
-                  "response": {
-                    "$ref": "SasPortalDevice"
-                  },
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "httpMethod": "POST",
-                  "request": {
-                    "$ref": "SasPortalCreateSignedDeviceRequest"
-                  },
-                  "parameters": {
-                    "parent": {
-                      "pattern": "^customers/[^/]+/nodes/[^/]+$",
-                      "location": "path",
-                      "type": "string",
-                      "required": true,
-                      "description": "Required. The name of the parent resource."
-                    }
-                  },
-                  "id": "prod_tt_sasportal.customers.nodes.devices.createSigned",
-                  "path": "v1alpha1/{+parent}/devices:createSigned"
-                },
-                "create": {
-                  "flatPath": "v1alpha1/customers/{customersId}/nodes/{nodesId}/devices",
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "id": "prod_tt_sasportal.customers.nodes.devices.create",
-                  "request": {
-                    "$ref": "SasPortalDevice"
-                  },
-                  "response": {
-                    "$ref": "SasPortalDevice"
-                  },
-                  "path": "v1alpha1/{+parent}/devices",
-                  "scopes": [
-                    "https://www.googleapis.com/auth/userinfo.email"
-                  ],
-                  "description": "Creates a device under a node or customer.",
-                  "httpMethod": "POST",
-                  "parameters": {
-                    "parent": {
-                      "description": "Required. The name of the parent resource.",
-                      "type": "string",
-                      "required": true,
-                      "location": "path",
-                      "pattern": "^customers/[^/]+/nodes/[^/]+$"
-                    }
-                  }
-                }
-              }
-            }
-          }
-        }
-      }
-    },
-    "deployments": {
-      "resources": {
-        "devices": {
-          "methods": {
-            "delete": {
-              "parameterOrder": [
-                "name"
-              ],
-              "httpMethod": "DELETE",
-              "path": "v1alpha1/{+name}",
-              "description": "Deletes a device.",
-              "flatPath": "v1alpha1/deployments/{deploymentsId}/devices/{devicesId}",
-              "parameters": {
-                "name": {
-                  "location": "path",
-                  "type": "string",
-                  "description": "Required. The name of the device.",
-                  "required": true,
-                  "pattern": "^deployments/[^/]+/devices/[^/]+$"
-                }
-              },
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "id": "prod_tt_sasportal.deployments.devices.delete",
-              "response": {
-                "$ref": "SasPortalEmpty"
-              }
-            },
-            "move": {
-              "parameters": {
-                "name": {
-                  "location": "path",
-                  "required": true,
-                  "description": "Required. The name of the device to move.",
-                  "pattern": "^deployments/[^/]+/devices/[^/]+$",
-                  "type": "string"
-                }
-              },
-              "description": "Moves a device under another node or customer.",
-              "parameterOrder": [
-                "name"
-              ],
-              "response": {
-                "$ref": "SasPortalOperation"
-              },
-              "id": "prod_tt_sasportal.deployments.devices.move",
-              "request": {
-                "$ref": "SasPortalMoveDeviceRequest"
-              },
-              "flatPath": "v1alpha1/deployments/{deploymentsId}/devices/{devicesId}:move",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "httpMethod": "POST",
-              "path": "v1alpha1/{+name}:move"
-            },
-            "updateSigned": {
-              "response": {
-                "$ref": "SasPortalDevice"
-              },
-              "httpMethod": "PATCH",
-              "description": "Updates a signed device.",
-              "parameters": {
-                "name": {
-                  "description": "Required. The name of the device to update.",
-                  "pattern": "^deployments/[^/]+/devices/[^/]+$",
-                  "location": "path",
-                  "type": "string",
-                  "required": true
-                }
-              },
-              "flatPath": "v1alpha1/deployments/{deploymentsId}/devices/{devicesId}:updateSigned",
-              "request": {
-                "$ref": "SasPortalUpdateSignedDeviceRequest"
-              },
-              "id": "prod_tt_sasportal.deployments.devices.updateSigned",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "parameterOrder": [
-                "name"
-              ],
-              "path": "v1alpha1/{+name}:updateSigned"
-            },
-            "signDevice": {
-              "id": "prod_tt_sasportal.deployments.devices.signDevice",
-              "response": {
-                "$ref": "SasPortalEmpty"
-              },
-              "httpMethod": "POST",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "path": "v1alpha1/{+name}:signDevice",
-              "parameterOrder": [
-                "name"
-              ],
-              "request": {
-                "$ref": "SasPortalSignDeviceRequest"
-              },
-              "flatPath": "v1alpha1/deployments/{deploymentsId}/devices/{devicesId}:signDevice",
-              "description": "Signs a device.",
-              "parameters": {
-                "name": {
-                  "required": true,
-                  "pattern": "^deployments/[^/]+/devices/[^/]+$",
-                  "location": "path",
-                  "type": "string",
-                  "description": "Output only. The resource path name."
-                }
-              }
-            },
-            "patch": {
-              "id": "prod_tt_sasportal.deployments.devices.patch",
-              "response": {
-                "$ref": "SasPortalDevice"
-              },
-              "parameterOrder": [
-                "name"
-              ],
-              "path": "v1alpha1/{+name}",
-              "parameters": {
-                "updateMask": {
-                  "type": "string",
-                  "format": "google-fieldmask",
-                  "description": "Fields to be updated.",
-                  "location": "query"
-                },
-                "name": {
-                  "type": "string",
-                  "pattern": "^deployments/[^/]+/devices/[^/]+$",
-                  "description": "Output only. The resource path name.",
-                  "required": true,
-                  "location": "path"
-                }
-              },
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "flatPath": "v1alpha1/deployments/{deploymentsId}/devices/{devicesId}",
-              "request": {
-                "$ref": "SasPortalDevice"
-              },
-              "description": "Updates a device.",
-              "httpMethod": "PATCH"
-            },
-            "get": {
-              "description": "Gets details about a device.",
-              "response": {
-                "$ref": "SasPortalDevice"
-              },
-              "path": "v1alpha1/{+name}",
-              "flatPath": "v1alpha1/deployments/{deploymentsId}/devices/{devicesId}",
-              "httpMethod": "GET",
-              "scopes": [
-                "https://www.googleapis.com/auth/userinfo.email"
-              ],
-              "id": "prod_tt_sasportal.deployments.devices.get",
-              "parameters": {
-                "name": {
-                  "required": true,
-                  "type": "string",
-                  "description": "Required. The name of the device.",
-                  "location": "path",
-                  "pattern": "^deployments/[^/]+/devices/[^/]+$"
-                }
-              },
-              "parameterOrder": [
-                "name"
-              ]
-            }
-          }
-        }
-      }
-    },
-    "installer": {
-      "methods": {
-        "generateSecret": {
-          "request": {
-            "$ref": "SasPortalGenerateSecretRequest"
-          },
-          "parameterOrder": [],
-          "parameters": {},
-          "scopes": [
-            "https://www.googleapis.com/auth/userinfo.email"
-          ],
-          "id": "prod_tt_sasportal.installer.generateSecret",
-          "response": {
-            "$ref": "SasPortalGenerateSecretResponse"
-          },
-          "flatPath": "v1alpha1/installer:generateSecret",
-          "path": "v1alpha1/installer:generateSecret",
-          "description": "Generates a secret to be used with the ValidateInstaller method",
-          "httpMethod": "POST"
-        },
-        "validate": {
-          "scopes": [
-            "https://www.googleapis.com/auth/userinfo.email"
-          ],
-          "parameterOrder": [],
-          "parameters": {},
-          "path": "v1alpha1/installer:validate",
-          "description": "Validates the identity of a Certified Professional Installer (CPI).",
-          "response": {
-            "$ref": "SasPortalValidateInstallerResponse"
-          },
-          "flatPath": "v1alpha1/installer:validate",
-          "request": {
-            "$ref": "SasPortalValidateInstallerRequest"
-          },
-          "httpMethod": "POST",
-          "id": "prod_tt_sasportal.installer.validate"
-        }
-      }
-    }
-  },
-  "fullyEncodeReservedExpansion": true,
-  "rootUrl": "https://prod-tt-sasportal.googleapis.com/",
-  "icons": {
-    "x32": "http://www.google.com/images/icons/product/search-32.gif",
-    "x16": "http://www.google.com/images/icons/product/search-16.gif"
-  },
-  "basePath": "",
-  "servicePath": "",
-  "title": "SAS Portal API (Testing)",
-  "ownerDomain": "google.com",
-  "name": "prod_tt_sasportal",
-  "ownerName": "Google",
-  "auth": {
-    "oauth2": {
-      "scopes": {
-        "https://www.googleapis.com/auth/userinfo.email": {
-          "description": "View your email address"
-        }
-      }
-    }
-  },
-  "kind": "discovery#restDescription",
-  "canonicalName": "SAS Portal Testing",
-  "revision": "20201013",
-  "documentationLink": "https://developers.google.com/spectrum-access-system/",
-  "discoveryVersion": "v1"
-}
+    "servicePath": "",
+    "title": "SAS Portal API (Testing)",
+    "version": "v1alpha1",
+    "version_module": true
+}
\ No newline at end of file