all: autogenerated update (2019-01-30)

Add:
- docs/v1

Update:
- adexchangebuyer2/v2beta1
- admin/reports/v1
- androidenterprise/v1
- books/v1
- cloudasset/v1beta1
- cloudbuild/v1alpha1
- doubleclickbidmanager/v1
- file/v1
- jobs/v3
- jobs/v3p1beta1
- ml/v1
- redis/v1
- redis/v1beta1
- remotebuildexecution/v1
- remotebuildexecution/v1alpha
- remotebuildexecution/v2
- servicenetworking/v1beta
- testing/v1
- toolresults/v1beta3
diff --git a/adexchangebuyer2/v2beta1/adexchangebuyer2-api.json b/adexchangebuyer2/v2beta1/adexchangebuyer2-api.json
index 153fc2d..8e5722e 100644
--- a/adexchangebuyer2/v2beta1/adexchangebuyer2-api.json
+++ b/adexchangebuyer2/v2beta1/adexchangebuyer2-api.json
@@ -2521,7 +2521,7 @@
       }
     }
   },
-  "revision": "20181210",
+  "revision": "20190128",
   "rootUrl": "https://adexchangebuyer.googleapis.com/",
   "schemas": {
     "AbsoluteDateRange": {
@@ -2967,7 +2967,7 @@
       "type": "object"
     },
     "Creative": {
-      "description": "A creative and its classification data.\n\nNext ID: 39",
+      "description": "A creative and its classification data.\n\nNext ID: 40",
       "id": "Creative",
       "properties": {
         "accountId": {
diff --git a/adexchangebuyer2/v2beta1/adexchangebuyer2-gen.go b/adexchangebuyer2/v2beta1/adexchangebuyer2-gen.go
index 447bfe8..cbaaf85 100644
--- a/adexchangebuyer2/v2beta1/adexchangebuyer2-gen.go
+++ b/adexchangebuyer2/v2beta1/adexchangebuyer2-gen.go
@@ -1307,7 +1307,7 @@
 
 // Creative: A creative and its classification data.
 //
-// Next ID: 39
+// Next ID: 40
 type Creative struct {
 	// AccountId: The account that this creative belongs to.
 	// Can be used to filter the response of the
diff --git a/admin/reports/v1/admin-api.json b/admin/reports/v1/admin-api.json
index 835d22d..eb5b4ba 100644
--- a/admin/reports/v1/admin-api.json
+++ b/admin/reports/v1/admin-api.json
@@ -18,7 +18,7 @@
   "description": "Fetches reports for the administrators of G Suite customers about the usage, collaboration, security, and risk for their users.",
   "discoveryVersion": "v1",
   "documentationLink": "https://developers.google.com/admin-sdk/reports/",
-  "etag": "\"J3WqvAcMk4eQjJXvfSI4Yr8VouA/UhkzND9lss5vlQ2BT91BGxI64WA\"",
+  "etag": "\"J3WqvAcMk4eQjJXvfSI4Yr8VouA/KxeH4adBmf7mUlvJEwydRVyJqZU\"",
   "icons": {
     "x16": "https://www.gstatic.com/images/branding/product/1x/googleg_16dp.png",
     "x32": "https://www.gstatic.com/images/branding/product/1x/googleg_32dp.png"
@@ -95,7 +95,7 @@
             "applicationName": {
               "description": "Application name for which the events are to be retrieved.",
               "location": "path",
-              "pattern": "(admin)|(calendar)|(drive)|(login)|(mobile)|(token)|(groups)|(saml)|(chat)|(gplus)|(rules)|(jamboard)|(meet)|(user_accounts)",
+              "pattern": "(admin)|(calendar)|(drive)|(login)|(mobile)|(token)|(groups)|(saml)|(chat)|(gplus)|(rules)|(jamboard)|(meet)|(user_accounts)|(access_transparency)",
               "required": true,
               "type": "string"
             },
@@ -181,7 +181,7 @@
             "applicationName": {
               "description": "Application name for which the events are to be retrieved.",
               "location": "path",
-              "pattern": "(admin)|(calendar)|(drive)|(login)|(mobile)|(token)|(groups)|(saml)|(chat)|(gplus)|(rules)|(jamboard)|(meet)|(user_accounts)",
+              "pattern": "(admin)|(calendar)|(drive)|(login)|(mobile)|(token)|(groups)|(saml)|(chat)|(gplus)|(rules)|(jamboard)|(meet)|(user_accounts)|(access_transparency)",
               "required": true,
               "type": "string"
             },
@@ -464,7 +464,7 @@
       }
     }
   },
-  "revision": "20181219",
+  "revision": "20190117",
   "rootUrl": "https://www.googleapis.com/",
   "schemas": {
     "Activities": {
diff --git a/admin/reports/v1/admin-gen.go b/admin/reports/v1/admin-gen.go
index 7dc1ece..8acadba 100644
--- a/admin/reports/v1/admin-gen.go
+++ b/admin/reports/v1/admin-gen.go
@@ -879,7 +879,7 @@
 	//     "applicationName": {
 	//       "description": "Application name for which the events are to be retrieved.",
 	//       "location": "path",
-	//       "pattern": "(admin)|(calendar)|(drive)|(login)|(mobile)|(token)|(groups)|(saml)|(chat)|(gplus)|(rules)|(jamboard)|(meet)|(user_accounts)",
+	//       "pattern": "(admin)|(calendar)|(drive)|(login)|(mobile)|(token)|(groups)|(saml)|(chat)|(gplus)|(rules)|(jamboard)|(meet)|(user_accounts)|(access_transparency)",
 	//       "required": true,
 	//       "type": "string"
 	//     },
@@ -1166,7 +1166,7 @@
 	//     "applicationName": {
 	//       "description": "Application name for which the events are to be retrieved.",
 	//       "location": "path",
-	//       "pattern": "(admin)|(calendar)|(drive)|(login)|(mobile)|(token)|(groups)|(saml)|(chat)|(gplus)|(rules)|(jamboard)|(meet)|(user_accounts)",
+	//       "pattern": "(admin)|(calendar)|(drive)|(login)|(mobile)|(token)|(groups)|(saml)|(chat)|(gplus)|(rules)|(jamboard)|(meet)|(user_accounts)|(access_transparency)",
 	//       "required": true,
 	//       "type": "string"
 	//     },
diff --git a/androidenterprise/v1/androidenterprise-api.json b/androidenterprise/v1/androidenterprise-api.json
index 02d393c..d5f7e3d 100644
--- a/androidenterprise/v1/androidenterprise-api.json
+++ b/androidenterprise/v1/androidenterprise-api.json
@@ -15,7 +15,7 @@
   "description": "Manages the deployment of apps to Android for Work users.",
   "discoveryVersion": "v1",
   "documentationLink": "https://developers.google.com/android/work/play/emm-api",
-  "etag": "\"J3WqvAcMk4eQjJXvfSI4Yr8VouA/62CTAjcZgObMIh6Lb59rsOBAAME\"",
+  "etag": "\"J3WqvAcMk4eQjJXvfSI4Yr8VouA/c9p6mtC7ozG3ElgN5bnD6rjWj10\"",
   "icons": {
     "x16": "https://www.google.com/images/icons/product/android-16.png",
     "x32": "https://www.google.com/images/icons/product/android-32.png"
@@ -1858,7 +1858,7 @@
               "type": "string"
             },
             "token": {
-              "description": "A pagination token is contained in a request''s response when there are more products. The token can be used in a subsequent request to obtain more products, and so forth. This parameter cannot be used in the initial request.",
+              "description": "A pagination token is contained in a request's response when there are more products. The token can be used in a subsequent request to obtain more products, and so forth. This parameter cannot be used in the initial request.",
               "location": "query",
               "type": "string"
             }
@@ -2911,7 +2911,7 @@
       }
     }
   },
-  "revision": "20190117",
+  "revision": "20190123",
   "rootUrl": "https://www.googleapis.com/",
   "schemas": {
     "Administrator": {
@@ -3228,15 +3228,15 @@
       "id": "AutoInstallConstraint",
       "properties": {
         "chargingStateConstraint": {
-          "description": "Charging state to constrain on.",
+          "description": "Charging state constraint.",
           "type": "string"
         },
         "deviceIdleStateConstraint": {
-          "description": "The idle state of the device to constrain on.",
+          "description": "Device idle state constraint.",
           "type": "string"
         },
         "networkTypeConstraint": {
-          "description": "Network type to constrain on.",
+          "description": "Network type constraint.",
           "type": "string"
         }
       },
@@ -3246,23 +3246,23 @@
       "id": "AutoInstallPolicy",
       "properties": {
         "autoInstallConstraint": {
-          "description": "The constraints for the install. Currently there can be at most one constraint.",
+          "description": "Constraints for auto-installing the app. You can specify a maximum of one constraint.",
           "items": {
             "$ref": "AutoInstallConstraint"
           },
           "type": "array"
         },
         "autoInstallMode": {
-          "description": "The auto install mode. If unset defaults to \"doNotAutoInstall\".",
+          "description": "The auto-install mode. If unset defaults to \"doNotAutoInstall\".",
           "type": "string"
         },
         "autoInstallPriority": {
-          "description": "The priority of the install, as an unsigned integer. Lower number means higher priority.",
+          "description": "The priority of the install, as an unsigned integer. A lower number means higher priority.",
           "format": "int32",
           "type": "integer"
         },
         "minimumVersionCode": {
-          "description": "The minimum version of the app. If a lower version of the app is installed then the app will be auto-updated according to the auto-install constraints, instead of waiting for the regular auto-update.",
+          "description": "The minimum version of the app. If a lower version of the app is installed, then the app will be auto-updated according to the auto-install constraints, instead of waiting for the regular auto-update.",
           "format": "int32",
           "type": "integer"
         }
diff --git a/androidenterprise/v1/androidenterprise-gen.go b/androidenterprise/v1/androidenterprise-gen.go
index 3b86d53..8376a8b 100644
--- a/androidenterprise/v1/androidenterprise-gen.go
+++ b/androidenterprise/v1/androidenterprise-gen.go
@@ -867,14 +867,13 @@
 // restrictions for installation. At least one of the fields must be
 // set.
 type AutoInstallConstraint struct {
-	// ChargingStateConstraint: Charging state to constrain on.
+	// ChargingStateConstraint: Charging state constraint.
 	ChargingStateConstraint string `json:"chargingStateConstraint,omitempty"`
 
-	// DeviceIdleStateConstraint: The idle state of the device to constrain
-	// on.
+	// DeviceIdleStateConstraint: Device idle state constraint.
 	DeviceIdleStateConstraint string `json:"deviceIdleStateConstraint,omitempty"`
 
-	// NetworkTypeConstraint: Network type to constrain on.
+	// NetworkTypeConstraint: Network type constraint.
 	NetworkTypeConstraint string `json:"networkTypeConstraint,omitempty"`
 
 	// ForceSendFields is a list of field names (e.g.
@@ -903,20 +902,20 @@
 }
 
 type AutoInstallPolicy struct {
-	// AutoInstallConstraint: The constraints for the install. Currently
-	// there can be at most one constraint.
+	// AutoInstallConstraint: Constraints for auto-installing the app. You
+	// can specify a maximum of one constraint.
 	AutoInstallConstraint []*AutoInstallConstraint `json:"autoInstallConstraint,omitempty"`
 
-	// AutoInstallMode: The auto install mode. If unset defaults to
+	// AutoInstallMode: The auto-install mode. If unset defaults to
 	// "doNotAutoInstall".
 	AutoInstallMode string `json:"autoInstallMode,omitempty"`
 
 	// AutoInstallPriority: The priority of the install, as an unsigned
-	// integer. Lower number means higher priority.
+	// integer. A lower number means higher priority.
 	AutoInstallPriority int64 `json:"autoInstallPriority,omitempty"`
 
 	// MinimumVersionCode: The minimum version of the app. If a lower
-	// version of the app is installed then the app will be auto-updated
+	// version of the app is installed, then the app will be auto-updated
 	// according to the auto-install constraints, instead of waiting for the
 	// regular auto-update.
 	MinimumVersionCode int64 `json:"minimumVersionCode,omitempty"`
@@ -11538,7 +11537,7 @@
 }
 
 // Token sets the optional parameter "token": A pagination token is
-// contained in a request''s response when there are more products. The
+// contained in a request's response when there are more products. The
 // token can be used in a subsequent request to obtain more products,
 // and so forth. This parameter cannot be used in the initial request.
 func (c *ProductsListCall) Token(token string) *ProductsListCall {
@@ -11679,7 +11678,7 @@
 	//       "type": "string"
 	//     },
 	//     "token": {
-	//       "description": "A pagination token is contained in a request''s response when there are more products. The token can be used in a subsequent request to obtain more products, and so forth. This parameter cannot be used in the initial request.",
+	//       "description": "A pagination token is contained in a request's response when there are more products. The token can be used in a subsequent request to obtain more products, and so forth. This parameter cannot be used in the initial request.",
 	//       "location": "query",
 	//       "type": "string"
 	//     }
diff --git a/api-list.json b/api-list.json
index 4496ada..7613716 100644
--- a/api-list.json
+++ b/api-list.json
@@ -520,6 +520,21 @@
   },
   {
    "kind": "discovery#directoryItem",
+   "id": "bigtableadmin:v1",
+   "name": "bigtableadmin",
+   "version": "v1",
+   "title": "Cloud Bigtable Admin API",
+   "description": "",
+   "discoveryRestUrl": "https://bigtableadmin.googleapis.com/$discovery/rest?version=v1",
+   "icons": {
+    "x16": "https://www.gstatic.com/images/branding/product/1x/googleg_16dp.png",
+    "x32": "https://www.gstatic.com/images/branding/product/1x/googleg_32dp.png"
+   },
+   "documentationLink": "https://cloud.google.com/bigtable/",
+   "preferred": false
+  },
+  {
+   "kind": "discovery#directoryItem",
    "id": "bigtableadmin:v2",
    "name": "bigtableadmin",
    "version": "v2",
@@ -1536,6 +1551,21 @@
   },
   {
    "kind": "discovery#directoryItem",
+   "id": "docs:v1",
+   "name": "docs",
+   "version": "v1",
+   "title": "Google Docs API",
+   "description": "An API for creating and editing Google Docs documents.",
+   "discoveryRestUrl": "https://docs.googleapis.com/$discovery/rest?version=v1",
+   "icons": {
+    "x16": "https://www.gstatic.com/images/branding/product/1x/googleg_16dp.png",
+    "x32": "https://www.gstatic.com/images/branding/product/1x/googleg_32dp.png"
+   },
+   "documentationLink": "https://developers.google.com/docs/",
+   "preferred": true
+  },
+  {
+   "kind": "discovery#directoryItem",
    "id": "doubleclickbidmanager:v1",
    "name": "doubleclickbidmanager",
    "version": "v1",
diff --git a/books/v1/books-api.json b/books/v1/books-api.json
index b07c48f..beee468 100644
--- a/books/v1/books-api.json
+++ b/books/v1/books-api.json
@@ -14,7 +14,7 @@
   "description": "Searches for books and manages your Google Books library.",
   "discoveryVersion": "v1",
   "documentationLink": "https://developers.google.com/books/docs/v1/getting_started",
-  "etag": "\"J3WqvAcMk4eQjJXvfSI4Yr8VouA/8P7g5wNCVmRGHn94JiqOIxt3z6w\"",
+  "etag": "\"J3WqvAcMk4eQjJXvfSI4Yr8VouA/xLh-0fCf99dNH-VZi7ducZabQdI\"",
   "icons": {
     "x16": "https://www.google.com/images/icons/product/ebooks-16.png",
     "x32": "https://www.google.com/images/icons/product/ebooks-32.png"
@@ -2480,7 +2480,7 @@
       }
     }
   },
-  "revision": "20180824",
+  "revision": "20181212",
   "rootUrl": "https://www.googleapis.com/",
   "schemas": {
     "Annotation": {
@@ -3629,6 +3629,10 @@
         "targetUrl": {
           "type": "string"
         },
+        "timeToExpireMs": {
+          "format": "int64",
+          "type": "string"
+        },
         "title": {
           "type": "string"
         }
diff --git a/books/v1/books-gen.go b/books/v1/books-gen.go
index a8e2d77..96bbda0 100644
--- a/books/v1/books-gen.go
+++ b/books/v1/books-gen.go
@@ -2433,6 +2433,8 @@
 
 	TargetUrl string `json:"targetUrl,omitempty"`
 
+	TimeToExpireMs int64 `json:"timeToExpireMs,omitempty,string"`
+
 	Title string `json:"title,omitempty"`
 
 	// ServerResponse contains the HTTP response code and headers from the
diff --git a/cloudasset/v1beta1/cloudasset-api.json b/cloudasset/v1beta1/cloudasset-api.json
index 0060381..d3fdec5 100644
--- a/cloudasset/v1beta1/cloudasset-api.json
+++ b/cloudasset/v1beta1/cloudasset-api.json
@@ -104,10 +104,73 @@
   },
   "protocol": "rest",
   "resources": {
+    "folders": {
+      "methods": {
+        "exportAssets": {
+          "description": "Exports assets with time and resource types to a given Cloud Storage\nlocation. The output format is newline-delimited JSON.\nThis API implements the google.longrunning.Operation API allowing you\nto keep track of the export.",
+          "flatPath": "v1beta1/folders/{foldersId}:exportAssets",
+          "httpMethod": "POST",
+          "id": "cloudasset.folders.exportAssets",
+          "parameterOrder": [
+            "parent"
+          ],
+          "parameters": {
+            "parent": {
+              "description": "Required. The relative name of the root asset. This can only be an\norganization number (such as \"organizations/123\"), a project ID (such as\n\"projects/my-project-id\"), a project number (such as \"projects/12345\"), or\na folder number (such as \"folders/123\").",
+              "location": "path",
+              "pattern": "^folders/[^/]+$",
+              "required": true,
+              "type": "string"
+            }
+          },
+          "path": "v1beta1/{+parent}:exportAssets",
+          "request": {
+            "$ref": "ExportAssetsRequest"
+          },
+          "response": {
+            "$ref": "Operation"
+          },
+          "scopes": [
+            "https://www.googleapis.com/auth/cloud-platform"
+          ]
+        }
+      },
+      "resources": {
+        "operations": {
+          "methods": {
+            "get": {
+              "description": "Gets the latest state of a long-running operation.  Clients can use this\nmethod to poll the operation result at intervals as recommended by the API\nservice.",
+              "flatPath": "v1beta1/folders/{foldersId}/operations/{operationsId}/{operationsId1}",
+              "httpMethod": "GET",
+              "id": "cloudasset.folders.operations.get",
+              "parameterOrder": [
+                "name"
+              ],
+              "parameters": {
+                "name": {
+                  "description": "The name of the operation resource.",
+                  "location": "path",
+                  "pattern": "^folders/[^/]+/operations/[^/]+/.+$",
+                  "required": true,
+                  "type": "string"
+                }
+              },
+              "path": "v1beta1/{+name}",
+              "response": {
+                "$ref": "Operation"
+              },
+              "scopes": [
+                "https://www.googleapis.com/auth/cloud-platform"
+              ]
+            }
+          }
+        }
+      }
+    },
     "organizations": {
       "methods": {
         "batchGetAssetsHistory": {
-          "description": "Batch gets the update history of assets that overlap a time window.\nFor RESOURCE content, this API outputs history with asset in both\nnon-delete or deleted status.\nFor IAM_POLICY content, this API outputs history when the asset and its\nattached IAM POLICY both exist. This can create gaps in the output history.",
+          "description": "Batch gets the update history of assets that overlap a time window.\nFor RESOURCE content, this API outputs history with asset in both\nnon-delete or deleted status.\nFor IAM_POLICY content, this API outputs history when the asset and its\nattached IAM POLICY both exist. This can create gaps in the output history.\nIf a specified asset does not exist, this API returns an INVALID_ARGUMENT\nerror.",
           "flatPath": "v1beta1/organizations/{organizationsId}:batchGetAssetsHistory",
           "httpMethod": "GET",
           "id": "cloudasset.organizations.batchGetAssetsHistory",
@@ -169,7 +232,7 @@
           ],
           "parameters": {
             "parent": {
-              "description": "Required. The relative name of the root asset. This can only be an organization\nnumber (such as \"organizations/123\"), a project ID (such as\n\"projects/my-project-id\"), or a project number (such as \"projects/12345\").",
+              "description": "Required. The relative name of the root asset. This can only be an\norganization number (such as \"organizations/123\"), a project ID (such as\n\"projects/my-project-id\"), a project number (such as \"projects/12345\"), or\na folder number (such as \"folders/123\").",
               "location": "path",
               "pattern": "^organizations/[^/]+$",
               "required": true,
@@ -203,7 +266,7 @@
                 "name": {
                   "description": "The name of the operation resource.",
                   "location": "path",
-                  "pattern": "^organizations/[^/]+/operations/[^/]+/[^/]+$",
+                  "pattern": "^organizations/[^/]+/operations/[^/]+/.+$",
                   "required": true,
                   "type": "string"
                 }
@@ -223,7 +286,7 @@
     "projects": {
       "methods": {
         "batchGetAssetsHistory": {
-          "description": "Batch gets the update history of assets that overlap a time window.\nFor RESOURCE content, this API outputs history with asset in both\nnon-delete or deleted status.\nFor IAM_POLICY content, this API outputs history when the asset and its\nattached IAM POLICY both exist. This can create gaps in the output history.",
+          "description": "Batch gets the update history of assets that overlap a time window.\nFor RESOURCE content, this API outputs history with asset in both\nnon-delete or deleted status.\nFor IAM_POLICY content, this API outputs history when the asset and its\nattached IAM POLICY both exist. This can create gaps in the output history.\nIf a specified asset does not exist, this API returns an INVALID_ARGUMENT\nerror.",
           "flatPath": "v1beta1/projects/{projectsId}:batchGetAssetsHistory",
           "httpMethod": "GET",
           "id": "cloudasset.projects.batchGetAssetsHistory",
@@ -285,7 +348,7 @@
           ],
           "parameters": {
             "parent": {
-              "description": "Required. The relative name of the root asset. This can only be an organization\nnumber (such as \"organizations/123\"), a project ID (such as\n\"projects/my-project-id\"), or a project number (such as \"projects/12345\").",
+              "description": "Required. The relative name of the root asset. This can only be an\norganization number (such as \"organizations/123\"), a project ID (such as\n\"projects/my-project-id\"), a project number (such as \"projects/12345\"), or\na folder number (such as \"folders/123\").",
               "location": "path",
               "pattern": "^projects/[^/]+$",
               "required": true,
@@ -319,7 +382,7 @@
                 "name": {
                   "description": "The name of the operation resource.",
                   "location": "path",
-                  "pattern": "^projects/[^/]+/operations/[^/]+/[^/]+$",
+                  "pattern": "^projects/[^/]+/operations/[^/]+/.+$",
                   "required": true,
                   "type": "string"
                 }
@@ -337,7 +400,7 @@
       }
     }
   },
-  "revision": "20181211",
+  "revision": "20190128",
   "rootUrl": "https://cloudasset.googleapis.com/",
   "schemas": {
     "Asset": {
diff --git a/cloudasset/v1beta1/cloudasset-gen.go b/cloudasset/v1beta1/cloudasset-gen.go
index 0b8fcab..849511f 100644
--- a/cloudasset/v1beta1/cloudasset-gen.go
+++ b/cloudasset/v1beta1/cloudasset-gen.go
@@ -61,6 +61,7 @@
 		return nil, errors.New("client is nil")
 	}
 	s := &Service{client: client, BasePath: basePath}
+	s.Folders = NewFoldersService(s)
 	s.Organizations = NewOrganizationsService(s)
 	s.Projects = NewProjectsService(s)
 	return s, nil
@@ -71,6 +72,8 @@
 	BasePath  string // API endpoint base URL
 	UserAgent string // optional additional User-Agent fragment
 
+	Folders *FoldersService
+
 	Organizations *OrganizationsService
 
 	Projects *ProjectsService
@@ -83,6 +86,27 @@
 	return googleapi.UserAgent + " " + s.UserAgent
 }
 
+func NewFoldersService(s *Service) *FoldersService {
+	rs := &FoldersService{s: s}
+	rs.Operations = NewFoldersOperationsService(s)
+	return rs
+}
+
+type FoldersService struct {
+	s *Service
+
+	Operations *FoldersOperationsService
+}
+
+func NewFoldersOperationsService(s *Service) *FoldersOperationsService {
+	rs := &FoldersOperationsService{s: s}
+	return rs
+}
+
+type FoldersOperationsService struct {
+	s *Service
+}
+
 func NewOrganizationsService(s *Service) *OrganizationsService {
 	rs := &OrganizationsService{s: s}
 	rs.Operations = NewOrganizationsOperationsService(s)
@@ -1058,6 +1082,297 @@
 	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
 }
 
+// method id "cloudasset.folders.exportAssets":
+
+type FoldersExportAssetsCall struct {
+	s                   *Service
+	parent              string
+	exportassetsrequest *ExportAssetsRequest
+	urlParams_          gensupport.URLParams
+	ctx_                context.Context
+	header_             http.Header
+}
+
+// ExportAssets: Exports assets with time and resource types to a given
+// Cloud Storage
+// location. The output format is newline-delimited JSON.
+// This API implements the google.longrunning.Operation API allowing
+// you
+// to keep track of the export.
+func (r *FoldersService) ExportAssets(parent string, exportassetsrequest *ExportAssetsRequest) *FoldersExportAssetsCall {
+	c := &FoldersExportAssetsCall{s: r.s, urlParams_: make(gensupport.URLParams)}
+	c.parent = parent
+	c.exportassetsrequest = exportassetsrequest
+	return c
+}
+
+// Fields allows partial responses to be retrieved. See
+// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
+// for more information.
+func (c *FoldersExportAssetsCall) Fields(s ...googleapi.Field) *FoldersExportAssetsCall {
+	c.urlParams_.Set("fields", googleapi.CombineFields(s))
+	return c
+}
+
+// Context sets the context to be used in this call's Do method. Any
+// pending HTTP request will be aborted if the provided context is
+// canceled.
+func (c *FoldersExportAssetsCall) Context(ctx context.Context) *FoldersExportAssetsCall {
+	c.ctx_ = ctx
+	return c
+}
+
+// Header returns an http.Header that can be modified by the caller to
+// add HTTP headers to the request.
+func (c *FoldersExportAssetsCall) Header() http.Header {
+	if c.header_ == nil {
+		c.header_ = make(http.Header)
+	}
+	return c.header_
+}
+
+func (c *FoldersExportAssetsCall) doRequest(alt string) (*http.Response, error) {
+	reqHeaders := make(http.Header)
+	for k, v := range c.header_ {
+		reqHeaders[k] = v
+	}
+	reqHeaders.Set("User-Agent", c.s.userAgent())
+	var body io.Reader = nil
+	body, err := googleapi.WithoutDataWrapper.JSONReader(c.exportassetsrequest)
+	if err != nil {
+		return nil, err
+	}
+	reqHeaders.Set("Content-Type", "application/json")
+	c.urlParams_.Set("alt", alt)
+	c.urlParams_.Set("prettyPrint", "false")
+	urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta1/{+parent}:exportAssets")
+	urls += "?" + c.urlParams_.Encode()
+	req, err := http.NewRequest("POST", urls, body)
+	if err != nil {
+		return nil, err
+	}
+	req.Header = reqHeaders
+	googleapi.Expand(req.URL, map[string]string{
+		"parent": c.parent,
+	})
+	return gensupport.SendRequest(c.ctx_, c.s.client, req)
+}
+
+// Do executes the "cloudasset.folders.exportAssets" call.
+// Exactly one of *Operation or error will be non-nil. Any non-2xx
+// status code is an error. Response headers are in either
+// *Operation.ServerResponse.Header or (if a response was returned at
+// all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified
+// to check whether the returned error was because
+// http.StatusNotModified was returned.
+func (c *FoldersExportAssetsCall) Do(opts ...googleapi.CallOption) (*Operation, error) {
+	gensupport.SetOptions(c.urlParams_, opts...)
+	res, err := c.doRequest("json")
+	if res != nil && res.StatusCode == http.StatusNotModified {
+		if res.Body != nil {
+			res.Body.Close()
+		}
+		return nil, &googleapi.Error{
+			Code:   res.StatusCode,
+			Header: res.Header,
+		}
+	}
+	if err != nil {
+		return nil, err
+	}
+	defer googleapi.CloseBody(res)
+	if err := googleapi.CheckResponse(res); err != nil {
+		return nil, err
+	}
+	ret := &Operation{
+		ServerResponse: googleapi.ServerResponse{
+			Header:         res.Header,
+			HTTPStatusCode: res.StatusCode,
+		},
+	}
+	target := &ret
+	if err := gensupport.DecodeResponse(target, res); err != nil {
+		return nil, err
+	}
+	return ret, nil
+	// {
+	//   "description": "Exports assets with time and resource types to a given Cloud Storage\nlocation. The output format is newline-delimited JSON.\nThis API implements the google.longrunning.Operation API allowing you\nto keep track of the export.",
+	//   "flatPath": "v1beta1/folders/{foldersId}:exportAssets",
+	//   "httpMethod": "POST",
+	//   "id": "cloudasset.folders.exportAssets",
+	//   "parameterOrder": [
+	//     "parent"
+	//   ],
+	//   "parameters": {
+	//     "parent": {
+	//       "description": "Required. The relative name of the root asset. This can only be an\norganization number (such as \"organizations/123\"), a project ID (such as\n\"projects/my-project-id\"), a project number (such as \"projects/12345\"), or\na folder number (such as \"folders/123\").",
+	//       "location": "path",
+	//       "pattern": "^folders/[^/]+$",
+	//       "required": true,
+	//       "type": "string"
+	//     }
+	//   },
+	//   "path": "v1beta1/{+parent}:exportAssets",
+	//   "request": {
+	//     "$ref": "ExportAssetsRequest"
+	//   },
+	//   "response": {
+	//     "$ref": "Operation"
+	//   },
+	//   "scopes": [
+	//     "https://www.googleapis.com/auth/cloud-platform"
+	//   ]
+	// }
+
+}
+
+// method id "cloudasset.folders.operations.get":
+
+type FoldersOperationsGetCall struct {
+	s            *Service
+	name         string
+	urlParams_   gensupport.URLParams
+	ifNoneMatch_ string
+	ctx_         context.Context
+	header_      http.Header
+}
+
+// Get: Gets the latest state of a long-running operation.  Clients can
+// use this
+// method to poll the operation result at intervals as recommended by
+// the API
+// service.
+func (r *FoldersOperationsService) Get(name string) *FoldersOperationsGetCall {
+	c := &FoldersOperationsGetCall{s: r.s, urlParams_: make(gensupport.URLParams)}
+	c.name = name
+	return c
+}
+
+// Fields allows partial responses to be retrieved. See
+// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
+// for more information.
+func (c *FoldersOperationsGetCall) Fields(s ...googleapi.Field) *FoldersOperationsGetCall {
+	c.urlParams_.Set("fields", googleapi.CombineFields(s))
+	return c
+}
+
+// IfNoneMatch sets the optional parameter which makes the operation
+// fail if the object's ETag matches the given value. This is useful for
+// getting updates only after the object has changed since the last
+// request. Use googleapi.IsNotModified to check whether the response
+// error from Do is the result of In-None-Match.
+func (c *FoldersOperationsGetCall) IfNoneMatch(entityTag string) *FoldersOperationsGetCall {
+	c.ifNoneMatch_ = entityTag
+	return c
+}
+
+// Context sets the context to be used in this call's Do method. Any
+// pending HTTP request will be aborted if the provided context is
+// canceled.
+func (c *FoldersOperationsGetCall) Context(ctx context.Context) *FoldersOperationsGetCall {
+	c.ctx_ = ctx
+	return c
+}
+
+// Header returns an http.Header that can be modified by the caller to
+// add HTTP headers to the request.
+func (c *FoldersOperationsGetCall) Header() http.Header {
+	if c.header_ == nil {
+		c.header_ = make(http.Header)
+	}
+	return c.header_
+}
+
+func (c *FoldersOperationsGetCall) doRequest(alt string) (*http.Response, error) {
+	reqHeaders := make(http.Header)
+	for k, v := range c.header_ {
+		reqHeaders[k] = v
+	}
+	reqHeaders.Set("User-Agent", c.s.userAgent())
+	if c.ifNoneMatch_ != "" {
+		reqHeaders.Set("If-None-Match", c.ifNoneMatch_)
+	}
+	var body io.Reader = nil
+	c.urlParams_.Set("alt", alt)
+	c.urlParams_.Set("prettyPrint", "false")
+	urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta1/{+name}")
+	urls += "?" + c.urlParams_.Encode()
+	req, err := http.NewRequest("GET", urls, body)
+	if err != nil {
+		return nil, err
+	}
+	req.Header = reqHeaders
+	googleapi.Expand(req.URL, map[string]string{
+		"name": c.name,
+	})
+	return gensupport.SendRequest(c.ctx_, c.s.client, req)
+}
+
+// Do executes the "cloudasset.folders.operations.get" call.
+// Exactly one of *Operation or error will be non-nil. Any non-2xx
+// status code is an error. Response headers are in either
+// *Operation.ServerResponse.Header or (if a response was returned at
+// all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified
+// to check whether the returned error was because
+// http.StatusNotModified was returned.
+func (c *FoldersOperationsGetCall) Do(opts ...googleapi.CallOption) (*Operation, error) {
+	gensupport.SetOptions(c.urlParams_, opts...)
+	res, err := c.doRequest("json")
+	if res != nil && res.StatusCode == http.StatusNotModified {
+		if res.Body != nil {
+			res.Body.Close()
+		}
+		return nil, &googleapi.Error{
+			Code:   res.StatusCode,
+			Header: res.Header,
+		}
+	}
+	if err != nil {
+		return nil, err
+	}
+	defer googleapi.CloseBody(res)
+	if err := googleapi.CheckResponse(res); err != nil {
+		return nil, err
+	}
+	ret := &Operation{
+		ServerResponse: googleapi.ServerResponse{
+			Header:         res.Header,
+			HTTPStatusCode: res.StatusCode,
+		},
+	}
+	target := &ret
+	if err := gensupport.DecodeResponse(target, res); err != nil {
+		return nil, err
+	}
+	return ret, nil
+	// {
+	//   "description": "Gets the latest state of a long-running operation.  Clients can use this\nmethod to poll the operation result at intervals as recommended by the API\nservice.",
+	//   "flatPath": "v1beta1/folders/{foldersId}/operations/{operationsId}/{operationsId1}",
+	//   "httpMethod": "GET",
+	//   "id": "cloudasset.folders.operations.get",
+	//   "parameterOrder": [
+	//     "name"
+	//   ],
+	//   "parameters": {
+	//     "name": {
+	//       "description": "The name of the operation resource.",
+	//       "location": "path",
+	//       "pattern": "^folders/[^/]+/operations/[^/]+/.+$",
+	//       "required": true,
+	//       "type": "string"
+	//     }
+	//   },
+	//   "path": "v1beta1/{+name}",
+	//   "response": {
+	//     "$ref": "Operation"
+	//   },
+	//   "scopes": [
+	//     "https://www.googleapis.com/auth/cloud-platform"
+	//   ]
+	// }
+
+}
+
 // method id "cloudasset.organizations.batchGetAssetsHistory":
 
 type OrganizationsBatchGetAssetsHistoryCall struct {
@@ -1078,6 +1393,9 @@
 // its
 // attached IAM POLICY both exist. This can create gaps in the output
 // history.
+// If a specified asset does not exist, this API returns an
+// INVALID_ARGUMENT
+// error.
 func (r *OrganizationsService) BatchGetAssetsHistory(parent string) *OrganizationsBatchGetAssetsHistoryCall {
 	c := &OrganizationsBatchGetAssetsHistoryCall{s: r.s, urlParams_: make(gensupport.URLParams)}
 	c.parent = parent
@@ -1229,7 +1547,7 @@
 	}
 	return ret, nil
 	// {
-	//   "description": "Batch gets the update history of assets that overlap a time window.\nFor RESOURCE content, this API outputs history with asset in both\nnon-delete or deleted status.\nFor IAM_POLICY content, this API outputs history when the asset and its\nattached IAM POLICY both exist. This can create gaps in the output history.",
+	//   "description": "Batch gets the update history of assets that overlap a time window.\nFor RESOURCE content, this API outputs history with asset in both\nnon-delete or deleted status.\nFor IAM_POLICY content, this API outputs history when the asset and its\nattached IAM POLICY both exist. This can create gaps in the output history.\nIf a specified asset does not exist, this API returns an INVALID_ARGUMENT\nerror.",
 	//   "flatPath": "v1beta1/organizations/{organizationsId}:batchGetAssetsHistory",
 	//   "httpMethod": "GET",
 	//   "id": "cloudasset.organizations.batchGetAssetsHistory",
@@ -1407,7 +1725,7 @@
 	//   ],
 	//   "parameters": {
 	//     "parent": {
-	//       "description": "Required. The relative name of the root asset. This can only be an organization\nnumber (such as \"organizations/123\"), a project ID (such as\n\"projects/my-project-id\"), or a project number (such as \"projects/12345\").",
+	//       "description": "Required. The relative name of the root asset. This can only be an\norganization number (such as \"organizations/123\"), a project ID (such as\n\"projects/my-project-id\"), a project number (such as \"projects/12345\"), or\na folder number (such as \"folders/123\").",
 	//       "location": "path",
 	//       "pattern": "^organizations/[^/]+$",
 	//       "required": true,
@@ -1559,7 +1877,7 @@
 	//     "name": {
 	//       "description": "The name of the operation resource.",
 	//       "location": "path",
-	//       "pattern": "^organizations/[^/]+/operations/[^/]+/[^/]+$",
+	//       "pattern": "^organizations/[^/]+/operations/[^/]+/.+$",
 	//       "required": true,
 	//       "type": "string"
 	//     }
@@ -1595,6 +1913,9 @@
 // its
 // attached IAM POLICY both exist. This can create gaps in the output
 // history.
+// If a specified asset does not exist, this API returns an
+// INVALID_ARGUMENT
+// error.
 func (r *ProjectsService) BatchGetAssetsHistory(parent string) *ProjectsBatchGetAssetsHistoryCall {
 	c := &ProjectsBatchGetAssetsHistoryCall{s: r.s, urlParams_: make(gensupport.URLParams)}
 	c.parent = parent
@@ -1746,7 +2067,7 @@
 	}
 	return ret, nil
 	// {
-	//   "description": "Batch gets the update history of assets that overlap a time window.\nFor RESOURCE content, this API outputs history with asset in both\nnon-delete or deleted status.\nFor IAM_POLICY content, this API outputs history when the asset and its\nattached IAM POLICY both exist. This can create gaps in the output history.",
+	//   "description": "Batch gets the update history of assets that overlap a time window.\nFor RESOURCE content, this API outputs history with asset in both\nnon-delete or deleted status.\nFor IAM_POLICY content, this API outputs history when the asset and its\nattached IAM POLICY both exist. This can create gaps in the output history.\nIf a specified asset does not exist, this API returns an INVALID_ARGUMENT\nerror.",
 	//   "flatPath": "v1beta1/projects/{projectsId}:batchGetAssetsHistory",
 	//   "httpMethod": "GET",
 	//   "id": "cloudasset.projects.batchGetAssetsHistory",
@@ -1924,7 +2245,7 @@
 	//   ],
 	//   "parameters": {
 	//     "parent": {
-	//       "description": "Required. The relative name of the root asset. This can only be an organization\nnumber (such as \"organizations/123\"), a project ID (such as\n\"projects/my-project-id\"), or a project number (such as \"projects/12345\").",
+	//       "description": "Required. The relative name of the root asset. This can only be an\norganization number (such as \"organizations/123\"), a project ID (such as\n\"projects/my-project-id\"), a project number (such as \"projects/12345\"), or\na folder number (such as \"folders/123\").",
 	//       "location": "path",
 	//       "pattern": "^projects/[^/]+$",
 	//       "required": true,
@@ -2076,7 +2397,7 @@
 	//     "name": {
 	//       "description": "The name of the operation resource.",
 	//       "location": "path",
-	//       "pattern": "^projects/[^/]+/operations/[^/]+/[^/]+$",
+	//       "pattern": "^projects/[^/]+/operations/[^/]+/.+$",
 	//       "required": true,
 	//       "type": "string"
 	//     }
diff --git a/cloudbuild/v1alpha1/cloudbuild-api.json b/cloudbuild/v1alpha1/cloudbuild-api.json
index 027d45d..c504074 100644
--- a/cloudbuild/v1alpha1/cloudbuild-api.json
+++ b/cloudbuild/v1alpha1/cloudbuild-api.json
@@ -244,7 +244,7 @@
       }
     }
   },
-  "revision": "20190116",
+  "revision": "20190127",
   "rootUrl": "https://cloudbuild.googleapis.com/",
   "schemas": {
     "ArtifactObjects": {
@@ -752,7 +752,7 @@
       "id": "Network",
       "properties": {
         "network": {
-          "description": "Network on which the workers are created.\n“default” network is used if empty.",
+          "description": "Network on which the workers are created.\n\"default\" network is used if empty.",
           "type": "string"
         },
         "projectId": {
@@ -760,7 +760,7 @@
           "type": "string"
         },
         "subnetwork": {
-          "description": "Subnetwork on which the workers are created.\n“default” subnetwork is used if empty.",
+          "description": "Subnetwork on which the workers are created.\n\"default\" subnetwork is used if empty.",
           "type": "string"
         }
       },
@@ -990,7 +990,7 @@
           "type": "string"
         },
         "regions": {
-          "description": "List of regions to create the `WorkerPool`. Regions can’t be empty.\nIf Cloud Build adds a new GCP region in the future, the existing\n`WorkerPool` will not be enabled in the new region automatically;\nyou must add the new region to the `regions` field to enable the\n`WorkerPool` in that region.",
+          "description": "List of regions to create the `WorkerPool`. Regions can't be empty.\nIf Cloud Build adds a new GCP region in the future, the existing\n`WorkerPool` will not be enabled in the new region automatically;\nyou must add the new region to the `regions` field to enable the\n`WorkerPool` in that region.",
           "enumDescriptions": [
             "no region",
             "us-central1 region",
diff --git a/cloudbuild/v1alpha1/cloudbuild-gen.go b/cloudbuild/v1alpha1/cloudbuild-gen.go
index 9be25ed..fe42c1a 100644
--- a/cloudbuild/v1alpha1/cloudbuild-gen.go
+++ b/cloudbuild/v1alpha1/cloudbuild-gen.go
@@ -905,7 +905,7 @@
 // Network: Network describes the GCP network used to create workers in.
 type Network struct {
 	// Network: Network on which the workers are created.
-	// “default” network is used if empty.
+	// "default" network is used if empty.
 	Network string `json:"network,omitempty"`
 
 	// ProjectId: Project id containing the defined network and subnetwork.
@@ -919,9 +919,8 @@
 	// with no VPC, this will be the same as project_id.
 	ProjectId string `json:"projectId,omitempty"`
 
-	// Subnetwork: Subnetwork on which the workers are
-	// created.
-	// “default” subnetwork is used if empty.
+	// Subnetwork: Subnetwork on which the workers are created.
+	// "default" subnetwork is used if empty.
 	Subnetwork string `json:"subnetwork,omitempty"`
 
 	// ForceSendFields is a list of field names (e.g. "Network") to
@@ -1403,8 +1402,8 @@
 	// `WorkerPool` is created.
 	ProjectId string `json:"projectId,omitempty"`
 
-	// Regions: List of regions to create the `WorkerPool`. Regions can’t
-	// be empty.
+	// Regions: List of regions to create the `WorkerPool`. Regions can't be
+	// empty.
 	// If Cloud Build adds a new GCP region in the future, the
 	// existing
 	// `WorkerPool` will not be enabled in the new region automatically;
diff --git a/docs/v1/docs-api.json b/docs/v1/docs-api.json
new file mode 100644
index 0000000..1aaae69
--- /dev/null
+++ b/docs/v1/docs-api.json
@@ -0,0 +1,3578 @@
+{
+  "auth": {
+    "oauth2": {
+      "scopes": {
+        "https://www.googleapis.com/auth/documents": {
+          "description": "View and manage your Google Docs documents"
+        },
+        "https://www.googleapis.com/auth/documents.readonly": {
+          "description": "View your Google Docs documents"
+        },
+        "https://www.googleapis.com/auth/drive": {
+          "description": "See, edit, create, and delete all of your Google Drive files"
+        },
+        "https://www.googleapis.com/auth/drive.file": {
+          "description": "View and manage Google Drive files and folders that you have opened or created with this app"
+        },
+        "https://www.googleapis.com/auth/drive.readonly": {
+          "description": "See and download all your Google Drive files"
+        }
+      }
+    }
+  },
+  "basePath": "",
+  "baseUrl": "https://docs.googleapis.com/",
+  "batchPath": "batch",
+  "canonicalName": "Docs",
+  "description": "An API for creating and editing Google Docs documents.",
+  "discoveryVersion": "v1",
+  "documentationLink": "https://developers.google.com/docs/",
+  "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"
+  },
+  "id": "docs:v1",
+  "kind": "discovery#restDescription",
+  "name": "docs",
+  "ownerDomain": "google.com",
+  "ownerName": "Google",
+  "parameters": {
+    "$.xgafv": {
+      "description": "V1 error format.",
+      "enum": [
+        "1",
+        "2"
+      ],
+      "enumDescriptions": [
+        "v1 error format",
+        "v2 error format"
+      ],
+      "location": "query",
+      "type": "string"
+    },
+    "access_token": {
+      "description": "OAuth access token.",
+      "location": "query",
+      "type": "string"
+    },
+    "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"
+    },
+    "callback": {
+      "description": "JSONP",
+      "location": "query",
+      "type": "string"
+    },
+    "fields": {
+      "description": "Selector specifying which fields to include in a partial response.",
+      "location": "query",
+      "type": "string"
+    },
+    "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"
+    },
+    "oauth_token": {
+      "description": "OAuth 2.0 token for the current user.",
+      "location": "query",
+      "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"
+    }
+  },
+  "protocol": "rest",
+  "resources": {
+    "documents": {
+      "methods": {
+        "batchUpdate": {
+          "description": "Applies one or more updates to the document.\n\nEach request is validated before\nbeing applied. If any request is not valid, then the entire request will\nfail and nothing will be applied.\n\nSome requests have replies to\ngive you some information about how they are applied. Other requests do\nnot need to return information; these each return an empty reply.\nThe order of replies matches that of the requests.\n\nFor example, suppose you call batchUpdate with four updates, and only the\nthird one returns information. The response would have two empty replies,\nthe reply to the third request, and another empty reply, in that order.\n\nBecause other users may be editing the document, the document\nmight not exactly reflect your changes: your changes may\nbe altered with respect to collaborator changes. If there are no\ncollaborators, the document should reflect your changes. In any case,\nthe updates in your request are guaranteed to be applied together\natomically.",
+          "flatPath": "v1/documents/{documentId}:batchUpdate",
+          "httpMethod": "POST",
+          "id": "docs.documents.batchUpdate",
+          "parameterOrder": [
+            "documentId"
+          ],
+          "parameters": {
+            "documentId": {
+              "description": "The ID of the document to update.",
+              "location": "path",
+              "required": true,
+              "type": "string"
+            }
+          },
+          "path": "v1/documents/{documentId}:batchUpdate",
+          "request": {
+            "$ref": "BatchUpdateDocumentRequest"
+          },
+          "response": {
+            "$ref": "BatchUpdateDocumentResponse"
+          },
+          "scopes": [
+            "https://www.googleapis.com/auth/documents",
+            "https://www.googleapis.com/auth/drive",
+            "https://www.googleapis.com/auth/drive.file"
+          ]
+        },
+        "create": {
+          "description": "Creates a blank document using the title given in the request. Other fields\nin the request, including any provided content, are ignored.\n\nReturns the created document.",
+          "flatPath": "v1/documents",
+          "httpMethod": "POST",
+          "id": "docs.documents.create",
+          "parameterOrder": [],
+          "parameters": {},
+          "path": "v1/documents",
+          "request": {
+            "$ref": "Document"
+          },
+          "response": {
+            "$ref": "Document"
+          },
+          "scopes": [
+            "https://www.googleapis.com/auth/documents",
+            "https://www.googleapis.com/auth/drive",
+            "https://www.googleapis.com/auth/drive.file"
+          ]
+        },
+        "get": {
+          "description": "Gets the latest version of the specified document.",
+          "flatPath": "v1/documents/{documentId}",
+          "httpMethod": "GET",
+          "id": "docs.documents.get",
+          "parameterOrder": [
+            "documentId"
+          ],
+          "parameters": {
+            "documentId": {
+              "description": "The ID of the document to retrieve.",
+              "location": "path",
+              "required": true,
+              "type": "string"
+            },
+            "suggestionsViewMode": {
+              "description": "The suggestions view mode to apply to the document. This allows viewing the\ndocument with all suggestions inline, accepted or rejected. If one is not\nspecified, DEFAULT_FOR_CURRENT_ACCESS is\nused.",
+              "enum": [
+                "DEFAULT_FOR_CURRENT_ACCESS",
+                "SUGGESTIONS_INLINE",
+                "PREVIEW_SUGGESTIONS_ACCEPTED",
+                "PREVIEW_WITHOUT_SUGGESTIONS"
+              ],
+              "location": "query",
+              "type": "string"
+            }
+          },
+          "path": "v1/documents/{documentId}",
+          "response": {
+            "$ref": "Document"
+          },
+          "scopes": [
+            "https://www.googleapis.com/auth/documents",
+            "https://www.googleapis.com/auth/documents.readonly",
+            "https://www.googleapis.com/auth/drive",
+            "https://www.googleapis.com/auth/drive.file",
+            "https://www.googleapis.com/auth/drive.readonly"
+          ]
+        }
+      }
+    }
+  },
+  "revision": "20190125",
+  "rootUrl": "https://docs.googleapis.com/",
+  "schemas": {
+    "AutoText": {
+      "description": "A ParagraphElement representing a\nspot in the text that is dynamically replaced with content that can change\nover time, like a page number.",
+      "id": "AutoText",
+      "properties": {
+        "suggestedDeletionIds": {
+          "description": "The suggested deletion IDs. If empty, then there are no suggested deletions\nof this content.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedInsertionIds": {
+          "description": "The suggested insertion IDs. An AutoText\nmay have multiple insertion IDs if it is a nested suggested change. If\nempty, then this is not a suggested insertion.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedTextStyleChanges": {
+          "additionalProperties": {
+            "$ref": "SuggestedTextStyle"
+          },
+          "description": "The suggested text style changes to this AutoText, keyed by suggestion ID.",
+          "type": "object"
+        },
+        "textStyle": {
+          "$ref": "TextStyle",
+          "description": "The text style of this AutoText."
+        },
+        "type": {
+          "description": "The type of this auto text.",
+          "enum": [
+            "TYPE_UNSPECIFIED",
+            "PAGE_NUMBER",
+            "PAGE_COUNT"
+          ],
+          "enumDescriptions": [
+            "An unspecified auto text type.",
+            "Type for auto text that represents the current page number.",
+            "Type for auto text that represents the total number of pages in the\ndocument."
+          ],
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "Background": {
+      "description": "Represents the background of a document.",
+      "id": "Background",
+      "properties": {
+        "color": {
+          "$ref": "OptionalColor",
+          "description": "The background color."
+        }
+      },
+      "type": "object"
+    },
+    "BackgroundSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base Background have been changed in this suggestion.\nFor any field set to true, the Backgound has a new suggested value.",
+      "id": "BackgroundSuggestionState",
+      "properties": {
+        "backgroundColorSuggested": {
+          "description": "Indicates whether the current background color has been modified in this\nsuggestion.",
+          "type": "boolean"
+        }
+      },
+      "type": "object"
+    },
+    "BatchUpdateDocumentRequest": {
+      "description": "Request message for BatchUpdateDocument.",
+      "id": "BatchUpdateDocumentRequest",
+      "properties": {
+        "requests": {
+          "description": "A list of updates to apply to the document.",
+          "items": {
+            "$ref": "Request"
+          },
+          "type": "array"
+        },
+        "writeControl": {
+          "$ref": "WriteControl",
+          "description": "Provides control over how write requests are executed."
+        }
+      },
+      "type": "object"
+    },
+    "BatchUpdateDocumentResponse": {
+      "description": "Response message from a BatchUpdateDocument request.",
+      "id": "BatchUpdateDocumentResponse",
+      "properties": {
+        "documentId": {
+          "description": "The ID of the document to which the updates were applied to.",
+          "type": "string"
+        },
+        "replies": {
+          "description": "The reply of the updates. This maps 1:1 with the updates, although replies\nto some requests may be empty.",
+          "items": {
+            "$ref": "Response"
+          },
+          "type": "array"
+        },
+        "writeControl": {
+          "$ref": "WriteControl",
+          "description": "The updated write control after applying the request."
+        }
+      },
+      "type": "object"
+    },
+    "Body": {
+      "description": "The document body.\n\nThe body typically contains the full document contents except for\nheaders, footers\nand footnotes.",
+      "id": "Body",
+      "properties": {
+        "content": {
+          "description": "The contents of the body.\n\nThe indices for the body's content begin at zero.",
+          "items": {
+            "$ref": "StructuralElement"
+          },
+          "type": "array"
+        }
+      },
+      "type": "object"
+    },
+    "Bullet": {
+      "description": "Describes the bullet of a paragraph.",
+      "id": "Bullet",
+      "properties": {
+        "listId": {
+          "description": "The ID of the list this paragraph belongs to.",
+          "type": "string"
+        },
+        "nestingLevel": {
+          "description": "The nesting level of this paragraph in the list.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "textStyle": {
+          "$ref": "TextStyle",
+          "description": "The paragraph specific text style applied to this bullet."
+        }
+      },
+      "type": "object"
+    },
+    "BulletSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base\nBullet have been changed in this suggestion.\nFor any field set to true, there is a new suggested value.",
+      "id": "BulletSuggestionState",
+      "properties": {
+        "listIdSuggested": {
+          "description": "Indicates if there was a suggested change to the\nlist_id.",
+          "type": "boolean"
+        },
+        "nestingLevelSuggested": {
+          "description": "Indicates if there was a suggested change to the\nnesting_level.",
+          "type": "boolean"
+        },
+        "textStyleSuggestionState": {
+          "$ref": "TextStyleSuggestionState",
+          "description": "A mask that indicates which of the fields in text style have been changed in this\nsuggestion."
+        }
+      },
+      "type": "object"
+    },
+    "Color": {
+      "description": "A solid color.",
+      "id": "Color",
+      "properties": {
+        "rgbColor": {
+          "$ref": "RgbColor",
+          "description": "The RGB color value."
+        }
+      },
+      "type": "object"
+    },
+    "ColumnBreak": {
+      "description": "A ParagraphElement representing a\ncolumn break. A column break makes the subsequent text start at the top of\nthe next column.",
+      "id": "ColumnBreak",
+      "properties": {
+        "suggestedDeletionIds": {
+          "description": "The suggested deletion IDs. If empty, then there are no suggested deletions\nof this content.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedInsertionIds": {
+          "description": "The suggested insertion IDs. A ColumnBreak may have multiple insertion IDs if it is\na nested suggested change. If empty, then this is not a suggested\ninsertion.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedTextStyleChanges": {
+          "additionalProperties": {
+            "$ref": "SuggestedTextStyle"
+          },
+          "description": "The suggested text style changes to this ColumnBreak, keyed by suggestion\nID.",
+          "type": "object"
+        },
+        "textStyle": {
+          "$ref": "TextStyle",
+          "description": "The text style of this ColumnBreak.\n\nSimilar to text content, like text runs and footnote references, the text\nstyle of a column break can affect content layout as well as the styling of\ntext inserted adjacent to it."
+        }
+      },
+      "type": "object"
+    },
+    "CreateNamedRangeRequest": {
+      "description": "Creates a NamedRange referencing the given\nrange.",
+      "id": "CreateNamedRangeRequest",
+      "properties": {
+        "name": {
+          "description": "The name of the NamedRange. Names do not need to be unique.\n\nNames must be at least 1 character and no more than 256 characters,\nmeasured in UTF-16 code units.",
+          "type": "string"
+        },
+        "range": {
+          "$ref": "Range",
+          "description": "The range to apply the name to."
+        }
+      },
+      "type": "object"
+    },
+    "CreateNamedRangeResponse": {
+      "description": "The result of creating a named range.",
+      "id": "CreateNamedRangeResponse",
+      "properties": {
+        "namedRangeId": {
+          "description": "The ID of the created named range.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "CreateParagraphBulletsRequest": {
+      "description": "Creates bullets for all of the paragraphs that overlap with the given range.\n\nThe nesting level of each paragraph will be determined by counting leading\ntabs in front of each paragraph. To avoid excess space between the bullet and\nthe corresponding paragraph, these leading tabs are removed by this request.\nThis may change the indices of parts of the text.\n\nIf the paragraph immediately before paragraphs being updated is in a list\nwith a matching preset, the paragraphs being updated are added to that\npreceding list.",
+      "id": "CreateParagraphBulletsRequest",
+      "properties": {
+        "bulletPreset": {
+          "description": "The kinds of bullet glyphs to be used.",
+          "enum": [
+            "BULLET_GLYPH_PRESET_UNSPECIFIED",
+            "BULLET_DISC_CIRCLE_SQUARE",
+            "BULLET_DIAMONDX_ARROW3D_SQUARE",
+            "BULLET_CHECKBOX",
+            "BULLET_ARROW_DIAMOND_DISC",
+            "BULLET_STAR_CIRCLE_SQUARE",
+            "BULLET_ARROW3D_CIRCLE_SQUARE",
+            "BULLET_LEFTTRIANGLE_DIAMOND_DISC",
+            "BULLET_DIAMONDX_HOLLOWDIAMOND_SQUARE",
+            "BULLET_DIAMOND_CIRCLE_SQUARE",
+            "NUMBERED_DECIMAL_ALPHA_ROMAN",
+            "NUMBERED_DECIMAL_ALPHA_ROMAN_PARENS",
+            "NUMBERED_DECIMAL_NESTED",
+            "NUMBERED_UPPERALPHA_ALPHA_ROMAN",
+            "NUMBERED_UPPERROMAN_UPPERALPHA_DECIMAL",
+            "NUMBERED_ZERODECIMAL_ALPHA_ROMAN"
+          ],
+          "enumDescriptions": [
+            "The bullet glyph preset is unspecified.",
+            "A bulleted list with a `DISC`, `CIRCLE` and `SQUARE` bullet glyph for the\nfirst 3 list nesting levels.",
+            "A bulleted list with a `DIAMONDX`, `ARROW3D` and `SQUARE` bullet glyph for\nthe first 3 list nesting levels.",
+            "A bulleted list with `CHECKBOX` bullet glyphs for all list nesting levels.",
+            "A bulleted list with a `ARROW`, `DIAMOND` and `DISC` bullet glyph for\nthe first 3 list nesting levels.",
+            "A bulleted list with a `STAR`, `CIRCLE` and `SQUARE` bullet glyph for\nthe first 3 list nesting levels.",
+            "A bulleted list with a `ARROW3D`, `CIRCLE` and `SQUARE` bullet glyph for\nthe first 3 list nesting levels.",
+            "A bulleted list with a `LEFTTRIANGLE`, `DIAMOND` and `DISC` bullet glyph\nfor the first 3 list nesting levels.",
+            "A bulleted list with a `DIAMONDX`, `HOLLOWDIAMOND` and `SQUARE` bullet\nglyph for the first 3 list nesting levels.",
+            "A bulleted list with a `DIAMOND`, `CIRCLE` and `SQUARE` bullet glyph\nfor the first 3 list nesting levels.",
+            "A numbered list with `DECIMAL`, `ALPHA` and `ROMAN` numeric glyphs for\nthe first 3 list nesting levels, followed by periods.",
+            "A numbered list with `DECIMAL`, `ALPHA` and `ROMAN` numeric glyphs for\nthe first 3 list nesting levels, followed by parenthesis.",
+            "A numbered list with `DECIMAL` numeric glyphs separated by periods, where\neach nesting level uses the previous nesting level's glyph as a prefix.\nFor example: '1.', '1.1.', '2.', '2.2.'.",
+            "A numbered list with `UPPERALPHA`, `ALPHA` and `ROMAN` numeric glyphs for\nthe first 3 list nesting levels, followed by periods.",
+            "A numbered list with `UPPERROMAN`, `UPPERALPHA` and `DECIMAL` numeric\nglyphs for the first 3 list nesting levels, followed by periods.",
+            "A numbered list with `ZERODECIMAL`, `ALPHA` and `ROMAN` numeric glyphs for\nthe first 3 list nesting levels, followed by periods."
+          ],
+          "type": "string"
+        },
+        "range": {
+          "$ref": "Range",
+          "description": "The range to apply the bullet preset to."
+        }
+      },
+      "type": "object"
+    },
+    "CropProperties": {
+      "description": "The crop properties of an image.\n\nThe crop rectangle is represented using fractional offsets from the original\ncontent's four edges.\n\n- If the offset is in the interval (0, 1), the corresponding edge of crop\nrectangle is positioned inside of the image's original bounding rectangle.\n- If the offset is negative or greater than 1, the corresponding edge of crop\nrectangle is positioned outside of the image's original bounding rectangle.\n- If all offsets and rotation angle are 0, the image is not cropped.",
+      "id": "CropProperties",
+      "properties": {
+        "angle": {
+          "description": "The clockwise rotation angle of the crop rectangle around its center, in\nradians. Rotation is applied after the offsets.",
+          "format": "float",
+          "type": "number"
+        },
+        "offsetBottom": {
+          "description": "The offset specifies how far inwards the bottom edge of the crop rectangle\nis from the bottom edge of the original content as a fraction of the\noriginal content's height.",
+          "format": "float",
+          "type": "number"
+        },
+        "offsetLeft": {
+          "description": "The offset specifies how far inwards the left edge of the crop rectangle is\nfrom the left edge of the original content as a fraction of the original\ncontent's width.",
+          "format": "float",
+          "type": "number"
+        },
+        "offsetRight": {
+          "description": "The offset specifies how far inwards the right edge of the crop rectangle\nis from the right edge of the original content as a fraction of the\noriginal content's width.",
+          "format": "float",
+          "type": "number"
+        },
+        "offsetTop": {
+          "description": "The offset specifies how far inwards the top edge of the crop rectangle is\nfrom the top edge of the original content as a fraction of the original\ncontent's height.",
+          "format": "float",
+          "type": "number"
+        }
+      },
+      "type": "object"
+    },
+    "CropPropertiesSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base CropProperties have been changed in this suggestion.\nFor any field set to true, there is a new suggested value.",
+      "id": "CropPropertiesSuggestionState",
+      "properties": {
+        "angleSuggested": {
+          "description": "Indicates if there was a suggested change to angle.",
+          "type": "boolean"
+        },
+        "offsetBottomSuggested": {
+          "description": "Indicates if there was a suggested change to offset_bottom.",
+          "type": "boolean"
+        },
+        "offsetLeftSuggested": {
+          "description": "Indicates if there was a suggested change to offset_left.",
+          "type": "boolean"
+        },
+        "offsetRightSuggested": {
+          "description": "Indicates if there was a suggested change to offset_right.",
+          "type": "boolean"
+        },
+        "offsetTopSuggested": {
+          "description": "Indicates if there was a suggested change to offset_top.",
+          "type": "boolean"
+        }
+      },
+      "type": "object"
+    },
+    "DeleteContentRangeRequest": {
+      "description": "Deletes content from the document.",
+      "id": "DeleteContentRangeRequest",
+      "properties": {
+        "range": {
+          "$ref": "Range",
+          "description": "The range of content to delete.\n\nDeleting text that crosses a paragraph boundary may result in changes\nto paragraph styles, lists, positioned objects and bookmarks as the two\nparagraphs are merged.\n\nAttempting to delete certain ranges can result in an invalid document\nstructure in which case a 400 bad request error is returned.\n\nSome examples of invalid delete requests include:\n\n* Deleting one code unit of a surrogate pair.\n* Deleting the last newline character of a Body, Header,\n  Footer, Footnote, TableCell or TableOfContents.\n* Deleting the start or end of a Table,\n  TableOfContents or Equation without deleting the entire element.\n* Deleting the newline character before a\n  Table,\n  TableOfContents or\n  SectionBreak without deleting the\n  the element.\n* Deleting individual rows or cells of a table. Deleting the content within\n  a table cell is allowed."
+        }
+      },
+      "type": "object"
+    },
+    "DeleteNamedRangeRequest": {
+      "description": "Deletes a NamedRange.",
+      "id": "DeleteNamedRangeRequest",
+      "properties": {
+        "name": {
+          "description": "The name of the range(s) to delete. All named ranges with the given\nname will be deleted.",
+          "type": "string"
+        },
+        "namedRangeId": {
+          "description": "The ID of the named range to delete.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "DeleteParagraphBulletsRequest": {
+      "description": "Deletes bullets from all of the paragraphs that overlap with the given range.\n\nThe nesting level of each paragraph will be visually preserved by adding\nindent to the start of the corresponding paragraph.",
+      "id": "DeleteParagraphBulletsRequest",
+      "properties": {
+        "range": {
+          "$ref": "Range",
+          "description": "The range to delete bullets from."
+        }
+      },
+      "type": "object"
+    },
+    "DeletePositionedObjectRequest": {
+      "description": "Deletes a PositionedObject from the\ndocument.",
+      "id": "DeletePositionedObjectRequest",
+      "properties": {
+        "objectId": {
+          "description": "The ID of the positioned object to delete.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "DeleteTableColumnRequest": {
+      "description": "Deletes a column from a table.",
+      "id": "DeleteTableColumnRequest",
+      "properties": {
+        "tableCellLocation": {
+          "$ref": "TableCellLocation",
+          "description": "The reference table cell location from which the column will be deleted.\n\nThe column this cell spans will be deleted. If this is a merged cell that\nspans multiple columns, all columns that the cell spans will be deleted. If\nno columns remain in the table after this deletion, the whole table is\ndeleted."
+        }
+      },
+      "type": "object"
+    },
+    "DeleteTableRowRequest": {
+      "description": "Deletes a row from a table.",
+      "id": "DeleteTableRowRequest",
+      "properties": {
+        "tableCellLocation": {
+          "$ref": "TableCellLocation",
+          "description": "The reference table cell location from which the row will be deleted.\n\nThe row this cell spans will be deleted. If this is a merged cell that\nspans multiple rows, all rows that the cell spans will be deleted. If no\nrows remain in the table after this deletion, the whole table is deleted."
+        }
+      },
+      "type": "object"
+    },
+    "Dimension": {
+      "description": "A magnitude in a single direction in the specified units.",
+      "id": "Dimension",
+      "properties": {
+        "magnitude": {
+          "description": "The magnitude.",
+          "format": "double",
+          "type": "number"
+        },
+        "unit": {
+          "description": "The units for magnitude.",
+          "enum": [
+            "UNIT_UNSPECIFIED",
+            "PT"
+          ],
+          "enumDescriptions": [
+            "The units are unknown.",
+            "A point, 1/72 of an inch."
+          ],
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "Document": {
+      "description": "A Google Docs document.",
+      "id": "Document",
+      "properties": {
+        "body": {
+          "$ref": "Body",
+          "description": "The main body of the document."
+        },
+        "documentId": {
+          "description": "The ID of the document.",
+          "type": "string"
+        },
+        "documentStyle": {
+          "$ref": "DocumentStyle",
+          "description": "The style of the document."
+        },
+        "footers": {
+          "additionalProperties": {
+            "$ref": "Footer"
+          },
+          "description": "The footers in the document, keyed by footer ID.",
+          "type": "object"
+        },
+        "footnotes": {
+          "additionalProperties": {
+            "$ref": "Footnote"
+          },
+          "description": "The footnotes in the document, keyed by footnote ID.",
+          "type": "object"
+        },
+        "headers": {
+          "additionalProperties": {
+            "$ref": "Header"
+          },
+          "description": "The headers in the document, keyed by header ID.",
+          "type": "object"
+        },
+        "inlineObjects": {
+          "additionalProperties": {
+            "$ref": "InlineObject"
+          },
+          "description": "The inline objects in the document, keyed by object ID.",
+          "type": "object"
+        },
+        "lists": {
+          "additionalProperties": {
+            "$ref": "List"
+          },
+          "description": "The lists in the document, keyed by list ID.",
+          "type": "object"
+        },
+        "namedRanges": {
+          "additionalProperties": {
+            "$ref": "NamedRanges"
+          },
+          "description": "The named ranges in the document, keyed by name.",
+          "type": "object"
+        },
+        "namedStyles": {
+          "$ref": "NamedStyles",
+          "description": "The named styles of the document."
+        },
+        "positionedObjects": {
+          "additionalProperties": {
+            "$ref": "PositionedObject"
+          },
+          "description": "The positioned objects in the document, keyed by object ID.",
+          "type": "object"
+        },
+        "revisionId": {
+          "description": "The revision ID of the document. Can be used in update requests to specify\nwhich revision of a document to apply updates to and how the request should\nbehave if the document has been edited since that revision. Only populated\nif the user has edit access to the document.\n\nThe format of the revision ID may change over time, so it should be treated\nopaquely. A returned revision ID is only guaranteed to be valid for 24\nhours after it has been returned and cannot be shared across users. If the\nrevision ID is unchanged between calls, then the document has not changed.\nConversely, a changed ID (for the same document and user) usually means the\ndocument has been updated; however, a changed ID can also be due to\ninternal factors such as ID format changes.",
+          "type": "string"
+        },
+        "suggestedDocumentStyleChanges": {
+          "additionalProperties": {
+            "$ref": "SuggestedDocumentStyle"
+          },
+          "description": "The suggested changes to the style of the document, keyed by suggestion ID.",
+          "type": "object"
+        },
+        "suggestedNamedStylesChanges": {
+          "additionalProperties": {
+            "$ref": "SuggestedNamedStyles"
+          },
+          "description": "The suggested changes to the named styles of the document, keyed by\nsuggestion ID.",
+          "type": "object"
+        },
+        "suggestionsViewMode": {
+          "description": "The suggestions view mode applied to the document.\n\nNote: When editing a document, changes must be based on a document with\nSUGGESTIONS_INLINE.",
+          "enum": [
+            "DEFAULT_FOR_CURRENT_ACCESS",
+            "SUGGESTIONS_INLINE",
+            "PREVIEW_SUGGESTIONS_ACCEPTED",
+            "PREVIEW_WITHOUT_SUGGESTIONS"
+          ],
+          "enumDescriptions": [
+            "The SuggestionsViewMode applied to the returned document depends on the\nuser's current access level. If the user only has view access,\nPREVIEW_WITHOUT_SUGGESTIONS is\napplied. Otherwise, SUGGESTIONS_INLINE is applied.\nThis is the default suggestions view mode.",
+            "The returned document has suggestions inline. Suggested changes will be\ndifferentiated from base content within the document.\n\nRequests to retrieve a document using this mode will return a 403 error if\nthe user does not have permission to view suggested changes.",
+            "The returned document is a preview with all suggested changes accepted.\n\nRequests to retrieve a document using this mode will return a 403 error if\nthe user does not have permission to view suggested changes.",
+            "The returned document is a preview with all suggested changes rejected if\nthere are any suggestions in the document."
+          ],
+          "type": "string"
+        },
+        "title": {
+          "description": "The title of the document.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "DocumentStyle": {
+      "description": "The style of the document.",
+      "id": "DocumentStyle",
+      "properties": {
+        "background": {
+          "$ref": "Background",
+          "description": "The background of the document."
+        },
+        "defaultFooterId": {
+          "description": "The ID of the default footer. If not set, there is no default footer.",
+          "type": "string"
+        },
+        "defaultHeaderId": {
+          "description": "The ID of the default header. If not set, there is no default header.",
+          "type": "string"
+        },
+        "evenPageFooterId": {
+          "description": "The ID of the footer used only for even pages. The value of\nuse_even_page_header_footer determines\nwhether to use the default_footer_id or this value for the\nfooter on even pages. If not set, there is no even page footer.",
+          "type": "string"
+        },
+        "evenPageHeaderId": {
+          "description": "The ID of the header used only for even pages. The value of\nuse_even_page_header_footer determines\nwhether to use the default_header_id or this value for the\nheader on even pages. If not set, there is no even page header.",
+          "type": "string"
+        },
+        "firstPageFooterId": {
+          "description": "The ID of the footer used only for the first page. If not set then\na unique footer for the first page does not exist. The value of\nuse_first_page_header_footer determines\nwhether to use the default_footer_id or this value for the\nfooter on the first page. If not set, there is no first page footer.",
+          "type": "string"
+        },
+        "firstPageHeaderId": {
+          "description": "The ID of the header used only for the first page. If not set then\na unique header for the first page does not exist.\nThe value of use_first_page_header_footer determines\nwhether to use the default_header_id or this value for the\nheader on the first page. If not set, there is no first page header.",
+          "type": "string"
+        },
+        "marginBottom": {
+          "$ref": "Dimension",
+          "description": "The bottom page margin."
+        },
+        "marginLeft": {
+          "$ref": "Dimension",
+          "description": "The left page margin."
+        },
+        "marginRight": {
+          "$ref": "Dimension",
+          "description": "The right page margin."
+        },
+        "marginTop": {
+          "$ref": "Dimension",
+          "description": "The top page margin."
+        },
+        "pageNumberStart": {
+          "description": "The page number from which to start counting the number of pages.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "pageSize": {
+          "$ref": "Size",
+          "description": "The size of a page in the document."
+        },
+        "useEvenPageHeaderFooter": {
+          "description": "Indicates whether to use the even page header / footer IDs for the even\npages.",
+          "type": "boolean"
+        },
+        "useFirstPageHeaderFooter": {
+          "description": "Indicates whether to use the first page header / footer IDs for the first\npage.",
+          "type": "boolean"
+        }
+      },
+      "type": "object"
+    },
+    "DocumentStyleSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base DocumentStyle have been changed in this suggestion.\nFor any field set to true, there is a new suggested value.",
+      "id": "DocumentStyleSuggestionState",
+      "properties": {
+        "backgroundSuggestionState": {
+          "$ref": "BackgroundSuggestionState",
+          "description": "A mask that indicates which of the fields in background have been changed in this\nsuggestion."
+        },
+        "defaultFooterIdSuggested": {
+          "description": "Indicates if there was a suggested change to default_footer_id.",
+          "type": "boolean"
+        },
+        "defaultHeaderIdSuggested": {
+          "description": "Indicates if there was a suggested change to default_header_id.",
+          "type": "boolean"
+        },
+        "evenPageFooterIdSuggested": {
+          "description": "Indicates if there was a suggested change to even_page_footer_id.",
+          "type": "boolean"
+        },
+        "evenPageHeaderIdSuggested": {
+          "description": "Indicates if there was a suggested change to even_page_header_id.",
+          "type": "boolean"
+        },
+        "firstPageFooterIdSuggested": {
+          "description": "Indicates if there was a suggested change to first_page_footer_id.",
+          "type": "boolean"
+        },
+        "firstPageHeaderIdSuggested": {
+          "description": "Indicates if there was a suggested change to first_page_header_id.",
+          "type": "boolean"
+        },
+        "marginBottomSuggested": {
+          "description": "Indicates if there was a suggested change to margin_bottom.",
+          "type": "boolean"
+        },
+        "marginLeftSuggested": {
+          "description": "Indicates if there was a suggested change to margin_left.",
+          "type": "boolean"
+        },
+        "marginRightSuggested": {
+          "description": "Indicates if there was a suggested change to margin_right.",
+          "type": "boolean"
+        },
+        "marginTopSuggested": {
+          "description": "Indicates if there was a suggested change to margin_top.",
+          "type": "boolean"
+        },
+        "pageNumberStartSuggested": {
+          "description": "Indicates if there was a suggested change to page_number_start.",
+          "type": "boolean"
+        },
+        "pageSizeSuggestionState": {
+          "$ref": "SizeSuggestionState",
+          "description": "A mask that indicates which of the fields in size have been changed in this\nsuggestion."
+        },
+        "useEvenPageHeaderFooterSuggested": {
+          "description": "Indicates if there was a suggested change to use_even_page_header_footer.",
+          "type": "boolean"
+        },
+        "useFirstPageHeaderFooterSuggested": {
+          "description": "Indicates if there was a suggested change to use_first_page_header_footer.",
+          "type": "boolean"
+        }
+      },
+      "type": "object"
+    },
+    "EmbeddedDrawingProperties": {
+      "description": "The properties of an embedded drawing.",
+      "id": "EmbeddedDrawingProperties",
+      "properties": {},
+      "type": "object"
+    },
+    "EmbeddedDrawingPropertiesSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base\nEmbeddedDrawingProperties\nhave been changed in this suggestion. For any field set to true, there is a\nnew suggested value.",
+      "id": "EmbeddedDrawingPropertiesSuggestionState",
+      "properties": {},
+      "type": "object"
+    },
+    "EmbeddedObject": {
+      "description": "An embedded object in the document.",
+      "id": "EmbeddedObject",
+      "properties": {
+        "description": {
+          "description": "The description of the embedded object. The `title` and `description` are\nboth combined to display alt text.",
+          "type": "string"
+        },
+        "embeddedDrawingProperties": {
+          "$ref": "EmbeddedDrawingProperties",
+          "description": "The properties of an embedded drawing."
+        },
+        "embeddedObjectBorder": {
+          "$ref": "EmbeddedObjectBorder",
+          "description": "The border of the embedded object."
+        },
+        "imageProperties": {
+          "$ref": "ImageProperties",
+          "description": "The properties of an image."
+        },
+        "linkedContentReference": {
+          "$ref": "LinkedContentReference",
+          "description": "A reference to the external linked source content. For example, it contains\na reference to the source Sheets chart when the embedded object is a linked\nchart.\n\nIf unset, then the embedded object is not linked."
+        },
+        "marginBottom": {
+          "$ref": "Dimension",
+          "description": "The bottom margin of the embedded object."
+        },
+        "marginLeft": {
+          "$ref": "Dimension",
+          "description": "The left margin of the embedded object."
+        },
+        "marginRight": {
+          "$ref": "Dimension",
+          "description": "The right margin of the embedded object."
+        },
+        "marginTop": {
+          "$ref": "Dimension",
+          "description": "The top margin of the embedded object."
+        },
+        "size": {
+          "$ref": "Size",
+          "description": "The size of the embedded object."
+        },
+        "title": {
+          "description": "The title of the embedded object. The `title` and `description` are both\ncombined to display alt text.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "EmbeddedObjectBorder": {
+      "description": "A border around an EmbeddedObject.",
+      "id": "EmbeddedObjectBorder",
+      "properties": {
+        "color": {
+          "$ref": "OptionalColor",
+          "description": "The color of the border."
+        },
+        "dashStyle": {
+          "description": "The dash style of the border.",
+          "enum": [
+            "DASH_STYLE_UNSPECIFIED",
+            "SOLID",
+            "DOT",
+            "DASH"
+          ],
+          "enumDescriptions": [
+            "Unspecified dash style.",
+            "Solid line. Corresponds to ECMA-376 ST_PresetLineDashVal value 'solid'.\nThis is the default dash style.",
+            "Dotted line. Corresponds to ECMA-376 ST_PresetLineDashVal value 'dot'.",
+            "Dashed line. Corresponds to ECMA-376 ST_PresetLineDashVal value 'dash'."
+          ],
+          "type": "string"
+        },
+        "propertyState": {
+          "description": "The property state of the border property.",
+          "enum": [
+            "RENDERED",
+            "NOT_RENDERED"
+          ],
+          "enumDescriptions": [
+            "If a property's state is RENDERED, then the element has the corresponding\nproperty when rendered in the document. This is the default value.",
+            "If a property's state is NOT_RENDERED, then the element does not have the\ncorresponding property when rendered in the document."
+          ],
+          "type": "string"
+        },
+        "width": {
+          "$ref": "Dimension",
+          "description": "The width of the border."
+        }
+      },
+      "type": "object"
+    },
+    "EmbeddedObjectBorderSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base EmbeddedObjectBorder have been changed in this\nsuggestion. For any field set to true, there is a new suggested value.",
+      "id": "EmbeddedObjectBorderSuggestionState",
+      "properties": {
+        "colorSuggested": {
+          "description": "Indicates if there was a suggested change to color.",
+          "type": "boolean"
+        },
+        "dashStyleSuggested": {
+          "description": "Indicates if there was a suggested change to dash_style.",
+          "type": "boolean"
+        },
+        "propertyStateSuggested": {
+          "description": "Indicates if there was a suggested change to property_state.",
+          "type": "boolean"
+        },
+        "widthSuggested": {
+          "description": "Indicates if there was a suggested change to width.",
+          "type": "boolean"
+        }
+      },
+      "type": "object"
+    },
+    "EmbeddedObjectSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base EmbeddedObject have been changed in this suggestion.\nFor any field set to true, there is a new suggested value.",
+      "id": "EmbeddedObjectSuggestionState",
+      "properties": {
+        "descriptionSuggested": {
+          "description": "Indicates if there was a suggested change to description.",
+          "type": "boolean"
+        },
+        "embeddedDrawingPropertiesSuggestionState": {
+          "$ref": "EmbeddedDrawingPropertiesSuggestionState",
+          "description": "A mask that indicates which of the fields in embedded_drawing_properties have been\nchanged in this suggestion."
+        },
+        "embeddedObjectBorderSuggestionState": {
+          "$ref": "EmbeddedObjectBorderSuggestionState",
+          "description": "A mask that indicates which of the fields in embedded_object_border have been\nchanged in this suggestion."
+        },
+        "imagePropertiesSuggestionState": {
+          "$ref": "ImagePropertiesSuggestionState",
+          "description": "A mask that indicates which of the fields in image_properties have been changed in\nthis suggestion."
+        },
+        "linkedContentReferenceSuggestionState": {
+          "$ref": "LinkedContentReferenceSuggestionState",
+          "description": "A mask that indicates which of the fields in linked_content_reference have been\nchanged in this suggestion."
+        },
+        "marginBottomSuggested": {
+          "description": "Indicates if there was a suggested change to margin_bottom.",
+          "type": "boolean"
+        },
+        "marginLeftSuggested": {
+          "description": "Indicates if there was a suggested change to margin_left.",
+          "type": "boolean"
+        },
+        "marginRightSuggested": {
+          "description": "Indicates if there was a suggested change to margin_right.",
+          "type": "boolean"
+        },
+        "marginTopSuggested": {
+          "description": "Indicates if there was a suggested change to margin_top.",
+          "type": "boolean"
+        },
+        "sizeSuggestionState": {
+          "$ref": "SizeSuggestionState",
+          "description": "A mask that indicates which of the fields in size have been changed in this\nsuggestion."
+        },
+        "titleSuggested": {
+          "description": "Indicates if there was a suggested change to title.",
+          "type": "boolean"
+        }
+      },
+      "type": "object"
+    },
+    "EndOfSegmentLocation": {
+      "description": "Location at the end of a body, header, footer or footnote. The location is\nimmediately before the last newline in the document segment.",
+      "id": "EndOfSegmentLocation",
+      "properties": {
+        "segmentId": {
+          "description": "The ID of the header, footer or footnote the location is in. An empty\nsegment ID signifies the document's body.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "Equation": {
+      "description": "A ParagraphElement representing an\nequation.",
+      "id": "Equation",
+      "properties": {
+        "suggestedDeletionIds": {
+          "description": "The suggested deletion IDs. If empty, then there are no suggested deletions\nof this content.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedInsertionIds": {
+          "description": "The suggested insertion IDs. A Equation\nmay have multiple insertion IDs if it is a nested suggested change. If\nempty, then this is not a suggested insertion.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        }
+      },
+      "type": "object"
+    },
+    "Footer": {
+      "description": "A document footer.",
+      "id": "Footer",
+      "properties": {
+        "content": {
+          "description": "The contents of the footer.\n\nThe indices for a footer's content begin at zero.",
+          "items": {
+            "$ref": "StructuralElement"
+          },
+          "type": "array"
+        },
+        "footerId": {
+          "description": "The ID of the footer.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "Footnote": {
+      "description": "A document footnote.",
+      "id": "Footnote",
+      "properties": {
+        "content": {
+          "description": "The contents of the footnote.\n\nThe indices for a footnote's content begin at zero.",
+          "items": {
+            "$ref": "StructuralElement"
+          },
+          "type": "array"
+        },
+        "footnoteId": {
+          "description": "The ID of the footnote.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "FootnoteReference": {
+      "description": "A ParagraphElement representing a\nfootnote reference. A footnote reference is the inline content rendered with\na number and is used to identify the footnote.",
+      "id": "FootnoteReference",
+      "properties": {
+        "footnoteId": {
+          "description": "The ID of the footnote that\ncontains the content of this footnote reference.",
+          "type": "string"
+        },
+        "footnoteNumber": {
+          "description": "The rendered number of this footnote.",
+          "type": "string"
+        },
+        "suggestedDeletionIds": {
+          "description": "The suggested deletion IDs. If empty, then there are no suggested deletions\nof this content.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedInsertionIds": {
+          "description": "The suggested insertion IDs. A FootnoteReference may have multiple insertion IDs if\nit is a nested suggested change. If empty, then this is not a suggested\ninsertion.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedTextStyleChanges": {
+          "additionalProperties": {
+            "$ref": "SuggestedTextStyle"
+          },
+          "description": "The suggested text style changes to this FootnoteReference, keyed by\nsuggestion ID.",
+          "type": "object"
+        },
+        "textStyle": {
+          "$ref": "TextStyle",
+          "description": "The text style of this FootnoteReference."
+        }
+      },
+      "type": "object"
+    },
+    "Header": {
+      "description": "A document header.",
+      "id": "Header",
+      "properties": {
+        "content": {
+          "description": "The contents of the header.\n\nThe indices for a header's content begin at zero.",
+          "items": {
+            "$ref": "StructuralElement"
+          },
+          "type": "array"
+        },
+        "headerId": {
+          "description": "The ID of the header.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "HorizontalRule": {
+      "description": "A ParagraphElement representing a\nhorizontal line.",
+      "id": "HorizontalRule",
+      "properties": {
+        "suggestedDeletionIds": {
+          "description": "The suggested deletion IDs. If empty, then there are no suggested deletions\nof this content.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedInsertionIds": {
+          "description": "The suggested insertion IDs. A HorizontalRule may have multiple insertion IDs if it\nis a nested suggested change. If empty, then this is not a suggested\ninsertion.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedTextStyleChanges": {
+          "additionalProperties": {
+            "$ref": "SuggestedTextStyle"
+          },
+          "description": "The suggested text style changes to this HorizontalRule, keyed by\nsuggestion ID.",
+          "type": "object"
+        },
+        "textStyle": {
+          "$ref": "TextStyle",
+          "description": "The text style of this HorizontalRule.\n\nSimilar to text content, like text runs and footnote references, the text\nstyle of a horizontal rule can affect content layout as well as the styling\nof text inserted adjacent to it."
+        }
+      },
+      "type": "object"
+    },
+    "ImageProperties": {
+      "description": "The properties of an image.",
+      "id": "ImageProperties",
+      "properties": {
+        "angle": {
+          "description": "The clockwise rotation angle of the image, in radians.",
+          "format": "float",
+          "type": "number"
+        },
+        "brightness": {
+          "description": "The brightness effect of the image. The value should be in the interval\n[-1.0, 1.0], where 0 means no effect.",
+          "format": "float",
+          "type": "number"
+        },
+        "contentUri": {
+          "description": "A URI to the image with a default lifetime of 30 minutes.\nThis URI is tagged with the account of the requester. Anyone with the URI\neffectively accesses the image as the original requester. Access to the\nimage may be lost if the document's sharing settings change.",
+          "type": "string"
+        },
+        "contrast": {
+          "description": "The contrast effect of the image. The value should be in the interval\n[-1.0, 1.0], where 0 means no effect.",
+          "format": "float",
+          "type": "number"
+        },
+        "cropProperties": {
+          "$ref": "CropProperties",
+          "description": "The crop properties of the image.\n\nAfter cropping, the image will be stretched to fit in its container."
+        },
+        "sourceUri": {
+          "description": "The source URI is the URI used to insert the image. The source URI can be\nempty.",
+          "type": "string"
+        },
+        "transparency": {
+          "description": "The transparency effect of the image. The value should be in the interval\n[0.0, 1.0], where 0 means no effect and 1 means completely transparent.",
+          "format": "float",
+          "type": "number"
+        }
+      },
+      "type": "object"
+    },
+    "ImagePropertiesSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base ImageProperties have been changed in this suggestion.\nFor any field set to true, there is a new suggested value.",
+      "id": "ImagePropertiesSuggestionState",
+      "properties": {
+        "angleSuggested": {
+          "description": "Indicates if there was a suggested change to angle.",
+          "type": "boolean"
+        },
+        "brightnessSuggested": {
+          "description": "Indicates if there was a suggested change to brightness.",
+          "type": "boolean"
+        },
+        "contentUriSuggested": {
+          "description": "Indicates if there was a suggested change to\ncontent_uri.",
+          "type": "boolean"
+        },
+        "contrastSuggested": {
+          "description": "Indicates if there was a suggested change to contrast.",
+          "type": "boolean"
+        },
+        "cropPropertiesSuggestionState": {
+          "$ref": "CropPropertiesSuggestionState",
+          "description": "A mask that indicates which of the fields in crop_properties have been changed in\nthis suggestion."
+        },
+        "sourceUriSuggested": {
+          "description": "Indicates if there was a suggested change to source_uri.",
+          "type": "boolean"
+        },
+        "transparencySuggested": {
+          "description": "Indicates if there was a suggested change to transparency.",
+          "type": "boolean"
+        }
+      },
+      "type": "object"
+    },
+    "InlineObject": {
+      "description": "An object that appears inline with text. An InlineObject contains\nan EmbeddedObject such as an image.",
+      "id": "InlineObject",
+      "properties": {
+        "inlineObjectProperties": {
+          "$ref": "InlineObjectProperties",
+          "description": "The properties of this inline object."
+        },
+        "objectId": {
+          "description": "The ID of this inline object.",
+          "type": "string"
+        },
+        "suggestedDeletionIds": {
+          "description": "The suggested deletion IDs. If empty, then there are no suggested deletions\nof this content.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedInlineObjectPropertiesChanges": {
+          "additionalProperties": {
+            "$ref": "SuggestedInlineObjectProperties"
+          },
+          "description": "The suggested changes to the inline object properties, keyed by suggestion\nID.",
+          "type": "object"
+        },
+        "suggestedInsertionId": {
+          "description": "The suggested insertion ID. If empty, then this is not a suggested\ninsertion.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "InlineObjectElement": {
+      "description": "A ParagraphElement that contains\nan InlineObject.",
+      "id": "InlineObjectElement",
+      "properties": {
+        "inlineObjectId": {
+          "description": "The ID of the InlineObject this\nelement contains.",
+          "type": "string"
+        },
+        "suggestedDeletionIds": {
+          "description": "The suggested deletion IDs. If empty, then there are no suggested deletions\nof this content.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedInsertionIds": {
+          "description": "The suggested insertion IDs. An InlineObjectElement may have multiple insertion IDs\nif it is a nested suggested change. If empty, then this is not a suggested\ninsertion.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedTextStyleChanges": {
+          "additionalProperties": {
+            "$ref": "SuggestedTextStyle"
+          },
+          "description": "The suggested text style changes to this InlineObject, keyed by suggestion\nID.",
+          "type": "object"
+        },
+        "textStyle": {
+          "$ref": "TextStyle",
+          "description": "The text style of this InlineObjectElement.\n\nSimilar to text content, like text runs and footnote references, the text\nstyle of an inline object element can affect content layout as well as the\nstyling of text inserted adjacent to it."
+        }
+      },
+      "type": "object"
+    },
+    "InlineObjectProperties": {
+      "description": "Properties of an InlineObject.",
+      "id": "InlineObjectProperties",
+      "properties": {
+        "embeddedObject": {
+          "$ref": "EmbeddedObject",
+          "description": "The embedded object of this inline object."
+        }
+      },
+      "type": "object"
+    },
+    "InlineObjectPropertiesSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base\nInlineObjectProperties have\nbeen changed in this suggestion. For any field set to true, there is a new\nsuggested value.",
+      "id": "InlineObjectPropertiesSuggestionState",
+      "properties": {
+        "embeddedObjectSuggestionState": {
+          "$ref": "EmbeddedObjectSuggestionState",
+          "description": "A mask that indicates which of the fields in embedded_object have been\nchanged in this suggestion."
+        }
+      },
+      "type": "object"
+    },
+    "InsertInlineImageRequest": {
+      "description": "Inserts an InlineObject containing an\nimage at the given location.",
+      "id": "InsertInlineImageRequest",
+      "properties": {
+        "endOfSegmentLocation": {
+          "$ref": "EndOfSegmentLocation",
+          "description": "Inserts the text at the end of a header, footer or the document body.\n\nInline images cannot be inserted inside a footnote."
+        },
+        "location": {
+          "$ref": "Location",
+          "description": "Inserts the image at a specific index in the document.\n\nThe image must be inserted inside the bounds of an existing\nParagraph. For instance, it cannot be\ninserted at a table's start index (i.e. between the table and its\npreceding paragraph).\n\nInline images cannot be inserted inside a footnote or equation."
+        },
+        "objectSize": {
+          "$ref": "Size",
+          "description": "The size that the image should appear as in the document. This property is\noptional and the final size of the image in the document is determined by\nthe following rules:\n * If neither width nor height is specified, then a default size of the\n image is calculated based on its resolution.\n * If one dimension is specified then the other dimension is calculated to\n preserve the aspect ratio of the image.\n * If both width and height are specified, the image is scaled to fit\n within the provided dimensions while maintaining its aspect ratio."
+        },
+        "uri": {
+          "description": "The image URI.\n\nThe image is fetched once at insertion time and a copy is stored for\ndisplay inside the document. Images must be less than 50MB in size, cannot\nexceed 25 megapixels, and must be in one of PNG, JPEG, or GIF format.\n\nThe provided URI can be at most 2 kB in length. The URI itself is saved\nwith the image, and exposed via the ImageProperties.content_uri field.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "InsertInlineImageResponse": {
+      "description": "The result of inserting an inline image.",
+      "id": "InsertInlineImageResponse",
+      "properties": {
+        "objectId": {
+          "description": "The ID of the created InlineObject.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "InsertInlineSheetsChartResponse": {
+      "description": "The result of inserting an embedded Google Sheets chart.",
+      "id": "InsertInlineSheetsChartResponse",
+      "properties": {
+        "objectId": {
+          "description": "The object ID of the inserted chart.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "InsertTableRowRequest": {
+      "description": "Inserts an empty row into a table.",
+      "id": "InsertTableRowRequest",
+      "properties": {
+        "insertBelow": {
+          "description": "Whether to insert new row below the reference cell location.\n\n- `True`: insert below the cell.\n- `False`: insert above the cell.",
+          "type": "boolean"
+        },
+        "tableCellLocation": {
+          "$ref": "TableCellLocation",
+          "description": "The reference table cell location from which rows will be inserted.\n\nA new row will be inserted above (or below) the row where the reference\ncell is. If the reference cell is a merged cell, a new row will be\ninserted above (or below) the merged cell."
+        }
+      },
+      "type": "object"
+    },
+    "InsertTextRequest": {
+      "description": "Inserts text at the specified location.",
+      "id": "InsertTextRequest",
+      "properties": {
+        "endOfSegmentLocation": {
+          "$ref": "EndOfSegmentLocation",
+          "description": "Inserts the text at the end of a header, footer, footnote or\nthe document body."
+        },
+        "location": {
+          "$ref": "Location",
+          "description": "Inserts the text at a specific index in the document.\n\nText must be inserted inside the bounds of an existing\nParagraph. For instance, text cannot be\ninserted at a table's start index (i.e. between the table and its\npreceding paragraph). The text must be inserted in the preceding\nparagraph."
+        },
+        "text": {
+          "description": "The text to be inserted.\n\nInserting a newline character will implicitly create a new\nParagraph at that index.\nThe paragraph style of the new paragraph will be copied from the paragraph\nat the current insertion index, including lists and bullets.\n\nText styles for inserted text will be determined automatically, generally\npreserving the styling of neighboring text. In most cases, the text style\nfor the inserted text will match the text immediately before the insertion\nindex.\n\nSome control characters (U+0000-U+0008, U+000C-U+001F) and characters\nfrom the Unicode Basic Multilingual Plane Private Use Area (U+E000-U+F8FF)\nwill be stripped out of the inserted text.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "Link": {
+      "description": "A reference to another portion of a document or an external URL resource.",
+      "id": "Link",
+      "properties": {
+        "bookmarkId": {
+          "description": "The ID of a bookmark in this document.",
+          "type": "string"
+        },
+        "headingId": {
+          "description": "The ID of a heading in this document.",
+          "type": "string"
+        },
+        "url": {
+          "description": "An external URL.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "LinkedContentReference": {
+      "description": "A reference to the external linked source content.",
+      "id": "LinkedContentReference",
+      "properties": {
+        "sheetsChartReference": {
+          "$ref": "SheetsChartReference",
+          "description": "A reference to the linked chart."
+        }
+      },
+      "type": "object"
+    },
+    "LinkedContentReferenceSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base\nLinkedContentReference have\nbeen changed in this suggestion. For any field set to true, there is a new\nsuggested value.",
+      "id": "LinkedContentReferenceSuggestionState",
+      "properties": {
+        "sheetsChartReferenceSuggestionState": {
+          "$ref": "SheetsChartReferenceSuggestionState",
+          "description": "A mask that indicates which of the fields in sheets_chart_reference have\nbeen changed in this suggestion."
+        }
+      },
+      "type": "object"
+    },
+    "List": {
+      "description": "A List represents the list attributes for a group of paragraphs that all\nbelong to the same list. A paragraph that is part of a list has a reference\nto the list's ID in its bullet.",
+      "id": "List",
+      "properties": {
+        "listProperties": {
+          "$ref": "ListProperties",
+          "description": "The properties of the list."
+        },
+        "suggestedDeletionIds": {
+          "description": "The suggested deletion IDs. If empty, then there are no suggested deletions\nof this list.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedInsertionId": {
+          "description": "The suggested insertion ID. If empty, then this is not a suggested\ninsertion.",
+          "type": "string"
+        },
+        "suggestedListPropertiesChanges": {
+          "additionalProperties": {
+            "$ref": "SuggestedListProperties"
+          },
+          "description": "The suggested changes to the list properties, keyed by suggestion\nID.",
+          "type": "object"
+        }
+      },
+      "type": "object"
+    },
+    "ListProperties": {
+      "description": "The properties of a list which describe the look\nand feel of bullets belonging to paragraphs associated with a list.",
+      "id": "ListProperties",
+      "properties": {
+        "nestingLevels": {
+          "description": "Describes the properties of the bullets at the associated level.\n\nA list has at most nine levels of nesting with nesting level 0\ncorresponding to the top-most level and nesting level 8 corresponding to\nthe most nested level. The nesting levels are returned in ascending order\nwith the least nested returned first.",
+          "items": {
+            "$ref": "NestingLevel"
+          },
+          "type": "array"
+        }
+      },
+      "type": "object"
+    },
+    "ListPropertiesSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base ListProperties have been changed in this suggestion.\nFor any field set to true, there is a new suggested value.",
+      "id": "ListPropertiesSuggestionState",
+      "properties": {
+        "nestingLevelsSuggestionStates": {
+          "description": "A mask that indicates which of the fields on the corresponding\nNestingLevel in nesting_levels have been changed in\nthis suggestion.\n\nThe nesting level suggestion states are returned in ascending order of the\nnesting level with the least nested returned first.",
+          "items": {
+            "$ref": "NestingLevelSuggestionState"
+          },
+          "type": "array"
+        }
+      },
+      "type": "object"
+    },
+    "Location": {
+      "description": "A particular location in the document.",
+      "id": "Location",
+      "properties": {
+        "index": {
+          "description": "The zero-based index, in UTF-16 code units.\n\nThe index is relative to the beginning of the segment specified by\nsegment_id.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "segmentId": {
+          "description": "The ID of the header, footer or footnote the location is in. An empty\nsegment ID signifies the document's body.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "NamedRange": {
+      "description": "A collection of Ranges with the same named range\nID.\n\nNamed ranges allow developers to associate parts of a document with an\narbitrary user-defined label so their contents can be programmatically read\nor edited at a later time. A document may contain multiple named ranges with\nthe same name, but every named range has a unique ID.\n\nA named range is created with a single Range,\nand content inserted inside a named range generally expands that range.\nHowever, certain document changes can cause the range to be split into\nmultiple ranges.",
+      "id": "NamedRange",
+      "properties": {
+        "name": {
+          "description": "The name of the named range.",
+          "type": "string"
+        },
+        "namedRangeId": {
+          "description": "The ID of the named range.",
+          "type": "string"
+        },
+        "ranges": {
+          "description": "The ranges that belong to this named range.",
+          "items": {
+            "$ref": "Range"
+          },
+          "type": "array"
+        }
+      },
+      "type": "object"
+    },
+    "NamedRanges": {
+      "description": "A collection of all the NamedRanges in the\ndocument that share a given name.",
+      "id": "NamedRanges",
+      "properties": {
+        "name": {
+          "description": "The name that all the named ranges share.",
+          "type": "string"
+        },
+        "namedRanges": {
+          "description": "The NamedRanges that share the same name.",
+          "items": {
+            "$ref": "NamedRange"
+          },
+          "type": "array"
+        }
+      },
+      "type": "object"
+    },
+    "NamedStyle": {
+      "description": "A named style. Paragraphs in the document can inherit their\nTextStyle and\nParagraphStyle from this named style\nwhen they have the same named style type.",
+      "id": "NamedStyle",
+      "properties": {
+        "namedStyleType": {
+          "description": "The type of this named style.",
+          "enum": [
+            "NAMED_STYLE_TYPE_UNSPECIFIED",
+            "NORMAL_TEXT",
+            "TITLE",
+            "SUBTITLE",
+            "HEADING_1",
+            "HEADING_2",
+            "HEADING_3",
+            "HEADING_4",
+            "HEADING_5",
+            "HEADING_6"
+          ],
+          "enumDescriptions": [
+            "The type of named style is unspecified.",
+            "Normal text.",
+            "Title.",
+            "Subtitle.",
+            "Heading 1.",
+            "Heading 2.",
+            "Heading 3.",
+            "Heading 4.",
+            "Heading 5.",
+            "Heading 6."
+          ],
+          "type": "string"
+        },
+        "paragraphStyle": {
+          "$ref": "ParagraphStyle",
+          "description": "The paragraph style of this named style."
+        },
+        "textStyle": {
+          "$ref": "TextStyle",
+          "description": "The text style of this named style."
+        }
+      },
+      "type": "object"
+    },
+    "NamedStyleSuggestionState": {
+      "description": "A suggestion state of a NamedStyle message.",
+      "id": "NamedStyleSuggestionState",
+      "properties": {
+        "namedStyleType": {
+          "description": "The named style type that this suggestion state corresponds to.\n\nThis field is provided as a convenience for matching the\nNamedStyleSuggestionState with its corresponding NamedStyle.",
+          "enum": [
+            "NAMED_STYLE_TYPE_UNSPECIFIED",
+            "NORMAL_TEXT",
+            "TITLE",
+            "SUBTITLE",
+            "HEADING_1",
+            "HEADING_2",
+            "HEADING_3",
+            "HEADING_4",
+            "HEADING_5",
+            "HEADING_6"
+          ],
+          "enumDescriptions": [
+            "The type of named style is unspecified.",
+            "Normal text.",
+            "Title.",
+            "Subtitle.",
+            "Heading 1.",
+            "Heading 2.",
+            "Heading 3.",
+            "Heading 4.",
+            "Heading 5.",
+            "Heading 6."
+          ],
+          "type": "string"
+        },
+        "paragraphStyleSuggestionState": {
+          "$ref": "ParagraphStyleSuggestionState",
+          "description": "A mask that indicates which of the fields in paragraph style have been changed in this\nsuggestion."
+        },
+        "textStyleSuggestionState": {
+          "$ref": "TextStyleSuggestionState",
+          "description": "A mask that indicates which of the fields in text style have been changed in this\nsuggestion."
+        }
+      },
+      "type": "object"
+    },
+    "NamedStyles": {
+      "description": "The named styles. Paragraphs in the document can inherit their\nTextStyle and\nParagraphStyle from these named styles.",
+      "id": "NamedStyles",
+      "properties": {
+        "styles": {
+          "description": "The named styles.\n\nThere is an entry for each of the possible named style types.",
+          "items": {
+            "$ref": "NamedStyle"
+          },
+          "type": "array"
+        }
+      },
+      "type": "object"
+    },
+    "NamedStylesSuggestionState": {
+      "description": "The suggestion state of a NamedStyles\nmessage.",
+      "id": "NamedStylesSuggestionState",
+      "properties": {
+        "stylesSuggestionStates": {
+          "description": "A mask that indicates which of the fields on the corresponding NamedStyle in styles have been changed in this\nsuggestion.\n\nThe order of these named style suggestion states match the order of the\ncorresponding named style within the named styles suggestion.",
+          "items": {
+            "$ref": "NamedStyleSuggestionState"
+          },
+          "type": "array"
+        }
+      },
+      "type": "object"
+    },
+    "NestingLevel": {
+      "description": "Contains properties describing the look and feel of a list bullet at a given\nlevel of nesting.",
+      "id": "NestingLevel",
+      "properties": {
+        "bulletAlignment": {
+          "description": "The alignment of the bullet within the space allotted for rendering the\nbullet.",
+          "enum": [
+            "BULLET_ALIGNMENT_UNSPECIFIED",
+            "START",
+            "CENTER",
+            "END"
+          ],
+          "enumDescriptions": [
+            "The bullet alignment is unspecified.",
+            "The bullet is aligned to the start of the space allotted for rendering\nthe bullet. Left-aligned for LTR text, right-aligned otherwise.",
+            "The bullet is aligned to the center of the space allotted for rendering\nthe bullet.",
+            "The bullet is aligned to the end of the space allotted for rendering the\nbullet. Right-aligned for LTR text, left-aligned otherwise."
+          ],
+          "type": "string"
+        },
+        "glyphFormat": {
+          "description": "The format string used by bullets at this level of nesting.\n\nThe glyph format contains one or more placeholders, and these placeholder\nare replaced with the appropriate values depending on the glyph_type or glyph_symbol. The placeholders follow\nthe pattern `%[nesting_level]`. Furthermore, placeholders can have prefixes\nand suffixes. Thus, the glyph format follows the pattern\n`\u003cprefix\u003e%[nesting_level]\u003csuffix\u003e`. Note that the prefix and suffix are\noptional and can be arbitrary strings.\n\nFor example, the glyph format `%0.` indicates that the rendered glyph will\nreplace the placeholder with the corresponding glyph for nesting level 0\nfollowed by a period as the suffix. So a list with a glyph type of\nUPPER_ALPHA and\nglyph format `%0.` at nesting level 0 will result in a list with rendered\nglyphs\n\u003cp\u003e`A.`\n\u003cp\u003e`B.`\n\u003cp\u003e`C.`\n\nThe glyph format can contain placeholders for the current nesting level as\nwell as placeholders for parent nesting levels. For example, a\nlist can have a glyph format of `%0.` at nesting level 0 and a\nglyph format of `%0.%1.` at nesting level 1. Assuming both nesting levels\nhave DECIMAL glyph\ntypes, this would result in a list with rendered glyphs\n\u003cp\u003e`1.`\n\u003cp\u003e`2.`\n\u003cp\u003e`  2.1.`\n\u003cp\u003e`  2.2.`\n\u003cp\u003e`3.`\n\nFor nesting levels that are ordered, the string that replaces a placeholder\nin the glyph format for a particular paragraph depends on the paragraph's\norder within the list.",
+          "type": "string"
+        },
+        "glyphSymbol": {
+          "description": "A custom glyph symbol used by bullets when paragraphs at this level of\nnesting are unordered.\n\nThe glyph symbol replaces placeholders within the glyph_format. For example, if the\nglyph_symbol is the solid circle corresponding to Unicode U+25cf code\npoint and the glyph_format is `%0`, the rendered\nglyph would be the solid circle.",
+          "type": "string"
+        },
+        "glyphType": {
+          "description": "The type of glyph used by bullets when paragraphs at this level of\nnesting are ordered.\n\nThe glyph type determines the type of glyph used to replace placeholders\nwithin the glyph_format\nwhen paragraphs at this level of nesting are ordered. For example, if the\nnesting level is 0, the glyph_format is `%0.` and the glyph\ntype is DECIMAL,\nthen the rendered glyph would replace the placeholder `%0` in the glyph\nformat with a number corresponding to list item's order within the list.",
+          "enum": [
+            "GLYPH_TYPE_UNSPECIFIED",
+            "NONE",
+            "DECIMAL",
+            "ZERO_DECIMAL",
+            "UPPER_ALPHA",
+            "ALPHA",
+            "UPPER_ROMAN",
+            "ROMAN"
+          ],
+          "enumDescriptions": [
+            "The glyph type is unspecified or unsupported.",
+            "An empty string.",
+            "A number, like `1`, `2`, or `3`.",
+            "A number where single digit numbers are prefixed with a zero, like `01`,\n`02`, or `03`. Numbers with more than one digit are not prefixed with a\nzero.",
+            "An uppercase letter, like `A`, `B`, or `C`.",
+            "A lowercase letter, like `a`, `b`, or `c`.",
+            "An uppercase roman numeral, like `I`, `II`, or `III`.",
+            "A lowercase roman numeral, like `i`, `ii`, or `iii`."
+          ],
+          "type": "string"
+        },
+        "indentFirstLine": {
+          "$ref": "Dimension",
+          "description": "The amount of indentation for the first line of paragraphs at this level of\nnesting."
+        },
+        "indentStart": {
+          "$ref": "Dimension",
+          "description": "The amount of indentation for paragraphs at this level of nesting. Applied\nto the side that corresponds to the start of the text, based on the\nparagraph's content direction."
+        },
+        "startNumber": {
+          "description": "The number of the first list item at this nesting level.\n\nA value of 0 is treated as a value of 1 for lettered lists and roman\nnumeraled lists, i.e. for values of both 0 and 1, lettered and roman\nnumeraled lists will begin at `a` and `i` respectively.\n\nThis value is ignored for nesting levels with unordered glyphs.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "textStyle": {
+          "$ref": "TextStyle",
+          "description": "The text style of bullets at this level of nesting."
+        }
+      },
+      "type": "object"
+    },
+    "NestingLevelSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base NestingLevel have been changed in this suggestion. For\nany field set to true, there is a new suggested value.",
+      "id": "NestingLevelSuggestionState",
+      "properties": {
+        "bulletAlignmentSuggested": {
+          "description": "Indicates if there was a suggested change to\nbullet_alignment.",
+          "type": "boolean"
+        },
+        "glyphFormatSuggested": {
+          "description": "Indicates if there was a suggested change to\nglyph_format.",
+          "type": "boolean"
+        },
+        "glyphSymbolSuggested": {
+          "description": "Indicates if there was a suggested change to\nglyph_symbol.",
+          "type": "boolean"
+        },
+        "glyphTypeSuggested": {
+          "description": "Indicates if there was a suggested change to\nglyph_type.",
+          "type": "boolean"
+        },
+        "indentFirstLineSuggested": {
+          "description": "Indicates if there was a suggested change to\nindent_first_line.",
+          "type": "boolean"
+        },
+        "indentStartSuggested": {
+          "description": "Indicates if there was a suggested change to\nindent_start.",
+          "type": "boolean"
+        },
+        "startNumberSuggested": {
+          "description": "Indicates if there was a suggested change to\nstart_number.",
+          "type": "boolean"
+        },
+        "textStyleSuggestionState": {
+          "$ref": "TextStyleSuggestionState",
+          "description": "A mask that indicates which of the fields in text style have been changed in this\nsuggestion."
+        }
+      },
+      "type": "object"
+    },
+    "ObjectReferences": {
+      "description": "A collection of object IDs.",
+      "id": "ObjectReferences",
+      "properties": {
+        "objectIds": {
+          "description": "The object IDs.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        }
+      },
+      "type": "object"
+    },
+    "OptionalColor": {
+      "description": "A color that can either be fully opaque or fully transparent.",
+      "id": "OptionalColor",
+      "properties": {
+        "color": {
+          "$ref": "Color",
+          "description": "If set, this will be used as an opaque color. If unset, this represents\na transparent color."
+        }
+      },
+      "type": "object"
+    },
+    "PageBreak": {
+      "description": "A ParagraphElement representing a\npage break. A page break makes the subsequent text start at the top of the\nnext page.",
+      "id": "PageBreak",
+      "properties": {
+        "suggestedDeletionIds": {
+          "description": "The suggested deletion IDs. If empty, then there are no suggested deletions\nof this content.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedInsertionIds": {
+          "description": "The suggested insertion IDs. A PageBreak\nmay have multiple insertion IDs if it is a nested suggested change. If\nempty, then this is not a suggested insertion.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedTextStyleChanges": {
+          "additionalProperties": {
+            "$ref": "SuggestedTextStyle"
+          },
+          "description": "The suggested text style changes to this PageBreak, keyed by suggestion ID.",
+          "type": "object"
+        },
+        "textStyle": {
+          "$ref": "TextStyle",
+          "description": "The text style of this PageBreak.\n\nSimilar to text content, like text runs and footnote references, the text\nstyle of a page break can affect content layout as well as the styling of\ntext inserted adjacent to it."
+        }
+      },
+      "type": "object"
+    },
+    "Paragraph": {
+      "description": "A StructuralElement representing a\nparagraph. A paragraph is a range of content that is terminated with a\nnewline character.",
+      "id": "Paragraph",
+      "properties": {
+        "bullet": {
+          "$ref": "Bullet",
+          "description": "The bullet for this paragraph. If not present, the paragraph does not\nbelong to a list."
+        },
+        "elements": {
+          "description": "The content of the paragraph broken down into its component parts.",
+          "items": {
+            "$ref": "ParagraphElement"
+          },
+          "type": "array"
+        },
+        "paragraphStyle": {
+          "$ref": "ParagraphStyle",
+          "description": "The style of this paragraph."
+        },
+        "positionedObjectIds": {
+          "description": "The IDs of the positioned objects tethered to this paragraph.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedBulletChanges": {
+          "additionalProperties": {
+            "$ref": "SuggestedBullet"
+          },
+          "description": "The suggested changes to this paragraph's bullet.",
+          "type": "object"
+        },
+        "suggestedParagraphStyleChanges": {
+          "additionalProperties": {
+            "$ref": "SuggestedParagraphStyle"
+          },
+          "description": "The suggested paragraph style changes to this paragraph, keyed by\nsuggestion ID.",
+          "type": "object"
+        },
+        "suggestedPositionedObjectIds": {
+          "additionalProperties": {
+            "$ref": "ObjectReferences"
+          },
+          "description": "The IDs of the positioned objects that are suggested to be attached to this\nparagraph, keyed by suggestion ID.",
+          "type": "object"
+        }
+      },
+      "type": "object"
+    },
+    "ParagraphBorder": {
+      "description": "A border around a paragraph.",
+      "id": "ParagraphBorder",
+      "properties": {
+        "color": {
+          "$ref": "OptionalColor",
+          "description": "The color of the border."
+        },
+        "dashStyle": {
+          "description": "The dash style of the border.",
+          "enum": [
+            "DASH_STYLE_UNSPECIFIED",
+            "SOLID",
+            "DOT",
+            "DASH"
+          ],
+          "enumDescriptions": [
+            "Unspecified dash style.",
+            "Solid line. Corresponds to ECMA-376 ST_PresetLineDashVal value 'solid'.\nThis is the default dash style.",
+            "Dotted line. Corresponds to ECMA-376 ST_PresetLineDashVal value 'dot'.",
+            "Dashed line. Corresponds to ECMA-376 ST_PresetLineDashVal value 'dash'."
+          ],
+          "type": "string"
+        },
+        "padding": {
+          "$ref": "Dimension",
+          "description": "The padding of the border."
+        },
+        "width": {
+          "$ref": "Dimension",
+          "description": "The width of the border."
+        }
+      },
+      "type": "object"
+    },
+    "ParagraphElement": {
+      "description": "A ParagraphElement describes content within a\nParagraph.",
+      "id": "ParagraphElement",
+      "properties": {
+        "autoText": {
+          "$ref": "AutoText",
+          "description": "An auto text paragraph element."
+        },
+        "columnBreak": {
+          "$ref": "ColumnBreak",
+          "description": "A column break paragraph element."
+        },
+        "endIndex": {
+          "description": "The zero-base end index of this paragraph element, exclusive, in Unicode\ncode units of the UTF-16 encoding.\n\nUnicode code units of the UTF-16 encoding means that surrogate pairs\nconsume two indices. For example, the \"GRINNING FACE\" emoji would be\nrepresented as \"\\uD83D\\uDE00\" and would consume two indices.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "equation": {
+          "$ref": "Equation",
+          "description": "An equation paragraph element."
+        },
+        "footnoteReference": {
+          "$ref": "FootnoteReference",
+          "description": "A footnote reference paragraph element."
+        },
+        "horizontalRule": {
+          "$ref": "HorizontalRule",
+          "description": "A horizontal rule paragraph element."
+        },
+        "inlineObjectElement": {
+          "$ref": "InlineObjectElement",
+          "description": "An inline object paragraph element."
+        },
+        "pageBreak": {
+          "$ref": "PageBreak",
+          "description": "A page break paragraph element."
+        },
+        "startIndex": {
+          "description": "The zero-based start index of this paragraph element, in Unicode code\nunits of the UTF-16 encoding.\n\nUnicode code units of the UTF-16 encoding means that surrogate pairs\nconsume two indices. For example, the \"GRINNING FACE\" emoji would be\nrepresented as \"\\uD83D\\uDE00\" and would consume two indices.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "textRun": {
+          "$ref": "TextRun",
+          "description": "A text run paragraph element."
+        }
+      },
+      "type": "object"
+    },
+    "ParagraphStyle": {
+      "description": "Styles that apply to a whole paragraph.\n\nInherited paragraph styles are represented as unset fields in this message.\nA paragraph style's parent depends on where the paragraph style is defined:\n\n  * The ParagraphStyle on a Paragraph\n    inherits from the paragraph's corresponding named style type.\n  * The ParagraphStyle on a named style\n    inherits from the normal text named style.\n  * The ParagraphStyle of the normal text named style inherits\n    from the default paragraph style in the Docs editor.\n  * The ParagraphStyle on a Paragraph\n    element that is contained in a table may inherit its paragraph style from\n    the table style.\n\nIf the paragraph style does not inherit from a parent, unsetting fields will\nrevert the style to a value matching the defaults in the Docs editor.",
+      "id": "ParagraphStyle",
+      "properties": {
+        "alignment": {
+          "description": "The text alignment for this paragraph.",
+          "enum": [
+            "ALIGNMENT_UNSPECIFIED",
+            "START",
+            "CENTER",
+            "END",
+            "JUSTIFIED"
+          ],
+          "enumDescriptions": [
+            "The paragraph alignment is inherited from the parent.",
+            "The paragraph is aligned to the start of the line. Left-aligned for LTR\ntext, right-aligned otherwise.",
+            "The paragraph is centered.",
+            "The paragraph is aligned to the end of the line. Right-aligned for LTR\ntext, left-aligned otherwise.",
+            "The paragraph is justified."
+          ],
+          "type": "string"
+        },
+        "avoidWidowAndOrphan": {
+          "description": "Whether to avoid widows and orphans for the paragraph. If unset, the value\nis inherited from the parent.",
+          "type": "boolean"
+        },
+        "borderBetween": {
+          "$ref": "ParagraphBorder",
+          "description": "The border between this paragraph and the next and previous paragraphs.\nIf unset, the value is inherited from the parent.\n\nThe between border is rendered when the adjacent paragraph has the same\nborder and indent properties.\n\nParagraph borders cannot be partially updated. When making\nchanges to a paragraph border the new border must be specified in\nits entirety."
+        },
+        "borderBottom": {
+          "$ref": "ParagraphBorder",
+          "description": "The border at the bottom of this paragraph. If unset, the value is\ninherited from the parent.\n\nThe bottom border is rendered when the paragraph below has different border\nand indent properties.\n\nParagraph borders cannot be partially updated. When making\nchanges to a paragraph border the new border must be specified in\nits entirety."
+        },
+        "borderLeft": {
+          "$ref": "ParagraphBorder",
+          "description": "The border to the left of this paragraph. If unset, the value is inherited\nfrom the parent.\n\nParagraph borders cannot be partially updated. When making\nchanges to a paragraph border the new border must be specified in\nits entirety."
+        },
+        "borderRight": {
+          "$ref": "ParagraphBorder",
+          "description": "The border to the right of this paragraph. If unset, the value is inherited\nfrom the parent.\n\nParagraph borders cannot be partially updated. When making\nchanges to a paragraph border the new border must be specified in\nits entirety."
+        },
+        "borderTop": {
+          "$ref": "ParagraphBorder",
+          "description": "The border at the top of this paragraph. If unset, the value is inherited\nfrom the parent.\n\nThe top border is rendered when the paragraph above has different border\nand indent properties.\n\nParagraph borders cannot be partially updated. When making\nchanges to a paragraph border the new border must be specified in\nits entirety."
+        },
+        "direction": {
+          "description": "The text direction of this paragraph. If unset, the value defaults to\nLEFT_TO_RIGHT since\nparagraph direction is not inherited.",
+          "enum": [
+            "CONTENT_DIRECTION_UNSPECIFIED",
+            "LEFT_TO_RIGHT",
+            "RIGHT_TO_LEFT"
+          ],
+          "enumDescriptions": [
+            "The content direction is unspecified.",
+            "The content goes from left to right.",
+            "The content goes from right to left."
+          ],
+          "type": "string"
+        },
+        "headingId": {
+          "description": "The heading ID of the paragraph. If empty, then this paragraph is not a\nheading. This property is read-only.",
+          "type": "string"
+        },
+        "indentEnd": {
+          "$ref": "Dimension",
+          "description": "The amount of indentation for the paragraph on the side that corresponds to\nthe end of the text, based on the current paragraph direction. If unset,\nthe value is inherited from the parent."
+        },
+        "indentFirstLine": {
+          "$ref": "Dimension",
+          "description": "The amount of indentation for the first line of the paragraph. If unset,\nthe value is inherited from the parent."
+        },
+        "indentStart": {
+          "$ref": "Dimension",
+          "description": "The amount of indentation for the paragraph on the side that corresponds to\nthe start of the text, based on the current paragraph direction. If unset,\nthe value is inherited from the parent."
+        },
+        "keepLinesTogether": {
+          "description": "Whether all lines of the paragraph should be laid out on the same page or\ncolumn if possible. If unset, the value is inherited from the parent.",
+          "type": "boolean"
+        },
+        "keepWithNext": {
+          "description": "Whether at least a part of this paragraph should be laid out on the same\npage or column as the next paragraph if possible. If unset, the value is\ninherited from the parent.",
+          "type": "boolean"
+        },
+        "lineSpacing": {
+          "description": "The amount of space between lines, as a percentage of normal, where normal\nis represented as 100.0. If unset, the value is inherited from the parent.",
+          "format": "float",
+          "type": "number"
+        },
+        "namedStyleType": {
+          "description": "The named style type of the paragraph.\n\nSince updating the named style type affects other properties within\nParagraphStyle, the named style type is applied before the other properties\nare updated.",
+          "enum": [
+            "NAMED_STYLE_TYPE_UNSPECIFIED",
+            "NORMAL_TEXT",
+            "TITLE",
+            "SUBTITLE",
+            "HEADING_1",
+            "HEADING_2",
+            "HEADING_3",
+            "HEADING_4",
+            "HEADING_5",
+            "HEADING_6"
+          ],
+          "enumDescriptions": [
+            "The type of named style is unspecified.",
+            "Normal text.",
+            "Title.",
+            "Subtitle.",
+            "Heading 1.",
+            "Heading 2.",
+            "Heading 3.",
+            "Heading 4.",
+            "Heading 5.",
+            "Heading 6."
+          ],
+          "type": "string"
+        },
+        "shading": {
+          "$ref": "Shading",
+          "description": "The shading of the paragraph. If unset, the value is inherited from the\nparent."
+        },
+        "spaceAbove": {
+          "$ref": "Dimension",
+          "description": "The amount of extra space above the paragraph. If unset, the value is\ninherited from the parent."
+        },
+        "spaceBelow": {
+          "$ref": "Dimension",
+          "description": "The amount of extra space below the paragraph. If unset, the value is\ninherited from the parent."
+        },
+        "spacingMode": {
+          "description": "The spacing mode for the paragraph.",
+          "enum": [
+            "SPACING_MODE_UNSPECIFIED",
+            "NEVER_COLLAPSE",
+            "COLLAPSE_LISTS"
+          ],
+          "enumDescriptions": [
+            "The spacing mode is inherited from the parent.",
+            "Paragraph spacing is always rendered.",
+            "Paragraph spacing is skipped between list elements."
+          ],
+          "type": "string"
+        },
+        "tabStops": {
+          "description": "A list of the tab stops for this paragraph. The list of tab stops is not\ninherited. This property is read-only.",
+          "items": {
+            "$ref": "TabStop"
+          },
+          "type": "array"
+        }
+      },
+      "type": "object"
+    },
+    "ParagraphStyleSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base ParagraphStyle have been changed in this suggestion.\nFor any field set to true, there is a new suggested value.",
+      "id": "ParagraphStyleSuggestionState",
+      "properties": {
+        "alignmentSuggested": {
+          "description": "Indicates if there was a suggested change to alignment.",
+          "type": "boolean"
+        },
+        "avoidWidowAndOrphanSuggested": {
+          "description": "Indicates if there was a suggested change to avoid_widow_and_orphan.",
+          "type": "boolean"
+        },
+        "borderBetweenSuggested": {
+          "description": "Indicates if there was a suggested change to border_between.",
+          "type": "boolean"
+        },
+        "borderBottomSuggested": {
+          "description": "Indicates if there was a suggested change to border_bottom.",
+          "type": "boolean"
+        },
+        "borderLeftSuggested": {
+          "description": "Indicates if there was a suggested change to border_left.",
+          "type": "boolean"
+        },
+        "borderRightSuggested": {
+          "description": "Indicates if there was a suggested change to border_right.",
+          "type": "boolean"
+        },
+        "borderTopSuggested": {
+          "description": "Indicates if there was a suggested change to border_top.",
+          "type": "boolean"
+        },
+        "directionSuggested": {
+          "description": "Indicates if there was a suggested change to direction.",
+          "type": "boolean"
+        },
+        "headingIdSuggested": {
+          "description": "Indicates if there was a suggested change to heading_id.",
+          "type": "boolean"
+        },
+        "indentEndSuggested": {
+          "description": "Indicates if there was a suggested change to indent_end.",
+          "type": "boolean"
+        },
+        "indentFirstLineSuggested": {
+          "description": "Indicates if there was a suggested change to indent_first_line.",
+          "type": "boolean"
+        },
+        "indentStartSuggested": {
+          "description": "Indicates if there was a suggested change to indent_start.",
+          "type": "boolean"
+        },
+        "keepLinesTogetherSuggested": {
+          "description": "Indicates if there was a suggested change to keep_lines_together.",
+          "type": "boolean"
+        },
+        "keepWithNextSuggested": {
+          "description": "Indicates if there was a suggested change to keep_with_next.",
+          "type": "boolean"
+        },
+        "lineSpacingSuggested": {
+          "description": "Indicates if there was a suggested change to line_spacing.",
+          "type": "boolean"
+        },
+        "namedStyleTypeSuggested": {
+          "description": "Indicates if there was a suggested change to named_style_type.",
+          "type": "boolean"
+        },
+        "shadingSuggestionState": {
+          "$ref": "ShadingSuggestionState",
+          "description": "A mask that indicates which of the fields in shading have been changed in\nthis suggestion."
+        },
+        "spaceAboveSuggested": {
+          "description": "Indicates if there was a suggested change to space_above.",
+          "type": "boolean"
+        },
+        "spaceBelowSuggested": {
+          "description": "Indicates if there was a suggested change to space_below.",
+          "type": "boolean"
+        },
+        "spacingModeSuggested": {
+          "description": "Indicates if there was a suggested change to spacing_mode.",
+          "type": "boolean"
+        }
+      },
+      "type": "object"
+    },
+    "PositionedObject": {
+      "description": "An object that is tethered to a Paragraph\nand positioned relative to the beginning of the paragraph. A PositionedObject\ncontains an EmbeddedObject such as an\nimage.",
+      "id": "PositionedObject",
+      "properties": {
+        "objectId": {
+          "description": "The ID of this positioned object.",
+          "type": "string"
+        },
+        "positionedObjectProperties": {
+          "$ref": "PositionedObjectProperties",
+          "description": "The properties of this positioned object."
+        },
+        "suggestedDeletionIds": {
+          "description": "The suggested deletion IDs. If empty, then there are no suggested deletions\nof this content.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedInsertionId": {
+          "description": "The suggested insertion ID. If empty, then this is not a suggested\ninsertion.",
+          "type": "string"
+        },
+        "suggestedPositionedObjectPropertiesChanges": {
+          "additionalProperties": {
+            "$ref": "SuggestedPositionedObjectProperties"
+          },
+          "description": "The suggested changes to the positioned object properties, keyed by\nsuggestion ID.",
+          "type": "object"
+        }
+      },
+      "type": "object"
+    },
+    "PositionedObjectPositioning": {
+      "description": "The positioning of a PositionedObject. The positioned object is positioned\nrelative to the beginning of the Paragraph\nit is tethered to.",
+      "id": "PositionedObjectPositioning",
+      "properties": {
+        "layout": {
+          "description": "The layout of this positioned object.",
+          "enum": [
+            "POSITIONED_OBJECT_LAYOUT_UNSPECIFIED",
+            "WRAP_TEXT",
+            "BREAK_LEFT",
+            "BREAK_RIGHT",
+            "BREAK_LEFT_RIGHT",
+            "IN_FRONT_OF_TEXT"
+          ],
+          "enumDescriptions": [
+            "The layout is unspecified.",
+            "The text wraps around the positioned object.",
+            "Breaks text such that the positioned object is on the left and text is on\nthe right.",
+            "Breaks text such that the positioned object is on the right and text is on\nthe left.",
+            "Breaks text such that there is no text on the left or right of the\npositioned object.",
+            "The positioned object is in front of the text."
+          ],
+          "type": "string"
+        },
+        "leftOffset": {
+          "$ref": "Dimension",
+          "description": "The offset of the left edge of the positioned object relative to the\nbeginning of the Paragraph it is tethered\nto. The exact positioning of the object can depend on other content in the\ndocument and the document's styling."
+        },
+        "topOffset": {
+          "$ref": "Dimension",
+          "description": "The offset of the top edge of the positioned object relative to the\nbeginning of the Paragraph it is tethered\nto. The exact positioning of the object can depend on other content in the\ndocument and the document's styling."
+        }
+      },
+      "type": "object"
+    },
+    "PositionedObjectPositioningSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base\nPositionedObjectPositioning have been changed in this\nsuggestion. For any field set to true, there is a new suggested value.",
+      "id": "PositionedObjectPositioningSuggestionState",
+      "properties": {
+        "layoutSuggested": {
+          "description": "Indicates if there was a suggested change to layout.",
+          "type": "boolean"
+        },
+        "leftOffsetSuggested": {
+          "description": "Indicates if there was a suggested change to left_offset.",
+          "type": "boolean"
+        },
+        "topOffsetSuggested": {
+          "description": "Indicates if there was a suggested change to top_offset.",
+          "type": "boolean"
+        }
+      },
+      "type": "object"
+    },
+    "PositionedObjectProperties": {
+      "description": "Properties of a PositionedObject.",
+      "id": "PositionedObjectProperties",
+      "properties": {
+        "embeddedObject": {
+          "$ref": "EmbeddedObject",
+          "description": "The embedded object of this positioned object."
+        },
+        "positioning": {
+          "$ref": "PositionedObjectPositioning",
+          "description": "The positioning of this positioned object relative to the newline of the\nParagraph that references this positioned\nobject."
+        }
+      },
+      "type": "object"
+    },
+    "PositionedObjectPropertiesSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base\nPositionedObjectProperties\nhave been changed in this suggestion. For any field set to true, there is a\nnew suggested value.",
+      "id": "PositionedObjectPropertiesSuggestionState",
+      "properties": {
+        "embeddedObjectSuggestionState": {
+          "$ref": "EmbeddedObjectSuggestionState",
+          "description": "A mask that indicates which of the fields in embedded_object have been\nchanged in this suggestion."
+        },
+        "positioningSuggestionState": {
+          "$ref": "PositionedObjectPositioningSuggestionState",
+          "description": "A mask that indicates which of the fields in positioning have been\nchanged in this suggestion."
+        }
+      },
+      "type": "object"
+    },
+    "Range": {
+      "description": "Specifies a contiguous range of text.",
+      "id": "Range",
+      "properties": {
+        "endIndex": {
+          "description": "The zero-based end index of this range, exclusive, in Unicode code units of\nthe UTF-16 encoding.\n\nIn all current uses, an end index must be provided. This field is an\nInt32Value in order to accommodate future use cases with open-ended ranges.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "segmentId": {
+          "description": "The ID of the header, footer or footnote that this range is contained in.\nAn empty segment ID signifies the document's body.",
+          "type": "string"
+        },
+        "startIndex": {
+          "description": "The zero-based start index of this range, in Unicode code units of the\nUTF-16 encoding.\n\nIn all current uses, a start index must be provided. This field is an\nInt32Value in order to accommodate future use cases with open-ended ranges.",
+          "format": "int32",
+          "type": "integer"
+        }
+      },
+      "type": "object"
+    },
+    "ReplaceAllTextRequest": {
+      "description": "Replaces all instances of text matching a criteria with replace text.",
+      "id": "ReplaceAllTextRequest",
+      "properties": {
+        "containsText": {
+          "$ref": "SubstringMatchCriteria",
+          "description": "Finds text in the document matching this substring."
+        },
+        "replaceText": {
+          "description": "The text that will replace the matched text.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "ReplaceAllTextResponse": {
+      "description": "The result of replacing text.",
+      "id": "ReplaceAllTextResponse",
+      "properties": {
+        "occurrencesChanged": {
+          "description": "The number of occurrences changed by replacing all text.",
+          "format": "int32",
+          "type": "integer"
+        }
+      },
+      "type": "object"
+    },
+    "Request": {
+      "description": "A single update to apply to a document.",
+      "id": "Request",
+      "properties": {
+        "createNamedRange": {
+          "$ref": "CreateNamedRangeRequest",
+          "description": "Creates a named range."
+        },
+        "createParagraphBullets": {
+          "$ref": "CreateParagraphBulletsRequest",
+          "description": "Creates bullets for paragraphs."
+        },
+        "deleteContentRange": {
+          "$ref": "DeleteContentRangeRequest",
+          "description": "Deletes content from the document."
+        },
+        "deleteNamedRange": {
+          "$ref": "DeleteNamedRangeRequest",
+          "description": "Deletes a named range."
+        },
+        "deleteParagraphBullets": {
+          "$ref": "DeleteParagraphBulletsRequest",
+          "description": "Deletes bullets from paragraphs."
+        },
+        "deletePositionedObject": {
+          "$ref": "DeletePositionedObjectRequest",
+          "description": "Deletes a positioned object from the document."
+        },
+        "deleteTableColumn": {
+          "$ref": "DeleteTableColumnRequest",
+          "description": "Deletes a column from a table."
+        },
+        "deleteTableRow": {
+          "$ref": "DeleteTableRowRequest",
+          "description": "Deletes a row from a table."
+        },
+        "insertInlineImage": {
+          "$ref": "InsertInlineImageRequest",
+          "description": "Inserts an inline image at the specified location."
+        },
+        "insertTableRow": {
+          "$ref": "InsertTableRowRequest",
+          "description": "Inserts an empty row into a table."
+        },
+        "insertText": {
+          "$ref": "InsertTextRequest",
+          "description": "Inserts text at the specified location."
+        },
+        "replaceAllText": {
+          "$ref": "ReplaceAllTextRequest",
+          "description": "Replaces all instances of the specified text."
+        },
+        "updateParagraphStyle": {
+          "$ref": "UpdateParagraphStyleRequest",
+          "description": "Updates the paragraph style at the specified range."
+        },
+        "updateTextStyle": {
+          "$ref": "UpdateTextStyleRequest",
+          "description": "Updates the text style at the specified range."
+        }
+      },
+      "type": "object"
+    },
+    "Response": {
+      "description": "A single response from an update.",
+      "id": "Response",
+      "properties": {
+        "createNamedRange": {
+          "$ref": "CreateNamedRangeResponse",
+          "description": "The result of creating a named range."
+        },
+        "insertInlineImage": {
+          "$ref": "InsertInlineImageResponse",
+          "description": "The result of inserting an inline image."
+        },
+        "insertInlineSheetsChart": {
+          "$ref": "InsertInlineSheetsChartResponse",
+          "description": "The result of inserting an inline Google Sheets chart."
+        },
+        "replaceAllText": {
+          "$ref": "ReplaceAllTextResponse",
+          "description": "The result of replacing text."
+        }
+      },
+      "type": "object"
+    },
+    "RgbColor": {
+      "description": "An RGB color.",
+      "id": "RgbColor",
+      "properties": {
+        "blue": {
+          "description": "The blue component of the color, from 0.0 to 1.0.",
+          "format": "float",
+          "type": "number"
+        },
+        "green": {
+          "description": "The green component of the color, from 0.0 to 1.0.",
+          "format": "float",
+          "type": "number"
+        },
+        "red": {
+          "description": "The red component of the color, from 0.0 to 1.0.",
+          "format": "float",
+          "type": "number"
+        }
+      },
+      "type": "object"
+    },
+    "SectionBreak": {
+      "description": "A StructuralElement representing a\nsection break. A section is a range of content which has the same\nSectionStyle. A section break represents\nthe start of a new section, and the section style applies to the section\nafter the section break.\n\nThe document body always begins with a section break.",
+      "id": "SectionBreak",
+      "properties": {
+        "sectionStyle": {
+          "$ref": "SectionStyle",
+          "description": "The style of the section after this section break."
+        },
+        "suggestedDeletionIds": {
+          "description": "The suggested deletion IDs. If empty, then there are no suggested deletions\nof this content.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedInsertionIds": {
+          "description": "The suggested insertion IDs. A SectionBreak may have multiple insertion IDs if it is\na nested suggested change. If empty, then this is not a suggested\ninsertion.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        }
+      },
+      "type": "object"
+    },
+    "SectionColumnProperties": {
+      "description": "Properties that apply to a section's column.",
+      "id": "SectionColumnProperties",
+      "properties": {
+        "paddingEnd": {
+          "$ref": "Dimension",
+          "description": "The padding at the end of the column."
+        },
+        "width": {
+          "$ref": "Dimension",
+          "description": "The width of the column."
+        }
+      },
+      "type": "object"
+    },
+    "SectionStyle": {
+      "description": "The styling that applies to a section.",
+      "id": "SectionStyle",
+      "properties": {
+        "columnProperties": {
+          "description": "The section's columns properties.\n\nIf empty, the section contains one column with the default properties in\nthe Docs editor.",
+          "items": {
+            "$ref": "SectionColumnProperties"
+          },
+          "type": "array"
+        },
+        "columnSeparatorStyle": {
+          "description": "The style of column separators.\n\nThis style can be set even when there is one column in the section.",
+          "enum": [
+            "COLUMN_SEPARATOR_STYLE_UNSPECIFIED",
+            "NONE",
+            "BETWEEN_EACH_COLUMN"
+          ],
+          "enumDescriptions": [
+            "An unspecified column separator style.",
+            "No column separator lines between columns.",
+            "Renders a column separator line between each column."
+          ],
+          "type": "string"
+        },
+        "contentDirection": {
+          "description": "The content direction of this section. If unset, the value defaults to\nLEFT_TO_RIGHT.",
+          "enum": [
+            "CONTENT_DIRECTION_UNSPECIFIED",
+            "LEFT_TO_RIGHT",
+            "RIGHT_TO_LEFT"
+          ],
+          "enumDescriptions": [
+            "The content direction is unspecified.",
+            "The content goes from left to right.",
+            "The content goes from right to left."
+          ],
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "Shading": {
+      "description": "The shading of a paragraph.",
+      "id": "Shading",
+      "properties": {
+        "backgroundColor": {
+          "$ref": "OptionalColor",
+          "description": "The background color of this paragraph shading."
+        }
+      },
+      "type": "object"
+    },
+    "ShadingSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base Shading have been changed in this\nsuggested change. For any field set to true, there is a new suggested value.",
+      "id": "ShadingSuggestionState",
+      "properties": {
+        "backgroundColorSuggested": {
+          "description": "Indicates if there was a suggested change to the Shading.",
+          "type": "boolean"
+        }
+      },
+      "type": "object"
+    },
+    "SheetsChartReference": {
+      "description": "A reference to a linked chart embedded from Google Sheets.",
+      "id": "SheetsChartReference",
+      "properties": {
+        "chartId": {
+          "description": "The ID of the specific chart in the Google Sheets spreadsheet that is\nembedded.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "spreadsheetId": {
+          "description": "The ID of the Google Sheets spreadsheet that contains the source chart.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "SheetsChartReferenceSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base SheetsChartReference have been changed in this\nsuggestion. For any field set to true, there is a new suggested value.",
+      "id": "SheetsChartReferenceSuggestionState",
+      "properties": {
+        "chartIdSuggested": {
+          "description": "Indicates if there was a suggested change to chart_id.",
+          "type": "boolean"
+        },
+        "spreadsheetIdSuggested": {
+          "description": "Indicates if there was a suggested change to spreadsheet_id.",
+          "type": "boolean"
+        }
+      },
+      "type": "object"
+    },
+    "Size": {
+      "description": "A width and height.",
+      "id": "Size",
+      "properties": {
+        "height": {
+          "$ref": "Dimension",
+          "description": "The height of the object."
+        },
+        "width": {
+          "$ref": "Dimension",
+          "description": "The width of the object."
+        }
+      },
+      "type": "object"
+    },
+    "SizeSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base Size have been changed in this suggestion.\nFor any field set to true, the Size has\na new suggested value.",
+      "id": "SizeSuggestionState",
+      "properties": {
+        "heightSuggested": {
+          "description": "Indicates if there was a suggested change to height.",
+          "type": "boolean"
+        },
+        "widthSuggested": {
+          "description": "Indicates if there was a suggested change to width.",
+          "type": "boolean"
+        }
+      },
+      "type": "object"
+    },
+    "StructuralElement": {
+      "description": "A StructuralElement describes content that provides structure to the\ndocument.",
+      "id": "StructuralElement",
+      "properties": {
+        "endIndex": {
+          "description": "The zero-based end index of this structural element, exclusive, in Unicode\ncode units of the UTF-16 encoding.\n\nUnicode code units of the UTF-16 encoding means that surrogate pairs\nconsume two indices. For example, the \"GRINNING FACE\" emoji would be\nrepresented as \"\\uD83D\\uDE00\" and would consume two indices.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "paragraph": {
+          "$ref": "Paragraph",
+          "description": "A paragraph type of structural element."
+        },
+        "sectionBreak": {
+          "$ref": "SectionBreak",
+          "description": "A section break type of structural element."
+        },
+        "startIndex": {
+          "description": "The zero-based start index of this structural element, in Unicode code\nunits of the UTF-16 encoding.\n\nUnicode code units of the UTF-16 encoding means that surrogate pairs\nconsume two indices. For example, the \"GRINNING FACE\" emoji would be\nrepresented as \"\\uD83D\\uDE00\" and would consume two indices.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "table": {
+          "$ref": "Table",
+          "description": "A table type of structural element."
+        },
+        "tableOfContents": {
+          "$ref": "TableOfContents",
+          "description": "A table of contents type of structural element."
+        }
+      },
+      "type": "object"
+    },
+    "SubstringMatchCriteria": {
+      "description": "A criteria that matches a specific string of text in the document.",
+      "id": "SubstringMatchCriteria",
+      "properties": {
+        "matchCase": {
+          "description": "Indicates whether the search should respect case:\n\n- `True`: the search is case sensitive.\n- `False`: the search is case insensitive.",
+          "type": "boolean"
+        },
+        "text": {
+          "description": "The text to search for in the document.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "SuggestedBullet": {
+      "description": "A suggested change to a Bullet.",
+      "id": "SuggestedBullet",
+      "properties": {
+        "bullet": {
+          "$ref": "Bullet",
+          "description": "A Bullet that only includes the changes made\nin this suggestion. This can be used along with the\nbullet_suggestion_state to see which\nfields have changed and their new values."
+        },
+        "bulletSuggestionState": {
+          "$ref": "BulletSuggestionState",
+          "description": "A mask that indicates which of the fields on the base\nBullet have been changed in this suggestion."
+        }
+      },
+      "type": "object"
+    },
+    "SuggestedDocumentStyle": {
+      "description": "A suggested change to the DocumentStyle.",
+      "id": "SuggestedDocumentStyle",
+      "properties": {
+        "documentStyle": {
+          "$ref": "DocumentStyle",
+          "description": "A DocumentStyle that only includes\nthe changes made in this suggestion. This can be used along with the\ndocument_style_suggestion_state\nto see which fields have changed and their new values."
+        },
+        "documentStyleSuggestionState": {
+          "$ref": "DocumentStyleSuggestionState",
+          "description": "A mask that indicates which of the fields on the base DocumentStyle have been changed in this suggestion."
+        }
+      },
+      "type": "object"
+    },
+    "SuggestedInlineObjectProperties": {
+      "description": "A suggested change to InlineObjectProperties.",
+      "id": "SuggestedInlineObjectProperties",
+      "properties": {
+        "inlineObjectProperties": {
+          "$ref": "InlineObjectProperties",
+          "description": "An InlineObjectProperties\nthat only includes the changes made in this suggestion. This can be used\nalong with the inline_object_properties_suggestion_state\nto see which fields have changed and their new values."
+        },
+        "inlineObjectPropertiesSuggestionState": {
+          "$ref": "InlineObjectPropertiesSuggestionState",
+          "description": "A mask that indicates which of the fields on the base\nInlineObjectProperties have\nbeen changed in this suggestion."
+        }
+      },
+      "type": "object"
+    },
+    "SuggestedListProperties": {
+      "description": "A suggested change to ListProperties.",
+      "id": "SuggestedListProperties",
+      "properties": {
+        "listProperties": {
+          "$ref": "ListProperties",
+          "description": "A ListProperties that only includes\nthe changes made in this suggestion. This can be used along with the\nlist_properties_suggestion_state\nto see which fields have changed and their new values."
+        },
+        "listPropertiesSuggestionState": {
+          "$ref": "ListPropertiesSuggestionState",
+          "description": "A mask that indicates which of the fields on the base ListProperties have been changed in this suggestion."
+        }
+      },
+      "type": "object"
+    },
+    "SuggestedNamedStyles": {
+      "description": "A suggested change to the NamedStyles.",
+      "id": "SuggestedNamedStyles",
+      "properties": {
+        "namedStyles": {
+          "$ref": "NamedStyles",
+          "description": "A NamedStyles that only includes the\nchanges made in this suggestion. This can be used along with the\nnamed_styles_suggestion_state to\nsee which fields have changed and their new values."
+        },
+        "namedStylesSuggestionState": {
+          "$ref": "NamedStylesSuggestionState",
+          "description": "A mask that indicates which of the fields on the base NamedStyles have been changed in this suggestion."
+        }
+      },
+      "type": "object"
+    },
+    "SuggestedParagraphStyle": {
+      "description": "A suggested change to a\nParagraphStyle.",
+      "id": "SuggestedParagraphStyle",
+      "properties": {
+        "paragraphStyle": {
+          "$ref": "ParagraphStyle",
+          "description": "A ParagraphStyle that only includes\nthe changes made in this suggestion. This can be used along with the\nparagraph_suggestion_state\nto see which fields have changed and their new values."
+        },
+        "paragraphStyleSuggestionState": {
+          "$ref": "ParagraphStyleSuggestionState",
+          "description": "A mask that indicates which of the fields on the base ParagraphStyle have been changed in this suggestion."
+        }
+      },
+      "type": "object"
+    },
+    "SuggestedPositionedObjectProperties": {
+      "description": "A suggested change to PositionedObjectProperties.",
+      "id": "SuggestedPositionedObjectProperties",
+      "properties": {
+        "positionedObjectProperties": {
+          "$ref": "PositionedObjectProperties",
+          "description": "A PositionedObjectProperties that only includes the\nchanges made in this suggestion. This can be used along with the\npositioned_object_properties_suggestion_state\nto see which fields have changed and their new values."
+        },
+        "positionedObjectPropertiesSuggestionState": {
+          "$ref": "PositionedObjectPropertiesSuggestionState",
+          "description": "A mask that indicates which of the fields on the base\nPositionedObjectProperties have been changed in this\nsuggestion."
+        }
+      },
+      "type": "object"
+    },
+    "SuggestedTableCellStyle": {
+      "description": "A suggested change to a TableCellStyle.",
+      "id": "SuggestedTableCellStyle",
+      "properties": {
+        "tableCellStyle": {
+          "$ref": "TableCellStyle",
+          "description": "A TableCellStyle that only includes\nthe changes made in this suggestion. This can be used along with the\ntable_cell_style_suggestion_state\nto see which fields have changed and their new values."
+        },
+        "tableCellStyleSuggestionState": {
+          "$ref": "TableCellStyleSuggestionState",
+          "description": "A mask that indicates which of the fields on the base TableCellStyle have been changed in this suggestion."
+        }
+      },
+      "type": "object"
+    },
+    "SuggestedTableRowStyle": {
+      "description": "A suggested change to a\nTableRowStyle.",
+      "id": "SuggestedTableRowStyle",
+      "properties": {
+        "tableRowStyle": {
+          "$ref": "TableRowStyle",
+          "description": "A TableRowStyle that only includes\nthe changes made in this suggestion. This can be used along with the\ntable_row_style_suggestion_state\nto see which fields have changed and their new values."
+        },
+        "tableRowStyleSuggestionState": {
+          "$ref": "TableRowStyleSuggestionState",
+          "description": "A mask that indicates which of the fields on the base TableRowStyle have been changed in this suggestion."
+        }
+      },
+      "type": "object"
+    },
+    "SuggestedTextStyle": {
+      "description": "A suggested change to a TextStyle.",
+      "id": "SuggestedTextStyle",
+      "properties": {
+        "textStyle": {
+          "$ref": "TextStyle",
+          "description": "A TextStyle that only includes\nthe changes made in this suggestion. This can be used along with the\ntext_style_suggestion_state\nto see which fields have changed and their new values."
+        },
+        "textStyleSuggestionState": {
+          "$ref": "TextStyleSuggestionState",
+          "description": "A mask that indicates which of the fields on the base TextStyle have been changed in this suggestion."
+        }
+      },
+      "type": "object"
+    },
+    "TabStop": {
+      "description": "A tab stop within a paragraph.",
+      "id": "TabStop",
+      "properties": {
+        "alignment": {
+          "description": "The alignment of this tab stop. If unset, the value defaults to START.",
+          "enum": [
+            "TAB_STOP_ALIGNMENT_UNSPECIFIED",
+            "START",
+            "CENTER",
+            "END"
+          ],
+          "enumDescriptions": [
+            "The tab stop alignment is unspecified.",
+            "The tab stop is aligned to the start of the line. This is the default.",
+            "The tab stop is aligned to the center of the line.",
+            "The tab stop is aligned to the end of the line."
+          ],
+          "type": "string"
+        },
+        "offset": {
+          "$ref": "Dimension",
+          "description": "The offset between this tab stop and the start margin."
+        }
+      },
+      "type": "object"
+    },
+    "Table": {
+      "description": "A StructuralElement representing a\ntable.",
+      "id": "Table",
+      "properties": {
+        "columns": {
+          "description": "Number of columns in the table.\n\nIt is possible for a table to be non-rectangular, so some rows may have a\ndifferent number of cells.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "rows": {
+          "description": "Number of rows in the table.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "suggestedDeletionIds": {
+          "description": "The suggested deletion IDs. If empty, then there are no suggested deletions\nof this content.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedInsertionIds": {
+          "description": "The suggested insertion IDs. A Table may have\nmultiple insertion IDs if it is a nested suggested change. If empty, then\nthis is not a suggested insertion.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "tableRows": {
+          "description": "The contents and style of each row.",
+          "items": {
+            "$ref": "TableRow"
+          },
+          "type": "array"
+        },
+        "tableStyle": {
+          "$ref": "TableStyle",
+          "description": "The style of the table."
+        }
+      },
+      "type": "object"
+    },
+    "TableCell": {
+      "description": "The contents and style of a cell in a Table.",
+      "id": "TableCell",
+      "properties": {
+        "content": {
+          "description": "The content of the cell.",
+          "items": {
+            "$ref": "StructuralElement"
+          },
+          "type": "array"
+        },
+        "endIndex": {
+          "description": "The zero-based end index of this cell, exclusive, in Unicode code units of\nthe UTF-16 encoding.\n\nUnicode code units of the UTF-16 encoding means that surrogate pairs\nconsume two indices. For example, the \"GRINNING FACE\" emoji would be\nrepresented as \"\\uD83D\\uDE00\" and would consume two indices.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "startIndex": {
+          "description": "The zero-based start index of this cell, in Unicode code units of the\nUTF-16 encoding.\n\nUnicode code units of the UTF-16 encoding means that surrogate pairs\nconsume two indices. For example, the \"GRINNING FACE\" emoji would be\nrepresented as \"\\uD83D\\uDE00\" and would consume two indices.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "suggestedDeletionIds": {
+          "description": "The suggested deletion IDs. If empty, then there are no suggested deletions\nof this content.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedInsertionIds": {
+          "description": "The suggested insertion IDs. A TableCell\nmay have multiple insertion IDs if it is a nested suggested change. If\nempty, then this is not a suggested insertion.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedTableCellStyleChanges": {
+          "additionalProperties": {
+            "$ref": "SuggestedTableCellStyle"
+          },
+          "description": "The suggested changes to the table cell style, keyed by suggestion ID.",
+          "type": "object"
+        },
+        "tableCellStyle": {
+          "$ref": "TableCellStyle",
+          "description": "The style of the cell."
+        }
+      },
+      "type": "object"
+    },
+    "TableCellBorder": {
+      "description": "A border around a table cell.",
+      "id": "TableCellBorder",
+      "properties": {
+        "color": {
+          "$ref": "OptionalColor",
+          "description": "The color of the border."
+        },
+        "dashStyle": {
+          "description": "The dash style of the border.",
+          "enum": [
+            "DASH_STYLE_UNSPECIFIED",
+            "SOLID",
+            "DOT",
+            "DASH"
+          ],
+          "enumDescriptions": [
+            "Unspecified dash style.",
+            "Solid line. Corresponds to ECMA-376 ST_PresetLineDashVal value 'solid'.\nThis is the default dash style.",
+            "Dotted line. Corresponds to ECMA-376 ST_PresetLineDashVal value 'dot'.",
+            "Dashed line. Corresponds to ECMA-376 ST_PresetLineDashVal value 'dash'."
+          ],
+          "type": "string"
+        },
+        "width": {
+          "$ref": "Dimension",
+          "description": "The width of the border."
+        }
+      },
+      "type": "object"
+    },
+    "TableCellLocation": {
+      "description": "Location of a single cell within a table.",
+      "id": "TableCellLocation",
+      "properties": {
+        "columnIndex": {
+          "description": "The zero-based column index. For example, the second column in the table\nhas a column index of 1.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "rowIndex": {
+          "description": "The zero-based row index. For example, the second row in the table has a\nrow index of 1.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "tableStartLocation": {
+          "$ref": "Location",
+          "description": "The location where the table starts in the document."
+        }
+      },
+      "type": "object"
+    },
+    "TableCellStyle": {
+      "description": "The style of a TableCell.\n\nInherited table cell styles are represented as unset fields in this message.\nA table cell style can inherit from the table's style.",
+      "id": "TableCellStyle",
+      "properties": {
+        "backgroundColor": {
+          "$ref": "OptionalColor",
+          "description": "The background color of the cell."
+        },
+        "borderBottom": {
+          "$ref": "TableCellBorder",
+          "description": "The bottom border of the cell."
+        },
+        "borderLeft": {
+          "$ref": "TableCellBorder",
+          "description": "The left border of the cell."
+        },
+        "borderRight": {
+          "$ref": "TableCellBorder",
+          "description": "The right border of the cell."
+        },
+        "borderTop": {
+          "$ref": "TableCellBorder",
+          "description": "The top border of the cell."
+        },
+        "columnSpan": {
+          "description": "The column span of the cell. This property is read-only.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "contentAlignment": {
+          "description": "The alignment of the content in the table cell. The default alignment\nmatches the alignment for newly created table cells in the Docs editor.",
+          "enum": [
+            "CONTENT_ALIGNMENT_UNSPECIFIED",
+            "CONTENT_ALIGNMENT_UNSUPPORTED",
+            "TOP",
+            "MIDDLE",
+            "BOTTOM"
+          ],
+          "enumDescriptions": [
+            "An unspecified content alignment. The content alignment is inherited from\nthe parent if one exists.",
+            "An unsupported content alignment.",
+            "An alignment that aligns the content to the top of the content holder.\nCorresponds to ECMA-376 ST_TextAnchoringType 't'.",
+            "An alignment that aligns the content to the middle of the content holder.\nCorresponds to ECMA-376 ST_TextAnchoringType 'ctr'.",
+            "An alignment that aligns the content to the bottom of the content holder.\nCorresponds to ECMA-376 ST_TextAnchoringType 'b'."
+          ],
+          "type": "string"
+        },
+        "paddingBottom": {
+          "$ref": "Dimension",
+          "description": "The bottom padding of the cell."
+        },
+        "paddingLeft": {
+          "$ref": "Dimension",
+          "description": "The left padding of the cell."
+        },
+        "paddingRight": {
+          "$ref": "Dimension",
+          "description": "The right padding of the cell."
+        },
+        "paddingTop": {
+          "$ref": "Dimension",
+          "description": "The top padding of the cell."
+        },
+        "rowSpan": {
+          "description": "The row span of the cell. This property is read-only.",
+          "format": "int32",
+          "type": "integer"
+        }
+      },
+      "type": "object"
+    },
+    "TableCellStyleSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base TableCellStyle have been changed in this suggestion.\nFor any field set to true, there is a new suggested value.",
+      "id": "TableCellStyleSuggestionState",
+      "properties": {
+        "backgroundColorSuggested": {
+          "description": "Indicates if there was a suggested change to background_color.",
+          "type": "boolean"
+        },
+        "borderBottomSuggested": {
+          "description": "Indicates if there was a suggested change to border_bottom.",
+          "type": "boolean"
+        },
+        "borderLeftSuggested": {
+          "description": "Indicates if there was a suggested change to border_left.",
+          "type": "boolean"
+        },
+        "borderRightSuggested": {
+          "description": "Indicates if there was a suggested change to border_right.",
+          "type": "boolean"
+        },
+        "borderTopSuggested": {
+          "description": "Indicates if there was a suggested change to border_top.",
+          "type": "boolean"
+        },
+        "columnSpanSuggested": {
+          "description": "Indicates if there was a suggested change to column_span.",
+          "type": "boolean"
+        },
+        "contentAlignmentSuggested": {
+          "description": "Indicates if there was a suggested change to content_alignment.",
+          "type": "boolean"
+        },
+        "paddingBottomSuggested": {
+          "description": "Indicates if there was a suggested change to padding_bottom.",
+          "type": "boolean"
+        },
+        "paddingLeftSuggested": {
+          "description": "Indicates if there was a suggested change to padding_left.",
+          "type": "boolean"
+        },
+        "paddingRightSuggested": {
+          "description": "Indicates if there was a suggested change to padding_right.",
+          "type": "boolean"
+        },
+        "paddingTopSuggested": {
+          "description": "Indicates if there was a suggested change to padding_top.",
+          "type": "boolean"
+        },
+        "rowSpanSuggested": {
+          "description": "Indicates if there was a suggested change to row_span.",
+          "type": "boolean"
+        }
+      },
+      "type": "object"
+    },
+    "TableColumnProperties": {
+      "description": "The properties of a column in a table.",
+      "id": "TableColumnProperties",
+      "properties": {
+        "width": {
+          "$ref": "Dimension",
+          "description": "The width of the column. Set when the column's `width_type` is\nFIXED_WIDTH."
+        },
+        "widthType": {
+          "description": "The width type of the column.",
+          "enum": [
+            "WIDTH_TYPE_UNSPECIFIED",
+            "EVENLY_DISTRIBUTED",
+            "FIXED_WIDTH"
+          ],
+          "enumDescriptions": [
+            "The column width type is unspecified.",
+            "The column width is evenly distributed among the other evenly distrubted\ncolumns.\n\nThe width of the column is automatically determined and will\nhave an equal portion of the width remaining for the table after\naccounting for all columns with specified widths.",
+            "A fixed column width. The\nwidth property\ncontains the column's width."
+          ],
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
+    "TableOfContents": {
+      "description": "A StructuralElement representing\na table of contents.",
+      "id": "TableOfContents",
+      "properties": {
+        "content": {
+          "description": "The content of the table of contents.",
+          "items": {
+            "$ref": "StructuralElement"
+          },
+          "type": "array"
+        },
+        "suggestedDeletionIds": {
+          "description": "The suggested deletion IDs. If empty, then there are no suggested deletions\nof this content.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedInsertionIds": {
+          "description": "The suggested insertion IDs. A TableOfContents may have multiple insertion IDs if it\nis a nested suggested change. If empty, then this is not a suggested\ninsertion.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        }
+      },
+      "type": "object"
+    },
+    "TableRow": {
+      "description": "The contents and style of a row in a Table.",
+      "id": "TableRow",
+      "properties": {
+        "endIndex": {
+          "description": "The zero-based end index of this row, exclusive, in Unicode code units of\nthe UTF-16 encoding.\n\nUnicode code units of the UTF-16 encoding means that surrogate pairs\nconsume two indices. For example, the \"GRINNING FACE\" emoji would be\nrepresented as \"\\uD83D\\uDE00\" and would consume two indices.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "startIndex": {
+          "description": "The zero-based start index of this row, in Unicode code units of the UTF-16\nencoding.\n\nUnicode code units of the UTF-16 encoding means that surrogate pairs\nconsume two indices. For example, the \"GRINNING FACE\" emoji would be\nrepresented as \"\\uD83D\\uDE00\" and would consume two indices.",
+          "format": "int32",
+          "type": "integer"
+        },
+        "suggestedDeletionIds": {
+          "description": "The suggested deletion IDs. If empty, then there are no suggested deletions\nof this content.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedInsertionIds": {
+          "description": "The suggested insertion IDs. A TableRow\nmay have multiple insertion IDs if it is a nested suggested change. If\nempty, then this is not a suggested insertion.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedTableRowStyleChanges": {
+          "additionalProperties": {
+            "$ref": "SuggestedTableRowStyle"
+          },
+          "description": "The suggested style changes to this row, keyed by suggestion ID.",
+          "type": "object"
+        },
+        "tableCells": {
+          "description": "The contents and style of each cell in this row.\n\nIt is possible for a table to be non-rectangular, so some rows may have a\ndifferent number of cells than other rows in the same table.",
+          "items": {
+            "$ref": "TableCell"
+          },
+          "type": "array"
+        },
+        "tableRowStyle": {
+          "$ref": "TableRowStyle",
+          "description": "The style of the table row."
+        }
+      },
+      "type": "object"
+    },
+    "TableRowStyle": {
+      "description": "Styles that apply to a table row.",
+      "id": "TableRowStyle",
+      "properties": {
+        "minRowHeight": {
+          "$ref": "Dimension",
+          "description": "The minimum height of the row. The row will be rendered in the Docs editor\nat a height equal to or greater than this value in order to show all the\ncontent in the row's cells."
+        }
+      },
+      "type": "object"
+    },
+    "TableRowStyleSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base TableRowStyle have been changed in this suggestion.\nFor any field set to true, there is a new suggested value.",
+      "id": "TableRowStyleSuggestionState",
+      "properties": {
+        "minRowHeightSuggested": {
+          "description": "Indicates if there was a suggested change to min_row_height.",
+          "type": "boolean"
+        }
+      },
+      "type": "object"
+    },
+    "TableStyle": {
+      "description": "Styles that apply to a table.",
+      "id": "TableStyle",
+      "properties": {
+        "tableColumnProperties": {
+          "description": "The properties of each column.\n\nNote that in Docs, tables contain rows and rows contain cells, similar to\nHTML. So the properties for a row can be found on the row's\ntable_row_style.",
+          "items": {
+            "$ref": "TableColumnProperties"
+          },
+          "type": "array"
+        }
+      },
+      "type": "object"
+    },
+    "TextRun": {
+      "description": "A ParagraphElement that represents a\nrun of text that all has the same styling.",
+      "id": "TextRun",
+      "properties": {
+        "content": {
+          "description": "The text of this run.\n\nAny non-text elements in the run are replaced with the Unicode character\nU+E907.",
+          "type": "string"
+        },
+        "suggestedDeletionIds": {
+          "description": "The suggested deletion IDs. If empty, then there are no suggested deletions\nof this content.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedInsertionIds": {
+          "description": "The suggested insertion IDs. A TextRun may\nhave multiple insertion IDs if it is a nested suggested change. If empty,\nthen this is not a suggested insertion.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "suggestedTextStyleChanges": {
+          "additionalProperties": {
+            "$ref": "SuggestedTextStyle"
+          },
+          "description": "The suggested text style changes to this run, keyed by suggestion ID.",
+          "type": "object"
+        },
+        "textStyle": {
+          "$ref": "TextStyle",
+          "description": "The text style of this run."
+        }
+      },
+      "type": "object"
+    },
+    "TextStyle": {
+      "description": "Represents the styling that can be applied to text.\n\nInherited text styles are represented as unset fields in this message. A\ntext style's parent depends on where the text style is defined:\n\n  * The TextStyle of text in a Paragraph\n    inherits from the paragraph's corresponding named style type.\n  * The TextStyle on a named style\n    inherits from the normal text named style.\n  * The TextStyle of the normal text named style inherits\n    from the default text style in the Docs editor.\n  * The TextStyle on a Paragraph element\n    that is contained in a table may inherit its text style from the table\n    style.\n\nIf the text style does not inherit from a parent, unsetting fields will\nrevert the style to a value matching the defaults in the Docs editor.",
+      "id": "TextStyle",
+      "properties": {
+        "backgroundColor": {
+          "$ref": "OptionalColor",
+          "description": "The background color of the text. If set, the color is either an RGB color\nor transparent, depending on the `color` field."
+        },
+        "baselineOffset": {
+          "description": "The text's vertical offset from its normal position.\n\nText with `SUPERSCRIPT` or `SUBSCRIPT` baseline offsets is automatically\nrendered in a smaller font size, computed based on the `font_size` field.\nThe `font_size` itself is not affected by changes in this field.",
+          "enum": [
+            "BASELINE_OFFSET_UNSPECIFIED",
+            "NONE",
+            "SUPERSCRIPT",
+            "SUBSCRIPT"
+          ],
+          "enumDescriptions": [
+            "The text's baseline offset is inherited from the parent.",
+            "The text is not vertically offset.",
+            "The text is vertically offset upwards (superscript).",
+            "The text is vertically offset downwards (subscript)."
+          ],
+          "type": "string"
+        },
+        "bold": {
+          "description": "Whether or not the text is rendered as bold.",
+          "type": "boolean"
+        },
+        "fontSize": {
+          "$ref": "Dimension",
+          "description": "The size of the text's font."
+        },
+        "foregroundColor": {
+          "$ref": "OptionalColor",
+          "description": "The foreground color of the text. If set, the color is either an RGB color\nor transparent, depending on the `color` field."
+        },
+        "italic": {
+          "description": "Whether or not the text is italicized.",
+          "type": "boolean"
+        },
+        "link": {
+          "$ref": "Link",
+          "description": "The hyperlink destination of the text. If unset, there is no link. Links\nare not inherited from parent text.\n\nChanging the link in an update request causes some other changes to the\ntext style of the range:\n\n* When setting a link, the text foreground color will be updated to the\n  default link color and the text will be underlined. If these fields are\n  modified in the same request, those values will be used instead of the\n  link defaults.\n* Setting a link on a text range that overlaps with an existing link will\n  also update the existing link to point to the new URL.\n* Links are not settable on newline characters. As a result, setting a link\n  on a text range that crosses a paragraph boundary, such as `\"ABC\\n123\"`,\n  will separate the newline character(s) into their own text runs. The\n  link will be applied separately to the runs before and after the newline.\n* Removing a link will update the text style of the range to match the\n  style of the preceding text (or the default text styles if the preceding\n  text is another link) unless different styles are being set in the same\n  request."
+        },
+        "smallCaps": {
+          "description": "Whether or not the text is in small capital letters.",
+          "type": "boolean"
+        },
+        "strikethrough": {
+          "description": "Whether or not the text is struck through.",
+          "type": "boolean"
+        },
+        "underline": {
+          "description": "Whether or not the text is underlined.",
+          "type": "boolean"
+        },
+        "weightedFontFamily": {
+          "$ref": "WeightedFontFamily",
+          "description": "The font family and rendered weight of the text.\n\nIf an update request specifies values for both `weighted_font_family` and\n`bold`, the `weighted_font_family` is applied first, then `bold`.\n\nIf `weighted_font_family#weight` is not set, it defaults to `400`.\n\nIf `weighted_font_family` is set, then `weighted_font_family#font_family`\nmust also be set with a non-empty value. Otherwise, a 400 bad request error\nis returned."
+        }
+      },
+      "type": "object"
+    },
+    "TextStyleSuggestionState": {
+      "description": "A mask that indicates which of the fields on the base TextStyle have been changed in this suggestion.\nFor any field set to true, there is a new suggested value.",
+      "id": "TextStyleSuggestionState",
+      "properties": {
+        "backgroundColorSuggested": {
+          "description": "Indicates if there was a suggested change to background_color.",
+          "type": "boolean"
+        },
+        "baselineOffsetSuggested": {
+          "description": "Indicates if there was a suggested change to baseline_offset.",
+          "type": "boolean"
+        },
+        "boldSuggested": {
+          "description": "Indicates if there was a suggested change to bold.",
+          "type": "boolean"
+        },
+        "fontSizeSuggested": {
+          "description": "Indicates if there was a suggested change to font_size.",
+          "type": "boolean"
+        },
+        "foregroundColorSuggested": {
+          "description": "Indicates if there was a suggested change to foreground_color.",
+          "type": "boolean"
+        },
+        "italicSuggested": {
+          "description": "Indicates if there was a suggested change to italic.",
+          "type": "boolean"
+        },
+        "linkSuggested": {
+          "description": "Indicates if there was a suggested change to link.",
+          "type": "boolean"
+        },
+        "smallCapsSuggested": {
+          "description": "Indicates if there was a suggested change to small_caps.",
+          "type": "boolean"
+        },
+        "strikethroughSuggested": {
+          "description": "Indicates if there was a suggested change to strikethrough.",
+          "type": "boolean"
+        },
+        "underlineSuggested": {
+          "description": "Indicates if there was a suggested change to underline.",
+          "type": "boolean"
+        },
+        "weightedFontFamilySuggested": {
+          "description": "Indicates if there was a suggested change to weighted_font_family.",
+          "type": "boolean"
+        }
+      },
+      "type": "object"
+    },
+    "UpdateParagraphStyleRequest": {
+      "description": "Update the styling of all paragraphs that overlap with the given range.",
+      "id": "UpdateParagraphStyleRequest",
+      "properties": {
+        "fields": {
+          "description": "The fields that should be updated.\n\nAt least one field must be specified. The root `paragraph_style` is implied\nand should not be specified.\n\nFor example, to update the paragraph style's alignment property, set\n`fields` to `\"alignment\"`.\n\nTo reset a property to its default value, include its field name in the\nfield mask but leave the field itself unset.",
+          "format": "google-fieldmask",
+          "type": "string"
+        },
+        "paragraphStyle": {
+          "$ref": "ParagraphStyle",
+          "description": "The styles to set on the paragraphs.\n\nCertain paragraph style changes may cause other changes in order to mirror\nthe behavior of the Docs editor. See the documentation of ParagraphStyle for more information."
+        },
+        "range": {
+          "$ref": "Range",
+          "description": "The range overlapping the paragraphs to style."
+        }
+      },
+      "type": "object"
+    },
+    "UpdateTextStyleRequest": {
+      "description": "Update the styling of text.",
+      "id": "UpdateTextStyleRequest",
+      "properties": {
+        "fields": {
+          "description": "The fields that should be updated.\n\nAt least one field must be specified. The root `text_style` is implied and\nshould not be specified. A single `\"*\"` can be used as short-hand for\nlisting every field.\n\nFor example, to update the text style to bold, set `fields` to `\"bold\"`.\n\nTo reset a property to its default value, include its field name in the\nfield mask but leave the field itself unset.",
+          "format": "google-fieldmask",
+          "type": "string"
+        },
+        "range": {
+          "$ref": "Range",
+          "description": "The range of text to style.\n\nThe range may be extended to include adjacent newlines.\n\nIf the range fully contains a paragraph belonging to a list, the\nparagraph's bullet is also updated with the matching text style."
+        },
+        "textStyle": {
+          "$ref": "TextStyle",
+          "description": "The styles to set on the text.\n\nIf the value for a particular style matches that of the parent, that style\nwill be set to inherit.\n\nCertain text style changes may cause other changes in order to to mirror\nthe behavior of the Docs editor. See the documentation of\nTextStyle for more information."
+        }
+      },
+      "type": "object"
+    },
+    "WeightedFontFamily": {
+      "description": "Represents a font family and weight of text.",
+      "id": "WeightedFontFamily",
+      "properties": {
+        "fontFamily": {
+          "description": "The font family of the text.\n\nThe font family can be any font from the Font menu in Docs or from\n[Google Fonts] (https://fonts.google.com/). If the font name is\nunrecognized, the text is rendered in `Arial`.",
+          "type": "string"
+        },
+        "weight": {
+          "description": "The weight of the font. This field can have any value that is a multiple of\n`100` between `100` and `900`, inclusive. This range corresponds to the\nnumerical values described in the CSS 2.1 Specification,\n[section 15.6](https://www.w3.org/TR/CSS21/fonts.html#font-boldness), with\nnon-numerical values disallowed.\n\nThe default value is `400` (\"normal\").\n\nThe font weight makes up just one component of the rendered font weight.\nThe rendered weight is determined by a combination of the `weight` and the\ntext style's resolved `bold` value, after accounting for inheritance:\n\n* If the text is bold and the weight is less than `400`, the rendered\n  weight is 400.\n* If the text is bold and the weight is greater than or equal to `400` but\n  is less than `700`, the rendered weight is `700`.\n* If the weight is greater than or equal to `700`, the rendered weight is\n  equal to the weight.\n* If the text is not bold, the rendered weight is equal to the weight.",
+          "format": "int32",
+          "type": "integer"
+        }
+      },
+      "type": "object"
+    },
+    "WriteControl": {
+      "description": "Provides control over how write requests are executed.",
+      "id": "WriteControl",
+      "properties": {
+        "requiredRevisionId": {
+          "description": "The ID of the revision of the document that the write request will be\napplied to. If this is not the latest revision of the document, the\nrequest will not be processed and will return a 400 bad request error.\n\nWhen a required revision ID is returned in a response, it indicates the\nrevision ID of the document after the request was applied.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    }
+  },
+  "servicePath": "",
+  "title": "Google Docs API",
+  "version": "v1",
+  "version_module": true
+}
\ No newline at end of file
diff --git a/docs/v1/docs-gen.go b/docs/v1/docs-gen.go
new file mode 100644
index 0000000..7a13d9f
--- /dev/null
+++ b/docs/v1/docs-gen.go
@@ -0,0 +1,6840 @@
+// Copyright 2019 Google Inc. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+// Code generated file. DO NOT EDIT.
+
+// Package docs provides access to the Google Docs API.
+//
+// See https://developers.google.com/docs/
+//
+// Usage example:
+//
+//   import "google.golang.org/api/docs/v1"
+//   ...
+//   docsService, err := docs.New(oauthHttpClient)
+package docs // import "google.golang.org/api/docs/v1"
+
+import (
+	"bytes"
+	"context"
+	"encoding/json"
+	"errors"
+	"fmt"
+	"io"
+	"net/http"
+	"net/url"
+	"strconv"
+	"strings"
+
+	gensupport "google.golang.org/api/gensupport"
+	googleapi "google.golang.org/api/googleapi"
+)
+
+// Always reference these packages, just in case the auto-generated code
+// below doesn't.
+var _ = bytes.NewBuffer
+var _ = strconv.Itoa
+var _ = fmt.Sprintf
+var _ = json.NewDecoder
+var _ = io.Copy
+var _ = url.Parse
+var _ = gensupport.MarshalJSON
+var _ = googleapi.Version
+var _ = errors.New
+var _ = strings.Replace
+var _ = context.Canceled
+
+const apiId = "docs:v1"
+const apiName = "docs"
+const apiVersion = "v1"
+const basePath = "https://docs.googleapis.com/"
+
+// OAuth2 scopes used by this API.
+const (
+	// View and manage your Google Docs documents
+	DocumentsScope = "https://www.googleapis.com/auth/documents"
+
+	// View your Google Docs documents
+	DocumentsReadonlyScope = "https://www.googleapis.com/auth/documents.readonly"
+
+	// See, edit, create, and delete all of your Google Drive files
+	DriveScope = "https://www.googleapis.com/auth/drive"
+
+	// View and manage Google Drive files and folders that you have opened
+	// or created with this app
+	DriveFileScope = "https://www.googleapis.com/auth/drive.file"
+
+	// See and download all your Google Drive files
+	DriveReadonlyScope = "https://www.googleapis.com/auth/drive.readonly"
+)
+
+func New(client *http.Client) (*Service, error) {
+	if client == nil {
+		return nil, errors.New("client is nil")
+	}
+	s := &Service{client: client, BasePath: basePath}
+	s.Documents = NewDocumentsService(s)
+	return s, nil
+}
+
+type Service struct {
+	client    *http.Client
+	BasePath  string // API endpoint base URL
+	UserAgent string // optional additional User-Agent fragment
+
+	Documents *DocumentsService
+}
+
+func (s *Service) userAgent() string {
+	if s.UserAgent == "" {
+		return googleapi.UserAgent
+	}
+	return googleapi.UserAgent + " " + s.UserAgent
+}
+
+func NewDocumentsService(s *Service) *DocumentsService {
+	rs := &DocumentsService{s: s}
+	return rs
+}
+
+type DocumentsService struct {
+	s *Service
+}
+
+// AutoText: A ParagraphElement representing a
+// spot in the text that is dynamically replaced with content that can
+// change
+// over time, like a page number.
+type AutoText struct {
+	// SuggestedDeletionIds: The suggested deletion IDs. If empty, then
+	// there are no suggested deletions
+	// of this content.
+	SuggestedDeletionIds []string `json:"suggestedDeletionIds,omitempty"`
+
+	// SuggestedInsertionIds: The suggested insertion IDs. An AutoText
+	// may have multiple insertion IDs if it is a nested suggested change.
+	// If
+	// empty, then this is not a suggested insertion.
+	SuggestedInsertionIds []string `json:"suggestedInsertionIds,omitempty"`
+
+	// SuggestedTextStyleChanges: The suggested text style changes to this
+	// AutoText, keyed by suggestion ID.
+	SuggestedTextStyleChanges map[string]SuggestedTextStyle `json:"suggestedTextStyleChanges,omitempty"`
+
+	// TextStyle: The text style of this AutoText.
+	TextStyle *TextStyle `json:"textStyle,omitempty"`
+
+	// Type: The type of this auto text.
+	//
+	// Possible values:
+	//   "TYPE_UNSPECIFIED" - An unspecified auto text type.
+	//   "PAGE_NUMBER" - Type for auto text that represents the current page
+	// number.
+	//   "PAGE_COUNT" - Type for auto text that represents the total number
+	// of pages in the
+	// document.
+	Type string `json:"type,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "SuggestedDeletionIds") to unconditionally include in API requests.
+	// By default, fields with empty values are omitted from API requests.
+	// However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "SuggestedDeletionIds") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *AutoText) MarshalJSON() ([]byte, error) {
+	type NoMethod AutoText
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Background: Represents the background of a document.
+type Background struct {
+	// Color: The background color.
+	Color *OptionalColor `json:"color,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Color") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Color") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Background) MarshalJSON() ([]byte, error) {
+	type NoMethod Background
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// BackgroundSuggestionState: A mask that indicates which of the fields
+// on the base Background have been changed in this suggestion.
+// For any field set to true, the Backgound has a new suggested value.
+type BackgroundSuggestionState struct {
+	// BackgroundColorSuggested: Indicates whether the current background
+	// color has been modified in this
+	// suggestion.
+	BackgroundColorSuggested bool `json:"backgroundColorSuggested,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "BackgroundColorSuggested") to unconditionally include in API
+	// requests. By default, fields with empty values are omitted from API
+	// requests. However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "BackgroundColorSuggested")
+	// to include in API requests with the JSON null value. By default,
+	// fields with empty values are omitted from API requests. However, any
+	// field with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *BackgroundSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod BackgroundSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// BatchUpdateDocumentRequest: Request message for BatchUpdateDocument.
+type BatchUpdateDocumentRequest struct {
+	// Requests: A list of updates to apply to the document.
+	Requests []*Request `json:"requests,omitempty"`
+
+	// WriteControl: Provides control over how write requests are executed.
+	WriteControl *WriteControl `json:"writeControl,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Requests") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Requests") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *BatchUpdateDocumentRequest) MarshalJSON() ([]byte, error) {
+	type NoMethod BatchUpdateDocumentRequest
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// BatchUpdateDocumentResponse: Response message from a
+// BatchUpdateDocument request.
+type BatchUpdateDocumentResponse struct {
+	// DocumentId: The ID of the document to which the updates were applied
+	// to.
+	DocumentId string `json:"documentId,omitempty"`
+
+	// Replies: The reply of the updates. This maps 1:1 with the updates,
+	// although replies
+	// to some requests may be empty.
+	Replies []*Response `json:"replies,omitempty"`
+
+	// WriteControl: The updated write control after applying the request.
+	WriteControl *WriteControl `json:"writeControl,omitempty"`
+
+	// ServerResponse contains the HTTP response code and headers from the
+	// server.
+	googleapi.ServerResponse `json:"-"`
+
+	// ForceSendFields is a list of field names (e.g. "DocumentId") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "DocumentId") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *BatchUpdateDocumentResponse) MarshalJSON() ([]byte, error) {
+	type NoMethod BatchUpdateDocumentResponse
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Body: The document body.
+//
+// The body typically contains the full document contents except
+// for
+// headers, footers
+// and footnotes.
+type Body struct {
+	// Content: The contents of the body.
+	//
+	// The indices for the body's content begin at zero.
+	Content []*StructuralElement `json:"content,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Content") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Content") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Body) MarshalJSON() ([]byte, error) {
+	type NoMethod Body
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Bullet: Describes the bullet of a paragraph.
+type Bullet struct {
+	// ListId: The ID of the list this paragraph belongs to.
+	ListId string `json:"listId,omitempty"`
+
+	// NestingLevel: The nesting level of this paragraph in the list.
+	NestingLevel int64 `json:"nestingLevel,omitempty"`
+
+	// TextStyle: The paragraph specific text style applied to this bullet.
+	TextStyle *TextStyle `json:"textStyle,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ListId") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ListId") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Bullet) MarshalJSON() ([]byte, error) {
+	type NoMethod Bullet
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// BulletSuggestionState: A mask that indicates which of the fields on
+// the base
+// Bullet have been changed in this suggestion.
+// For any field set to true, there is a new suggested value.
+type BulletSuggestionState struct {
+	// ListIdSuggested: Indicates if there was a suggested change to
+	// the
+	// list_id.
+	ListIdSuggested bool `json:"listIdSuggested,omitempty"`
+
+	// NestingLevelSuggested: Indicates if there was a suggested change to
+	// the
+	// nesting_level.
+	NestingLevelSuggested bool `json:"nestingLevelSuggested,omitempty"`
+
+	// TextStyleSuggestionState: A mask that indicates which of the fields
+	// in text style have been changed in this
+	// suggestion.
+	TextStyleSuggestionState *TextStyleSuggestionState `json:"textStyleSuggestionState,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ListIdSuggested") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ListIdSuggested") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *BulletSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod BulletSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Color: A solid color.
+type Color struct {
+	// RgbColor: The RGB color value.
+	RgbColor *RgbColor `json:"rgbColor,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "RgbColor") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "RgbColor") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Color) MarshalJSON() ([]byte, error) {
+	type NoMethod Color
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// ColumnBreak: A ParagraphElement representing a
+// column break. A column break makes the subsequent text start at the
+// top of
+// the next column.
+type ColumnBreak struct {
+	// SuggestedDeletionIds: The suggested deletion IDs. If empty, then
+	// there are no suggested deletions
+	// of this content.
+	SuggestedDeletionIds []string `json:"suggestedDeletionIds,omitempty"`
+
+	// SuggestedInsertionIds: The suggested insertion IDs. A ColumnBreak may
+	// have multiple insertion IDs if it is
+	// a nested suggested change. If empty, then this is not a
+	// suggested
+	// insertion.
+	SuggestedInsertionIds []string `json:"suggestedInsertionIds,omitempty"`
+
+	// SuggestedTextStyleChanges: The suggested text style changes to this
+	// ColumnBreak, keyed by suggestion
+	// ID.
+	SuggestedTextStyleChanges map[string]SuggestedTextStyle `json:"suggestedTextStyleChanges,omitempty"`
+
+	// TextStyle: The text style of this ColumnBreak.
+	//
+	// Similar to text content, like text runs and footnote references, the
+	// text
+	// style of a column break can affect content layout as well as the
+	// styling of
+	// text inserted adjacent to it.
+	TextStyle *TextStyle `json:"textStyle,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "SuggestedDeletionIds") to unconditionally include in API requests.
+	// By default, fields with empty values are omitted from API requests.
+	// However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "SuggestedDeletionIds") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *ColumnBreak) MarshalJSON() ([]byte, error) {
+	type NoMethod ColumnBreak
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// CreateNamedRangeRequest: Creates a NamedRange referencing the
+// given
+// range.
+type CreateNamedRangeRequest struct {
+	// Name: The name of the NamedRange. Names do not need to be
+	// unique.
+	//
+	// Names must be at least 1 character and no more than 256
+	// characters,
+	// measured in UTF-16 code units.
+	Name string `json:"name,omitempty"`
+
+	// Range: The range to apply the name to.
+	Range *Range `json:"range,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Name") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Name") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *CreateNamedRangeRequest) MarshalJSON() ([]byte, error) {
+	type NoMethod CreateNamedRangeRequest
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// CreateNamedRangeResponse: The result of creating a named range.
+type CreateNamedRangeResponse struct {
+	// NamedRangeId: The ID of the created named range.
+	NamedRangeId string `json:"namedRangeId,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "NamedRangeId") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "NamedRangeId") to include
+	// in API requests with the JSON null value. By default, fields with
+	// empty values are omitted from API requests. However, any field with
+	// an empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *CreateNamedRangeResponse) MarshalJSON() ([]byte, error) {
+	type NoMethod CreateNamedRangeResponse
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// CreateParagraphBulletsRequest: Creates bullets for all of the
+// paragraphs that overlap with the given range.
+//
+// The nesting level of each paragraph will be determined by counting
+// leading
+// tabs in front of each paragraph. To avoid excess space between the
+// bullet and
+// the corresponding paragraph, these leading tabs are removed by this
+// request.
+// This may change the indices of parts of the text.
+//
+// If the paragraph immediately before paragraphs being updated is in a
+// list
+// with a matching preset, the paragraphs being updated are added to
+// that
+// preceding list.
+type CreateParagraphBulletsRequest struct {
+	// BulletPreset: The kinds of bullet glyphs to be used.
+	//
+	// Possible values:
+	//   "BULLET_GLYPH_PRESET_UNSPECIFIED" - The bullet glyph preset is
+	// unspecified.
+	//   "BULLET_DISC_CIRCLE_SQUARE" - A bulleted list with a `DISC`,
+	// `CIRCLE` and `SQUARE` bullet glyph for the
+	// first 3 list nesting levels.
+	//   "BULLET_DIAMONDX_ARROW3D_SQUARE" - A bulleted list with a
+	// `DIAMONDX`, `ARROW3D` and `SQUARE` bullet glyph for
+	// the first 3 list nesting levels.
+	//   "BULLET_CHECKBOX" - A bulleted list with `CHECKBOX` bullet glyphs
+	// for all list nesting levels.
+	//   "BULLET_ARROW_DIAMOND_DISC" - A bulleted list with a `ARROW`,
+	// `DIAMOND` and `DISC` bullet glyph for
+	// the first 3 list nesting levels.
+	//   "BULLET_STAR_CIRCLE_SQUARE" - A bulleted list with a `STAR`,
+	// `CIRCLE` and `SQUARE` bullet glyph for
+	// the first 3 list nesting levels.
+	//   "BULLET_ARROW3D_CIRCLE_SQUARE" - A bulleted list with a `ARROW3D`,
+	// `CIRCLE` and `SQUARE` bullet glyph for
+	// the first 3 list nesting levels.
+	//   "BULLET_LEFTTRIANGLE_DIAMOND_DISC" - A bulleted list with a
+	// `LEFTTRIANGLE`, `DIAMOND` and `DISC` bullet glyph
+	// for the first 3 list nesting levels.
+	//   "BULLET_DIAMONDX_HOLLOWDIAMOND_SQUARE" - A bulleted list with a
+	// `DIAMONDX`, `HOLLOWDIAMOND` and `SQUARE` bullet
+	// glyph for the first 3 list nesting levels.
+	//   "BULLET_DIAMOND_CIRCLE_SQUARE" - A bulleted list with a `DIAMOND`,
+	// `CIRCLE` and `SQUARE` bullet glyph
+	// for the first 3 list nesting levels.
+	//   "NUMBERED_DECIMAL_ALPHA_ROMAN" - A numbered list with `DECIMAL`,
+	// `ALPHA` and `ROMAN` numeric glyphs for
+	// the first 3 list nesting levels, followed by periods.
+	//   "NUMBERED_DECIMAL_ALPHA_ROMAN_PARENS" - A numbered list with
+	// `DECIMAL`, `ALPHA` and `ROMAN` numeric glyphs for
+	// the first 3 list nesting levels, followed by parenthesis.
+	//   "NUMBERED_DECIMAL_NESTED" - A numbered list with `DECIMAL` numeric
+	// glyphs separated by periods, where
+	// each nesting level uses the previous nesting level's glyph as a
+	// prefix.
+	// For example: '1.', '1.1.', '2.', '2.2.'.
+	//   "NUMBERED_UPPERALPHA_ALPHA_ROMAN" - A numbered list with
+	// `UPPERALPHA`, `ALPHA` and `ROMAN` numeric glyphs for
+	// the first 3 list nesting levels, followed by periods.
+	//   "NUMBERED_UPPERROMAN_UPPERALPHA_DECIMAL" - A numbered list with
+	// `UPPERROMAN`, `UPPERALPHA` and `DECIMAL` numeric
+	// glyphs for the first 3 list nesting levels, followed by periods.
+	//   "NUMBERED_ZERODECIMAL_ALPHA_ROMAN" - A numbered list with
+	// `ZERODECIMAL`, `ALPHA` and `ROMAN` numeric glyphs for
+	// the first 3 list nesting levels, followed by periods.
+	BulletPreset string `json:"bulletPreset,omitempty"`
+
+	// Range: The range to apply the bullet preset to.
+	Range *Range `json:"range,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "BulletPreset") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "BulletPreset") to include
+	// in API requests with the JSON null value. By default, fields with
+	// empty values are omitted from API requests. However, any field with
+	// an empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *CreateParagraphBulletsRequest) MarshalJSON() ([]byte, error) {
+	type NoMethod CreateParagraphBulletsRequest
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// CropProperties: The crop properties of an image.
+//
+// The crop rectangle is represented using fractional offsets from the
+// original
+// content's four edges.
+//
+// - If the offset is in the interval (0, 1), the corresponding edge of
+// crop
+// rectangle is positioned inside of the image's original bounding
+// rectangle.
+// - If the offset is negative or greater than 1, the corresponding edge
+// of crop
+// rectangle is positioned outside of the image's original bounding
+// rectangle.
+// - If all offsets and rotation angle are 0, the image is not cropped.
+type CropProperties struct {
+	// Angle: The clockwise rotation angle of the crop rectangle around its
+	// center, in
+	// radians. Rotation is applied after the offsets.
+	Angle float64 `json:"angle,omitempty"`
+
+	// OffsetBottom: The offset specifies how far inwards the bottom edge of
+	// the crop rectangle
+	// is from the bottom edge of the original content as a fraction of
+	// the
+	// original content's height.
+	OffsetBottom float64 `json:"offsetBottom,omitempty"`
+
+	// OffsetLeft: The offset specifies how far inwards the left edge of the
+	// crop rectangle is
+	// from the left edge of the original content as a fraction of the
+	// original
+	// content's width.
+	OffsetLeft float64 `json:"offsetLeft,omitempty"`
+
+	// OffsetRight: The offset specifies how far inwards the right edge of
+	// the crop rectangle
+	// is from the right edge of the original content as a fraction of
+	// the
+	// original content's width.
+	OffsetRight float64 `json:"offsetRight,omitempty"`
+
+	// OffsetTop: The offset specifies how far inwards the top edge of the
+	// crop rectangle is
+	// from the top edge of the original content as a fraction of the
+	// original
+	// content's height.
+	OffsetTop float64 `json:"offsetTop,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Angle") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Angle") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *CropProperties) MarshalJSON() ([]byte, error) {
+	type NoMethod CropProperties
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+func (s *CropProperties) UnmarshalJSON(data []byte) error {
+	type NoMethod CropProperties
+	var s1 struct {
+		Angle        gensupport.JSONFloat64 `json:"angle"`
+		OffsetBottom gensupport.JSONFloat64 `json:"offsetBottom"`
+		OffsetLeft   gensupport.JSONFloat64 `json:"offsetLeft"`
+		OffsetRight  gensupport.JSONFloat64 `json:"offsetRight"`
+		OffsetTop    gensupport.JSONFloat64 `json:"offsetTop"`
+		*NoMethod
+	}
+	s1.NoMethod = (*NoMethod)(s)
+	if err := json.Unmarshal(data, &s1); err != nil {
+		return err
+	}
+	s.Angle = float64(s1.Angle)
+	s.OffsetBottom = float64(s1.OffsetBottom)
+	s.OffsetLeft = float64(s1.OffsetLeft)
+	s.OffsetRight = float64(s1.OffsetRight)
+	s.OffsetTop = float64(s1.OffsetTop)
+	return nil
+}
+
+// CropPropertiesSuggestionState: A mask that indicates which of the
+// fields on the base CropProperties have been changed in this
+// suggestion.
+// For any field set to true, there is a new suggested value.
+type CropPropertiesSuggestionState struct {
+	// AngleSuggested: Indicates if there was a suggested change to angle.
+	AngleSuggested bool `json:"angleSuggested,omitempty"`
+
+	// OffsetBottomSuggested: Indicates if there was a suggested change to
+	// offset_bottom.
+	OffsetBottomSuggested bool `json:"offsetBottomSuggested,omitempty"`
+
+	// OffsetLeftSuggested: Indicates if there was a suggested change to
+	// offset_left.
+	OffsetLeftSuggested bool `json:"offsetLeftSuggested,omitempty"`
+
+	// OffsetRightSuggested: Indicates if there was a suggested change to
+	// offset_right.
+	OffsetRightSuggested bool `json:"offsetRightSuggested,omitempty"`
+
+	// OffsetTopSuggested: Indicates if there was a suggested change to
+	// offset_top.
+	OffsetTopSuggested bool `json:"offsetTopSuggested,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "AngleSuggested") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "AngleSuggested") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *CropPropertiesSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod CropPropertiesSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// DeleteContentRangeRequest: Deletes content from the document.
+type DeleteContentRangeRequest struct {
+	// Range: The range of content to delete.
+	//
+	// Deleting text that crosses a paragraph boundary may result in
+	// changes
+	// to paragraph styles, lists, positioned objects and bookmarks as the
+	// two
+	// paragraphs are merged.
+	//
+	// Attempting to delete certain ranges can result in an invalid
+	// document
+	// structure in which case a 400 bad request error is returned.
+	//
+	// Some examples of invalid delete requests include:
+	//
+	// * Deleting one code unit of a surrogate pair.
+	// * Deleting the last newline character of a Body, Header,
+	//   Footer, Footnote, TableCell or TableOfContents.
+	// * Deleting the start or end of a Table,
+	//   TableOfContents or Equation without deleting the entire element.
+	// * Deleting the newline character before a
+	//   Table,
+	//   TableOfContents or
+	//   SectionBreak without deleting the
+	//   the element.
+	// * Deleting individual rows or cells of a table. Deleting the content
+	// within
+	//   a table cell is allowed.
+	Range *Range `json:"range,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Range") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Range") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *DeleteContentRangeRequest) MarshalJSON() ([]byte, error) {
+	type NoMethod DeleteContentRangeRequest
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// DeleteNamedRangeRequest: Deletes a NamedRange.
+type DeleteNamedRangeRequest struct {
+	// Name: The name of the range(s) to delete. All named ranges with the
+	// given
+	// name will be deleted.
+	Name string `json:"name,omitempty"`
+
+	// NamedRangeId: The ID of the named range to delete.
+	NamedRangeId string `json:"namedRangeId,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Name") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Name") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *DeleteNamedRangeRequest) MarshalJSON() ([]byte, error) {
+	type NoMethod DeleteNamedRangeRequest
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// DeleteParagraphBulletsRequest: Deletes bullets from all of the
+// paragraphs that overlap with the given range.
+//
+// The nesting level of each paragraph will be visually preserved by
+// adding
+// indent to the start of the corresponding paragraph.
+type DeleteParagraphBulletsRequest struct {
+	// Range: The range to delete bullets from.
+	Range *Range `json:"range,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Range") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Range") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *DeleteParagraphBulletsRequest) MarshalJSON() ([]byte, error) {
+	type NoMethod DeleteParagraphBulletsRequest
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// DeletePositionedObjectRequest: Deletes a PositionedObject from
+// the
+// document.
+type DeletePositionedObjectRequest struct {
+	// ObjectId: The ID of the positioned object to delete.
+	ObjectId string `json:"objectId,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ObjectId") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ObjectId") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *DeletePositionedObjectRequest) MarshalJSON() ([]byte, error) {
+	type NoMethod DeletePositionedObjectRequest
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// DeleteTableColumnRequest: Deletes a column from a table.
+type DeleteTableColumnRequest struct {
+	// TableCellLocation: The reference table cell location from which the
+	// column will be deleted.
+	//
+	// The column this cell spans will be deleted. If this is a merged cell
+	// that
+	// spans multiple columns, all columns that the cell spans will be
+	// deleted. If
+	// no columns remain in the table after this deletion, the whole table
+	// is
+	// deleted.
+	TableCellLocation *TableCellLocation `json:"tableCellLocation,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "TableCellLocation")
+	// to unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "TableCellLocation") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *DeleteTableColumnRequest) MarshalJSON() ([]byte, error) {
+	type NoMethod DeleteTableColumnRequest
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// DeleteTableRowRequest: Deletes a row from a table.
+type DeleteTableRowRequest struct {
+	// TableCellLocation: The reference table cell location from which the
+	// row will be deleted.
+	//
+	// The row this cell spans will be deleted. If this is a merged cell
+	// that
+	// spans multiple rows, all rows that the cell spans will be deleted. If
+	// no
+	// rows remain in the table after this deletion, the whole table is
+	// deleted.
+	TableCellLocation *TableCellLocation `json:"tableCellLocation,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "TableCellLocation")
+	// to unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "TableCellLocation") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *DeleteTableRowRequest) MarshalJSON() ([]byte, error) {
+	type NoMethod DeleteTableRowRequest
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Dimension: A magnitude in a single direction in the specified units.
+type Dimension struct {
+	// Magnitude: The magnitude.
+	Magnitude float64 `json:"magnitude,omitempty"`
+
+	// Unit: The units for magnitude.
+	//
+	// Possible values:
+	//   "UNIT_UNSPECIFIED" - The units are unknown.
+	//   "PT" - A point, 1/72 of an inch.
+	Unit string `json:"unit,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Magnitude") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Magnitude") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Dimension) MarshalJSON() ([]byte, error) {
+	type NoMethod Dimension
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+func (s *Dimension) UnmarshalJSON(data []byte) error {
+	type NoMethod Dimension
+	var s1 struct {
+		Magnitude gensupport.JSONFloat64 `json:"magnitude"`
+		*NoMethod
+	}
+	s1.NoMethod = (*NoMethod)(s)
+	if err := json.Unmarshal(data, &s1); err != nil {
+		return err
+	}
+	s.Magnitude = float64(s1.Magnitude)
+	return nil
+}
+
+// Document: A Google Docs document.
+type Document struct {
+	// Body: The main body of the document.
+	Body *Body `json:"body,omitempty"`
+
+	// DocumentId: The ID of the document.
+	DocumentId string `json:"documentId,omitempty"`
+
+	// DocumentStyle: The style of the document.
+	DocumentStyle *DocumentStyle `json:"documentStyle,omitempty"`
+
+	// Footers: The footers in the document, keyed by footer ID.
+	Footers map[string]Footer `json:"footers,omitempty"`
+
+	// Footnotes: The footnotes in the document, keyed by footnote ID.
+	Footnotes map[string]Footnote `json:"footnotes,omitempty"`
+
+	// Headers: The headers in the document, keyed by header ID.
+	Headers map[string]Header `json:"headers,omitempty"`
+
+	// InlineObjects: The inline objects in the document, keyed by object
+	// ID.
+	InlineObjects map[string]InlineObject `json:"inlineObjects,omitempty"`
+
+	// Lists: The lists in the document, keyed by list ID.
+	Lists map[string]List `json:"lists,omitempty"`
+
+	// NamedRanges: The named ranges in the document, keyed by name.
+	NamedRanges map[string]NamedRanges `json:"namedRanges,omitempty"`
+
+	// NamedStyles: The named styles of the document.
+	NamedStyles *NamedStyles `json:"namedStyles,omitempty"`
+
+	// PositionedObjects: The positioned objects in the document, keyed by
+	// object ID.
+	PositionedObjects map[string]PositionedObject `json:"positionedObjects,omitempty"`
+
+	// RevisionId: The revision ID of the document. Can be used in update
+	// requests to specify
+	// which revision of a document to apply updates to and how the request
+	// should
+	// behave if the document has been edited since that revision. Only
+	// populated
+	// if the user has edit access to the document.
+	//
+	// The format of the revision ID may change over time, so it should be
+	// treated
+	// opaquely. A returned revision ID is only guaranteed to be valid for
+	// 24
+	// hours after it has been returned and cannot be shared across users.
+	// If the
+	// revision ID is unchanged between calls, then the document has not
+	// changed.
+	// Conversely, a changed ID (for the same document and user) usually
+	// means the
+	// document has been updated; however, a changed ID can also be due
+	// to
+	// internal factors such as ID format changes.
+	RevisionId string `json:"revisionId,omitempty"`
+
+	// SuggestedDocumentStyleChanges: The suggested changes to the style of
+	// the document, keyed by suggestion ID.
+	SuggestedDocumentStyleChanges map[string]SuggestedDocumentStyle `json:"suggestedDocumentStyleChanges,omitempty"`
+
+	// SuggestedNamedStylesChanges: The suggested changes to the named
+	// styles of the document, keyed by
+	// suggestion ID.
+	SuggestedNamedStylesChanges map[string]SuggestedNamedStyles `json:"suggestedNamedStylesChanges,omitempty"`
+
+	// SuggestionsViewMode: The suggestions view mode applied to the
+	// document.
+	//
+	// Note: When editing a document, changes must be based on a document
+	// with
+	// SUGGESTIONS_INLINE.
+	//
+	// Possible values:
+	//   "DEFAULT_FOR_CURRENT_ACCESS" - The SuggestionsViewMode applied to
+	// the returned document depends on the
+	// user's current access level. If the user only has view
+	// access,
+	// PREVIEW_WITHOUT_SUGGESTIONS is
+	// applied. Otherwise, SUGGESTIONS_INLINE is applied.
+	// This is the default suggestions view mode.
+	//   "SUGGESTIONS_INLINE" - The returned document has suggestions
+	// inline. Suggested changes will be
+	// differentiated from base content within the document.
+	//
+	// Requests to retrieve a document using this mode will return a 403
+	// error if
+	// the user does not have permission to view suggested changes.
+	//   "PREVIEW_SUGGESTIONS_ACCEPTED" - The returned document is a preview
+	// with all suggested changes accepted.
+	//
+	// Requests to retrieve a document using this mode will return a 403
+	// error if
+	// the user does not have permission to view suggested changes.
+	//   "PREVIEW_WITHOUT_SUGGESTIONS" - The returned document is a preview
+	// with all suggested changes rejected if
+	// there are any suggestions in the document.
+	SuggestionsViewMode string `json:"suggestionsViewMode,omitempty"`
+
+	// Title: The title of the document.
+	Title string `json:"title,omitempty"`
+
+	// ServerResponse contains the HTTP response code and headers from the
+	// server.
+	googleapi.ServerResponse `json:"-"`
+
+	// ForceSendFields is a list of field names (e.g. "Body") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Body") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Document) MarshalJSON() ([]byte, error) {
+	type NoMethod Document
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// DocumentStyle: The style of the document.
+type DocumentStyle struct {
+	// Background: The background of the document.
+	Background *Background `json:"background,omitempty"`
+
+	// DefaultFooterId: The ID of the default footer. If not set, there is
+	// no default footer.
+	DefaultFooterId string `json:"defaultFooterId,omitempty"`
+
+	// DefaultHeaderId: The ID of the default header. If not set, there is
+	// no default header.
+	DefaultHeaderId string `json:"defaultHeaderId,omitempty"`
+
+	// EvenPageFooterId: The ID of the footer used only for even pages. The
+	// value of
+	// use_even_page_header_footer determines
+	// whether to use the default_footer_id or this value for the
+	// footer on even pages. If not set, there is no even page footer.
+	EvenPageFooterId string `json:"evenPageFooterId,omitempty"`
+
+	// EvenPageHeaderId: The ID of the header used only for even pages. The
+	// value of
+	// use_even_page_header_footer determines
+	// whether to use the default_header_id or this value for the
+	// header on even pages. If not set, there is no even page header.
+	EvenPageHeaderId string `json:"evenPageHeaderId,omitempty"`
+
+	// FirstPageFooterId: The ID of the footer used only for the first page.
+	// If not set then
+	// a unique footer for the first page does not exist. The value
+	// of
+	// use_first_page_header_footer determines
+	// whether to use the default_footer_id or this value for the
+	// footer on the first page. If not set, there is no first page footer.
+	FirstPageFooterId string `json:"firstPageFooterId,omitempty"`
+
+	// FirstPageHeaderId: The ID of the header used only for the first page.
+	// If not set then
+	// a unique header for the first page does not exist.
+	// The value of use_first_page_header_footer determines
+	// whether to use the default_header_id or this value for the
+	// header on the first page. If not set, there is no first page header.
+	FirstPageHeaderId string `json:"firstPageHeaderId,omitempty"`
+
+	// MarginBottom: The bottom page margin.
+	MarginBottom *Dimension `json:"marginBottom,omitempty"`
+
+	// MarginLeft: The left page margin.
+	MarginLeft *Dimension `json:"marginLeft,omitempty"`
+
+	// MarginRight: The right page margin.
+	MarginRight *Dimension `json:"marginRight,omitempty"`
+
+	// MarginTop: The top page margin.
+	MarginTop *Dimension `json:"marginTop,omitempty"`
+
+	// PageNumberStart: The page number from which to start counting the
+	// number of pages.
+	PageNumberStart int64 `json:"pageNumberStart,omitempty"`
+
+	// PageSize: The size of a page in the document.
+	PageSize *Size `json:"pageSize,omitempty"`
+
+	// UseEvenPageHeaderFooter: Indicates whether to use the even page
+	// header / footer IDs for the even
+	// pages.
+	UseEvenPageHeaderFooter bool `json:"useEvenPageHeaderFooter,omitempty"`
+
+	// UseFirstPageHeaderFooter: Indicates whether to use the first page
+	// header / footer IDs for the first
+	// page.
+	UseFirstPageHeaderFooter bool `json:"useFirstPageHeaderFooter,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Background") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Background") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *DocumentStyle) MarshalJSON() ([]byte, error) {
+	type NoMethod DocumentStyle
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// DocumentStyleSuggestionState: A mask that indicates which of the
+// fields on the base DocumentStyle have been changed in this
+// suggestion.
+// For any field set to true, there is a new suggested value.
+type DocumentStyleSuggestionState struct {
+	// BackgroundSuggestionState: A mask that indicates which of the fields
+	// in background have been changed in this
+	// suggestion.
+	BackgroundSuggestionState *BackgroundSuggestionState `json:"backgroundSuggestionState,omitempty"`
+
+	// DefaultFooterIdSuggested: Indicates if there was a suggested change
+	// to default_footer_id.
+	DefaultFooterIdSuggested bool `json:"defaultFooterIdSuggested,omitempty"`
+
+	// DefaultHeaderIdSuggested: Indicates if there was a suggested change
+	// to default_header_id.
+	DefaultHeaderIdSuggested bool `json:"defaultHeaderIdSuggested,omitempty"`
+
+	// EvenPageFooterIdSuggested: Indicates if there was a suggested change
+	// to even_page_footer_id.
+	EvenPageFooterIdSuggested bool `json:"evenPageFooterIdSuggested,omitempty"`
+
+	// EvenPageHeaderIdSuggested: Indicates if there was a suggested change
+	// to even_page_header_id.
+	EvenPageHeaderIdSuggested bool `json:"evenPageHeaderIdSuggested,omitempty"`
+
+	// FirstPageFooterIdSuggested: Indicates if there was a suggested change
+	// to first_page_footer_id.
+	FirstPageFooterIdSuggested bool `json:"firstPageFooterIdSuggested,omitempty"`
+
+	// FirstPageHeaderIdSuggested: Indicates if there was a suggested change
+	// to first_page_header_id.
+	FirstPageHeaderIdSuggested bool `json:"firstPageHeaderIdSuggested,omitempty"`
+
+	// MarginBottomSuggested: Indicates if there was a suggested change to
+	// margin_bottom.
+	MarginBottomSuggested bool `json:"marginBottomSuggested,omitempty"`
+
+	// MarginLeftSuggested: Indicates if there was a suggested change to
+	// margin_left.
+	MarginLeftSuggested bool `json:"marginLeftSuggested,omitempty"`
+
+	// MarginRightSuggested: Indicates if there was a suggested change to
+	// margin_right.
+	MarginRightSuggested bool `json:"marginRightSuggested,omitempty"`
+
+	// MarginTopSuggested: Indicates if there was a suggested change to
+	// margin_top.
+	MarginTopSuggested bool `json:"marginTopSuggested,omitempty"`
+
+	// PageNumberStartSuggested: Indicates if there was a suggested change
+	// to page_number_start.
+	PageNumberStartSuggested bool `json:"pageNumberStartSuggested,omitempty"`
+
+	// PageSizeSuggestionState: A mask that indicates which of the fields in
+	// size have been changed in this
+	// suggestion.
+	PageSizeSuggestionState *SizeSuggestionState `json:"pageSizeSuggestionState,omitempty"`
+
+	// UseEvenPageHeaderFooterSuggested: Indicates if there was a suggested
+	// change to use_even_page_header_footer.
+	UseEvenPageHeaderFooterSuggested bool `json:"useEvenPageHeaderFooterSuggested,omitempty"`
+
+	// UseFirstPageHeaderFooterSuggested: Indicates if there was a suggested
+	// change to use_first_page_header_footer.
+	UseFirstPageHeaderFooterSuggested bool `json:"useFirstPageHeaderFooterSuggested,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "BackgroundSuggestionState") to unconditionally include in API
+	// requests. By default, fields with empty values are omitted from API
+	// requests. However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g.
+	// "BackgroundSuggestionState") to include in API requests with the JSON
+	// null value. By default, fields with empty values are omitted from API
+	// requests. However, any field with an empty value appearing in
+	// NullFields will be sent to the server as null. It is an error if a
+	// field in this list has a non-empty value. This may be used to include
+	// null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *DocumentStyleSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod DocumentStyleSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// EmbeddedDrawingProperties: The properties of an embedded drawing.
+type EmbeddedDrawingProperties struct {
+}
+
+// EmbeddedDrawingPropertiesSuggestionState: A mask that indicates which
+// of the fields on the base
+// EmbeddedDrawingProperties
+// have been changed in this suggestion. For any field set to true,
+// there is a
+// new suggested value.
+type EmbeddedDrawingPropertiesSuggestionState struct {
+}
+
+// EmbeddedObject: An embedded object in the document.
+type EmbeddedObject struct {
+	// Description: The description of the embedded object. The `title` and
+	// `description` are
+	// both combined to display alt text.
+	Description string `json:"description,omitempty"`
+
+	// EmbeddedDrawingProperties: The properties of an embedded drawing.
+	EmbeddedDrawingProperties *EmbeddedDrawingProperties `json:"embeddedDrawingProperties,omitempty"`
+
+	// EmbeddedObjectBorder: The border of the embedded object.
+	EmbeddedObjectBorder *EmbeddedObjectBorder `json:"embeddedObjectBorder,omitempty"`
+
+	// ImageProperties: The properties of an image.
+	ImageProperties *ImageProperties `json:"imageProperties,omitempty"`
+
+	// LinkedContentReference: A reference to the external linked source
+	// content. For example, it contains
+	// a reference to the source Sheets chart when the embedded object is a
+	// linked
+	// chart.
+	//
+	// If unset, then the embedded object is not linked.
+	LinkedContentReference *LinkedContentReference `json:"linkedContentReference,omitempty"`
+
+	// MarginBottom: The bottom margin of the embedded object.
+	MarginBottom *Dimension `json:"marginBottom,omitempty"`
+
+	// MarginLeft: The left margin of the embedded object.
+	MarginLeft *Dimension `json:"marginLeft,omitempty"`
+
+	// MarginRight: The right margin of the embedded object.
+	MarginRight *Dimension `json:"marginRight,omitempty"`
+
+	// MarginTop: The top margin of the embedded object.
+	MarginTop *Dimension `json:"marginTop,omitempty"`
+
+	// Size: The size of the embedded object.
+	Size *Size `json:"size,omitempty"`
+
+	// Title: The title of the embedded object. The `title` and
+	// `description` are both
+	// combined to display alt text.
+	Title string `json:"title,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Description") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Description") to include
+	// in API requests with the JSON null value. By default, fields with
+	// empty values are omitted from API requests. However, any field with
+	// an empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *EmbeddedObject) MarshalJSON() ([]byte, error) {
+	type NoMethod EmbeddedObject
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// EmbeddedObjectBorder: A border around an EmbeddedObject.
+type EmbeddedObjectBorder struct {
+	// Color: The color of the border.
+	Color *OptionalColor `json:"color,omitempty"`
+
+	// DashStyle: The dash style of the border.
+	//
+	// Possible values:
+	//   "DASH_STYLE_UNSPECIFIED" - Unspecified dash style.
+	//   "SOLID" - Solid line. Corresponds to ECMA-376 ST_PresetLineDashVal
+	// value 'solid'.
+	// This is the default dash style.
+	//   "DOT" - Dotted line. Corresponds to ECMA-376 ST_PresetLineDashVal
+	// value 'dot'.
+	//   "DASH" - Dashed line. Corresponds to ECMA-376 ST_PresetLineDashVal
+	// value 'dash'.
+	DashStyle string `json:"dashStyle,omitempty"`
+
+	// PropertyState: The property state of the border property.
+	//
+	// Possible values:
+	//   "RENDERED" - If a property's state is RENDERED, then the element
+	// has the corresponding
+	// property when rendered in the document. This is the default value.
+	//   "NOT_RENDERED" - If a property's state is NOT_RENDERED, then the
+	// element does not have the
+	// corresponding property when rendered in the document.
+	PropertyState string `json:"propertyState,omitempty"`
+
+	// Width: The width of the border.
+	Width *Dimension `json:"width,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Color") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Color") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *EmbeddedObjectBorder) MarshalJSON() ([]byte, error) {
+	type NoMethod EmbeddedObjectBorder
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// EmbeddedObjectBorderSuggestionState: A mask that indicates which of
+// the fields on the base EmbeddedObjectBorder have been changed in
+// this
+// suggestion. For any field set to true, there is a new suggested
+// value.
+type EmbeddedObjectBorderSuggestionState struct {
+	// ColorSuggested: Indicates if there was a suggested change to color.
+	ColorSuggested bool `json:"colorSuggested,omitempty"`
+
+	// DashStyleSuggested: Indicates if there was a suggested change to
+	// dash_style.
+	DashStyleSuggested bool `json:"dashStyleSuggested,omitempty"`
+
+	// PropertyStateSuggested: Indicates if there was a suggested change to
+	// property_state.
+	PropertyStateSuggested bool `json:"propertyStateSuggested,omitempty"`
+
+	// WidthSuggested: Indicates if there was a suggested change to width.
+	WidthSuggested bool `json:"widthSuggested,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ColorSuggested") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ColorSuggested") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *EmbeddedObjectBorderSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod EmbeddedObjectBorderSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// EmbeddedObjectSuggestionState: A mask that indicates which of the
+// fields on the base EmbeddedObject have been changed in this
+// suggestion.
+// For any field set to true, there is a new suggested value.
+type EmbeddedObjectSuggestionState struct {
+	// DescriptionSuggested: Indicates if there was a suggested change to
+	// description.
+	DescriptionSuggested bool `json:"descriptionSuggested,omitempty"`
+
+	// EmbeddedDrawingPropertiesSuggestionState: A mask that indicates which
+	// of the fields in embedded_drawing_properties have been
+	// changed in this suggestion.
+	EmbeddedDrawingPropertiesSuggestionState *EmbeddedDrawingPropertiesSuggestionState `json:"embeddedDrawingPropertiesSuggestionState,omitempty"`
+
+	// EmbeddedObjectBorderSuggestionState: A mask that indicates which of
+	// the fields in embedded_object_border have been
+	// changed in this suggestion.
+	EmbeddedObjectBorderSuggestionState *EmbeddedObjectBorderSuggestionState `json:"embeddedObjectBorderSuggestionState,omitempty"`
+
+	// ImagePropertiesSuggestionState: A mask that indicates which of the
+	// fields in image_properties have been changed in
+	// this suggestion.
+	ImagePropertiesSuggestionState *ImagePropertiesSuggestionState `json:"imagePropertiesSuggestionState,omitempty"`
+
+	// LinkedContentReferenceSuggestionState: A mask that indicates which of
+	// the fields in linked_content_reference have been
+	// changed in this suggestion.
+	LinkedContentReferenceSuggestionState *LinkedContentReferenceSuggestionState `json:"linkedContentReferenceSuggestionState,omitempty"`
+
+	// MarginBottomSuggested: Indicates if there was a suggested change to
+	// margin_bottom.
+	MarginBottomSuggested bool `json:"marginBottomSuggested,omitempty"`
+
+	// MarginLeftSuggested: Indicates if there was a suggested change to
+	// margin_left.
+	MarginLeftSuggested bool `json:"marginLeftSuggested,omitempty"`
+
+	// MarginRightSuggested: Indicates if there was a suggested change to
+	// margin_right.
+	MarginRightSuggested bool `json:"marginRightSuggested,omitempty"`
+
+	// MarginTopSuggested: Indicates if there was a suggested change to
+	// margin_top.
+	MarginTopSuggested bool `json:"marginTopSuggested,omitempty"`
+
+	// SizeSuggestionState: A mask that indicates which of the fields in
+	// size have been changed in this
+	// suggestion.
+	SizeSuggestionState *SizeSuggestionState `json:"sizeSuggestionState,omitempty"`
+
+	// TitleSuggested: Indicates if there was a suggested change to title.
+	TitleSuggested bool `json:"titleSuggested,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "DescriptionSuggested") to unconditionally include in API requests.
+	// By default, fields with empty values are omitted from API requests.
+	// However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "DescriptionSuggested") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *EmbeddedObjectSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod EmbeddedObjectSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// EndOfSegmentLocation: Location at the end of a body, header, footer
+// or footnote. The location is
+// immediately before the last newline in the document segment.
+type EndOfSegmentLocation struct {
+	// SegmentId: The ID of the header, footer or footnote the location is
+	// in. An empty
+	// segment ID signifies the document's body.
+	SegmentId string `json:"segmentId,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "SegmentId") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "SegmentId") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *EndOfSegmentLocation) MarshalJSON() ([]byte, error) {
+	type NoMethod EndOfSegmentLocation
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Equation: A ParagraphElement representing an
+// equation.
+type Equation struct {
+	// SuggestedDeletionIds: The suggested deletion IDs. If empty, then
+	// there are no suggested deletions
+	// of this content.
+	SuggestedDeletionIds []string `json:"suggestedDeletionIds,omitempty"`
+
+	// SuggestedInsertionIds: The suggested insertion IDs. A Equation
+	// may have multiple insertion IDs if it is a nested suggested change.
+	// If
+	// empty, then this is not a suggested insertion.
+	SuggestedInsertionIds []string `json:"suggestedInsertionIds,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "SuggestedDeletionIds") to unconditionally include in API requests.
+	// By default, fields with empty values are omitted from API requests.
+	// However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "SuggestedDeletionIds") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Equation) MarshalJSON() ([]byte, error) {
+	type NoMethod Equation
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Footer: A document footer.
+type Footer struct {
+	// Content: The contents of the footer.
+	//
+	// The indices for a footer's content begin at zero.
+	Content []*StructuralElement `json:"content,omitempty"`
+
+	// FooterId: The ID of the footer.
+	FooterId string `json:"footerId,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Content") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Content") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Footer) MarshalJSON() ([]byte, error) {
+	type NoMethod Footer
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Footnote: A document footnote.
+type Footnote struct {
+	// Content: The contents of the footnote.
+	//
+	// The indices for a footnote's content begin at zero.
+	Content []*StructuralElement `json:"content,omitempty"`
+
+	// FootnoteId: The ID of the footnote.
+	FootnoteId string `json:"footnoteId,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Content") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Content") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Footnote) MarshalJSON() ([]byte, error) {
+	type NoMethod Footnote
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// FootnoteReference: A ParagraphElement representing a
+// footnote reference. A footnote reference is the inline content
+// rendered with
+// a number and is used to identify the footnote.
+type FootnoteReference struct {
+	// FootnoteId: The ID of the footnote that
+	// contains the content of this footnote reference.
+	FootnoteId string `json:"footnoteId,omitempty"`
+
+	// FootnoteNumber: The rendered number of this footnote.
+	FootnoteNumber string `json:"footnoteNumber,omitempty"`
+
+	// SuggestedDeletionIds: The suggested deletion IDs. If empty, then
+	// there are no suggested deletions
+	// of this content.
+	SuggestedDeletionIds []string `json:"suggestedDeletionIds,omitempty"`
+
+	// SuggestedInsertionIds: The suggested insertion IDs. A
+	// FootnoteReference may have multiple insertion IDs if
+	// it is a nested suggested change. If empty, then this is not a
+	// suggested
+	// insertion.
+	SuggestedInsertionIds []string `json:"suggestedInsertionIds,omitempty"`
+
+	// SuggestedTextStyleChanges: The suggested text style changes to this
+	// FootnoteReference, keyed by
+	// suggestion ID.
+	SuggestedTextStyleChanges map[string]SuggestedTextStyle `json:"suggestedTextStyleChanges,omitempty"`
+
+	// TextStyle: The text style of this FootnoteReference.
+	TextStyle *TextStyle `json:"textStyle,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "FootnoteId") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "FootnoteId") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *FootnoteReference) MarshalJSON() ([]byte, error) {
+	type NoMethod FootnoteReference
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Header: A document header.
+type Header struct {
+	// Content: The contents of the header.
+	//
+	// The indices for a header's content begin at zero.
+	Content []*StructuralElement `json:"content,omitempty"`
+
+	// HeaderId: The ID of the header.
+	HeaderId string `json:"headerId,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Content") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Content") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Header) MarshalJSON() ([]byte, error) {
+	type NoMethod Header
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// HorizontalRule: A ParagraphElement representing a
+// horizontal line.
+type HorizontalRule struct {
+	// SuggestedDeletionIds: The suggested deletion IDs. If empty, then
+	// there are no suggested deletions
+	// of this content.
+	SuggestedDeletionIds []string `json:"suggestedDeletionIds,omitempty"`
+
+	// SuggestedInsertionIds: The suggested insertion IDs. A HorizontalRule
+	// may have multiple insertion IDs if it
+	// is a nested suggested change. If empty, then this is not a
+	// suggested
+	// insertion.
+	SuggestedInsertionIds []string `json:"suggestedInsertionIds,omitempty"`
+
+	// SuggestedTextStyleChanges: The suggested text style changes to this
+	// HorizontalRule, keyed by
+	// suggestion ID.
+	SuggestedTextStyleChanges map[string]SuggestedTextStyle `json:"suggestedTextStyleChanges,omitempty"`
+
+	// TextStyle: The text style of this HorizontalRule.
+	//
+	// Similar to text content, like text runs and footnote references, the
+	// text
+	// style of a horizontal rule can affect content layout as well as the
+	// styling
+	// of text inserted adjacent to it.
+	TextStyle *TextStyle `json:"textStyle,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "SuggestedDeletionIds") to unconditionally include in API requests.
+	// By default, fields with empty values are omitted from API requests.
+	// However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "SuggestedDeletionIds") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *HorizontalRule) MarshalJSON() ([]byte, error) {
+	type NoMethod HorizontalRule
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// ImageProperties: The properties of an image.
+type ImageProperties struct {
+	// Angle: The clockwise rotation angle of the image, in radians.
+	Angle float64 `json:"angle,omitempty"`
+
+	// Brightness: The brightness effect of the image. The value should be
+	// in the interval
+	// [-1.0, 1.0], where 0 means no effect.
+	Brightness float64 `json:"brightness,omitempty"`
+
+	// ContentUri: A URI to the image with a default lifetime of 30
+	// minutes.
+	// This URI is tagged with the account of the requester. Anyone with the
+	// URI
+	// effectively accesses the image as the original requester. Access to
+	// the
+	// image may be lost if the document's sharing settings change.
+	ContentUri string `json:"contentUri,omitempty"`
+
+	// Contrast: The contrast effect of the image. The value should be in
+	// the interval
+	// [-1.0, 1.0], where 0 means no effect.
+	Contrast float64 `json:"contrast,omitempty"`
+
+	// CropProperties: The crop properties of the image.
+	//
+	// After cropping, the image will be stretched to fit in its container.
+	CropProperties *CropProperties `json:"cropProperties,omitempty"`
+
+	// SourceUri: The source URI is the URI used to insert the image. The
+	// source URI can be
+	// empty.
+	SourceUri string `json:"sourceUri,omitempty"`
+
+	// Transparency: The transparency effect of the image. The value should
+	// be in the interval
+	// [0.0, 1.0], where 0 means no effect and 1 means completely
+	// transparent.
+	Transparency float64 `json:"transparency,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Angle") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Angle") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *ImageProperties) MarshalJSON() ([]byte, error) {
+	type NoMethod ImageProperties
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+func (s *ImageProperties) UnmarshalJSON(data []byte) error {
+	type NoMethod ImageProperties
+	var s1 struct {
+		Angle        gensupport.JSONFloat64 `json:"angle"`
+		Brightness   gensupport.JSONFloat64 `json:"brightness"`
+		Contrast     gensupport.JSONFloat64 `json:"contrast"`
+		Transparency gensupport.JSONFloat64 `json:"transparency"`
+		*NoMethod
+	}
+	s1.NoMethod = (*NoMethod)(s)
+	if err := json.Unmarshal(data, &s1); err != nil {
+		return err
+	}
+	s.Angle = float64(s1.Angle)
+	s.Brightness = float64(s1.Brightness)
+	s.Contrast = float64(s1.Contrast)
+	s.Transparency = float64(s1.Transparency)
+	return nil
+}
+
+// ImagePropertiesSuggestionState: A mask that indicates which of the
+// fields on the base ImageProperties have been changed in this
+// suggestion.
+// For any field set to true, there is a new suggested value.
+type ImagePropertiesSuggestionState struct {
+	// AngleSuggested: Indicates if there was a suggested change to angle.
+	AngleSuggested bool `json:"angleSuggested,omitempty"`
+
+	// BrightnessSuggested: Indicates if there was a suggested change to
+	// brightness.
+	BrightnessSuggested bool `json:"brightnessSuggested,omitempty"`
+
+	// ContentUriSuggested: Indicates if there was a suggested change
+	// to
+	// content_uri.
+	ContentUriSuggested bool `json:"contentUriSuggested,omitempty"`
+
+	// ContrastSuggested: Indicates if there was a suggested change to
+	// contrast.
+	ContrastSuggested bool `json:"contrastSuggested,omitempty"`
+
+	// CropPropertiesSuggestionState: A mask that indicates which of the
+	// fields in crop_properties have been changed in
+	// this suggestion.
+	CropPropertiesSuggestionState *CropPropertiesSuggestionState `json:"cropPropertiesSuggestionState,omitempty"`
+
+	// SourceUriSuggested: Indicates if there was a suggested change to
+	// source_uri.
+	SourceUriSuggested bool `json:"sourceUriSuggested,omitempty"`
+
+	// TransparencySuggested: Indicates if there was a suggested change to
+	// transparency.
+	TransparencySuggested bool `json:"transparencySuggested,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "AngleSuggested") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "AngleSuggested") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *ImagePropertiesSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod ImagePropertiesSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// InlineObject: An object that appears inline with text. An
+// InlineObject contains
+// an EmbeddedObject such as an image.
+type InlineObject struct {
+	// InlineObjectProperties: The properties of this inline object.
+	InlineObjectProperties *InlineObjectProperties `json:"inlineObjectProperties,omitempty"`
+
+	// ObjectId: The ID of this inline object.
+	ObjectId string `json:"objectId,omitempty"`
+
+	// SuggestedDeletionIds: The suggested deletion IDs. If empty, then
+	// there are no suggested deletions
+	// of this content.
+	SuggestedDeletionIds []string `json:"suggestedDeletionIds,omitempty"`
+
+	// SuggestedInlineObjectPropertiesChanges: The suggested changes to the
+	// inline object properties, keyed by suggestion
+	// ID.
+	SuggestedInlineObjectPropertiesChanges map[string]SuggestedInlineObjectProperties `json:"suggestedInlineObjectPropertiesChanges,omitempty"`
+
+	// SuggestedInsertionId: The suggested insertion ID. If empty, then this
+	// is not a suggested
+	// insertion.
+	SuggestedInsertionId string `json:"suggestedInsertionId,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "InlineObjectProperties") to unconditionally include in API requests.
+	// By default, fields with empty values are omitted from API requests.
+	// However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "InlineObjectProperties")
+	// to include in API requests with the JSON null value. By default,
+	// fields with empty values are omitted from API requests. However, any
+	// field with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *InlineObject) MarshalJSON() ([]byte, error) {
+	type NoMethod InlineObject
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// InlineObjectElement: A ParagraphElement that contains
+// an InlineObject.
+type InlineObjectElement struct {
+	// InlineObjectId: The ID of the InlineObject this
+	// element contains.
+	InlineObjectId string `json:"inlineObjectId,omitempty"`
+
+	// SuggestedDeletionIds: The suggested deletion IDs. If empty, then
+	// there are no suggested deletions
+	// of this content.
+	SuggestedDeletionIds []string `json:"suggestedDeletionIds,omitempty"`
+
+	// SuggestedInsertionIds: The suggested insertion IDs. An
+	// InlineObjectElement may have multiple insertion IDs
+	// if it is a nested suggested change. If empty, then this is not a
+	// suggested
+	// insertion.
+	SuggestedInsertionIds []string `json:"suggestedInsertionIds,omitempty"`
+
+	// SuggestedTextStyleChanges: The suggested text style changes to this
+	// InlineObject, keyed by suggestion
+	// ID.
+	SuggestedTextStyleChanges map[string]SuggestedTextStyle `json:"suggestedTextStyleChanges,omitempty"`
+
+	// TextStyle: The text style of this InlineObjectElement.
+	//
+	// Similar to text content, like text runs and footnote references, the
+	// text
+	// style of an inline object element can affect content layout as well
+	// as the
+	// styling of text inserted adjacent to it.
+	TextStyle *TextStyle `json:"textStyle,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "InlineObjectId") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "InlineObjectId") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *InlineObjectElement) MarshalJSON() ([]byte, error) {
+	type NoMethod InlineObjectElement
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// InlineObjectProperties: Properties of an InlineObject.
+type InlineObjectProperties struct {
+	// EmbeddedObject: The embedded object of this inline object.
+	EmbeddedObject *EmbeddedObject `json:"embeddedObject,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "EmbeddedObject") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "EmbeddedObject") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *InlineObjectProperties) MarshalJSON() ([]byte, error) {
+	type NoMethod InlineObjectProperties
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// InlineObjectPropertiesSuggestionState: A mask that indicates which of
+// the fields on the base
+// InlineObjectProperties have
+// been changed in this suggestion. For any field set to true, there is
+// a new
+// suggested value.
+type InlineObjectPropertiesSuggestionState struct {
+	// EmbeddedObjectSuggestionState: A mask that indicates which of the
+	// fields in embedded_object have been
+	// changed in this suggestion.
+	EmbeddedObjectSuggestionState *EmbeddedObjectSuggestionState `json:"embeddedObjectSuggestionState,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "EmbeddedObjectSuggestionState") to unconditionally include in API
+	// requests. By default, fields with empty values are omitted from API
+	// requests. However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g.
+	// "EmbeddedObjectSuggestionState") to include in API requests with the
+	// JSON null value. By default, fields with empty values are omitted
+	// from API requests. However, any field with an empty value appearing
+	// in NullFields will be sent to the server as null. It is an error if a
+	// field in this list has a non-empty value. This may be used to include
+	// null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *InlineObjectPropertiesSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod InlineObjectPropertiesSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// InsertInlineImageRequest: Inserts an InlineObject containing an
+// image at the given location.
+type InsertInlineImageRequest struct {
+	// EndOfSegmentLocation: Inserts the text at the end of a header, footer
+	// or the document body.
+	//
+	// Inline images cannot be inserted inside a footnote.
+	EndOfSegmentLocation *EndOfSegmentLocation `json:"endOfSegmentLocation,omitempty"`
+
+	// Location: Inserts the image at a specific index in the document.
+	//
+	// The image must be inserted inside the bounds of an
+	// existing
+	// Paragraph. For instance, it cannot be
+	// inserted at a table's start index (i.e. between the table and
+	// its
+	// preceding paragraph).
+	//
+	// Inline images cannot be inserted inside a footnote or equation.
+	Location *Location `json:"location,omitempty"`
+
+	// ObjectSize: The size that the image should appear as in the document.
+	// This property is
+	// optional and the final size of the image in the document is
+	// determined by
+	// the following rules:
+	//  * If neither width nor height is specified, then a default size of
+	// the
+	//  image is calculated based on its resolution.
+	//  * If one dimension is specified then the other dimension is
+	// calculated to
+	//  preserve the aspect ratio of the image.
+	//  * If both width and height are specified, the image is scaled to
+	// fit
+	//  within the provided dimensions while maintaining its aspect ratio.
+	ObjectSize *Size `json:"objectSize,omitempty"`
+
+	// Uri: The image URI.
+	//
+	// The image is fetched once at insertion time and a copy is stored
+	// for
+	// display inside the document. Images must be less than 50MB in size,
+	// cannot
+	// exceed 25 megapixels, and must be in one of PNG, JPEG, or GIF
+	// format.
+	//
+	// The provided URI can be at most 2 kB in length. The URI itself is
+	// saved
+	// with the image, and exposed via the ImageProperties.content_uri
+	// field.
+	Uri string `json:"uri,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "EndOfSegmentLocation") to unconditionally include in API requests.
+	// By default, fields with empty values are omitted from API requests.
+	// However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "EndOfSegmentLocation") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *InsertInlineImageRequest) MarshalJSON() ([]byte, error) {
+	type NoMethod InsertInlineImageRequest
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// InsertInlineImageResponse: The result of inserting an inline image.
+type InsertInlineImageResponse struct {
+	// ObjectId: The ID of the created InlineObject.
+	ObjectId string `json:"objectId,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ObjectId") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ObjectId") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *InsertInlineImageResponse) MarshalJSON() ([]byte, error) {
+	type NoMethod InsertInlineImageResponse
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// InsertInlineSheetsChartResponse: The result of inserting an embedded
+// Google Sheets chart.
+type InsertInlineSheetsChartResponse struct {
+	// ObjectId: The object ID of the inserted chart.
+	ObjectId string `json:"objectId,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ObjectId") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ObjectId") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *InsertInlineSheetsChartResponse) MarshalJSON() ([]byte, error) {
+	type NoMethod InsertInlineSheetsChartResponse
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// InsertTableRowRequest: Inserts an empty row into a table.
+type InsertTableRowRequest struct {
+	// InsertBelow: Whether to insert new row below the reference cell
+	// location.
+	//
+	// - `True`: insert below the cell.
+	// - `False`: insert above the cell.
+	InsertBelow bool `json:"insertBelow,omitempty"`
+
+	// TableCellLocation: The reference table cell location from which rows
+	// will be inserted.
+	//
+	// A new row will be inserted above (or below) the row where the
+	// reference
+	// cell is. If the reference cell is a merged cell, a new row will
+	// be
+	// inserted above (or below) the merged cell.
+	TableCellLocation *TableCellLocation `json:"tableCellLocation,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "InsertBelow") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "InsertBelow") to include
+	// in API requests with the JSON null value. By default, fields with
+	// empty values are omitted from API requests. However, any field with
+	// an empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *InsertTableRowRequest) MarshalJSON() ([]byte, error) {
+	type NoMethod InsertTableRowRequest
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// InsertTextRequest: Inserts text at the specified location.
+type InsertTextRequest struct {
+	// EndOfSegmentLocation: Inserts the text at the end of a header,
+	// footer, footnote or
+	// the document body.
+	EndOfSegmentLocation *EndOfSegmentLocation `json:"endOfSegmentLocation,omitempty"`
+
+	// Location: Inserts the text at a specific index in the document.
+	//
+	// Text must be inserted inside the bounds of an existing
+	// Paragraph. For instance, text cannot be
+	// inserted at a table's start index (i.e. between the table and
+	// its
+	// preceding paragraph). The text must be inserted in the
+	// preceding
+	// paragraph.
+	Location *Location `json:"location,omitempty"`
+
+	// Text: The text to be inserted.
+	//
+	// Inserting a newline character will implicitly create a new
+	// Paragraph at that index.
+	// The paragraph style of the new paragraph will be copied from the
+	// paragraph
+	// at the current insertion index, including lists and bullets.
+	//
+	// Text styles for inserted text will be determined automatically,
+	// generally
+	// preserving the styling of neighboring text. In most cases, the text
+	// style
+	// for the inserted text will match the text immediately before the
+	// insertion
+	// index.
+	//
+	// Some control characters (U+0000-U+0008, U+000C-U+001F) and
+	// characters
+	// from the Unicode Basic Multilingual Plane Private Use Area
+	// (U+E000-U+F8FF)
+	// will be stripped out of the inserted text.
+	Text string `json:"text,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "EndOfSegmentLocation") to unconditionally include in API requests.
+	// By default, fields with empty values are omitted from API requests.
+	// However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "EndOfSegmentLocation") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *InsertTextRequest) MarshalJSON() ([]byte, error) {
+	type NoMethod InsertTextRequest
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Link: A reference to another portion of a document or an external URL
+// resource.
+type Link struct {
+	// BookmarkId: The ID of a bookmark in this document.
+	BookmarkId string `json:"bookmarkId,omitempty"`
+
+	// HeadingId: The ID of a heading in this document.
+	HeadingId string `json:"headingId,omitempty"`
+
+	// Url: An external URL.
+	Url string `json:"url,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "BookmarkId") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "BookmarkId") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Link) MarshalJSON() ([]byte, error) {
+	type NoMethod Link
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// LinkedContentReference: A reference to the external linked source
+// content.
+type LinkedContentReference struct {
+	// SheetsChartReference: A reference to the linked chart.
+	SheetsChartReference *SheetsChartReference `json:"sheetsChartReference,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "SheetsChartReference") to unconditionally include in API requests.
+	// By default, fields with empty values are omitted from API requests.
+	// However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "SheetsChartReference") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *LinkedContentReference) MarshalJSON() ([]byte, error) {
+	type NoMethod LinkedContentReference
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// LinkedContentReferenceSuggestionState: A mask that indicates which of
+// the fields on the base
+// LinkedContentReference have
+// been changed in this suggestion. For any field set to true, there is
+// a new
+// suggested value.
+type LinkedContentReferenceSuggestionState struct {
+	// SheetsChartReferenceSuggestionState: A mask that indicates which of
+	// the fields in sheets_chart_reference have
+	// been changed in this suggestion.
+	SheetsChartReferenceSuggestionState *SheetsChartReferenceSuggestionState `json:"sheetsChartReferenceSuggestionState,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "SheetsChartReferenceSuggestionState") to unconditionally include in
+	// API requests. By default, fields with empty values are omitted from
+	// API requests. However, any non-pointer, non-interface field appearing
+	// in ForceSendFields will be sent to the server regardless of whether
+	// the field is empty or not. This may be used to include empty fields
+	// in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g.
+	// "SheetsChartReferenceSuggestionState") to include in API requests
+	// with the JSON null value. By default, fields with empty values are
+	// omitted from API requests. However, any field with an empty value
+	// appearing in NullFields will be sent to the server as null. It is an
+	// error if a field in this list has a non-empty value. This may be used
+	// to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *LinkedContentReferenceSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod LinkedContentReferenceSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// List: A List represents the list attributes for a group of paragraphs
+// that all
+// belong to the same list. A paragraph that is part of a list has a
+// reference
+// to the list's ID in its bullet.
+type List struct {
+	// ListProperties: The properties of the list.
+	ListProperties *ListProperties `json:"listProperties,omitempty"`
+
+	// SuggestedDeletionIds: The suggested deletion IDs. If empty, then
+	// there are no suggested deletions
+	// of this list.
+	SuggestedDeletionIds []string `json:"suggestedDeletionIds,omitempty"`
+
+	// SuggestedInsertionId: The suggested insertion ID. If empty, then this
+	// is not a suggested
+	// insertion.
+	SuggestedInsertionId string `json:"suggestedInsertionId,omitempty"`
+
+	// SuggestedListPropertiesChanges: The suggested changes to the list
+	// properties, keyed by suggestion
+	// ID.
+	SuggestedListPropertiesChanges map[string]SuggestedListProperties `json:"suggestedListPropertiesChanges,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ListProperties") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ListProperties") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *List) MarshalJSON() ([]byte, error) {
+	type NoMethod List
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// ListProperties: The properties of a list which describe the look
+// and feel of bullets belonging to paragraphs associated with a list.
+type ListProperties struct {
+	// NestingLevels: Describes the properties of the bullets at the
+	// associated level.
+	//
+	// A list has at most nine levels of nesting with nesting level
+	// 0
+	// corresponding to the top-most level and nesting level 8 corresponding
+	// to
+	// the most nested level. The nesting levels are returned in ascending
+	// order
+	// with the least nested returned first.
+	NestingLevels []*NestingLevel `json:"nestingLevels,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "NestingLevels") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "NestingLevels") to include
+	// in API requests with the JSON null value. By default, fields with
+	// empty values are omitted from API requests. However, any field with
+	// an empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *ListProperties) MarshalJSON() ([]byte, error) {
+	type NoMethod ListProperties
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// ListPropertiesSuggestionState: A mask that indicates which of the
+// fields on the base ListProperties have been changed in this
+// suggestion.
+// For any field set to true, there is a new suggested value.
+type ListPropertiesSuggestionState struct {
+	// NestingLevelsSuggestionStates: A mask that indicates which of the
+	// fields on the corresponding
+	// NestingLevel in nesting_levels have been changed in
+	// this suggestion.
+	//
+	// The nesting level suggestion states are returned in ascending order
+	// of the
+	// nesting level with the least nested returned first.
+	NestingLevelsSuggestionStates []*NestingLevelSuggestionState `json:"nestingLevelsSuggestionStates,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "NestingLevelsSuggestionStates") to unconditionally include in API
+	// requests. By default, fields with empty values are omitted from API
+	// requests. However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g.
+	// "NestingLevelsSuggestionStates") to include in API requests with the
+	// JSON null value. By default, fields with empty values are omitted
+	// from API requests. However, any field with an empty value appearing
+	// in NullFields will be sent to the server as null. It is an error if a
+	// field in this list has a non-empty value. This may be used to include
+	// null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *ListPropertiesSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod ListPropertiesSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Location: A particular location in the document.
+type Location struct {
+	// Index: The zero-based index, in UTF-16 code units.
+	//
+	// The index is relative to the beginning of the segment specified
+	// by
+	// segment_id.
+	Index int64 `json:"index,omitempty"`
+
+	// SegmentId: The ID of the header, footer or footnote the location is
+	// in. An empty
+	// segment ID signifies the document's body.
+	SegmentId string `json:"segmentId,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Index") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Index") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Location) MarshalJSON() ([]byte, error) {
+	type NoMethod Location
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// NamedRange: A collection of Ranges with the same named
+// range
+// ID.
+//
+// Named ranges allow developers to associate parts of a document with
+// an
+// arbitrary user-defined label so their contents can be
+// programmatically read
+// or edited at a later time. A document may contain multiple named
+// ranges with
+// the same name, but every named range has a unique ID.
+//
+// A named range is created with a single Range,
+// and content inserted inside a named range generally expands that
+// range.
+// However, certain document changes can cause the range to be split
+// into
+// multiple ranges.
+type NamedRange struct {
+	// Name: The name of the named range.
+	Name string `json:"name,omitempty"`
+
+	// NamedRangeId: The ID of the named range.
+	NamedRangeId string `json:"namedRangeId,omitempty"`
+
+	// Ranges: The ranges that belong to this named range.
+	Ranges []*Range `json:"ranges,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Name") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Name") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *NamedRange) MarshalJSON() ([]byte, error) {
+	type NoMethod NamedRange
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// NamedRanges: A collection of all the NamedRanges in the
+// document that share a given name.
+type NamedRanges struct {
+	// Name: The name that all the named ranges share.
+	Name string `json:"name,omitempty"`
+
+	// NamedRanges: The NamedRanges that share the same name.
+	NamedRanges []*NamedRange `json:"namedRanges,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Name") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Name") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *NamedRanges) MarshalJSON() ([]byte, error) {
+	type NoMethod NamedRanges
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// NamedStyle: A named style. Paragraphs in the document can inherit
+// their
+// TextStyle and
+// ParagraphStyle from this named style
+// when they have the same named style type.
+type NamedStyle struct {
+	// NamedStyleType: The type of this named style.
+	//
+	// Possible values:
+	//   "NAMED_STYLE_TYPE_UNSPECIFIED" - The type of named style is
+	// unspecified.
+	//   "NORMAL_TEXT" - Normal text.
+	//   "TITLE" - Title.
+	//   "SUBTITLE" - Subtitle.
+	//   "HEADING_1" - Heading 1.
+	//   "HEADING_2" - Heading 2.
+	//   "HEADING_3" - Heading 3.
+	//   "HEADING_4" - Heading 4.
+	//   "HEADING_5" - Heading 5.
+	//   "HEADING_6" - Heading 6.
+	NamedStyleType string `json:"namedStyleType,omitempty"`
+
+	// ParagraphStyle: The paragraph style of this named style.
+	ParagraphStyle *ParagraphStyle `json:"paragraphStyle,omitempty"`
+
+	// TextStyle: The text style of this named style.
+	TextStyle *TextStyle `json:"textStyle,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "NamedStyleType") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "NamedStyleType") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *NamedStyle) MarshalJSON() ([]byte, error) {
+	type NoMethod NamedStyle
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// NamedStyleSuggestionState: A suggestion state of a NamedStyle
+// message.
+type NamedStyleSuggestionState struct {
+	// NamedStyleType: The named style type that this suggestion state
+	// corresponds to.
+	//
+	// This field is provided as a convenience for matching
+	// the
+	// NamedStyleSuggestionState with its corresponding NamedStyle.
+	//
+	// Possible values:
+	//   "NAMED_STYLE_TYPE_UNSPECIFIED" - The type of named style is
+	// unspecified.
+	//   "NORMAL_TEXT" - Normal text.
+	//   "TITLE" - Title.
+	//   "SUBTITLE" - Subtitle.
+	//   "HEADING_1" - Heading 1.
+	//   "HEADING_2" - Heading 2.
+	//   "HEADING_3" - Heading 3.
+	//   "HEADING_4" - Heading 4.
+	//   "HEADING_5" - Heading 5.
+	//   "HEADING_6" - Heading 6.
+	NamedStyleType string `json:"namedStyleType,omitempty"`
+
+	// ParagraphStyleSuggestionState: A mask that indicates which of the
+	// fields in paragraph style have been changed in this
+	// suggestion.
+	ParagraphStyleSuggestionState *ParagraphStyleSuggestionState `json:"paragraphStyleSuggestionState,omitempty"`
+
+	// TextStyleSuggestionState: A mask that indicates which of the fields
+	// in text style have been changed in this
+	// suggestion.
+	TextStyleSuggestionState *TextStyleSuggestionState `json:"textStyleSuggestionState,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "NamedStyleType") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "NamedStyleType") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *NamedStyleSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod NamedStyleSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// NamedStyles: The named styles. Paragraphs in the document can inherit
+// their
+// TextStyle and
+// ParagraphStyle from these named styles.
+type NamedStyles struct {
+	// Styles: The named styles.
+	//
+	// There is an entry for each of the possible named style types.
+	Styles []*NamedStyle `json:"styles,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Styles") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Styles") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *NamedStyles) MarshalJSON() ([]byte, error) {
+	type NoMethod NamedStyles
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// NamedStylesSuggestionState: The suggestion state of a
+// NamedStyles
+// message.
+type NamedStylesSuggestionState struct {
+	// StylesSuggestionStates: A mask that indicates which of the fields on
+	// the corresponding NamedStyle in styles have been changed in
+	// this
+	// suggestion.
+	//
+	// The order of these named style suggestion states match the order of
+	// the
+	// corresponding named style within the named styles suggestion.
+	StylesSuggestionStates []*NamedStyleSuggestionState `json:"stylesSuggestionStates,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "StylesSuggestionStates") to unconditionally include in API requests.
+	// By default, fields with empty values are omitted from API requests.
+	// However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "StylesSuggestionStates")
+	// to include in API requests with the JSON null value. By default,
+	// fields with empty values are omitted from API requests. However, any
+	// field with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *NamedStylesSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod NamedStylesSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// NestingLevel: Contains properties describing the look and feel of a
+// list bullet at a given
+// level of nesting.
+type NestingLevel struct {
+	// BulletAlignment: The alignment of the bullet within the space
+	// allotted for rendering the
+	// bullet.
+	//
+	// Possible values:
+	//   "BULLET_ALIGNMENT_UNSPECIFIED" - The bullet alignment is
+	// unspecified.
+	//   "START" - The bullet is aligned to the start of the space allotted
+	// for rendering
+	// the bullet. Left-aligned for LTR text, right-aligned otherwise.
+	//   "CENTER" - The bullet is aligned to the center of the space
+	// allotted for rendering
+	// the bullet.
+	//   "END" - The bullet is aligned to the end of the space allotted for
+	// rendering the
+	// bullet. Right-aligned for LTR text, left-aligned otherwise.
+	BulletAlignment string `json:"bulletAlignment,omitempty"`
+
+	// GlyphFormat: The format string used by bullets at this level of
+	// nesting.
+	//
+	// The glyph format contains one or more placeholders, and these
+	// placeholder
+	// are replaced with the appropriate values depending on the glyph_type
+	// or glyph_symbol. The placeholders follow
+	// the pattern `%[nesting_level]`. Furthermore, placeholders can have
+	// prefixes
+	// and suffixes. Thus, the glyph format follows the
+	// pattern
+	// `<prefix>%[nesting_level]<suffix>`. Note that the prefix and suffix
+	// are
+	// optional and can be arbitrary strings.
+	//
+	// For example, the glyph format `%0.` indicates that the rendered glyph
+	// will
+	// replace the placeholder with the corresponding glyph for nesting
+	// level 0
+	// followed by a period as the suffix. So a list with a glyph type
+	// of
+	// UPPER_ALPHA and
+	// glyph format `%0.` at nesting level 0 will result in a list with
+	// rendered
+	// glyphs
+	// <p>`A.`
+	// <p>`B.`
+	// <p>`C.`
+	//
+	// The glyph format can contain placeholders for the current nesting
+	// level as
+	// well as placeholders for parent nesting levels. For example, a
+	// list can have a glyph format of `%0.` at nesting level 0 and a
+	// glyph format of `%0.%1.` at nesting level 1. Assuming both nesting
+	// levels
+	// have DECIMAL glyph
+	// types, this would result in a list with rendered
+	// glyphs
+	// <p>`1.`
+	// <p>`2.`
+	// <p>`  2.1.`
+	// <p>`  2.2.`
+	// <p>`3.`
+	//
+	// For nesting levels that are ordered, the string that replaces a
+	// placeholder
+	// in the glyph format for a particular paragraph depends on the
+	// paragraph's
+	// order within the list.
+	GlyphFormat string `json:"glyphFormat,omitempty"`
+
+	// GlyphSymbol: A custom glyph symbol used by bullets when paragraphs at
+	// this level of
+	// nesting are unordered.
+	//
+	// The glyph symbol replaces placeholders within the glyph_format. For
+	// example, if the
+	// glyph_symbol is the solid circle corresponding to Unicode U+25cf
+	// code
+	// point and the glyph_format is `%0`, the rendered
+	// glyph would be the solid circle.
+	GlyphSymbol string `json:"glyphSymbol,omitempty"`
+
+	// GlyphType: The type of glyph used by bullets when paragraphs at this
+	// level of
+	// nesting are ordered.
+	//
+	// The glyph type determines the type of glyph used to replace
+	// placeholders
+	// within the glyph_format
+	// when paragraphs at this level of nesting are ordered. For example, if
+	// the
+	// nesting level is 0, the glyph_format is `%0.` and the glyph
+	// type is DECIMAL,
+	// then the rendered glyph would replace the placeholder `%0` in the
+	// glyph
+	// format with a number corresponding to list item's order within the
+	// list.
+	//
+	// Possible values:
+	//   "GLYPH_TYPE_UNSPECIFIED" - The glyph type is unspecified or
+	// unsupported.
+	//   "NONE" - An empty string.
+	//   "DECIMAL" - A number, like `1`, `2`, or `3`.
+	//   "ZERO_DECIMAL" - A number where single digit numbers are prefixed
+	// with a zero, like `01`,
+	// `02`, or `03`. Numbers with more than one digit are not prefixed with
+	// a
+	// zero.
+	//   "UPPER_ALPHA" - An uppercase letter, like `A`, `B`, or `C`.
+	//   "ALPHA" - A lowercase letter, like `a`, `b`, or `c`.
+	//   "UPPER_ROMAN" - An uppercase roman numeral, like `I`, `II`, or
+	// `III`.
+	//   "ROMAN" - A lowercase roman numeral, like `i`, `ii`, or `iii`.
+	GlyphType string `json:"glyphType,omitempty"`
+
+	// IndentFirstLine: The amount of indentation for the first line of
+	// paragraphs at this level of
+	// nesting.
+	IndentFirstLine *Dimension `json:"indentFirstLine,omitempty"`
+
+	// IndentStart: The amount of indentation for paragraphs at this level
+	// of nesting. Applied
+	// to the side that corresponds to the start of the text, based on
+	// the
+	// paragraph's content direction.
+	IndentStart *Dimension `json:"indentStart,omitempty"`
+
+	// StartNumber: The number of the first list item at this nesting
+	// level.
+	//
+	// A value of 0 is treated as a value of 1 for lettered lists and
+	// roman
+	// numeraled lists, i.e. for values of both 0 and 1, lettered and
+	// roman
+	// numeraled lists will begin at `a` and `i` respectively.
+	//
+	// This value is ignored for nesting levels with unordered glyphs.
+	StartNumber int64 `json:"startNumber,omitempty"`
+
+	// TextStyle: The text style of bullets at this level of nesting.
+	TextStyle *TextStyle `json:"textStyle,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "BulletAlignment") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "BulletAlignment") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *NestingLevel) MarshalJSON() ([]byte, error) {
+	type NoMethod NestingLevel
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// NestingLevelSuggestionState: A mask that indicates which of the
+// fields on the base NestingLevel have been changed in this suggestion.
+// For
+// any field set to true, there is a new suggested value.
+type NestingLevelSuggestionState struct {
+	// BulletAlignmentSuggested: Indicates if there was a suggested change
+	// to
+	// bullet_alignment.
+	BulletAlignmentSuggested bool `json:"bulletAlignmentSuggested,omitempty"`
+
+	// GlyphFormatSuggested: Indicates if there was a suggested change
+	// to
+	// glyph_format.
+	GlyphFormatSuggested bool `json:"glyphFormatSuggested,omitempty"`
+
+	// GlyphSymbolSuggested: Indicates if there was a suggested change
+	// to
+	// glyph_symbol.
+	GlyphSymbolSuggested bool `json:"glyphSymbolSuggested,omitempty"`
+
+	// GlyphTypeSuggested: Indicates if there was a suggested change
+	// to
+	// glyph_type.
+	GlyphTypeSuggested bool `json:"glyphTypeSuggested,omitempty"`
+
+	// IndentFirstLineSuggested: Indicates if there was a suggested change
+	// to
+	// indent_first_line.
+	IndentFirstLineSuggested bool `json:"indentFirstLineSuggested,omitempty"`
+
+	// IndentStartSuggested: Indicates if there was a suggested change
+	// to
+	// indent_start.
+	IndentStartSuggested bool `json:"indentStartSuggested,omitempty"`
+
+	// StartNumberSuggested: Indicates if there was a suggested change
+	// to
+	// start_number.
+	StartNumberSuggested bool `json:"startNumberSuggested,omitempty"`
+
+	// TextStyleSuggestionState: A mask that indicates which of the fields
+	// in text style have been changed in this
+	// suggestion.
+	TextStyleSuggestionState *TextStyleSuggestionState `json:"textStyleSuggestionState,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "BulletAlignmentSuggested") to unconditionally include in API
+	// requests. By default, fields with empty values are omitted from API
+	// requests. However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "BulletAlignmentSuggested")
+	// to include in API requests with the JSON null value. By default,
+	// fields with empty values are omitted from API requests. However, any
+	// field with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *NestingLevelSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod NestingLevelSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// ObjectReferences: A collection of object IDs.
+type ObjectReferences struct {
+	// ObjectIds: The object IDs.
+	ObjectIds []string `json:"objectIds,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ObjectIds") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ObjectIds") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *ObjectReferences) MarshalJSON() ([]byte, error) {
+	type NoMethod ObjectReferences
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// OptionalColor: A color that can either be fully opaque or fully
+// transparent.
+type OptionalColor struct {
+	// Color: If set, this will be used as an opaque color. If unset, this
+	// represents
+	// a transparent color.
+	Color *Color `json:"color,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Color") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Color") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *OptionalColor) MarshalJSON() ([]byte, error) {
+	type NoMethod OptionalColor
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// PageBreak: A ParagraphElement representing a
+// page break. A page break makes the subsequent text start at the top
+// of the
+// next page.
+type PageBreak struct {
+	// SuggestedDeletionIds: The suggested deletion IDs. If empty, then
+	// there are no suggested deletions
+	// of this content.
+	SuggestedDeletionIds []string `json:"suggestedDeletionIds,omitempty"`
+
+	// SuggestedInsertionIds: The suggested insertion IDs. A PageBreak
+	// may have multiple insertion IDs if it is a nested suggested change.
+	// If
+	// empty, then this is not a suggested insertion.
+	SuggestedInsertionIds []string `json:"suggestedInsertionIds,omitempty"`
+
+	// SuggestedTextStyleChanges: The suggested text style changes to this
+	// PageBreak, keyed by suggestion ID.
+	SuggestedTextStyleChanges map[string]SuggestedTextStyle `json:"suggestedTextStyleChanges,omitempty"`
+
+	// TextStyle: The text style of this PageBreak.
+	//
+	// Similar to text content, like text runs and footnote references, the
+	// text
+	// style of a page break can affect content layout as well as the
+	// styling of
+	// text inserted adjacent to it.
+	TextStyle *TextStyle `json:"textStyle,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "SuggestedDeletionIds") to unconditionally include in API requests.
+	// By default, fields with empty values are omitted from API requests.
+	// However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "SuggestedDeletionIds") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *PageBreak) MarshalJSON() ([]byte, error) {
+	type NoMethod PageBreak
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Paragraph: A StructuralElement representing a
+// paragraph. A paragraph is a range of content that is terminated with
+// a
+// newline character.
+type Paragraph struct {
+	// Bullet: The bullet for this paragraph. If not present, the paragraph
+	// does not
+	// belong to a list.
+	Bullet *Bullet `json:"bullet,omitempty"`
+
+	// Elements: The content of the paragraph broken down into its component
+	// parts.
+	Elements []*ParagraphElement `json:"elements,omitempty"`
+
+	// ParagraphStyle: The style of this paragraph.
+	ParagraphStyle *ParagraphStyle `json:"paragraphStyle,omitempty"`
+
+	// PositionedObjectIds: The IDs of the positioned objects tethered to
+	// this paragraph.
+	PositionedObjectIds []string `json:"positionedObjectIds,omitempty"`
+
+	// SuggestedBulletChanges: The suggested changes to this paragraph's
+	// bullet.
+	SuggestedBulletChanges map[string]SuggestedBullet `json:"suggestedBulletChanges,omitempty"`
+
+	// SuggestedParagraphStyleChanges: The suggested paragraph style changes
+	// to this paragraph, keyed by
+	// suggestion ID.
+	SuggestedParagraphStyleChanges map[string]SuggestedParagraphStyle `json:"suggestedParagraphStyleChanges,omitempty"`
+
+	// SuggestedPositionedObjectIds: The IDs of the positioned objects that
+	// are suggested to be attached to this
+	// paragraph, keyed by suggestion ID.
+	SuggestedPositionedObjectIds map[string]ObjectReferences `json:"suggestedPositionedObjectIds,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Bullet") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Bullet") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Paragraph) MarshalJSON() ([]byte, error) {
+	type NoMethod Paragraph
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// ParagraphBorder: A border around a paragraph.
+type ParagraphBorder struct {
+	// Color: The color of the border.
+	Color *OptionalColor `json:"color,omitempty"`
+
+	// DashStyle: The dash style of the border.
+	//
+	// Possible values:
+	//   "DASH_STYLE_UNSPECIFIED" - Unspecified dash style.
+	//   "SOLID" - Solid line. Corresponds to ECMA-376 ST_PresetLineDashVal
+	// value 'solid'.
+	// This is the default dash style.
+	//   "DOT" - Dotted line. Corresponds to ECMA-376 ST_PresetLineDashVal
+	// value 'dot'.
+	//   "DASH" - Dashed line. Corresponds to ECMA-376 ST_PresetLineDashVal
+	// value 'dash'.
+	DashStyle string `json:"dashStyle,omitempty"`
+
+	// Padding: The padding of the border.
+	Padding *Dimension `json:"padding,omitempty"`
+
+	// Width: The width of the border.
+	Width *Dimension `json:"width,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Color") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Color") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *ParagraphBorder) MarshalJSON() ([]byte, error) {
+	type NoMethod ParagraphBorder
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// ParagraphElement: A ParagraphElement describes content within
+// a
+// Paragraph.
+type ParagraphElement struct {
+	// AutoText: An auto text paragraph element.
+	AutoText *AutoText `json:"autoText,omitempty"`
+
+	// ColumnBreak: A column break paragraph element.
+	ColumnBreak *ColumnBreak `json:"columnBreak,omitempty"`
+
+	// EndIndex: The zero-base end index of this paragraph element,
+	// exclusive, in Unicode
+	// code units of the UTF-16 encoding.
+	//
+	// Unicode code units of the UTF-16 encoding means that surrogate
+	// pairs
+	// consume two indices. For example, the "GRINNING FACE" emoji would
+	// be
+	// represented as "\uD83D\uDE00" and would consume two indices.
+	EndIndex int64 `json:"endIndex,omitempty"`
+
+	// Equation: An equation paragraph element.
+	Equation *Equation `json:"equation,omitempty"`
+
+	// FootnoteReference: A footnote reference paragraph element.
+	FootnoteReference *FootnoteReference `json:"footnoteReference,omitempty"`
+
+	// HorizontalRule: A horizontal rule paragraph element.
+	HorizontalRule *HorizontalRule `json:"horizontalRule,omitempty"`
+
+	// InlineObjectElement: An inline object paragraph element.
+	InlineObjectElement *InlineObjectElement `json:"inlineObjectElement,omitempty"`
+
+	// PageBreak: A page break paragraph element.
+	PageBreak *PageBreak `json:"pageBreak,omitempty"`
+
+	// StartIndex: The zero-based start index of this paragraph element, in
+	// Unicode code
+	// units of the UTF-16 encoding.
+	//
+	// Unicode code units of the UTF-16 encoding means that surrogate
+	// pairs
+	// consume two indices. For example, the "GRINNING FACE" emoji would
+	// be
+	// represented as "\uD83D\uDE00" and would consume two indices.
+	StartIndex int64 `json:"startIndex,omitempty"`
+
+	// TextRun: A text run paragraph element.
+	TextRun *TextRun `json:"textRun,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "AutoText") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "AutoText") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *ParagraphElement) MarshalJSON() ([]byte, error) {
+	type NoMethod ParagraphElement
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// ParagraphStyle: Styles that apply to a whole paragraph.
+//
+// Inherited paragraph styles are represented as unset fields in this
+// message.
+// A paragraph style's parent depends on where the paragraph style is
+// defined:
+//
+//   * The ParagraphStyle on a Paragraph
+//     inherits from the paragraph's corresponding named style type.
+//   * The ParagraphStyle on a named style
+//     inherits from the normal text named style.
+//   * The ParagraphStyle of the normal text named style inherits
+//     from the default paragraph style in the Docs editor.
+//   * The ParagraphStyle on a Paragraph
+//     element that is contained in a table may inherit its paragraph
+// style from
+//     the table style.
+//
+// If the paragraph style does not inherit from a parent, unsetting
+// fields will
+// revert the style to a value matching the defaults in the Docs editor.
+type ParagraphStyle struct {
+	// Alignment: The text alignment for this paragraph.
+	//
+	// Possible values:
+	//   "ALIGNMENT_UNSPECIFIED" - The paragraph alignment is inherited from
+	// the parent.
+	//   "START" - The paragraph is aligned to the start of the line.
+	// Left-aligned for LTR
+	// text, right-aligned otherwise.
+	//   "CENTER" - The paragraph is centered.
+	//   "END" - The paragraph is aligned to the end of the line.
+	// Right-aligned for LTR
+	// text, left-aligned otherwise.
+	//   "JUSTIFIED" - The paragraph is justified.
+	Alignment string `json:"alignment,omitempty"`
+
+	// AvoidWidowAndOrphan: Whether to avoid widows and orphans for the
+	// paragraph. If unset, the value
+	// is inherited from the parent.
+	AvoidWidowAndOrphan bool `json:"avoidWidowAndOrphan,omitempty"`
+
+	// BorderBetween: The border between this paragraph and the next and
+	// previous paragraphs.
+	// If unset, the value is inherited from the parent.
+	//
+	// The between border is rendered when the adjacent paragraph has the
+	// same
+	// border and indent properties.
+	//
+	// Paragraph borders cannot be partially updated. When making
+	// changes to a paragraph border the new border must be specified in
+	// its entirety.
+	BorderBetween *ParagraphBorder `json:"borderBetween,omitempty"`
+
+	// BorderBottom: The border at the bottom of this paragraph. If unset,
+	// the value is
+	// inherited from the parent.
+	//
+	// The bottom border is rendered when the paragraph below has different
+	// border
+	// and indent properties.
+	//
+	// Paragraph borders cannot be partially updated. When making
+	// changes to a paragraph border the new border must be specified in
+	// its entirety.
+	BorderBottom *ParagraphBorder `json:"borderBottom,omitempty"`
+
+	// BorderLeft: The border to the left of this paragraph. If unset, the
+	// value is inherited
+	// from the parent.
+	//
+	// Paragraph borders cannot be partially updated. When making
+	// changes to a paragraph border the new border must be specified in
+	// its entirety.
+	BorderLeft *ParagraphBorder `json:"borderLeft,omitempty"`
+
+	// BorderRight: The border to the right of this paragraph. If unset, the
+	// value is inherited
+	// from the parent.
+	//
+	// Paragraph borders cannot be partially updated. When making
+	// changes to a paragraph border the new border must be specified in
+	// its entirety.
+	BorderRight *ParagraphBorder `json:"borderRight,omitempty"`
+
+	// BorderTop: The border at the top of this paragraph. If unset, the
+	// value is inherited
+	// from the parent.
+	//
+	// The top border is rendered when the paragraph above has different
+	// border
+	// and indent properties.
+	//
+	// Paragraph borders cannot be partially updated. When making
+	// changes to a paragraph border the new border must be specified in
+	// its entirety.
+	BorderTop *ParagraphBorder `json:"borderTop,omitempty"`
+
+	// Direction: The text direction of this paragraph. If unset, the value
+	// defaults to
+	// LEFT_TO_RIGHT since
+	// paragraph direction is not inherited.
+	//
+	// Possible values:
+	//   "CONTENT_DIRECTION_UNSPECIFIED" - The content direction is
+	// unspecified.
+	//   "LEFT_TO_RIGHT" - The content goes from left to right.
+	//   "RIGHT_TO_LEFT" - The content goes from right to left.
+	Direction string `json:"direction,omitempty"`
+
+	// HeadingId: The heading ID of the paragraph. If empty, then this
+	// paragraph is not a
+	// heading. This property is read-only.
+	HeadingId string `json:"headingId,omitempty"`
+
+	// IndentEnd: The amount of indentation for the paragraph on the side
+	// that corresponds to
+	// the end of the text, based on the current paragraph direction. If
+	// unset,
+	// the value is inherited from the parent.
+	IndentEnd *Dimension `json:"indentEnd,omitempty"`
+
+	// IndentFirstLine: The amount of indentation for the first line of the
+	// paragraph. If unset,
+	// the value is inherited from the parent.
+	IndentFirstLine *Dimension `json:"indentFirstLine,omitempty"`
+
+	// IndentStart: The amount of indentation for the paragraph on the side
+	// that corresponds to
+	// the start of the text, based on the current paragraph direction. If
+	// unset,
+	// the value is inherited from the parent.
+	IndentStart *Dimension `json:"indentStart,omitempty"`
+
+	// KeepLinesTogether: Whether all lines of the paragraph should be laid
+	// out on the same page or
+	// column if possible. If unset, the value is inherited from the parent.
+	KeepLinesTogether bool `json:"keepLinesTogether,omitempty"`
+
+	// KeepWithNext: Whether at least a part of this paragraph should be
+	// laid out on the same
+	// page or column as the next paragraph if possible. If unset, the value
+	// is
+	// inherited from the parent.
+	KeepWithNext bool `json:"keepWithNext,omitempty"`
+
+	// LineSpacing: The amount of space between lines, as a percentage of
+	// normal, where normal
+	// is represented as 100.0. If unset, the value is inherited from the
+	// parent.
+	LineSpacing float64 `json:"lineSpacing,omitempty"`
+
+	// NamedStyleType: The named style type of the paragraph.
+	//
+	// Since updating the named style type affects other properties
+	// within
+	// ParagraphStyle, the named style type is applied before the other
+	// properties
+	// are updated.
+	//
+	// Possible values:
+	//   "NAMED_STYLE_TYPE_UNSPECIFIED" - The type of named style is
+	// unspecified.
+	//   "NORMAL_TEXT" - Normal text.
+	//   "TITLE" - Title.
+	//   "SUBTITLE" - Subtitle.
+	//   "HEADING_1" - Heading 1.
+	//   "HEADING_2" - Heading 2.
+	//   "HEADING_3" - Heading 3.
+	//   "HEADING_4" - Heading 4.
+	//   "HEADING_5" - Heading 5.
+	//   "HEADING_6" - Heading 6.
+	NamedStyleType string `json:"namedStyleType,omitempty"`
+
+	// Shading: The shading of the paragraph. If unset, the value is
+	// inherited from the
+	// parent.
+	Shading *Shading `json:"shading,omitempty"`
+
+	// SpaceAbove: The amount of extra space above the paragraph. If unset,
+	// the value is
+	// inherited from the parent.
+	SpaceAbove *Dimension `json:"spaceAbove,omitempty"`
+
+	// SpaceBelow: The amount of extra space below the paragraph. If unset,
+	// the value is
+	// inherited from the parent.
+	SpaceBelow *Dimension `json:"spaceBelow,omitempty"`
+
+	// SpacingMode: The spacing mode for the paragraph.
+	//
+	// Possible values:
+	//   "SPACING_MODE_UNSPECIFIED" - The spacing mode is inherited from the
+	// parent.
+	//   "NEVER_COLLAPSE" - Paragraph spacing is always rendered.
+	//   "COLLAPSE_LISTS" - Paragraph spacing is skipped between list
+	// elements.
+	SpacingMode string `json:"spacingMode,omitempty"`
+
+	// TabStops: A list of the tab stops for this paragraph. The list of tab
+	// stops is not
+	// inherited. This property is read-only.
+	TabStops []*TabStop `json:"tabStops,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Alignment") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Alignment") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *ParagraphStyle) MarshalJSON() ([]byte, error) {
+	type NoMethod ParagraphStyle
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+func (s *ParagraphStyle) UnmarshalJSON(data []byte) error {
+	type NoMethod ParagraphStyle
+	var s1 struct {
+		LineSpacing gensupport.JSONFloat64 `json:"lineSpacing"`
+		*NoMethod
+	}
+	s1.NoMethod = (*NoMethod)(s)
+	if err := json.Unmarshal(data, &s1); err != nil {
+		return err
+	}
+	s.LineSpacing = float64(s1.LineSpacing)
+	return nil
+}
+
+// ParagraphStyleSuggestionState: A mask that indicates which of the
+// fields on the base ParagraphStyle have been changed in this
+// suggestion.
+// For any field set to true, there is a new suggested value.
+type ParagraphStyleSuggestionState struct {
+	// AlignmentSuggested: Indicates if there was a suggested change to
+	// alignment.
+	AlignmentSuggested bool `json:"alignmentSuggested,omitempty"`
+
+	// AvoidWidowAndOrphanSuggested: Indicates if there was a suggested
+	// change to avoid_widow_and_orphan.
+	AvoidWidowAndOrphanSuggested bool `json:"avoidWidowAndOrphanSuggested,omitempty"`
+
+	// BorderBetweenSuggested: Indicates if there was a suggested change to
+	// border_between.
+	BorderBetweenSuggested bool `json:"borderBetweenSuggested,omitempty"`
+
+	// BorderBottomSuggested: Indicates if there was a suggested change to
+	// border_bottom.
+	BorderBottomSuggested bool `json:"borderBottomSuggested,omitempty"`
+
+	// BorderLeftSuggested: Indicates if there was a suggested change to
+	// border_left.
+	BorderLeftSuggested bool `json:"borderLeftSuggested,omitempty"`
+
+	// BorderRightSuggested: Indicates if there was a suggested change to
+	// border_right.
+	BorderRightSuggested bool `json:"borderRightSuggested,omitempty"`
+
+	// BorderTopSuggested: Indicates if there was a suggested change to
+	// border_top.
+	BorderTopSuggested bool `json:"borderTopSuggested,omitempty"`
+
+	// DirectionSuggested: Indicates if there was a suggested change to
+	// direction.
+	DirectionSuggested bool `json:"directionSuggested,omitempty"`
+
+	// HeadingIdSuggested: Indicates if there was a suggested change to
+	// heading_id.
+	HeadingIdSuggested bool `json:"headingIdSuggested,omitempty"`
+
+	// IndentEndSuggested: Indicates if there was a suggested change to
+	// indent_end.
+	IndentEndSuggested bool `json:"indentEndSuggested,omitempty"`
+
+	// IndentFirstLineSuggested: Indicates if there was a suggested change
+	// to indent_first_line.
+	IndentFirstLineSuggested bool `json:"indentFirstLineSuggested,omitempty"`
+
+	// IndentStartSuggested: Indicates if there was a suggested change to
+	// indent_start.
+	IndentStartSuggested bool `json:"indentStartSuggested,omitempty"`
+
+	// KeepLinesTogetherSuggested: Indicates if there was a suggested change
+	// to keep_lines_together.
+	KeepLinesTogetherSuggested bool `json:"keepLinesTogetherSuggested,omitempty"`
+
+	// KeepWithNextSuggested: Indicates if there was a suggested change to
+	// keep_with_next.
+	KeepWithNextSuggested bool `json:"keepWithNextSuggested,omitempty"`
+
+	// LineSpacingSuggested: Indicates if there was a suggested change to
+	// line_spacing.
+	LineSpacingSuggested bool `json:"lineSpacingSuggested,omitempty"`
+
+	// NamedStyleTypeSuggested: Indicates if there was a suggested change to
+	// named_style_type.
+	NamedStyleTypeSuggested bool `json:"namedStyleTypeSuggested,omitempty"`
+
+	// ShadingSuggestionState: A mask that indicates which of the fields in
+	// shading have been changed in
+	// this suggestion.
+	ShadingSuggestionState *ShadingSuggestionState `json:"shadingSuggestionState,omitempty"`
+
+	// SpaceAboveSuggested: Indicates if there was a suggested change to
+	// space_above.
+	SpaceAboveSuggested bool `json:"spaceAboveSuggested,omitempty"`
+
+	// SpaceBelowSuggested: Indicates if there was a suggested change to
+	// space_below.
+	SpaceBelowSuggested bool `json:"spaceBelowSuggested,omitempty"`
+
+	// SpacingModeSuggested: Indicates if there was a suggested change to
+	// spacing_mode.
+	SpacingModeSuggested bool `json:"spacingModeSuggested,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "AlignmentSuggested")
+	// to unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "AlignmentSuggested") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *ParagraphStyleSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod ParagraphStyleSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// PositionedObject: An object that is tethered to a Paragraph
+// and positioned relative to the beginning of the paragraph. A
+// PositionedObject
+// contains an EmbeddedObject such as an
+// image.
+type PositionedObject struct {
+	// ObjectId: The ID of this positioned object.
+	ObjectId string `json:"objectId,omitempty"`
+
+	// PositionedObjectProperties: The properties of this positioned object.
+	PositionedObjectProperties *PositionedObjectProperties `json:"positionedObjectProperties,omitempty"`
+
+	// SuggestedDeletionIds: The suggested deletion IDs. If empty, then
+	// there are no suggested deletions
+	// of this content.
+	SuggestedDeletionIds []string `json:"suggestedDeletionIds,omitempty"`
+
+	// SuggestedInsertionId: The suggested insertion ID. If empty, then this
+	// is not a suggested
+	// insertion.
+	SuggestedInsertionId string `json:"suggestedInsertionId,omitempty"`
+
+	// SuggestedPositionedObjectPropertiesChanges: The suggested changes to
+	// the positioned object properties, keyed by
+	// suggestion ID.
+	SuggestedPositionedObjectPropertiesChanges map[string]SuggestedPositionedObjectProperties `json:"suggestedPositionedObjectPropertiesChanges,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ObjectId") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ObjectId") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *PositionedObject) MarshalJSON() ([]byte, error) {
+	type NoMethod PositionedObject
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// PositionedObjectPositioning: The positioning of a PositionedObject.
+// The positioned object is positioned
+// relative to the beginning of the Paragraph
+// it is tethered to.
+type PositionedObjectPositioning struct {
+	// Layout: The layout of this positioned object.
+	//
+	// Possible values:
+	//   "POSITIONED_OBJECT_LAYOUT_UNSPECIFIED" - The layout is unspecified.
+	//   "WRAP_TEXT" - The text wraps around the positioned object.
+	//   "BREAK_LEFT" - Breaks text such that the positioned object is on
+	// the left and text is on
+	// the right.
+	//   "BREAK_RIGHT" - Breaks text such that the positioned object is on
+	// the right and text is on
+	// the left.
+	//   "BREAK_LEFT_RIGHT" - Breaks text such that there is no text on the
+	// left or right of the
+	// positioned object.
+	//   "IN_FRONT_OF_TEXT" - The positioned object is in front of the text.
+	Layout string `json:"layout,omitempty"`
+
+	// LeftOffset: The offset of the left edge of the positioned object
+	// relative to the
+	// beginning of the Paragraph it is tethered
+	// to. The exact positioning of the object can depend on other content
+	// in the
+	// document and the document's styling.
+	LeftOffset *Dimension `json:"leftOffset,omitempty"`
+
+	// TopOffset: The offset of the top edge of the positioned object
+	// relative to the
+	// beginning of the Paragraph it is tethered
+	// to. The exact positioning of the object can depend on other content
+	// in the
+	// document and the document's styling.
+	TopOffset *Dimension `json:"topOffset,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Layout") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Layout") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *PositionedObjectPositioning) MarshalJSON() ([]byte, error) {
+	type NoMethod PositionedObjectPositioning
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// PositionedObjectPositioningSuggestionState: A mask that indicates
+// which of the fields on the base
+// PositionedObjectPositioning have been changed in this
+// suggestion. For any field set to true, there is a new suggested
+// value.
+type PositionedObjectPositioningSuggestionState struct {
+	// LayoutSuggested: Indicates if there was a suggested change to layout.
+	LayoutSuggested bool `json:"layoutSuggested,omitempty"`
+
+	// LeftOffsetSuggested: Indicates if there was a suggested change to
+	// left_offset.
+	LeftOffsetSuggested bool `json:"leftOffsetSuggested,omitempty"`
+
+	// TopOffsetSuggested: Indicates if there was a suggested change to
+	// top_offset.
+	TopOffsetSuggested bool `json:"topOffsetSuggested,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "LayoutSuggested") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "LayoutSuggested") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *PositionedObjectPositioningSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod PositionedObjectPositioningSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// PositionedObjectProperties: Properties of a PositionedObject.
+type PositionedObjectProperties struct {
+	// EmbeddedObject: The embedded object of this positioned object.
+	EmbeddedObject *EmbeddedObject `json:"embeddedObject,omitempty"`
+
+	// Positioning: The positioning of this positioned object relative to
+	// the newline of the
+	// Paragraph that references this positioned
+	// object.
+	Positioning *PositionedObjectPositioning `json:"positioning,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "EmbeddedObject") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "EmbeddedObject") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *PositionedObjectProperties) MarshalJSON() ([]byte, error) {
+	type NoMethod PositionedObjectProperties
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// PositionedObjectPropertiesSuggestionState: A mask that indicates
+// which of the fields on the base
+// PositionedObjectProperties
+// have been changed in this suggestion. For any field set to true,
+// there is a
+// new suggested value.
+type PositionedObjectPropertiesSuggestionState struct {
+	// EmbeddedObjectSuggestionState: A mask that indicates which of the
+	// fields in embedded_object have been
+	// changed in this suggestion.
+	EmbeddedObjectSuggestionState *EmbeddedObjectSuggestionState `json:"embeddedObjectSuggestionState,omitempty"`
+
+	// PositioningSuggestionState: A mask that indicates which of the fields
+	// in positioning have been
+	// changed in this suggestion.
+	PositioningSuggestionState *PositionedObjectPositioningSuggestionState `json:"positioningSuggestionState,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "EmbeddedObjectSuggestionState") to unconditionally include in API
+	// requests. By default, fields with empty values are omitted from API
+	// requests. However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g.
+	// "EmbeddedObjectSuggestionState") to include in API requests with the
+	// JSON null value. By default, fields with empty values are omitted
+	// from API requests. However, any field with an empty value appearing
+	// in NullFields will be sent to the server as null. It is an error if a
+	// field in this list has a non-empty value. This may be used to include
+	// null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *PositionedObjectPropertiesSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod PositionedObjectPropertiesSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Range: Specifies a contiguous range of text.
+type Range struct {
+	// EndIndex: The zero-based end index of this range, exclusive, in
+	// Unicode code units of
+	// the UTF-16 encoding.
+	//
+	// In all current uses, an end index must be provided. This field is
+	// an
+	// Int32Value in order to accommodate future use cases with open-ended
+	// ranges.
+	EndIndex int64 `json:"endIndex,omitempty"`
+
+	// SegmentId: The ID of the header, footer or footnote that this range
+	// is contained in.
+	// An empty segment ID signifies the document's body.
+	SegmentId string `json:"segmentId,omitempty"`
+
+	// StartIndex: The zero-based start index of this range, in Unicode code
+	// units of the
+	// UTF-16 encoding.
+	//
+	// In all current uses, a start index must be provided. This field is
+	// an
+	// Int32Value in order to accommodate future use cases with open-ended
+	// ranges.
+	StartIndex int64 `json:"startIndex,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "EndIndex") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "EndIndex") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Range) MarshalJSON() ([]byte, error) {
+	type NoMethod Range
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// ReplaceAllTextRequest: Replaces all instances of text matching a
+// criteria with replace text.
+type ReplaceAllTextRequest struct {
+	// ContainsText: Finds text in the document matching this substring.
+	ContainsText *SubstringMatchCriteria `json:"containsText,omitempty"`
+
+	// ReplaceText: The text that will replace the matched text.
+	ReplaceText string `json:"replaceText,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ContainsText") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ContainsText") to include
+	// in API requests with the JSON null value. By default, fields with
+	// empty values are omitted from API requests. However, any field with
+	// an empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *ReplaceAllTextRequest) MarshalJSON() ([]byte, error) {
+	type NoMethod ReplaceAllTextRequest
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// ReplaceAllTextResponse: The result of replacing text.
+type ReplaceAllTextResponse struct {
+	// OccurrencesChanged: The number of occurrences changed by replacing
+	// all text.
+	OccurrencesChanged int64 `json:"occurrencesChanged,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "OccurrencesChanged")
+	// to unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "OccurrencesChanged") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *ReplaceAllTextResponse) MarshalJSON() ([]byte, error) {
+	type NoMethod ReplaceAllTextResponse
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Request: A single update to apply to a document.
+type Request struct {
+	// CreateNamedRange: Creates a named range.
+	CreateNamedRange *CreateNamedRangeRequest `json:"createNamedRange,omitempty"`
+
+	// CreateParagraphBullets: Creates bullets for paragraphs.
+	CreateParagraphBullets *CreateParagraphBulletsRequest `json:"createParagraphBullets,omitempty"`
+
+	// DeleteContentRange: Deletes content from the document.
+	DeleteContentRange *DeleteContentRangeRequest `json:"deleteContentRange,omitempty"`
+
+	// DeleteNamedRange: Deletes a named range.
+	DeleteNamedRange *DeleteNamedRangeRequest `json:"deleteNamedRange,omitempty"`
+
+	// DeleteParagraphBullets: Deletes bullets from paragraphs.
+	DeleteParagraphBullets *DeleteParagraphBulletsRequest `json:"deleteParagraphBullets,omitempty"`
+
+	// DeletePositionedObject: Deletes a positioned object from the
+	// document.
+	DeletePositionedObject *DeletePositionedObjectRequest `json:"deletePositionedObject,omitempty"`
+
+	// DeleteTableColumn: Deletes a column from a table.
+	DeleteTableColumn *DeleteTableColumnRequest `json:"deleteTableColumn,omitempty"`
+
+	// DeleteTableRow: Deletes a row from a table.
+	DeleteTableRow *DeleteTableRowRequest `json:"deleteTableRow,omitempty"`
+
+	// InsertInlineImage: Inserts an inline image at the specified location.
+	InsertInlineImage *InsertInlineImageRequest `json:"insertInlineImage,omitempty"`
+
+	// InsertTableRow: Inserts an empty row into a table.
+	InsertTableRow *InsertTableRowRequest `json:"insertTableRow,omitempty"`
+
+	// InsertText: Inserts text at the specified location.
+	InsertText *InsertTextRequest `json:"insertText,omitempty"`
+
+	// ReplaceAllText: Replaces all instances of the specified text.
+	ReplaceAllText *ReplaceAllTextRequest `json:"replaceAllText,omitempty"`
+
+	// UpdateParagraphStyle: Updates the paragraph style at the specified
+	// range.
+	UpdateParagraphStyle *UpdateParagraphStyleRequest `json:"updateParagraphStyle,omitempty"`
+
+	// UpdateTextStyle: Updates the text style at the specified range.
+	UpdateTextStyle *UpdateTextStyleRequest `json:"updateTextStyle,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "CreateNamedRange") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "CreateNamedRange") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Request) MarshalJSON() ([]byte, error) {
+	type NoMethod Request
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Response: A single response from an update.
+type Response struct {
+	// CreateNamedRange: The result of creating a named range.
+	CreateNamedRange *CreateNamedRangeResponse `json:"createNamedRange,omitempty"`
+
+	// InsertInlineImage: The result of inserting an inline image.
+	InsertInlineImage *InsertInlineImageResponse `json:"insertInlineImage,omitempty"`
+
+	// InsertInlineSheetsChart: The result of inserting an inline Google
+	// Sheets chart.
+	InsertInlineSheetsChart *InsertInlineSheetsChartResponse `json:"insertInlineSheetsChart,omitempty"`
+
+	// ReplaceAllText: The result of replacing text.
+	ReplaceAllText *ReplaceAllTextResponse `json:"replaceAllText,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "CreateNamedRange") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "CreateNamedRange") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Response) MarshalJSON() ([]byte, error) {
+	type NoMethod Response
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// RgbColor: An RGB color.
+type RgbColor struct {
+	// Blue: The blue component of the color, from 0.0 to 1.0.
+	Blue float64 `json:"blue,omitempty"`
+
+	// Green: The green component of the color, from 0.0 to 1.0.
+	Green float64 `json:"green,omitempty"`
+
+	// Red: The red component of the color, from 0.0 to 1.0.
+	Red float64 `json:"red,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Blue") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Blue") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *RgbColor) MarshalJSON() ([]byte, error) {
+	type NoMethod RgbColor
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+func (s *RgbColor) UnmarshalJSON(data []byte) error {
+	type NoMethod RgbColor
+	var s1 struct {
+		Blue  gensupport.JSONFloat64 `json:"blue"`
+		Green gensupport.JSONFloat64 `json:"green"`
+		Red   gensupport.JSONFloat64 `json:"red"`
+		*NoMethod
+	}
+	s1.NoMethod = (*NoMethod)(s)
+	if err := json.Unmarshal(data, &s1); err != nil {
+		return err
+	}
+	s.Blue = float64(s1.Blue)
+	s.Green = float64(s1.Green)
+	s.Red = float64(s1.Red)
+	return nil
+}
+
+// SectionBreak: A StructuralElement representing a
+// section break. A section is a range of content which has the
+// same
+// SectionStyle. A section break represents
+// the start of a new section, and the section style applies to the
+// section
+// after the section break.
+//
+// The document body always begins with a section break.
+type SectionBreak struct {
+	// SectionStyle: The style of the section after this section break.
+	SectionStyle *SectionStyle `json:"sectionStyle,omitempty"`
+
+	// SuggestedDeletionIds: The suggested deletion IDs. If empty, then
+	// there are no suggested deletions
+	// of this content.
+	SuggestedDeletionIds []string `json:"suggestedDeletionIds,omitempty"`
+
+	// SuggestedInsertionIds: The suggested insertion IDs. A SectionBreak
+	// may have multiple insertion IDs if it is
+	// a nested suggested change. If empty, then this is not a
+	// suggested
+	// insertion.
+	SuggestedInsertionIds []string `json:"suggestedInsertionIds,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "SectionStyle") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "SectionStyle") to include
+	// in API requests with the JSON null value. By default, fields with
+	// empty values are omitted from API requests. However, any field with
+	// an empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SectionBreak) MarshalJSON() ([]byte, error) {
+	type NoMethod SectionBreak
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// SectionColumnProperties: Properties that apply to a section's column.
+type SectionColumnProperties struct {
+	// PaddingEnd: The padding at the end of the column.
+	PaddingEnd *Dimension `json:"paddingEnd,omitempty"`
+
+	// Width: The width of the column.
+	Width *Dimension `json:"width,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "PaddingEnd") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "PaddingEnd") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SectionColumnProperties) MarshalJSON() ([]byte, error) {
+	type NoMethod SectionColumnProperties
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// SectionStyle: The styling that applies to a section.
+type SectionStyle struct {
+	// ColumnProperties: The section's columns properties.
+	//
+	// If empty, the section contains one column with the default properties
+	// in
+	// the Docs editor.
+	ColumnProperties []*SectionColumnProperties `json:"columnProperties,omitempty"`
+
+	// ColumnSeparatorStyle: The style of column separators.
+	//
+	// This style can be set even when there is one column in the section.
+	//
+	// Possible values:
+	//   "COLUMN_SEPARATOR_STYLE_UNSPECIFIED" - An unspecified column
+	// separator style.
+	//   "NONE" - No column separator lines between columns.
+	//   "BETWEEN_EACH_COLUMN" - Renders a column separator line between
+	// each column.
+	ColumnSeparatorStyle string `json:"columnSeparatorStyle,omitempty"`
+
+	// ContentDirection: The content direction of this section. If unset,
+	// the value defaults to
+	// LEFT_TO_RIGHT.
+	//
+	// Possible values:
+	//   "CONTENT_DIRECTION_UNSPECIFIED" - The content direction is
+	// unspecified.
+	//   "LEFT_TO_RIGHT" - The content goes from left to right.
+	//   "RIGHT_TO_LEFT" - The content goes from right to left.
+	ContentDirection string `json:"contentDirection,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ColumnProperties") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ColumnProperties") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SectionStyle) MarshalJSON() ([]byte, error) {
+	type NoMethod SectionStyle
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Shading: The shading of a paragraph.
+type Shading struct {
+	// BackgroundColor: The background color of this paragraph shading.
+	BackgroundColor *OptionalColor `json:"backgroundColor,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "BackgroundColor") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "BackgroundColor") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Shading) MarshalJSON() ([]byte, error) {
+	type NoMethod Shading
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// ShadingSuggestionState: A mask that indicates which of the fields on
+// the base Shading have been changed in this
+// suggested change. For any field set to true, there is a new suggested
+// value.
+type ShadingSuggestionState struct {
+	// BackgroundColorSuggested: Indicates if there was a suggested change
+	// to the Shading.
+	BackgroundColorSuggested bool `json:"backgroundColorSuggested,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "BackgroundColorSuggested") to unconditionally include in API
+	// requests. By default, fields with empty values are omitted from API
+	// requests. However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "BackgroundColorSuggested")
+	// to include in API requests with the JSON null value. By default,
+	// fields with empty values are omitted from API requests. However, any
+	// field with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *ShadingSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod ShadingSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// SheetsChartReference: A reference to a linked chart embedded from
+// Google Sheets.
+type SheetsChartReference struct {
+	// ChartId: The ID of the specific chart in the Google Sheets
+	// spreadsheet that is
+	// embedded.
+	ChartId int64 `json:"chartId,omitempty"`
+
+	// SpreadsheetId: The ID of the Google Sheets spreadsheet that contains
+	// the source chart.
+	SpreadsheetId string `json:"spreadsheetId,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ChartId") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ChartId") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SheetsChartReference) MarshalJSON() ([]byte, error) {
+	type NoMethod SheetsChartReference
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// SheetsChartReferenceSuggestionState: A mask that indicates which of
+// the fields on the base SheetsChartReference have been changed in
+// this
+// suggestion. For any field set to true, there is a new suggested
+// value.
+type SheetsChartReferenceSuggestionState struct {
+	// ChartIdSuggested: Indicates if there was a suggested change to
+	// chart_id.
+	ChartIdSuggested bool `json:"chartIdSuggested,omitempty"`
+
+	// SpreadsheetIdSuggested: Indicates if there was a suggested change to
+	// spreadsheet_id.
+	SpreadsheetIdSuggested bool `json:"spreadsheetIdSuggested,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ChartIdSuggested") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ChartIdSuggested") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SheetsChartReferenceSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod SheetsChartReferenceSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Size: A width and height.
+type Size struct {
+	// Height: The height of the object.
+	Height *Dimension `json:"height,omitempty"`
+
+	// Width: The width of the object.
+	Width *Dimension `json:"width,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Height") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Height") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Size) MarshalJSON() ([]byte, error) {
+	type NoMethod Size
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// SizeSuggestionState: A mask that indicates which of the fields on the
+// base Size have been changed in this suggestion.
+// For any field set to true, the Size has
+// a new suggested value.
+type SizeSuggestionState struct {
+	// HeightSuggested: Indicates if there was a suggested change to height.
+	HeightSuggested bool `json:"heightSuggested,omitempty"`
+
+	// WidthSuggested: Indicates if there was a suggested change to width.
+	WidthSuggested bool `json:"widthSuggested,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "HeightSuggested") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "HeightSuggested") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SizeSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod SizeSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// StructuralElement: A StructuralElement describes content that
+// provides structure to the
+// document.
+type StructuralElement struct {
+	// EndIndex: The zero-based end index of this structural element,
+	// exclusive, in Unicode
+	// code units of the UTF-16 encoding.
+	//
+	// Unicode code units of the UTF-16 encoding means that surrogate
+	// pairs
+	// consume two indices. For example, the "GRINNING FACE" emoji would
+	// be
+	// represented as "\uD83D\uDE00" and would consume two indices.
+	EndIndex int64 `json:"endIndex,omitempty"`
+
+	// Paragraph: A paragraph type of structural element.
+	Paragraph *Paragraph `json:"paragraph,omitempty"`
+
+	// SectionBreak: A section break type of structural element.
+	SectionBreak *SectionBreak `json:"sectionBreak,omitempty"`
+
+	// StartIndex: The zero-based start index of this structural element, in
+	// Unicode code
+	// units of the UTF-16 encoding.
+	//
+	// Unicode code units of the UTF-16 encoding means that surrogate
+	// pairs
+	// consume two indices. For example, the "GRINNING FACE" emoji would
+	// be
+	// represented as "\uD83D\uDE00" and would consume two indices.
+	StartIndex int64 `json:"startIndex,omitempty"`
+
+	// Table: A table type of structural element.
+	Table *Table `json:"table,omitempty"`
+
+	// TableOfContents: A table of contents type of structural element.
+	TableOfContents *TableOfContents `json:"tableOfContents,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "EndIndex") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "EndIndex") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *StructuralElement) MarshalJSON() ([]byte, error) {
+	type NoMethod StructuralElement
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// SubstringMatchCriteria: A criteria that matches a specific string of
+// text in the document.
+type SubstringMatchCriteria struct {
+	// MatchCase: Indicates whether the search should respect case:
+	//
+	// - `True`: the search is case sensitive.
+	// - `False`: the search is case insensitive.
+	MatchCase bool `json:"matchCase,omitempty"`
+
+	// Text: The text to search for in the document.
+	Text string `json:"text,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "MatchCase") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "MatchCase") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SubstringMatchCriteria) MarshalJSON() ([]byte, error) {
+	type NoMethod SubstringMatchCriteria
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// SuggestedBullet: A suggested change to a Bullet.
+type SuggestedBullet struct {
+	// Bullet: A Bullet that only includes the changes made
+	// in this suggestion. This can be used along with
+	// the
+	// bullet_suggestion_state to see which
+	// fields have changed and their new values.
+	Bullet *Bullet `json:"bullet,omitempty"`
+
+	// BulletSuggestionState: A mask that indicates which of the fields on
+	// the base
+	// Bullet have been changed in this suggestion.
+	BulletSuggestionState *BulletSuggestionState `json:"bulletSuggestionState,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Bullet") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Bullet") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SuggestedBullet) MarshalJSON() ([]byte, error) {
+	type NoMethod SuggestedBullet
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// SuggestedDocumentStyle: A suggested change to the DocumentStyle.
+type SuggestedDocumentStyle struct {
+	// DocumentStyle: A DocumentStyle that only includes
+	// the changes made in this suggestion. This can be used along with
+	// the
+	// document_style_suggestion_state
+	// to see which fields have changed and their new values.
+	DocumentStyle *DocumentStyle `json:"documentStyle,omitempty"`
+
+	// DocumentStyleSuggestionState: A mask that indicates which of the
+	// fields on the base DocumentStyle have been changed in this
+	// suggestion.
+	DocumentStyleSuggestionState *DocumentStyleSuggestionState `json:"documentStyleSuggestionState,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "DocumentStyle") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "DocumentStyle") to include
+	// in API requests with the JSON null value. By default, fields with
+	// empty values are omitted from API requests. However, any field with
+	// an empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SuggestedDocumentStyle) MarshalJSON() ([]byte, error) {
+	type NoMethod SuggestedDocumentStyle
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// SuggestedInlineObjectProperties: A suggested change to
+// InlineObjectProperties.
+type SuggestedInlineObjectProperties struct {
+	// InlineObjectProperties: An InlineObjectProperties
+	// that only includes the changes made in this suggestion. This can be
+	// used
+	// along with the inline_object_properties_suggestion_state
+	// to see which fields have changed and their new values.
+	InlineObjectProperties *InlineObjectProperties `json:"inlineObjectProperties,omitempty"`
+
+	// InlineObjectPropertiesSuggestionState: A mask that indicates which of
+	// the fields on the base
+	// InlineObjectProperties have
+	// been changed in this suggestion.
+	InlineObjectPropertiesSuggestionState *InlineObjectPropertiesSuggestionState `json:"inlineObjectPropertiesSuggestionState,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "InlineObjectProperties") to unconditionally include in API requests.
+	// By default, fields with empty values are omitted from API requests.
+	// However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "InlineObjectProperties")
+	// to include in API requests with the JSON null value. By default,
+	// fields with empty values are omitted from API requests. However, any
+	// field with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SuggestedInlineObjectProperties) MarshalJSON() ([]byte, error) {
+	type NoMethod SuggestedInlineObjectProperties
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// SuggestedListProperties: A suggested change to ListProperties.
+type SuggestedListProperties struct {
+	// ListProperties: A ListProperties that only includes
+	// the changes made in this suggestion. This can be used along with
+	// the
+	// list_properties_suggestion_state
+	// to see which fields have changed and their new values.
+	ListProperties *ListProperties `json:"listProperties,omitempty"`
+
+	// ListPropertiesSuggestionState: A mask that indicates which of the
+	// fields on the base ListProperties have been changed in this
+	// suggestion.
+	ListPropertiesSuggestionState *ListPropertiesSuggestionState `json:"listPropertiesSuggestionState,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ListProperties") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ListProperties") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SuggestedListProperties) MarshalJSON() ([]byte, error) {
+	type NoMethod SuggestedListProperties
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// SuggestedNamedStyles: A suggested change to the NamedStyles.
+type SuggestedNamedStyles struct {
+	// NamedStyles: A NamedStyles that only includes the
+	// changes made in this suggestion. This can be used along with
+	// the
+	// named_styles_suggestion_state to
+	// see which fields have changed and their new values.
+	NamedStyles *NamedStyles `json:"namedStyles,omitempty"`
+
+	// NamedStylesSuggestionState: A mask that indicates which of the fields
+	// on the base NamedStyles have been changed in this suggestion.
+	NamedStylesSuggestionState *NamedStylesSuggestionState `json:"namedStylesSuggestionState,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "NamedStyles") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "NamedStyles") to include
+	// in API requests with the JSON null value. By default, fields with
+	// empty values are omitted from API requests. However, any field with
+	// an empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SuggestedNamedStyles) MarshalJSON() ([]byte, error) {
+	type NoMethod SuggestedNamedStyles
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// SuggestedParagraphStyle: A suggested change to a
+// ParagraphStyle.
+type SuggestedParagraphStyle struct {
+	// ParagraphStyle: A ParagraphStyle that only includes
+	// the changes made in this suggestion. This can be used along with
+	// the
+	// paragraph_suggestion_state
+	// to see which fields have changed and their new values.
+	ParagraphStyle *ParagraphStyle `json:"paragraphStyle,omitempty"`
+
+	// ParagraphStyleSuggestionState: A mask that indicates which of the
+	// fields on the base ParagraphStyle have been changed in this
+	// suggestion.
+	ParagraphStyleSuggestionState *ParagraphStyleSuggestionState `json:"paragraphStyleSuggestionState,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ParagraphStyle") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ParagraphStyle") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SuggestedParagraphStyle) MarshalJSON() ([]byte, error) {
+	type NoMethod SuggestedParagraphStyle
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// SuggestedPositionedObjectProperties: A suggested change to
+// PositionedObjectProperties.
+type SuggestedPositionedObjectProperties struct {
+	// PositionedObjectProperties: A PositionedObjectProperties that only
+	// includes the
+	// changes made in this suggestion. This can be used along with
+	// the
+	// positioned_object_properties_suggestion_state
+	// to see which fields have changed and their new values.
+	PositionedObjectProperties *PositionedObjectProperties `json:"positionedObjectProperties,omitempty"`
+
+	// PositionedObjectPropertiesSuggestionState: A mask that indicates
+	// which of the fields on the base
+	// PositionedObjectProperties have been changed in this
+	// suggestion.
+	PositionedObjectPropertiesSuggestionState *PositionedObjectPropertiesSuggestionState `json:"positionedObjectPropertiesSuggestionState,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "PositionedObjectProperties") to unconditionally include in API
+	// requests. By default, fields with empty values are omitted from API
+	// requests. However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g.
+	// "PositionedObjectProperties") to include in API requests with the
+	// JSON null value. By default, fields with empty values are omitted
+	// from API requests. However, any field with an empty value appearing
+	// in NullFields will be sent to the server as null. It is an error if a
+	// field in this list has a non-empty value. This may be used to include
+	// null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SuggestedPositionedObjectProperties) MarshalJSON() ([]byte, error) {
+	type NoMethod SuggestedPositionedObjectProperties
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// SuggestedTableCellStyle: A suggested change to a TableCellStyle.
+type SuggestedTableCellStyle struct {
+	// TableCellStyle: A TableCellStyle that only includes
+	// the changes made in this suggestion. This can be used along with
+	// the
+	// table_cell_style_suggestion_state
+	// to see which fields have changed and their new values.
+	TableCellStyle *TableCellStyle `json:"tableCellStyle,omitempty"`
+
+	// TableCellStyleSuggestionState: A mask that indicates which of the
+	// fields on the base TableCellStyle have been changed in this
+	// suggestion.
+	TableCellStyleSuggestionState *TableCellStyleSuggestionState `json:"tableCellStyleSuggestionState,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "TableCellStyle") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "TableCellStyle") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SuggestedTableCellStyle) MarshalJSON() ([]byte, error) {
+	type NoMethod SuggestedTableCellStyle
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// SuggestedTableRowStyle: A suggested change to a
+// TableRowStyle.
+type SuggestedTableRowStyle struct {
+	// TableRowStyle: A TableRowStyle that only includes
+	// the changes made in this suggestion. This can be used along with
+	// the
+	// table_row_style_suggestion_state
+	// to see which fields have changed and their new values.
+	TableRowStyle *TableRowStyle `json:"tableRowStyle,omitempty"`
+
+	// TableRowStyleSuggestionState: A mask that indicates which of the
+	// fields on the base TableRowStyle have been changed in this
+	// suggestion.
+	TableRowStyleSuggestionState *TableRowStyleSuggestionState `json:"tableRowStyleSuggestionState,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "TableRowStyle") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "TableRowStyle") to include
+	// in API requests with the JSON null value. By default, fields with
+	// empty values are omitted from API requests. However, any field with
+	// an empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SuggestedTableRowStyle) MarshalJSON() ([]byte, error) {
+	type NoMethod SuggestedTableRowStyle
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// SuggestedTextStyle: A suggested change to a TextStyle.
+type SuggestedTextStyle struct {
+	// TextStyle: A TextStyle that only includes
+	// the changes made in this suggestion. This can be used along with
+	// the
+	// text_style_suggestion_state
+	// to see which fields have changed and their new values.
+	TextStyle *TextStyle `json:"textStyle,omitempty"`
+
+	// TextStyleSuggestionState: A mask that indicates which of the fields
+	// on the base TextStyle have been changed in this suggestion.
+	TextStyleSuggestionState *TextStyleSuggestionState `json:"textStyleSuggestionState,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "TextStyle") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "TextStyle") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *SuggestedTextStyle) MarshalJSON() ([]byte, error) {
+	type NoMethod SuggestedTextStyle
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// TabStop: A tab stop within a paragraph.
+type TabStop struct {
+	// Alignment: The alignment of this tab stop. If unset, the value
+	// defaults to START.
+	//
+	// Possible values:
+	//   "TAB_STOP_ALIGNMENT_UNSPECIFIED" - The tab stop alignment is
+	// unspecified.
+	//   "START" - The tab stop is aligned to the start of the line. This is
+	// the default.
+	//   "CENTER" - The tab stop is aligned to the center of the line.
+	//   "END" - The tab stop is aligned to the end of the line.
+	Alignment string `json:"alignment,omitempty"`
+
+	// Offset: The offset between this tab stop and the start margin.
+	Offset *Dimension `json:"offset,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Alignment") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Alignment") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *TabStop) MarshalJSON() ([]byte, error) {
+	type NoMethod TabStop
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// Table: A StructuralElement representing a
+// table.
+type Table struct {
+	// Columns: Number of columns in the table.
+	//
+	// It is possible for a table to be non-rectangular, so some rows may
+	// have a
+	// different number of cells.
+	Columns int64 `json:"columns,omitempty"`
+
+	// Rows: Number of rows in the table.
+	Rows int64 `json:"rows,omitempty"`
+
+	// SuggestedDeletionIds: The suggested deletion IDs. If empty, then
+	// there are no suggested deletions
+	// of this content.
+	SuggestedDeletionIds []string `json:"suggestedDeletionIds,omitempty"`
+
+	// SuggestedInsertionIds: The suggested insertion IDs. A Table may
+	// have
+	// multiple insertion IDs if it is a nested suggested change. If empty,
+	// then
+	// this is not a suggested insertion.
+	SuggestedInsertionIds []string `json:"suggestedInsertionIds,omitempty"`
+
+	// TableRows: The contents and style of each row.
+	TableRows []*TableRow `json:"tableRows,omitempty"`
+
+	// TableStyle: The style of the table.
+	TableStyle *TableStyle `json:"tableStyle,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Columns") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Columns") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *Table) MarshalJSON() ([]byte, error) {
+	type NoMethod Table
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// TableCell: The contents and style of a cell in a Table.
+type TableCell struct {
+	// Content: The content of the cell.
+	Content []*StructuralElement `json:"content,omitempty"`
+
+	// EndIndex: The zero-based end index of this cell, exclusive, in
+	// Unicode code units of
+	// the UTF-16 encoding.
+	//
+	// Unicode code units of the UTF-16 encoding means that surrogate
+	// pairs
+	// consume two indices. For example, the "GRINNING FACE" emoji would
+	// be
+	// represented as "\uD83D\uDE00" and would consume two indices.
+	EndIndex int64 `json:"endIndex,omitempty"`
+
+	// StartIndex: The zero-based start index of this cell, in Unicode code
+	// units of the
+	// UTF-16 encoding.
+	//
+	// Unicode code units of the UTF-16 encoding means that surrogate
+	// pairs
+	// consume two indices. For example, the "GRINNING FACE" emoji would
+	// be
+	// represented as "\uD83D\uDE00" and would consume two indices.
+	StartIndex int64 `json:"startIndex,omitempty"`
+
+	// SuggestedDeletionIds: The suggested deletion IDs. If empty, then
+	// there are no suggested deletions
+	// of this content.
+	SuggestedDeletionIds []string `json:"suggestedDeletionIds,omitempty"`
+
+	// SuggestedInsertionIds: The suggested insertion IDs. A TableCell
+	// may have multiple insertion IDs if it is a nested suggested change.
+	// If
+	// empty, then this is not a suggested insertion.
+	SuggestedInsertionIds []string `json:"suggestedInsertionIds,omitempty"`
+
+	// SuggestedTableCellStyleChanges: The suggested changes to the table
+	// cell style, keyed by suggestion ID.
+	SuggestedTableCellStyleChanges map[string]SuggestedTableCellStyle `json:"suggestedTableCellStyleChanges,omitempty"`
+
+	// TableCellStyle: The style of the cell.
+	TableCellStyle *TableCellStyle `json:"tableCellStyle,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Content") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Content") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *TableCell) MarshalJSON() ([]byte, error) {
+	type NoMethod TableCell
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// TableCellBorder: A border around a table cell.
+type TableCellBorder struct {
+	// Color: The color of the border.
+	Color *OptionalColor `json:"color,omitempty"`
+
+	// DashStyle: The dash style of the border.
+	//
+	// Possible values:
+	//   "DASH_STYLE_UNSPECIFIED" - Unspecified dash style.
+	//   "SOLID" - Solid line. Corresponds to ECMA-376 ST_PresetLineDashVal
+	// value 'solid'.
+	// This is the default dash style.
+	//   "DOT" - Dotted line. Corresponds to ECMA-376 ST_PresetLineDashVal
+	// value 'dot'.
+	//   "DASH" - Dashed line. Corresponds to ECMA-376 ST_PresetLineDashVal
+	// value 'dash'.
+	DashStyle string `json:"dashStyle,omitempty"`
+
+	// Width: The width of the border.
+	Width *Dimension `json:"width,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Color") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Color") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *TableCellBorder) MarshalJSON() ([]byte, error) {
+	type NoMethod TableCellBorder
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// TableCellLocation: Location of a single cell within a table.
+type TableCellLocation struct {
+	// ColumnIndex: The zero-based column index. For example, the second
+	// column in the table
+	// has a column index of 1.
+	ColumnIndex int64 `json:"columnIndex,omitempty"`
+
+	// RowIndex: The zero-based row index. For example, the second row in
+	// the table has a
+	// row index of 1.
+	RowIndex int64 `json:"rowIndex,omitempty"`
+
+	// TableStartLocation: The location where the table starts in the
+	// document.
+	TableStartLocation *Location `json:"tableStartLocation,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ColumnIndex") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ColumnIndex") to include
+	// in API requests with the JSON null value. By default, fields with
+	// empty values are omitted from API requests. However, any field with
+	// an empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *TableCellLocation) MarshalJSON() ([]byte, error) {
+	type NoMethod TableCellLocation
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// TableCellStyle: The style of a TableCell.
+//
+// Inherited table cell styles are represented as unset fields in this
+// message.
+// A table cell style can inherit from the table's style.
+type TableCellStyle struct {
+	// BackgroundColor: The background color of the cell.
+	BackgroundColor *OptionalColor `json:"backgroundColor,omitempty"`
+
+	// BorderBottom: The bottom border of the cell.
+	BorderBottom *TableCellBorder `json:"borderBottom,omitempty"`
+
+	// BorderLeft: The left border of the cell.
+	BorderLeft *TableCellBorder `json:"borderLeft,omitempty"`
+
+	// BorderRight: The right border of the cell.
+	BorderRight *TableCellBorder `json:"borderRight,omitempty"`
+
+	// BorderTop: The top border of the cell.
+	BorderTop *TableCellBorder `json:"borderTop,omitempty"`
+
+	// ColumnSpan: The column span of the cell. This property is read-only.
+	ColumnSpan int64 `json:"columnSpan,omitempty"`
+
+	// ContentAlignment: The alignment of the content in the table cell. The
+	// default alignment
+	// matches the alignment for newly created table cells in the Docs
+	// editor.
+	//
+	// Possible values:
+	//   "CONTENT_ALIGNMENT_UNSPECIFIED" - An unspecified content alignment.
+	// The content alignment is inherited from
+	// the parent if one exists.
+	//   "CONTENT_ALIGNMENT_UNSUPPORTED" - An unsupported content alignment.
+	//   "TOP" - An alignment that aligns the content to the top of the
+	// content holder.
+	// Corresponds to ECMA-376 ST_TextAnchoringType 't'.
+	//   "MIDDLE" - An alignment that aligns the content to the middle of
+	// the content holder.
+	// Corresponds to ECMA-376 ST_TextAnchoringType 'ctr'.
+	//   "BOTTOM" - An alignment that aligns the content to the bottom of
+	// the content holder.
+	// Corresponds to ECMA-376 ST_TextAnchoringType 'b'.
+	ContentAlignment string `json:"contentAlignment,omitempty"`
+
+	// PaddingBottom: The bottom padding of the cell.
+	PaddingBottom *Dimension `json:"paddingBottom,omitempty"`
+
+	// PaddingLeft: The left padding of the cell.
+	PaddingLeft *Dimension `json:"paddingLeft,omitempty"`
+
+	// PaddingRight: The right padding of the cell.
+	PaddingRight *Dimension `json:"paddingRight,omitempty"`
+
+	// PaddingTop: The top padding of the cell.
+	PaddingTop *Dimension `json:"paddingTop,omitempty"`
+
+	// RowSpan: The row span of the cell. This property is read-only.
+	RowSpan int64 `json:"rowSpan,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "BackgroundColor") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "BackgroundColor") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *TableCellStyle) MarshalJSON() ([]byte, error) {
+	type NoMethod TableCellStyle
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// TableCellStyleSuggestionState: A mask that indicates which of the
+// fields on the base TableCellStyle have been changed in this
+// suggestion.
+// For any field set to true, there is a new suggested value.
+type TableCellStyleSuggestionState struct {
+	// BackgroundColorSuggested: Indicates if there was a suggested change
+	// to background_color.
+	BackgroundColorSuggested bool `json:"backgroundColorSuggested,omitempty"`
+
+	// BorderBottomSuggested: Indicates if there was a suggested change to
+	// border_bottom.
+	BorderBottomSuggested bool `json:"borderBottomSuggested,omitempty"`
+
+	// BorderLeftSuggested: Indicates if there was a suggested change to
+	// border_left.
+	BorderLeftSuggested bool `json:"borderLeftSuggested,omitempty"`
+
+	// BorderRightSuggested: Indicates if there was a suggested change to
+	// border_right.
+	BorderRightSuggested bool `json:"borderRightSuggested,omitempty"`
+
+	// BorderTopSuggested: Indicates if there was a suggested change to
+	// border_top.
+	BorderTopSuggested bool `json:"borderTopSuggested,omitempty"`
+
+	// ColumnSpanSuggested: Indicates if there was a suggested change to
+	// column_span.
+	ColumnSpanSuggested bool `json:"columnSpanSuggested,omitempty"`
+
+	// ContentAlignmentSuggested: Indicates if there was a suggested change
+	// to content_alignment.
+	ContentAlignmentSuggested bool `json:"contentAlignmentSuggested,omitempty"`
+
+	// PaddingBottomSuggested: Indicates if there was a suggested change to
+	// padding_bottom.
+	PaddingBottomSuggested bool `json:"paddingBottomSuggested,omitempty"`
+
+	// PaddingLeftSuggested: Indicates if there was a suggested change to
+	// padding_left.
+	PaddingLeftSuggested bool `json:"paddingLeftSuggested,omitempty"`
+
+	// PaddingRightSuggested: Indicates if there was a suggested change to
+	// padding_right.
+	PaddingRightSuggested bool `json:"paddingRightSuggested,omitempty"`
+
+	// PaddingTopSuggested: Indicates if there was a suggested change to
+	// padding_top.
+	PaddingTopSuggested bool `json:"paddingTopSuggested,omitempty"`
+
+	// RowSpanSuggested: Indicates if there was a suggested change to
+	// row_span.
+	RowSpanSuggested bool `json:"rowSpanSuggested,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "BackgroundColorSuggested") to unconditionally include in API
+	// requests. By default, fields with empty values are omitted from API
+	// requests. However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "BackgroundColorSuggested")
+	// to include in API requests with the JSON null value. By default,
+	// fields with empty values are omitted from API requests. However, any
+	// field with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *TableCellStyleSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod TableCellStyleSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// TableColumnProperties: The properties of a column in a table.
+type TableColumnProperties struct {
+	// Width: The width of the column. Set when the column's `width_type`
+	// is
+	// FIXED_WIDTH.
+	Width *Dimension `json:"width,omitempty"`
+
+	// WidthType: The width type of the column.
+	//
+	// Possible values:
+	//   "WIDTH_TYPE_UNSPECIFIED" - The column width type is unspecified.
+	//   "EVENLY_DISTRIBUTED" - The column width is evenly distributed among
+	// the other evenly distrubted
+	// columns.
+	//
+	// The width of the column is automatically determined and will
+	// have an equal portion of the width remaining for the table
+	// after
+	// accounting for all columns with specified widths.
+	//   "FIXED_WIDTH" - A fixed column width. The
+	// width property
+	// contains the column's width.
+	WidthType string `json:"widthType,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Width") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Width") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *TableColumnProperties) MarshalJSON() ([]byte, error) {
+	type NoMethod TableColumnProperties
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// TableOfContents: A StructuralElement representing
+// a table of contents.
+type TableOfContents struct {
+	// Content: The content of the table of contents.
+	Content []*StructuralElement `json:"content,omitempty"`
+
+	// SuggestedDeletionIds: The suggested deletion IDs. If empty, then
+	// there are no suggested deletions
+	// of this content.
+	SuggestedDeletionIds []string `json:"suggestedDeletionIds,omitempty"`
+
+	// SuggestedInsertionIds: The suggested insertion IDs. A TableOfContents
+	// may have multiple insertion IDs if it
+	// is a nested suggested change. If empty, then this is not a
+	// suggested
+	// insertion.
+	SuggestedInsertionIds []string `json:"suggestedInsertionIds,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Content") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Content") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *TableOfContents) MarshalJSON() ([]byte, error) {
+	type NoMethod TableOfContents
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// TableRow: The contents and style of a row in a Table.
+type TableRow struct {
+	// EndIndex: The zero-based end index of this row, exclusive, in Unicode
+	// code units of
+	// the UTF-16 encoding.
+	//
+	// Unicode code units of the UTF-16 encoding means that surrogate
+	// pairs
+	// consume two indices. For example, the "GRINNING FACE" emoji would
+	// be
+	// represented as "\uD83D\uDE00" and would consume two indices.
+	EndIndex int64 `json:"endIndex,omitempty"`
+
+	// StartIndex: The zero-based start index of this row, in Unicode code
+	// units of the UTF-16
+	// encoding.
+	//
+	// Unicode code units of the UTF-16 encoding means that surrogate
+	// pairs
+	// consume two indices. For example, the "GRINNING FACE" emoji would
+	// be
+	// represented as "\uD83D\uDE00" and would consume two indices.
+	StartIndex int64 `json:"startIndex,omitempty"`
+
+	// SuggestedDeletionIds: The suggested deletion IDs. If empty, then
+	// there are no suggested deletions
+	// of this content.
+	SuggestedDeletionIds []string `json:"suggestedDeletionIds,omitempty"`
+
+	// SuggestedInsertionIds: The suggested insertion IDs. A TableRow
+	// may have multiple insertion IDs if it is a nested suggested change.
+	// If
+	// empty, then this is not a suggested insertion.
+	SuggestedInsertionIds []string `json:"suggestedInsertionIds,omitempty"`
+
+	// SuggestedTableRowStyleChanges: The suggested style changes to this
+	// row, keyed by suggestion ID.
+	SuggestedTableRowStyleChanges map[string]SuggestedTableRowStyle `json:"suggestedTableRowStyleChanges,omitempty"`
+
+	// TableCells: The contents and style of each cell in this row.
+	//
+	// It is possible for a table to be non-rectangular, so some rows may
+	// have a
+	// different number of cells than other rows in the same table.
+	TableCells []*TableCell `json:"tableCells,omitempty"`
+
+	// TableRowStyle: The style of the table row.
+	TableRowStyle *TableRowStyle `json:"tableRowStyle,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "EndIndex") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "EndIndex") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *TableRow) MarshalJSON() ([]byte, error) {
+	type NoMethod TableRow
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// TableRowStyle: Styles that apply to a table row.
+type TableRowStyle struct {
+	// MinRowHeight: The minimum height of the row. The row will be rendered
+	// in the Docs editor
+	// at a height equal to or greater than this value in order to show all
+	// the
+	// content in the row's cells.
+	MinRowHeight *Dimension `json:"minRowHeight,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "MinRowHeight") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "MinRowHeight") to include
+	// in API requests with the JSON null value. By default, fields with
+	// empty values are omitted from API requests. However, any field with
+	// an empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *TableRowStyle) MarshalJSON() ([]byte, error) {
+	type NoMethod TableRowStyle
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// TableRowStyleSuggestionState: A mask that indicates which of the
+// fields on the base TableRowStyle have been changed in this
+// suggestion.
+// For any field set to true, there is a new suggested value.
+type TableRowStyleSuggestionState struct {
+	// MinRowHeightSuggested: Indicates if there was a suggested change to
+	// min_row_height.
+	MinRowHeightSuggested bool `json:"minRowHeightSuggested,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "MinRowHeightSuggested") to unconditionally include in API requests.
+	// By default, fields with empty values are omitted from API requests.
+	// However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "MinRowHeightSuggested") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *TableRowStyleSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod TableRowStyleSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// TableStyle: Styles that apply to a table.
+type TableStyle struct {
+	// TableColumnProperties: The properties of each column.
+	//
+	// Note that in Docs, tables contain rows and rows contain cells,
+	// similar to
+	// HTML. So the properties for a row can be found on the
+	// row's
+	// table_row_style.
+	TableColumnProperties []*TableColumnProperties `json:"tableColumnProperties,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "TableColumnProperties") to unconditionally include in API requests.
+	// By default, fields with empty values are omitted from API requests.
+	// However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "TableColumnProperties") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *TableStyle) MarshalJSON() ([]byte, error) {
+	type NoMethod TableStyle
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// TextRun: A ParagraphElement that represents a
+// run of text that all has the same styling.
+type TextRun struct {
+	// Content: The text of this run.
+	//
+	// Any non-text elements in the run are replaced with the Unicode
+	// character
+	// U+E907.
+	Content string `json:"content,omitempty"`
+
+	// SuggestedDeletionIds: The suggested deletion IDs. If empty, then
+	// there are no suggested deletions
+	// of this content.
+	SuggestedDeletionIds []string `json:"suggestedDeletionIds,omitempty"`
+
+	// SuggestedInsertionIds: The suggested insertion IDs. A TextRun
+	// may
+	// have multiple insertion IDs if it is a nested suggested change. If
+	// empty,
+	// then this is not a suggested insertion.
+	SuggestedInsertionIds []string `json:"suggestedInsertionIds,omitempty"`
+
+	// SuggestedTextStyleChanges: The suggested text style changes to this
+	// run, keyed by suggestion ID.
+	SuggestedTextStyleChanges map[string]SuggestedTextStyle `json:"suggestedTextStyleChanges,omitempty"`
+
+	// TextStyle: The text style of this run.
+	TextStyle *TextStyle `json:"textStyle,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Content") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Content") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *TextRun) MarshalJSON() ([]byte, error) {
+	type NoMethod TextRun
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// TextStyle: Represents the styling that can be applied to
+// text.
+//
+// Inherited text styles are represented as unset fields in this
+// message. A
+// text style's parent depends on where the text style is defined:
+//
+//   * The TextStyle of text in a Paragraph
+//     inherits from the paragraph's corresponding named style type.
+//   * The TextStyle on a named style
+//     inherits from the normal text named style.
+//   * The TextStyle of the normal text named style inherits
+//     from the default text style in the Docs editor.
+//   * The TextStyle on a Paragraph element
+//     that is contained in a table may inherit its text style from the
+// table
+//     style.
+//
+// If the text style does not inherit from a parent, unsetting fields
+// will
+// revert the style to a value matching the defaults in the Docs editor.
+type TextStyle struct {
+	// BackgroundColor: The background color of the text. If set, the color
+	// is either an RGB color
+	// or transparent, depending on the `color` field.
+	BackgroundColor *OptionalColor `json:"backgroundColor,omitempty"`
+
+	// BaselineOffset: The text's vertical offset from its normal
+	// position.
+	//
+	// Text with `SUPERSCRIPT` or `SUBSCRIPT` baseline offsets is
+	// automatically
+	// rendered in a smaller font size, computed based on the `font_size`
+	// field.
+	// The `font_size` itself is not affected by changes in this field.
+	//
+	// Possible values:
+	//   "BASELINE_OFFSET_UNSPECIFIED" - The text's baseline offset is
+	// inherited from the parent.
+	//   "NONE" - The text is not vertically offset.
+	//   "SUPERSCRIPT" - The text is vertically offset upwards
+	// (superscript).
+	//   "SUBSCRIPT" - The text is vertically offset downwards (subscript).
+	BaselineOffset string `json:"baselineOffset,omitempty"`
+
+	// Bold: Whether or not the text is rendered as bold.
+	Bold bool `json:"bold,omitempty"`
+
+	// FontSize: The size of the text's font.
+	FontSize *Dimension `json:"fontSize,omitempty"`
+
+	// ForegroundColor: The foreground color of the text. If set, the color
+	// is either an RGB color
+	// or transparent, depending on the `color` field.
+	ForegroundColor *OptionalColor `json:"foregroundColor,omitempty"`
+
+	// Italic: Whether or not the text is italicized.
+	Italic bool `json:"italic,omitempty"`
+
+	// Link: The hyperlink destination of the text. If unset, there is no
+	// link. Links
+	// are not inherited from parent text.
+	//
+	// Changing the link in an update request causes some other changes to
+	// the
+	// text style of the range:
+	//
+	// * When setting a link, the text foreground color will be updated to
+	// the
+	//   default link color and the text will be underlined. If these fields
+	// are
+	//   modified in the same request, those values will be used instead of
+	// the
+	//   link defaults.
+	// * Setting a link on a text range that overlaps with an existing link
+	// will
+	//   also update the existing link to point to the new URL.
+	// * Links are not settable on newline characters. As a result, setting
+	// a link
+	//   on a text range that crosses a paragraph boundary, such as
+	// "ABC\n123",
+	//   will separate the newline character(s) into their own text runs.
+	// The
+	//   link will be applied separately to the runs before and after the
+	// newline.
+	// * Removing a link will update the text style of the range to match
+	// the
+	//   style of the preceding text (or the default text styles if the
+	// preceding
+	//   text is another link) unless different styles are being set in the
+	// same
+	//   request.
+	Link *Link `json:"link,omitempty"`
+
+	// SmallCaps: Whether or not the text is in small capital letters.
+	SmallCaps bool `json:"smallCaps,omitempty"`
+
+	// Strikethrough: Whether or not the text is struck through.
+	Strikethrough bool `json:"strikethrough,omitempty"`
+
+	// Underline: Whether or not the text is underlined.
+	Underline bool `json:"underline,omitempty"`
+
+	// WeightedFontFamily: The font family and rendered weight of the
+	// text.
+	//
+	// If an update request specifies values for both `weighted_font_family`
+	// and
+	// `bold`, the `weighted_font_family` is applied first, then `bold`.
+	//
+	// If `weighted_font_family#weight` is not set, it defaults to
+	// `400`.
+	//
+	// If `weighted_font_family` is set, then
+	// `weighted_font_family#font_family`
+	// must also be set with a non-empty value. Otherwise, a 400 bad request
+	// error
+	// is returned.
+	WeightedFontFamily *WeightedFontFamily `json:"weightedFontFamily,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "BackgroundColor") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "BackgroundColor") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *TextStyle) MarshalJSON() ([]byte, error) {
+	type NoMethod TextStyle
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// TextStyleSuggestionState: A mask that indicates which of the fields
+// on the base TextStyle have been changed in this suggestion.
+// For any field set to true, there is a new suggested value.
+type TextStyleSuggestionState struct {
+	// BackgroundColorSuggested: Indicates if there was a suggested change
+	// to background_color.
+	BackgroundColorSuggested bool `json:"backgroundColorSuggested,omitempty"`
+
+	// BaselineOffsetSuggested: Indicates if there was a suggested change to
+	// baseline_offset.
+	BaselineOffsetSuggested bool `json:"baselineOffsetSuggested,omitempty"`
+
+	// BoldSuggested: Indicates if there was a suggested change to bold.
+	BoldSuggested bool `json:"boldSuggested,omitempty"`
+
+	// FontSizeSuggested: Indicates if there was a suggested change to
+	// font_size.
+	FontSizeSuggested bool `json:"fontSizeSuggested,omitempty"`
+
+	// ForegroundColorSuggested: Indicates if there was a suggested change
+	// to foreground_color.
+	ForegroundColorSuggested bool `json:"foregroundColorSuggested,omitempty"`
+
+	// ItalicSuggested: Indicates if there was a suggested change to italic.
+	ItalicSuggested bool `json:"italicSuggested,omitempty"`
+
+	// LinkSuggested: Indicates if there was a suggested change to link.
+	LinkSuggested bool `json:"linkSuggested,omitempty"`
+
+	// SmallCapsSuggested: Indicates if there was a suggested change to
+	// small_caps.
+	SmallCapsSuggested bool `json:"smallCapsSuggested,omitempty"`
+
+	// StrikethroughSuggested: Indicates if there was a suggested change to
+	// strikethrough.
+	StrikethroughSuggested bool `json:"strikethroughSuggested,omitempty"`
+
+	// UnderlineSuggested: Indicates if there was a suggested change to
+	// underline.
+	UnderlineSuggested bool `json:"underlineSuggested,omitempty"`
+
+	// WeightedFontFamilySuggested: Indicates if there was a suggested
+	// change to weighted_font_family.
+	WeightedFontFamilySuggested bool `json:"weightedFontFamilySuggested,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g.
+	// "BackgroundColorSuggested") to unconditionally include in API
+	// requests. By default, fields with empty values are omitted from API
+	// requests. However, any non-pointer, non-interface field appearing in
+	// ForceSendFields will be sent to the server regardless of whether the
+	// field is empty or not. This may be used to include empty fields in
+	// Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "BackgroundColorSuggested")
+	// to include in API requests with the JSON null value. By default,
+	// fields with empty values are omitted from API requests. However, any
+	// field with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *TextStyleSuggestionState) MarshalJSON() ([]byte, error) {
+	type NoMethod TextStyleSuggestionState
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// UpdateParagraphStyleRequest: Update the styling of all paragraphs
+// that overlap with the given range.
+type UpdateParagraphStyleRequest struct {
+	// Fields: The fields that should be updated.
+	//
+	// At least one field must be specified. The root `paragraph_style` is
+	// implied
+	// and should not be specified.
+	//
+	// For example, to update the paragraph style's alignment property,
+	// set
+	// `fields` to "alignment".
+	//
+	// To reset a property to its default value, include its field name in
+	// the
+	// field mask but leave the field itself unset.
+	Fields string `json:"fields,omitempty"`
+
+	// ParagraphStyle: The styles to set on the paragraphs.
+	//
+	// Certain paragraph style changes may cause other changes in order to
+	// mirror
+	// the behavior of the Docs editor. See the documentation of
+	// ParagraphStyle for more information.
+	ParagraphStyle *ParagraphStyle `json:"paragraphStyle,omitempty"`
+
+	// Range: The range overlapping the paragraphs to style.
+	Range *Range `json:"range,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Fields") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Fields") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *UpdateParagraphStyleRequest) MarshalJSON() ([]byte, error) {
+	type NoMethod UpdateParagraphStyleRequest
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// UpdateTextStyleRequest: Update the styling of text.
+type UpdateTextStyleRequest struct {
+	// Fields: The fields that should be updated.
+	//
+	// At least one field must be specified. The root `text_style` is
+	// implied and
+	// should not be specified. A single "*" can be used as short-hand
+	// for
+	// listing every field.
+	//
+	// For example, to update the text style to bold, set `fields` to
+	// "bold".
+	//
+	// To reset a property to its default value, include its field name in
+	// the
+	// field mask but leave the field itself unset.
+	Fields string `json:"fields,omitempty"`
+
+	// Range: The range of text to style.
+	//
+	// The range may be extended to include adjacent newlines.
+	//
+	// If the range fully contains a paragraph belonging to a list,
+	// the
+	// paragraph's bullet is also updated with the matching text style.
+	Range *Range `json:"range,omitempty"`
+
+	// TextStyle: The styles to set on the text.
+	//
+	// If the value for a particular style matches that of the parent, that
+	// style
+	// will be set to inherit.
+	//
+	// Certain text style changes may cause other changes in order to to
+	// mirror
+	// the behavior of the Docs editor. See the documentation of
+	// TextStyle for more information.
+	TextStyle *TextStyle `json:"textStyle,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Fields") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Fields") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *UpdateTextStyleRequest) MarshalJSON() ([]byte, error) {
+	type NoMethod UpdateTextStyleRequest
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// WeightedFontFamily: Represents a font family and weight of text.
+type WeightedFontFamily struct {
+	// FontFamily: The font family of the text.
+	//
+	// The font family can be any font from the Font menu in Docs or
+	// from
+	// [Google Fonts] (https://fonts.google.com/). If the font name
+	// is
+	// unrecognized, the text is rendered in `Arial`.
+	FontFamily string `json:"fontFamily,omitempty"`
+
+	// Weight: The weight of the font. This field can have any value that is
+	// a multiple of
+	// `100` between `100` and `900`, inclusive. This range corresponds to
+	// the
+	// numerical values described in the CSS 2.1 Specification,
+	// [section 15.6](https://www.w3.org/TR/CSS21/fonts.html#font-boldness),
+	// with
+	// non-numerical values disallowed.
+	//
+	// The default value is `400` ("normal").
+	//
+	// The font weight makes up just one component of the rendered font
+	// weight.
+	// The rendered weight is determined by a combination of the `weight`
+	// and the
+	// text style's resolved `bold` value, after accounting for
+	// inheritance:
+	//
+	// * If the text is bold and the weight is less than `400`, the
+	// rendered
+	//   weight is 400.
+	// * If the text is bold and the weight is greater than or equal to
+	// `400` but
+	//   is less than `700`, the rendered weight is `700`.
+	// * If the weight is greater than or equal to `700`, the rendered
+	// weight is
+	//   equal to the weight.
+	// * If the text is not bold, the rendered weight is equal to the
+	// weight.
+	Weight int64 `json:"weight,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "FontFamily") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "FontFamily") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *WeightedFontFamily) MarshalJSON() ([]byte, error) {
+	type NoMethod WeightedFontFamily
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// WriteControl: Provides control over how write requests are executed.
+type WriteControl struct {
+	// RequiredRevisionId: The ID of the revision of the document that the
+	// write request will be
+	// applied to. If this is not the latest revision of the document,
+	// the
+	// request will not be processed and will return a 400 bad request
+	// error.
+	//
+	// When a required revision ID is returned in a response, it indicates
+	// the
+	// revision ID of the document after the request was applied.
+	RequiredRevisionId string `json:"requiredRevisionId,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "RequiredRevisionId")
+	// to unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "RequiredRevisionId") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *WriteControl) MarshalJSON() ([]byte, error) {
+	type NoMethod WriteControl
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
+// method id "docs.documents.batchUpdate":
+
+type DocumentsBatchUpdateCall struct {
+	s                          *Service
+	documentId                 string
+	batchupdatedocumentrequest *BatchUpdateDocumentRequest
+	urlParams_                 gensupport.URLParams
+	ctx_                       context.Context
+	header_                    http.Header
+}
+
+// BatchUpdate: Applies one or more updates to the document.
+//
+// Each request is validated before
+// being applied. If any request is not valid, then the entire request
+// will
+// fail and nothing will be applied.
+//
+// Some requests have replies to
+// give you some information about how they are applied. Other requests
+// do
+// not need to return information; these each return an empty reply.
+// The order of replies matches that of the requests.
+//
+// For example, suppose you call batchUpdate with four updates, and only
+// the
+// third one returns information. The response would have two empty
+// replies,
+// the reply to the third request, and another empty reply, in that
+// order.
+//
+// Because other users may be editing the document, the document
+// might not exactly reflect your changes: your changes may
+// be altered with respect to collaborator changes. If there are
+// no
+// collaborators, the document should reflect your changes. In any
+// case,
+// the updates in your request are guaranteed to be applied
+// together
+// atomically.
+func (r *DocumentsService) BatchUpdate(documentId string, batchupdatedocumentrequest *BatchUpdateDocumentRequest) *DocumentsBatchUpdateCall {
+	c := &DocumentsBatchUpdateCall{s: r.s, urlParams_: make(gensupport.URLParams)}
+	c.documentId = documentId
+	c.batchupdatedocumentrequest = batchupdatedocumentrequest
+	return c
+}
+
+// Fields allows partial responses to be retrieved. See
+// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
+// for more information.
+func (c *DocumentsBatchUpdateCall) Fields(s ...googleapi.Field) *DocumentsBatchUpdateCall {
+	c.urlParams_.Set("fields", googleapi.CombineFields(s))
+	return c
+}
+
+// Context sets the context to be used in this call's Do method. Any
+// pending HTTP request will be aborted if the provided context is
+// canceled.
+func (c *DocumentsBatchUpdateCall) Context(ctx context.Context) *DocumentsBatchUpdateCall {
+	c.ctx_ = ctx
+	return c
+}
+
+// Header returns an http.Header that can be modified by the caller to
+// add HTTP headers to the request.
+func (c *DocumentsBatchUpdateCall) Header() http.Header {
+	if c.header_ == nil {
+		c.header_ = make(http.Header)
+	}
+	return c.header_
+}
+
+func (c *DocumentsBatchUpdateCall) doRequest(alt string) (*http.Response, error) {
+	reqHeaders := make(http.Header)
+	for k, v := range c.header_ {
+		reqHeaders[k] = v
+	}
+	reqHeaders.Set("User-Agent", c.s.userAgent())
+	var body io.Reader = nil
+	body, err := googleapi.WithoutDataWrapper.JSONReader(c.batchupdatedocumentrequest)
+	if err != nil {
+		return nil, err
+	}
+	reqHeaders.Set("Content-Type", "application/json")
+	c.urlParams_.Set("alt", alt)
+	c.urlParams_.Set("prettyPrint", "false")
+	urls := googleapi.ResolveRelative(c.s.BasePath, "v1/documents/{documentId}:batchUpdate")
+	urls += "?" + c.urlParams_.Encode()
+	req, err := http.NewRequest("POST", urls, body)
+	if err != nil {
+		return nil, err
+	}
+	req.Header = reqHeaders
+	googleapi.Expand(req.URL, map[string]string{
+		"documentId": c.documentId,
+	})
+	return gensupport.SendRequest(c.ctx_, c.s.client, req)
+}
+
+// Do executes the "docs.documents.batchUpdate" call.
+// Exactly one of *BatchUpdateDocumentResponse or error will be non-nil.
+// Any non-2xx status code is an error. Response headers are in either
+// *BatchUpdateDocumentResponse.ServerResponse.Header or (if a response
+// was returned at all) in error.(*googleapi.Error).Header. Use
+// googleapi.IsNotModified to check whether the returned error was
+// because http.StatusNotModified was returned.
+func (c *DocumentsBatchUpdateCall) Do(opts ...googleapi.CallOption) (*BatchUpdateDocumentResponse, error) {
+	gensupport.SetOptions(c.urlParams_, opts...)
+	res, err := c.doRequest("json")
+	if res != nil && res.StatusCode == http.StatusNotModified {
+		if res.Body != nil {
+			res.Body.Close()
+		}
+		return nil, &googleapi.Error{
+			Code:   res.StatusCode,
+			Header: res.Header,
+		}
+	}
+	if err != nil {
+		return nil, err
+	}
+	defer googleapi.CloseBody(res)
+	if err := googleapi.CheckResponse(res); err != nil {
+		return nil, err
+	}
+	ret := &BatchUpdateDocumentResponse{
+		ServerResponse: googleapi.ServerResponse{
+			Header:         res.Header,
+			HTTPStatusCode: res.StatusCode,
+		},
+	}
+	target := &ret
+	if err := gensupport.DecodeResponse(target, res); err != nil {
+		return nil, err
+	}
+	return ret, nil
+	// {
+	//   "description": "Applies one or more updates to the document.\n\nEach request is validated before\nbeing applied. If any request is not valid, then the entire request will\nfail and nothing will be applied.\n\nSome requests have replies to\ngive you some information about how they are applied. Other requests do\nnot need to return information; these each return an empty reply.\nThe order of replies matches that of the requests.\n\nFor example, suppose you call batchUpdate with four updates, and only the\nthird one returns information. The response would have two empty replies,\nthe reply to the third request, and another empty reply, in that order.\n\nBecause other users may be editing the document, the document\nmight not exactly reflect your changes: your changes may\nbe altered with respect to collaborator changes. If there are no\ncollaborators, the document should reflect your changes. In any case,\nthe updates in your request are guaranteed to be applied together\natomically.",
+	//   "flatPath": "v1/documents/{documentId}:batchUpdate",
+	//   "httpMethod": "POST",
+	//   "id": "docs.documents.batchUpdate",
+	//   "parameterOrder": [
+	//     "documentId"
+	//   ],
+	//   "parameters": {
+	//     "documentId": {
+	//       "description": "The ID of the document to update.",
+	//       "location": "path",
+	//       "required": true,
+	//       "type": "string"
+	//     }
+	//   },
+	//   "path": "v1/documents/{documentId}:batchUpdate",
+	//   "request": {
+	//     "$ref": "BatchUpdateDocumentRequest"
+	//   },
+	//   "response": {
+	//     "$ref": "BatchUpdateDocumentResponse"
+	//   },
+	//   "scopes": [
+	//     "https://www.googleapis.com/auth/documents",
+	//     "https://www.googleapis.com/auth/drive",
+	//     "https://www.googleapis.com/auth/drive.file"
+	//   ]
+	// }
+
+}
+
+// method id "docs.documents.create":
+
+type DocumentsCreateCall struct {
+	s          *Service
+	document   *Document
+	urlParams_ gensupport.URLParams
+	ctx_       context.Context
+	header_    http.Header
+}
+
+// Create: Creates a blank document using the title given in the
+// request. Other fields
+// in the request, including any provided content, are ignored.
+//
+// Returns the created document.
+func (r *DocumentsService) Create(document *Document) *DocumentsCreateCall {
+	c := &DocumentsCreateCall{s: r.s, urlParams_: make(gensupport.URLParams)}
+	c.document = document
+	return c
+}
+
+// Fields allows partial responses to be retrieved. See
+// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
+// for more information.
+func (c *DocumentsCreateCall) Fields(s ...googleapi.Field) *DocumentsCreateCall {
+	c.urlParams_.Set("fields", googleapi.CombineFields(s))
+	return c
+}
+
+// Context sets the context to be used in this call's Do method. Any
+// pending HTTP request will be aborted if the provided context is
+// canceled.
+func (c *DocumentsCreateCall) Context(ctx context.Context) *DocumentsCreateCall {
+	c.ctx_ = ctx
+	return c
+}
+
+// Header returns an http.Header that can be modified by the caller to
+// add HTTP headers to the request.
+func (c *DocumentsCreateCall) Header() http.Header {
+	if c.header_ == nil {
+		c.header_ = make(http.Header)
+	}
+	return c.header_
+}
+
+func (c *DocumentsCreateCall) doRequest(alt string) (*http.Response, error) {
+	reqHeaders := make(http.Header)
+	for k, v := range c.header_ {
+		reqHeaders[k] = v
+	}
+	reqHeaders.Set("User-Agent", c.s.userAgent())
+	var body io.Reader = nil
+	body, err := googleapi.WithoutDataWrapper.JSONReader(c.document)
+	if err != nil {
+		return nil, err
+	}
+	reqHeaders.Set("Content-Type", "application/json")
+	c.urlParams_.Set("alt", alt)
+	c.urlParams_.Set("prettyPrint", "false")
+	urls := googleapi.ResolveRelative(c.s.BasePath, "v1/documents")
+	urls += "?" + c.urlParams_.Encode()
+	req, err := http.NewRequest("POST", urls, body)
+	if err != nil {
+		return nil, err
+	}
+	req.Header = reqHeaders
+	return gensupport.SendRequest(c.ctx_, c.s.client, req)
+}
+
+// Do executes the "docs.documents.create" call.
+// Exactly one of *Document or error will be non-nil. Any non-2xx status
+// code is an error. Response headers are in either
+// *Document.ServerResponse.Header or (if a response was returned at
+// all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified
+// to check whether the returned error was because
+// http.StatusNotModified was returned.
+func (c *DocumentsCreateCall) Do(opts ...googleapi.CallOption) (*Document, error) {
+	gensupport.SetOptions(c.urlParams_, opts...)
+	res, err := c.doRequest("json")
+	if res != nil && res.StatusCode == http.StatusNotModified {
+		if res.Body != nil {
+			res.Body.Close()
+		}
+		return nil, &googleapi.Error{
+			Code:   res.StatusCode,
+			Header: res.Header,
+		}
+	}
+	if err != nil {
+		return nil, err
+	}
+	defer googleapi.CloseBody(res)
+	if err := googleapi.CheckResponse(res); err != nil {
+		return nil, err
+	}
+	ret := &Document{
+		ServerResponse: googleapi.ServerResponse{
+			Header:         res.Header,
+			HTTPStatusCode: res.StatusCode,
+		},
+	}
+	target := &ret
+	if err := gensupport.DecodeResponse(target, res); err != nil {
+		return nil, err
+	}
+	return ret, nil
+	// {
+	//   "description": "Creates a blank document using the title given in the request. Other fields\nin the request, including any provided content, are ignored.\n\nReturns the created document.",
+	//   "flatPath": "v1/documents",
+	//   "httpMethod": "POST",
+	//   "id": "docs.documents.create",
+	//   "parameterOrder": [],
+	//   "parameters": {},
+	//   "path": "v1/documents",
+	//   "request": {
+	//     "$ref": "Document"
+	//   },
+	//   "response": {
+	//     "$ref": "Document"
+	//   },
+	//   "scopes": [
+	//     "https://www.googleapis.com/auth/documents",
+	//     "https://www.googleapis.com/auth/drive",
+	//     "https://www.googleapis.com/auth/drive.file"
+	//   ]
+	// }
+
+}
+
+// method id "docs.documents.get":
+
+type DocumentsGetCall struct {
+	s            *Service
+	documentId   string
+	urlParams_   gensupport.URLParams
+	ifNoneMatch_ string
+	ctx_         context.Context
+	header_      http.Header
+}
+
+// Get: Gets the latest version of the specified document.
+func (r *DocumentsService) Get(documentId string) *DocumentsGetCall {
+	c := &DocumentsGetCall{s: r.s, urlParams_: make(gensupport.URLParams)}
+	c.documentId = documentId
+	return c
+}
+
+// SuggestionsViewMode sets the optional parameter
+// "suggestionsViewMode": The suggestions view mode to apply to the
+// document. This allows viewing the
+// document with all suggestions inline, accepted or rejected. If one is
+// not
+// specified, DEFAULT_FOR_CURRENT_ACCESS is
+// used.
+//
+// Possible values:
+//   "DEFAULT_FOR_CURRENT_ACCESS"
+//   "SUGGESTIONS_INLINE"
+//   "PREVIEW_SUGGESTIONS_ACCEPTED"
+//   "PREVIEW_WITHOUT_SUGGESTIONS"
+func (c *DocumentsGetCall) SuggestionsViewMode(suggestionsViewMode string) *DocumentsGetCall {
+	c.urlParams_.Set("suggestionsViewMode", suggestionsViewMode)
+	return c
+}
+
+// Fields allows partial responses to be retrieved. See
+// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
+// for more information.
+func (c *DocumentsGetCall) Fields(s ...googleapi.Field) *DocumentsGetCall {
+	c.urlParams_.Set("fields", googleapi.CombineFields(s))
+	return c
+}
+
+// IfNoneMatch sets the optional parameter which makes the operation
+// fail if the object's ETag matches the given value. This is useful for
+// getting updates only after the object has changed since the last
+// request. Use googleapi.IsNotModified to check whether the response
+// error from Do is the result of In-None-Match.
+func (c *DocumentsGetCall) IfNoneMatch(entityTag string) *DocumentsGetCall {
+	c.ifNoneMatch_ = entityTag
+	return c
+}
+
+// Context sets the context to be used in this call's Do method. Any
+// pending HTTP request will be aborted if the provided context is
+// canceled.
+func (c *DocumentsGetCall) Context(ctx context.Context) *DocumentsGetCall {
+	c.ctx_ = ctx
+	return c
+}
+
+// Header returns an http.Header that can be modified by the caller to
+// add HTTP headers to the request.
+func (c *DocumentsGetCall) Header() http.Header {
+	if c.header_ == nil {
+		c.header_ = make(http.Header)
+	}
+	return c.header_
+}
+
+func (c *DocumentsGetCall) doRequest(alt string) (*http.Response, error) {
+	reqHeaders := make(http.Header)
+	for k, v := range c.header_ {
+		reqHeaders[k] = v
+	}
+	reqHeaders.Set("User-Agent", c.s.userAgent())
+	if c.ifNoneMatch_ != "" {
+		reqHeaders.Set("If-None-Match", c.ifNoneMatch_)
+	}
+	var body io.Reader = nil
+	c.urlParams_.Set("alt", alt)
+	c.urlParams_.Set("prettyPrint", "false")
+	urls := googleapi.ResolveRelative(c.s.BasePath, "v1/documents/{documentId}")
+	urls += "?" + c.urlParams_.Encode()
+	req, err := http.NewRequest("GET", urls, body)
+	if err != nil {
+		return nil, err
+	}
+	req.Header = reqHeaders
+	googleapi.Expand(req.URL, map[string]string{
+		"documentId": c.documentId,
+	})
+	return gensupport.SendRequest(c.ctx_, c.s.client, req)
+}
+
+// Do executes the "docs.documents.get" call.
+// Exactly one of *Document or error will be non-nil. Any non-2xx status
+// code is an error. Response headers are in either
+// *Document.ServerResponse.Header or (if a response was returned at
+// all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified
+// to check whether the returned error was because
+// http.StatusNotModified was returned.
+func (c *DocumentsGetCall) Do(opts ...googleapi.CallOption) (*Document, error) {
+	gensupport.SetOptions(c.urlParams_, opts...)
+	res, err := c.doRequest("json")
+	if res != nil && res.StatusCode == http.StatusNotModified {
+		if res.Body != nil {
+			res.Body.Close()
+		}
+		return nil, &googleapi.Error{
+			Code:   res.StatusCode,
+			Header: res.Header,
+		}
+	}
+	if err != nil {
+		return nil, err
+	}
+	defer googleapi.CloseBody(res)
+	if err := googleapi.CheckResponse(res); err != nil {
+		return nil, err
+	}
+	ret := &Document{
+		ServerResponse: googleapi.ServerResponse{
+			Header:         res.Header,
+			HTTPStatusCode: res.StatusCode,
+		},
+	}
+	target := &ret
+	if err := gensupport.DecodeResponse(target, res); err != nil {
+		return nil, err
+	}
+	return ret, nil
+	// {
+	//   "description": "Gets the latest version of the specified document.",
+	//   "flatPath": "v1/documents/{documentId}",
+	//   "httpMethod": "GET",
+	//   "id": "docs.documents.get",
+	//   "parameterOrder": [
+	//     "documentId"
+	//   ],
+	//   "parameters": {
+	//     "documentId": {
+	//       "description": "The ID of the document to retrieve.",
+	//       "location": "path",
+	//       "required": true,
+	//       "type": "string"
+	//     },
+	//     "suggestionsViewMode": {
+	//       "description": "The suggestions view mode to apply to the document. This allows viewing the\ndocument with all suggestions inline, accepted or rejected. If one is not\nspecified, DEFAULT_FOR_CURRENT_ACCESS is\nused.",
+	//       "enum": [
+	//         "DEFAULT_FOR_CURRENT_ACCESS",
+	//         "SUGGESTIONS_INLINE",
+	//         "PREVIEW_SUGGESTIONS_ACCEPTED",
+	//         "PREVIEW_WITHOUT_SUGGESTIONS"
+	//       ],
+	//       "location": "query",
+	//       "type": "string"
+	//     }
+	//   },
+	//   "path": "v1/documents/{documentId}",
+	//   "response": {
+	//     "$ref": "Document"
+	//   },
+	//   "scopes": [
+	//     "https://www.googleapis.com/auth/documents",
+	//     "https://www.googleapis.com/auth/documents.readonly",
+	//     "https://www.googleapis.com/auth/drive",
+	//     "https://www.googleapis.com/auth/drive.file",
+	//     "https://www.googleapis.com/auth/drive.readonly"
+	//   ]
+	// }
+
+}
diff --git a/doubleclickbidmanager/v1/doubleclickbidmanager-api.json b/doubleclickbidmanager/v1/doubleclickbidmanager-api.json
index bb19c28..e68d41e 100644
--- a/doubleclickbidmanager/v1/doubleclickbidmanager-api.json
+++ b/doubleclickbidmanager/v1/doubleclickbidmanager-api.json
@@ -15,7 +15,7 @@
   "description": "API for viewing and managing your reports in DoubleClick Bid Manager.",
   "discoveryVersion": "v1",
   "documentationLink": "https://developers.google.com/bid-manager/",
-  "etag": "\"J3WqvAcMk4eQjJXvfSI4Yr8VouA/lPeOK93Z0eJies1sxdn4f7TLHKM\"",
+  "etag": "\"J3WqvAcMk4eQjJXvfSI4Yr8VouA/0dzG-z_oNgrCZpAyJtYBKcW1vgQ\"",
   "icons": {
     "x16": "https://www.gstatic.com/images/branding/product/1x/googleg_16dp.png",
     "x32": "https://www.gstatic.com/images/branding/product/1x/googleg_32dp.png"
@@ -257,7 +257,7 @@
       }
     }
   },
-  "revision": "20190114",
+  "revision": "20190125",
   "rootUrl": "https://www.googleapis.com/",
   "schemas": {
     "DownloadLineItemsRequest": {
@@ -457,7 +457,10 @@
             "FILTER_FLOODLIGHT_PIXEL_ID",
             "FILTER_GENDER",
             "FILTER_INSERTION_ORDER",
+            "FILTER_INVENTORY_COMMITMENT_TYPE",
+            "FILTER_INVENTORY_DELIVERY_METHOD",
             "FILTER_INVENTORY_FORMAT",
+            "FILTER_INVENTORY_RATE_TYPE",
             "FILTER_INVENTORY_SOURCE",
             "FILTER_INVENTORY_SOURCE_TYPE",
             "FILTER_KEYWORD",
@@ -670,6 +673,9 @@
             "",
             "",
             "",
+            "",
+            "",
+            "",
             ""
           ],
           "type": "string"
@@ -772,7 +778,10 @@
               "FILTER_FLOODLIGHT_PIXEL_ID",
               "FILTER_GENDER",
               "FILTER_INSERTION_ORDER",
+              "FILTER_INVENTORY_COMMITMENT_TYPE",
+              "FILTER_INVENTORY_DELIVERY_METHOD",
               "FILTER_INVENTORY_FORMAT",
+              "FILTER_INVENTORY_RATE_TYPE",
               "FILTER_INVENTORY_SOURCE",
               "FILTER_INVENTORY_SOURCE_TYPE",
               "FILTER_KEYWORD",
@@ -985,6 +994,9 @@
               "",
               "",
               "",
+              "",
+              "",
+              "",
               ""
             ],
             "type": "string"
diff --git a/doubleclickbidmanager/v1/doubleclickbidmanager-gen.go b/doubleclickbidmanager/v1/doubleclickbidmanager-gen.go
index 8550edd..f9762b4 100644
--- a/doubleclickbidmanager/v1/doubleclickbidmanager-gen.go
+++ b/doubleclickbidmanager/v1/doubleclickbidmanager-gen.go
@@ -362,7 +362,10 @@
 	//   "FILTER_FLOODLIGHT_PIXEL_ID"
 	//   "FILTER_GENDER"
 	//   "FILTER_INSERTION_ORDER"
+	//   "FILTER_INVENTORY_COMMITMENT_TYPE"
+	//   "FILTER_INVENTORY_DELIVERY_METHOD"
 	//   "FILTER_INVENTORY_FORMAT"
+	//   "FILTER_INVENTORY_RATE_TYPE"
 	//   "FILTER_INVENTORY_SOURCE"
 	//   "FILTER_INVENTORY_SOURCE_TYPE"
 	//   "FILTER_KEYWORD"
@@ -595,7 +598,10 @@
 	//   "FILTER_FLOODLIGHT_PIXEL_ID"
 	//   "FILTER_GENDER"
 	//   "FILTER_INSERTION_ORDER"
+	//   "FILTER_INVENTORY_COMMITMENT_TYPE"
+	//   "FILTER_INVENTORY_DELIVERY_METHOD"
 	//   "FILTER_INVENTORY_FORMAT"
+	//   "FILTER_INVENTORY_RATE_TYPE"
 	//   "FILTER_INVENTORY_SOURCE"
 	//   "FILTER_INVENTORY_SOURCE_TYPE"
 	//   "FILTER_KEYWORD"
diff --git a/file/v1/file-api.json b/file/v1/file-api.json
index 5d152fe..2a1cacd 100644
--- a/file/v1/file-api.json
+++ b/file/v1/file-api.json
@@ -176,173 +176,6 @@
             }
           },
           "resources": {
-            "instances": {
-              "methods": {
-                "create": {
-                  "description": "Creates an instance.",
-                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/instances",
-                  "httpMethod": "POST",
-                  "id": "file.projects.locations.instances.create",
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "parameters": {
-                    "instanceId": {
-                      "description": "The name of the instance to create.\nThe name must be unique for the specified project and location.",
-                      "location": "query",
-                      "type": "string"
-                    },
-                    "parent": {
-                      "description": "The instance's project and location, in the format\nprojects/{project_id}/locations/{location}. In Cloud Filestore,\nlocations map to GCP zones, for example **us-west1-b**.",
-                      "location": "path",
-                      "pattern": "^projects/[^/]+/locations/[^/]+$",
-                      "required": true,
-                      "type": "string"
-                    }
-                  },
-                  "path": "v1/{+parent}/instances",
-                  "request": {
-                    "$ref": "Instance"
-                  },
-                  "response": {
-                    "$ref": "Operation"
-                  },
-                  "scopes": [
-                    "https://www.googleapis.com/auth/cloud-platform"
-                  ]
-                },
-                "delete": {
-                  "description": "Deletes an instance.",
-                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/instances/{instancesId}",
-                  "httpMethod": "DELETE",
-                  "id": "file.projects.locations.instances.delete",
-                  "parameterOrder": [
-                    "name"
-                  ],
-                  "parameters": {
-                    "name": {
-                      "description": "The instance resource name, in the format\nprojects/{project_id}/locations/{location}/instances/{instance_id}",
-                      "location": "path",
-                      "pattern": "^projects/[^/]+/locations/[^/]+/instances/[^/]+$",
-                      "required": true,
-                      "type": "string"
-                    }
-                  },
-                  "path": "v1/{+name}",
-                  "response": {
-                    "$ref": "Operation"
-                  },
-                  "scopes": [
-                    "https://www.googleapis.com/auth/cloud-platform"
-                  ]
-                },
-                "get": {
-                  "description": "Gets the details of a specific instance.",
-                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/instances/{instancesId}",
-                  "httpMethod": "GET",
-                  "id": "file.projects.locations.instances.get",
-                  "parameterOrder": [
-                    "name"
-                  ],
-                  "parameters": {
-                    "name": {
-                      "description": "The instance resource name, in the format\nprojects/{project_id}/locations/{location}/instances/{instance_id}.",
-                      "location": "path",
-                      "pattern": "^projects/[^/]+/locations/[^/]+/instances/[^/]+$",
-                      "required": true,
-                      "type": "string"
-                    }
-                  },
-                  "path": "v1/{+name}",
-                  "response": {
-                    "$ref": "Instance"
-                  },
-                  "scopes": [
-                    "https://www.googleapis.com/auth/cloud-platform"
-                  ]
-                },
-                "list": {
-                  "description": "Lists all instances in a project for either a specified location\nor for all locations.",
-                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/instances",
-                  "httpMethod": "GET",
-                  "id": "file.projects.locations.instances.list",
-                  "parameterOrder": [
-                    "parent"
-                  ],
-                  "parameters": {
-                    "filter": {
-                      "description": "List filter.",
-                      "location": "query",
-                      "type": "string"
-                    },
-                    "orderBy": {
-                      "description": "Sort results. Supported values are \"name\", \"name desc\" or \"\" (unsorted).",
-                      "location": "query",
-                      "type": "string"
-                    },
-                    "pageSize": {
-                      "description": "The maximum number of items to return.",
-                      "format": "int32",
-                      "location": "query",
-                      "type": "integer"
-                    },
-                    "pageToken": {
-                      "description": "The next_page_token value to use if there are additional\nresults to retrieve for this list request.",
-                      "location": "query",
-                      "type": "string"
-                    },
-                    "parent": {
-                      "description": "The project and location for which to retrieve instance information,\nin the format projects/{project_id}/locations/{location}. In Cloud\nFilestore, locations map to GCP zones, for example **us-west1-b**. To\nretrieve instance information for all locations, use \"-\" for the {location}\nvalue.",
-                      "location": "path",
-                      "pattern": "^projects/[^/]+/locations/[^/]+$",
-                      "required": true,
-                      "type": "string"
-                    }
-                  },
-                  "path": "v1/{+parent}/instances",
-                  "response": {
-                    "$ref": "ListInstancesResponse"
-                  },
-                  "scopes": [
-                    "https://www.googleapis.com/auth/cloud-platform"
-                  ]
-                },
-                "patch": {
-                  "description": "Updates the settings of a specific instance.",
-                  "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/instances/{instancesId}",
-                  "httpMethod": "PATCH",
-                  "id": "file.projects.locations.instances.patch",
-                  "parameterOrder": [
-                    "name"
-                  ],
-                  "parameters": {
-                    "name": {
-                      "description": "Output only.\nThe resource name of the instance, in the format\nprojects/{project_id}/locations/{location_id}/instances/{instance_id}.",
-                      "location": "path",
-                      "pattern": "^projects/[^/]+/locations/[^/]+/instances/[^/]+$",
-                      "required": true,
-                      "type": "string"
-                    },
-                    "updateMask": {
-                      "description": "Mask of fields to update.  At least one path must be supplied in this\nfield.  The elements of the repeated paths field may only include these\nfields:\n\"description\"",
-                      "format": "google-fieldmask",
-                      "location": "query",
-                      "type": "string"
-                    }
-                  },
-                  "path": "v1/{+name}",
-                  "request": {
-                    "$ref": "Instance"
-                  },
-                  "response": {
-                    "$ref": "Operation"
-                  },
-                  "scopes": [
-                    "https://www.googleapis.com/auth/cloud-platform"
-                  ]
-                }
-              }
-            },
             "operations": {
               "methods": {
                 "cancel": {
@@ -471,7 +304,7 @@
       }
     }
   },
-  "revision": "20190123",
+  "revision": "20190129",
   "rootUrl": "https://file.googleapis.com/",
   "schemas": {
     "CancelOperationRequest": {
@@ -486,130 +319,6 @@
       "properties": {},
       "type": "object"
     },
-    "FileShareConfig": {
-      "description": "File share configuration for the instance.",
-      "id": "FileShareConfig",
-      "properties": {
-        "capacityGb": {
-          "description": "File share capacity in gigabytes (GB).\nCloud Filestore defines 1 GB as 1024^3 bytes.",
-          "format": "int64",
-          "type": "string"
-        },
-        "name": {
-          "description": "The name of the file share (must be 16 characters or less).",
-          "type": "string"
-        }
-      },
-      "type": "object"
-    },
-    "Instance": {
-      "description": "A Cloud Filestore instance.",
-      "id": "Instance",
-      "properties": {
-        "createTime": {
-          "description": "Output only.\nThe time when the instance was created.",
-          "format": "google-datetime",
-          "type": "string"
-        },
-        "description": {
-          "description": "Optional. A description of the instance (2048 characters or less).",
-          "type": "string"
-        },
-        "etag": {
-          "description": "Server-specified ETag for the instance resource to prevent simultaneous\nupdates from overwriting each other.",
-          "type": "string"
-        },
-        "fileShares": {
-          "description": "File system shares on the instance.\nFor this version, only a single file share is supported.",
-          "items": {
-            "$ref": "FileShareConfig"
-          },
-          "type": "array"
-        },
-        "labels": {
-          "additionalProperties": {
-            "type": "string"
-          },
-          "description": "Resource labels to represent user provided metadata.",
-          "type": "object"
-        },
-        "name": {
-          "description": "Output only.\nThe resource name of the instance, in the format\nprojects/{project_id}/locations/{location_id}/instances/{instance_id}.",
-          "type": "string"
-        },
-        "networks": {
-          "description": "VPC networks to which the instance is connected.\nFor this version, only a single network is supported.",
-          "items": {
-            "$ref": "NetworkConfig"
-          },
-          "type": "array"
-        },
-        "state": {
-          "description": "Output only.\nThe instance state.",
-          "enum": [
-            "STATE_UNSPECIFIED",
-            "CREATING",
-            "READY",
-            "REPAIRING",
-            "DELETING",
-            "ERROR"
-          ],
-          "enumDescriptions": [
-            "State not set.",
-            "The instance is being created.",
-            "The instance is available for use.",
-            "Work is being done on the instance. You can get further details from the\n`statusMessage` field of the `Instance` resource.",
-            "The instance is shutting down.",
-            "The instance is experiencing an issue and might be unusable. You can get\nfurther details from the `statusMessage` field of the `Instance`\nresource."
-          ],
-          "type": "string"
-        },
-        "statusMessage": {
-          "description": "Output only.\nAdditional information about the instance state, if available.",
-          "type": "string"
-        },
-        "tier": {
-          "description": "The service tier of the instance.",
-          "enum": [
-            "TIER_UNSPECIFIED",
-            "STANDARD",
-            "PREMIUM"
-          ],
-          "enumDescriptions": [
-            "Not set.",
-            "STANDARD tier.",
-            "PREMIUM tier."
-          ],
-          "type": "string"
-        }
-      },
-      "type": "object"
-    },
-    "ListInstancesResponse": {
-      "description": "ListInstancesResponse is the result of ListInstancesRequest.",
-      "id": "ListInstancesResponse",
-      "properties": {
-        "instances": {
-          "description": "A list of instances in the project for the specified location.\n\nIf the {location} value in the request is \"-\", the response contains a list\nof instances from all locations. If any location is unreachable, the\nresponse will only return instances in reachable locations and the\n\"unreachable\" field will be populated with a list of unreachable locations.",
-          "items": {
-            "$ref": "Instance"
-          },
-          "type": "array"
-        },
-        "nextPageToken": {
-          "description": "The token you can use to retrieve the next page of results. Not returned\nif there are no more results in the list.",
-          "type": "string"
-        },
-        "unreachable": {
-          "description": "Locations that could not be reached.",
-          "items": {
-            "type": "string"
-          },
-          "type": "array"
-        }
-      },
-      "type": "object"
-    },
     "ListLocationsResponse": {
       "description": "The response message for Locations.ListLocations.",
       "id": "ListLocationsResponse",
@@ -680,43 +389,6 @@
       },
       "type": "object"
     },
-    "NetworkConfig": {
-      "description": "Network configuration for the instance.",
-      "id": "NetworkConfig",
-      "properties": {
-        "ipAddresses": {
-          "description": "Output only.\nIPv4 addresses in the format\n{octet 1}.{octet 2}.{octet 3}.{octet 4} or IPv6 addresses in the format\n{block 1}:{block 2}:{block 3}:{block 4}:{block 5}:{block 6}:{block 7}:{block 8}.",
-          "items": {
-            "type": "string"
-          },
-          "type": "array"
-        },
-        "modes": {
-          "description": "Internet protocol versions for which the instance has IP addresses\nassigned. For this version, only MODE_IPV4 is supported.",
-          "enumDescriptions": [
-            "Internet protocol not set.",
-            "Use the IPv4 internet protocol."
-          ],
-          "items": {
-            "enum": [
-              "ADDRESS_MODE_UNSPECIFIED",
-              "MODE_IPV4"
-            ],
-            "type": "string"
-          },
-          "type": "array"
-        },
-        "network": {
-          "description": "The name of the Google Compute Engine\n[VPC network](/compute/docs/networks-and-firewalls#networks) to which the\ninstance is connected.",
-          "type": "string"
-        },
-        "reservedIpRange": {
-          "description": "A /29 CIDR block in one of the\n[internal IP address ranges](https://www.arin.net/knowledge/address_filters.html)\nthat identifies the range of IP addresses reserved for this\ninstance. For example, 10.0.0.0/29 or 192.168.0.0/29. The range you specify\ncan't overlap with either existing subnets or assigned IP address ranges\nfor other Cloud Filestore instances in the selected VPC network.",
-          "type": "string"
-        }
-      },
-      "type": "object"
-    },
     "Operation": {
       "description": "This resource represents a long-running operation that is the result of a\nnetwork API call.",
       "id": "Operation",
diff --git a/file/v1/file-gen.go b/file/v1/file-gen.go
index ba6ec4d..2223159 100644
--- a/file/v1/file-gen.go
+++ b/file/v1/file-gen.go
@@ -94,7 +94,6 @@
 
 func NewProjectsLocationsService(s *Service) *ProjectsLocationsService {
 	rs := &ProjectsLocationsService{s: s}
-	rs.Instances = NewProjectsLocationsInstancesService(s)
 	rs.Operations = NewProjectsLocationsOperationsService(s)
 	return rs
 }
@@ -102,20 +101,9 @@
 type ProjectsLocationsService struct {
 	s *Service
 
-	Instances *ProjectsLocationsInstancesService
-
 	Operations *ProjectsLocationsOperationsService
 }
 
-func NewProjectsLocationsInstancesService(s *Service) *ProjectsLocationsInstancesService {
-	rs := &ProjectsLocationsInstancesService{s: s}
-	return rs
-}
-
-type ProjectsLocationsInstancesService struct {
-	s *Service
-}
-
 func NewProjectsLocationsOperationsService(s *Service) *ProjectsLocationsOperationsService {
 	rs := &ProjectsLocationsOperationsService{s: s}
 	return rs
@@ -148,179 +136,6 @@
 	googleapi.ServerResponse `json:"-"`
 }
 
-// FileShareConfig: File share configuration for the instance.
-type FileShareConfig struct {
-	// CapacityGb: File share capacity in gigabytes (GB).
-	// Cloud Filestore defines 1 GB as 1024^3 bytes.
-	CapacityGb int64 `json:"capacityGb,omitempty,string"`
-
-	// Name: The name of the file share (must be 16 characters or less).
-	Name string `json:"name,omitempty"`
-
-	// ForceSendFields is a list of field names (e.g. "CapacityGb") to
-	// unconditionally include in API requests. By default, fields with
-	// empty values are omitted from API requests. However, any non-pointer,
-	// non-interface field appearing in ForceSendFields will be sent to the
-	// server regardless of whether the field is empty or not. This may be
-	// used to include empty fields in Patch requests.
-	ForceSendFields []string `json:"-"`
-
-	// NullFields is a list of field names (e.g. "CapacityGb") to include in
-	// API requests with the JSON null value. By default, fields with empty
-	// values are omitted from API requests. However, any field with an
-	// empty value appearing in NullFields will be sent to the server as
-	// null. It is an error if a field in this list has a non-empty value.
-	// This may be used to include null fields in Patch requests.
-	NullFields []string `json:"-"`
-}
-
-func (s *FileShareConfig) MarshalJSON() ([]byte, error) {
-	type NoMethod FileShareConfig
-	raw := NoMethod(*s)
-	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
-}
-
-// Instance: A Cloud Filestore instance.
-type Instance struct {
-	// CreateTime: Output only.
-	// The time when the instance was created.
-	CreateTime string `json:"createTime,omitempty"`
-
-	// Description: Optional. A description of the instance (2048 characters
-	// or less).
-	Description string `json:"description,omitempty"`
-
-	// Etag: Server-specified ETag for the instance resource to prevent
-	// simultaneous
-	// updates from overwriting each other.
-	Etag string `json:"etag,omitempty"`
-
-	// FileShares: File system shares on the instance.
-	// For this version, only a single file share is supported.
-	FileShares []*FileShareConfig `json:"fileShares,omitempty"`
-
-	// Labels: Resource labels to represent user provided metadata.
-	Labels map[string]string `json:"labels,omitempty"`
-
-	// Name: Output only.
-	// The resource name of the instance, in the
-	// format
-	// projects/{project_id}/locations/{location_id}/instances/{instan
-	// ce_id}.
-	Name string `json:"name,omitempty"`
-
-	// Networks: VPC networks to which the instance is connected.
-	// For this version, only a single network is supported.
-	Networks []*NetworkConfig `json:"networks,omitempty"`
-
-	// State: Output only.
-	// The instance state.
-	//
-	// Possible values:
-	//   "STATE_UNSPECIFIED" - State not set.
-	//   "CREATING" - The instance is being created.
-	//   "READY" - The instance is available for use.
-	//   "REPAIRING" - Work is being done on the instance. You can get
-	// further details from the
-	// `statusMessage` field of the `Instance` resource.
-	//   "DELETING" - The instance is shutting down.
-	//   "ERROR" - The instance is experiencing an issue and might be
-	// unusable. You can get
-	// further details from the `statusMessage` field of the
-	// `Instance`
-	// resource.
-	State string `json:"state,omitempty"`
-
-	// StatusMessage: Output only.
-	// Additional information about the instance state, if available.
-	StatusMessage string `json:"statusMessage,omitempty"`
-
-	// Tier: The service tier of the instance.
-	//
-	// Possible values:
-	//   "TIER_UNSPECIFIED" - Not set.
-	//   "STANDARD" - STANDARD tier.
-	//   "PREMIUM" - PREMIUM tier.
-	Tier string `json:"tier,omitempty"`
-
-	// ServerResponse contains the HTTP response code and headers from the
-	// server.
-	googleapi.ServerResponse `json:"-"`
-
-	// ForceSendFields is a list of field names (e.g. "CreateTime") to
-	// unconditionally include in API requests. By default, fields with
-	// empty values are omitted from API requests. However, any non-pointer,
-	// non-interface field appearing in ForceSendFields will be sent to the
-	// server regardless of whether the field is empty or not. This may be
-	// used to include empty fields in Patch requests.
-	ForceSendFields []string `json:"-"`
-
-	// NullFields is a list of field names (e.g. "CreateTime") to include in
-	// API requests with the JSON null value. By default, fields with empty
-	// values are omitted from API requests. However, any field with an
-	// empty value appearing in NullFields will be sent to the server as
-	// null. It is an error if a field in this list has a non-empty value.
-	// This may be used to include null fields in Patch requests.
-	NullFields []string `json:"-"`
-}
-
-func (s *Instance) MarshalJSON() ([]byte, error) {
-	type NoMethod Instance
-	raw := NoMethod(*s)
-	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
-}
-
-// ListInstancesResponse: ListInstancesResponse is the result of
-// ListInstancesRequest.
-type ListInstancesResponse struct {
-	// Instances: A list of instances in the project for the specified
-	// location.
-	//
-	// If the {location} value in the request is "-", the response contains
-	// a list
-	// of instances from all locations. If any location is unreachable,
-	// the
-	// response will only return instances in reachable locations and
-	// the
-	// "unreachable" field will be populated with a list of unreachable
-	// locations.
-	Instances []*Instance `json:"instances,omitempty"`
-
-	// NextPageToken: The token you can use to retrieve the next page of
-	// results. Not returned
-	// if there are no more results in the list.
-	NextPageToken string `json:"nextPageToken,omitempty"`
-
-	// Unreachable: Locations that could not be reached.
-	Unreachable []string `json:"unreachable,omitempty"`
-
-	// ServerResponse contains the HTTP response code and headers from the
-	// server.
-	googleapi.ServerResponse `json:"-"`
-
-	// ForceSendFields is a list of field names (e.g. "Instances") to
-	// unconditionally include in API requests. By default, fields with
-	// empty values are omitted from API requests. However, any non-pointer,
-	// non-interface field appearing in ForceSendFields will be sent to the
-	// server regardless of whether the field is empty or not. This may be
-	// used to include empty fields in Patch requests.
-	ForceSendFields []string `json:"-"`
-
-	// NullFields is a list of field names (e.g. "Instances") to include in
-	// API requests with the JSON null value. By default, fields with empty
-	// values are omitted from API requests. However, any field with an
-	// empty value appearing in NullFields will be sent to the server as
-	// null. It is an error if a field in this list has a non-empty value.
-	// This may be used to include null fields in Patch requests.
-	NullFields []string `json:"-"`
-}
-
-func (s *ListInstancesResponse) MarshalJSON() ([]byte, error) {
-	type NoMethod ListInstancesResponse
-	raw := NoMethod(*s)
-	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
-}
-
 // ListLocationsResponse: The response message for
 // Locations.ListLocations.
 type ListLocationsResponse struct {
@@ -448,65 +263,6 @@
 	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
 }
 
-// NetworkConfig: Network configuration for the instance.
-type NetworkConfig struct {
-	// IpAddresses: Output only.
-	// IPv4 addresses in the format
-	// {octet 1}.{octet 2}.{octet 3}.{octet 4} or IPv6 addresses in the
-	// format
-	// {block 1}:{block 2}:{block 3}:{block 4}:{block 5}:{block 6}:{block
-	// 7}:{block 8}.
-	IpAddresses []string `json:"ipAddresses,omitempty"`
-
-	// Modes: Internet protocol versions for which the instance has IP
-	// addresses
-	// assigned. For this version, only MODE_IPV4 is supported.
-	//
-	// Possible values:
-	//   "ADDRESS_MODE_UNSPECIFIED" - Internet protocol not set.
-	//   "MODE_IPV4" - Use the IPv4 internet protocol.
-	Modes []string `json:"modes,omitempty"`
-
-	// Network: The name of the Google Compute Engine
-	// [VPC network](/compute/docs/networks-and-firewalls#networks) to which
-	// the
-	// instance is connected.
-	Network string `json:"network,omitempty"`
-
-	// ReservedIpRange: A /29 CIDR block in one of the
-	// [internal IP address
-	// ranges](https://www.arin.net/knowledge/address_filters.html)
-	// that identifies the range of IP addresses reserved for this
-	// instance. For example, 10.0.0.0/29 or 192.168.0.0/29. The range you
-	// specify
-	// can't overlap with either existing subnets or assigned IP address
-	// ranges
-	// for other Cloud Filestore instances in the selected VPC network.
-	ReservedIpRange string `json:"reservedIpRange,omitempty"`
-
-	// ForceSendFields is a list of field names (e.g. "IpAddresses") to
-	// unconditionally include in API requests. By default, fields with
-	// empty values are omitted from API requests. However, any non-pointer,
-	// non-interface field appearing in ForceSendFields will be sent to the
-	// server regardless of whether the field is empty or not. This may be
-	// used to include empty fields in Patch requests.
-	ForceSendFields []string `json:"-"`
-
-	// NullFields is a list of field names (e.g. "IpAddresses") to include
-	// in API requests with the JSON null value. By default, fields with
-	// empty values are omitted from API requests. However, any field with
-	// an empty value appearing in NullFields will be sent to the server as
-	// null. It is an error if a field in this list has a non-empty value.
-	// This may be used to include null fields in Patch requests.
-	NullFields []string `json:"-"`
-}
-
-func (s *NetworkConfig) MarshalJSON() ([]byte, error) {
-	type NoMethod NetworkConfig
-	raw := NoMethod(*s)
-	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
-}
-
 // Operation: This resource represents a long-running operation that is
 // the result of a
 // network API call.
@@ -1101,801 +857,6 @@
 	}
 }
 
-// method id "file.projects.locations.instances.create":
-
-type ProjectsLocationsInstancesCreateCall struct {
-	s          *Service
-	parent     string
-	instance   *Instance
-	urlParams_ gensupport.URLParams
-	ctx_       context.Context
-	header_    http.Header
-}
-
-// Create: Creates an instance.
-func (r *ProjectsLocationsInstancesService) Create(parent string, instance *Instance) *ProjectsLocationsInstancesCreateCall {
-	c := &ProjectsLocationsInstancesCreateCall{s: r.s, urlParams_: make(gensupport.URLParams)}
-	c.parent = parent
-	c.instance = instance
-	return c
-}
-
-// InstanceId sets the optional parameter "instanceId": The name of the
-// instance to create.
-// The name must be unique for the specified project and location.
-func (c *ProjectsLocationsInstancesCreateCall) InstanceId(instanceId string) *ProjectsLocationsInstancesCreateCall {
-	c.urlParams_.Set("instanceId", instanceId)
-	return c
-}
-
-// Fields allows partial responses to be retrieved. See
-// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
-// for more information.
-func (c *ProjectsLocationsInstancesCreateCall) Fields(s ...googleapi.Field) *ProjectsLocationsInstancesCreateCall {
-	c.urlParams_.Set("fields", googleapi.CombineFields(s))
-	return c
-}
-
-// Context sets the context to be used in this call's Do method. Any
-// pending HTTP request will be aborted if the provided context is
-// canceled.
-func (c *ProjectsLocationsInstancesCreateCall) Context(ctx context.Context) *ProjectsLocationsInstancesCreateCall {
-	c.ctx_ = ctx
-	return c
-}
-
-// Header returns an http.Header that can be modified by the caller to
-// add HTTP headers to the request.
-func (c *ProjectsLocationsInstancesCreateCall) Header() http.Header {
-	if c.header_ == nil {
-		c.header_ = make(http.Header)
-	}
-	return c.header_
-}
-
-func (c *ProjectsLocationsInstancesCreateCall) doRequest(alt string) (*http.Response, error) {
-	reqHeaders := make(http.Header)
-	for k, v := range c.header_ {
-		reqHeaders[k] = v
-	}
-	reqHeaders.Set("User-Agent", c.s.userAgent())
-	var body io.Reader = nil
-	body, err := googleapi.WithoutDataWrapper.JSONReader(c.instance)
-	if err != nil {
-		return nil, err
-	}
-	reqHeaders.Set("Content-Type", "application/json")
-	c.urlParams_.Set("alt", alt)
-	c.urlParams_.Set("prettyPrint", "false")
-	urls := googleapi.ResolveRelative(c.s.BasePath, "v1/{+parent}/instances")
-	urls += "?" + c.urlParams_.Encode()
-	req, err := http.NewRequest("POST", urls, body)
-	if err != nil {
-		return nil, err
-	}
-	req.Header = reqHeaders
-	googleapi.Expand(req.URL, map[string]string{
-		"parent": c.parent,
-	})
-	return gensupport.SendRequest(c.ctx_, c.s.client, req)
-}
-
-// Do executes the "file.projects.locations.instances.create" call.
-// Exactly one of *Operation or error will be non-nil. Any non-2xx
-// status code is an error. Response headers are in either
-// *Operation.ServerResponse.Header or (if a response was returned at
-// all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified
-// to check whether the returned error was because
-// http.StatusNotModified was returned.
-func (c *ProjectsLocationsInstancesCreateCall) Do(opts ...googleapi.CallOption) (*Operation, error) {
-	gensupport.SetOptions(c.urlParams_, opts...)
-	res, err := c.doRequest("json")
-	if res != nil && res.StatusCode == http.StatusNotModified {
-		if res.Body != nil {
-			res.Body.Close()
-		}
-		return nil, &googleapi.Error{
-			Code:   res.StatusCode,
-			Header: res.Header,
-		}
-	}
-	if err != nil {
-		return nil, err
-	}
-	defer googleapi.CloseBody(res)
-	if err := googleapi.CheckResponse(res); err != nil {
-		return nil, err
-	}
-	ret := &Operation{
-		ServerResponse: googleapi.ServerResponse{
-			Header:         res.Header,
-			HTTPStatusCode: res.StatusCode,
-		},
-	}
-	target := &ret
-	if err := gensupport.DecodeResponse(target, res); err != nil {
-		return nil, err
-	}
-	return ret, nil
-	// {
-	//   "description": "Creates an instance.",
-	//   "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/instances",
-	//   "httpMethod": "POST",
-	//   "id": "file.projects.locations.instances.create",
-	//   "parameterOrder": [
-	//     "parent"
-	//   ],
-	//   "parameters": {
-	//     "instanceId": {
-	//       "description": "The name of the instance to create.\nThe name must be unique for the specified project and location.",
-	//       "location": "query",
-	//       "type": "string"
-	//     },
-	//     "parent": {
-	//       "description": "The instance's project and location, in the format\nprojects/{project_id}/locations/{location}. In Cloud Filestore,\nlocations map to GCP zones, for example **us-west1-b**.",
-	//       "location": "path",
-	//       "pattern": "^projects/[^/]+/locations/[^/]+$",
-	//       "required": true,
-	//       "type": "string"
-	//     }
-	//   },
-	//   "path": "v1/{+parent}/instances",
-	//   "request": {
-	//     "$ref": "Instance"
-	//   },
-	//   "response": {
-	//     "$ref": "Operation"
-	//   },
-	//   "scopes": [
-	//     "https://www.googleapis.com/auth/cloud-platform"
-	//   ]
-	// }
-
-}
-
-// method id "file.projects.locations.instances.delete":
-
-type ProjectsLocationsInstancesDeleteCall struct {
-	s          *Service
-	name       string
-	urlParams_ gensupport.URLParams
-	ctx_       context.Context
-	header_    http.Header
-}
-
-// Delete: Deletes an instance.
-func (r *ProjectsLocationsInstancesService) Delete(name string) *ProjectsLocationsInstancesDeleteCall {
-	c := &ProjectsLocationsInstancesDeleteCall{s: r.s, urlParams_: make(gensupport.URLParams)}
-	c.name = name
-	return c
-}
-
-// Fields allows partial responses to be retrieved. See
-// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
-// for more information.
-func (c *ProjectsLocationsInstancesDeleteCall) Fields(s ...googleapi.Field) *ProjectsLocationsInstancesDeleteCall {
-	c.urlParams_.Set("fields", googleapi.CombineFields(s))
-	return c
-}
-
-// Context sets the context to be used in this call's Do method. Any
-// pending HTTP request will be aborted if the provided context is
-// canceled.
-func (c *ProjectsLocationsInstancesDeleteCall) Context(ctx context.Context) *ProjectsLocationsInstancesDeleteCall {
-	c.ctx_ = ctx
-	return c
-}
-
-// Header returns an http.Header that can be modified by the caller to
-// add HTTP headers to the request.
-func (c *ProjectsLocationsInstancesDeleteCall) Header() http.Header {
-	if c.header_ == nil {
-		c.header_ = make(http.Header)
-	}
-	return c.header_
-}
-
-func (c *ProjectsLocationsInstancesDeleteCall) doRequest(alt string) (*http.Response, error) {
-	reqHeaders := make(http.Header)
-	for k, v := range c.header_ {
-		reqHeaders[k] = v
-	}
-	reqHeaders.Set("User-Agent", c.s.userAgent())
-	var body io.Reader = nil
-	c.urlParams_.Set("alt", alt)
-	c.urlParams_.Set("prettyPrint", "false")
-	urls := googleapi.ResolveRelative(c.s.BasePath, "v1/{+name}")
-	urls += "?" + c.urlParams_.Encode()
-	req, err := http.NewRequest("DELETE", urls, body)
-	if err != nil {
-		return nil, err
-	}
-	req.Header = reqHeaders
-	googleapi.Expand(req.URL, map[string]string{
-		"name": c.name,
-	})
-	return gensupport.SendRequest(c.ctx_, c.s.client, req)
-}
-
-// Do executes the "file.projects.locations.instances.delete" call.
-// Exactly one of *Operation or error will be non-nil. Any non-2xx
-// status code is an error. Response headers are in either
-// *Operation.ServerResponse.Header or (if a response was returned at
-// all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified
-// to check whether the returned error was because
-// http.StatusNotModified was returned.
-func (c *ProjectsLocationsInstancesDeleteCall) Do(opts ...googleapi.CallOption) (*Operation, error) {
-	gensupport.SetOptions(c.urlParams_, opts...)
-	res, err := c.doRequest("json")
-	if res != nil && res.StatusCode == http.StatusNotModified {
-		if res.Body != nil {
-			res.Body.Close()
-		}
-		return nil, &googleapi.Error{
-			Code:   res.StatusCode,
-			Header: res.Header,
-		}
-	}
-	if err != nil {
-		return nil, err
-	}
-	defer googleapi.CloseBody(res)
-	if err := googleapi.CheckResponse(res); err != nil {
-		return nil, err
-	}
-	ret := &Operation{
-		ServerResponse: googleapi.ServerResponse{
-			Header:         res.Header,
-			HTTPStatusCode: res.StatusCode,
-		},
-	}
-	target := &ret
-	if err := gensupport.DecodeResponse(target, res); err != nil {
-		return nil, err
-	}
-	return ret, nil
-	// {
-	//   "description": "Deletes an instance.",
-	//   "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/instances/{instancesId}",
-	//   "httpMethod": "DELETE",
-	//   "id": "file.projects.locations.instances.delete",
-	//   "parameterOrder": [
-	//     "name"
-	//   ],
-	//   "parameters": {
-	//     "name": {
-	//       "description": "The instance resource name, in the format\nprojects/{project_id}/locations/{location}/instances/{instance_id}",
-	//       "location": "path",
-	//       "pattern": "^projects/[^/]+/locations/[^/]+/instances/[^/]+$",
-	//       "required": true,
-	//       "type": "string"
-	//     }
-	//   },
-	//   "path": "v1/{+name}",
-	//   "response": {
-	//     "$ref": "Operation"
-	//   },
-	//   "scopes": [
-	//     "https://www.googleapis.com/auth/cloud-platform"
-	//   ]
-	// }
-
-}
-
-// method id "file.projects.locations.instances.get":
-
-type ProjectsLocationsInstancesGetCall struct {
-	s            *Service
-	name         string
-	urlParams_   gensupport.URLParams
-	ifNoneMatch_ string
-	ctx_         context.Context
-	header_      http.Header
-}
-
-// Get: Gets the details of a specific instance.
-func (r *ProjectsLocationsInstancesService) Get(name string) *ProjectsLocationsInstancesGetCall {
-	c := &ProjectsLocationsInstancesGetCall{s: r.s, urlParams_: make(gensupport.URLParams)}
-	c.name = name
-	return c
-}
-
-// Fields allows partial responses to be retrieved. See
-// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
-// for more information.
-func (c *ProjectsLocationsInstancesGetCall) Fields(s ...googleapi.Field) *ProjectsLocationsInstancesGetCall {
-	c.urlParams_.Set("fields", googleapi.CombineFields(s))
-	return c
-}
-
-// IfNoneMatch sets the optional parameter which makes the operation
-// fail if the object's ETag matches the given value. This is useful for
-// getting updates only after the object has changed since the last
-// request. Use googleapi.IsNotModified to check whether the response
-// error from Do is the result of In-None-Match.
-func (c *ProjectsLocationsInstancesGetCall) IfNoneMatch(entityTag string) *ProjectsLocationsInstancesGetCall {
-	c.ifNoneMatch_ = entityTag
-	return c
-}
-
-// Context sets the context to be used in this call's Do method. Any
-// pending HTTP request will be aborted if the provided context is
-// canceled.
-func (c *ProjectsLocationsInstancesGetCall) Context(ctx context.Context) *ProjectsLocationsInstancesGetCall {
-	c.ctx_ = ctx
-	return c
-}
-
-// Header returns an http.Header that can be modified by the caller to
-// add HTTP headers to the request.
-func (c *ProjectsLocationsInstancesGetCall) Header() http.Header {
-	if c.header_ == nil {
-		c.header_ = make(http.Header)
-	}
-	return c.header_
-}
-
-func (c *ProjectsLocationsInstancesGetCall) doRequest(alt string) (*http.Response, error) {
-	reqHeaders := make(http.Header)
-	for k, v := range c.header_ {
-		reqHeaders[k] = v
-	}
-	reqHeaders.Set("User-Agent", c.s.userAgent())
-	if c.ifNoneMatch_ != "" {
-		reqHeaders.Set("If-None-Match", c.ifNoneMatch_)
-	}
-	var body io.Reader = nil
-	c.urlParams_.Set("alt", alt)
-	c.urlParams_.Set("prettyPrint", "false")
-	urls := googleapi.ResolveRelative(c.s.BasePath, "v1/{+name}")
-	urls += "?" + c.urlParams_.Encode()
-	req, err := http.NewRequest("GET", urls, body)
-	if err != nil {
-		return nil, err
-	}
-	req.Header = reqHeaders
-	googleapi.Expand(req.URL, map[string]string{
-		"name": c.name,
-	})
-	return gensupport.SendRequest(c.ctx_, c.s.client, req)
-}
-
-// Do executes the "file.projects.locations.instances.get" call.
-// Exactly one of *Instance or error will be non-nil. Any non-2xx status
-// code is an error. Response headers are in either
-// *Instance.ServerResponse.Header or (if a response was returned at
-// all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified
-// to check whether the returned error was because
-// http.StatusNotModified was returned.
-func (c *ProjectsLocationsInstancesGetCall) Do(opts ...googleapi.CallOption) (*Instance, error) {
-	gensupport.SetOptions(c.urlParams_, opts...)
-	res, err := c.doRequest("json")
-	if res != nil && res.StatusCode == http.StatusNotModified {
-		if res.Body != nil {
-			res.Body.Close()
-		}
-		return nil, &googleapi.Error{
-			Code:   res.StatusCode,
-			Header: res.Header,
-		}
-	}
-	if err != nil {
-		return nil, err
-	}
-	defer googleapi.CloseBody(res)
-	if err := googleapi.CheckResponse(res); err != nil {
-		return nil, err
-	}
-	ret := &Instance{
-		ServerResponse: googleapi.ServerResponse{
-			Header:         res.Header,
-			HTTPStatusCode: res.StatusCode,
-		},
-	}
-	target := &ret
-	if err := gensupport.DecodeResponse(target, res); err != nil {
-		return nil, err
-	}
-	return ret, nil
-	// {
-	//   "description": "Gets the details of a specific instance.",
-	//   "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/instances/{instancesId}",
-	//   "httpMethod": "GET",
-	//   "id": "file.projects.locations.instances.get",
-	//   "parameterOrder": [
-	//     "name"
-	//   ],
-	//   "parameters": {
-	//     "name": {
-	//       "description": "The instance resource name, in the format\nprojects/{project_id}/locations/{location}/instances/{instance_id}.",
-	//       "location": "path",
-	//       "pattern": "^projects/[^/]+/locations/[^/]+/instances/[^/]+$",
-	//       "required": true,
-	//       "type": "string"
-	//     }
-	//   },
-	//   "path": "v1/{+name}",
-	//   "response": {
-	//     "$ref": "Instance"
-	//   },
-	//   "scopes": [
-	//     "https://www.googleapis.com/auth/cloud-platform"
-	//   ]
-	// }
-
-}
-
-// method id "file.projects.locations.instances.list":
-
-type ProjectsLocationsInstancesListCall struct {
-	s            *Service
-	parent       string
-	urlParams_   gensupport.URLParams
-	ifNoneMatch_ string
-	ctx_         context.Context
-	header_      http.Header
-}
-
-// List: Lists all instances in a project for either a specified
-// location
-// or for all locations.
-func (r *ProjectsLocationsInstancesService) List(parent string) *ProjectsLocationsInstancesListCall {
-	c := &ProjectsLocationsInstancesListCall{s: r.s, urlParams_: make(gensupport.URLParams)}
-	c.parent = parent
-	return c
-}
-
-// Filter sets the optional parameter "filter": List filter.
-func (c *ProjectsLocationsInstancesListCall) Filter(filter string) *ProjectsLocationsInstancesListCall {
-	c.urlParams_.Set("filter", filter)
-	return c
-}
-
-// OrderBy sets the optional parameter "orderBy": Sort results.
-// Supported values are "name", "name desc" or "" (unsorted).
-func (c *ProjectsLocationsInstancesListCall) OrderBy(orderBy string) *ProjectsLocationsInstancesListCall {
-	c.urlParams_.Set("orderBy", orderBy)
-	return c
-}
-
-// PageSize sets the optional parameter "pageSize": The maximum number
-// of items to return.
-func (c *ProjectsLocationsInstancesListCall) PageSize(pageSize int64) *ProjectsLocationsInstancesListCall {
-	c.urlParams_.Set("pageSize", fmt.Sprint(pageSize))
-	return c
-}
-
-// PageToken sets the optional parameter "pageToken": The
-// next_page_token value to use if there are additional
-// results to retrieve for this list request.
-func (c *ProjectsLocationsInstancesListCall) PageToken(pageToken string) *ProjectsLocationsInstancesListCall {
-	c.urlParams_.Set("pageToken", pageToken)
-	return c
-}
-
-// Fields allows partial responses to be retrieved. See
-// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
-// for more information.
-func (c *ProjectsLocationsInstancesListCall) Fields(s ...googleapi.Field) *ProjectsLocationsInstancesListCall {
-	c.urlParams_.Set("fields", googleapi.CombineFields(s))
-	return c
-}
-
-// IfNoneMatch sets the optional parameter which makes the operation
-// fail if the object's ETag matches the given value. This is useful for
-// getting updates only after the object has changed since the last
-// request. Use googleapi.IsNotModified to check whether the response
-// error from Do is the result of In-None-Match.
-func (c *ProjectsLocationsInstancesListCall) IfNoneMatch(entityTag string) *ProjectsLocationsInstancesListCall {
-	c.ifNoneMatch_ = entityTag
-	return c
-}
-
-// Context sets the context to be used in this call's Do method. Any
-// pending HTTP request will be aborted if the provided context is
-// canceled.
-func (c *ProjectsLocationsInstancesListCall) Context(ctx context.Context) *ProjectsLocationsInstancesListCall {
-	c.ctx_ = ctx
-	return c
-}
-
-// Header returns an http.Header that can be modified by the caller to
-// add HTTP headers to the request.
-func (c *ProjectsLocationsInstancesListCall) Header() http.Header {
-	if c.header_ == nil {
-		c.header_ = make(http.Header)
-	}
-	return c.header_
-}
-
-func (c *ProjectsLocationsInstancesListCall) doRequest(alt string) (*http.Response, error) {
-	reqHeaders := make(http.Header)
-	for k, v := range c.header_ {
-		reqHeaders[k] = v
-	}
-	reqHeaders.Set("User-Agent", c.s.userAgent())
-	if c.ifNoneMatch_ != "" {
-		reqHeaders.Set("If-None-Match", c.ifNoneMatch_)
-	}
-	var body io.Reader = nil
-	c.urlParams_.Set("alt", alt)
-	c.urlParams_.Set("prettyPrint", "false")
-	urls := googleapi.ResolveRelative(c.s.BasePath, "v1/{+parent}/instances")
-	urls += "?" + c.urlParams_.Encode()
-	req, err := http.NewRequest("GET", urls, body)
-	if err != nil {
-		return nil, err
-	}
-	req.Header = reqHeaders
-	googleapi.Expand(req.URL, map[string]string{
-		"parent": c.parent,
-	})
-	return gensupport.SendRequest(c.ctx_, c.s.client, req)
-}
-
-// Do executes the "file.projects.locations.instances.list" call.
-// Exactly one of *ListInstancesResponse or error will be non-nil. Any
-// non-2xx status code is an error. Response headers are in either
-// *ListInstancesResponse.ServerResponse.Header or (if a response was
-// returned at all) in error.(*googleapi.Error).Header. Use
-// googleapi.IsNotModified to check whether the returned error was
-// because http.StatusNotModified was returned.
-func (c *ProjectsLocationsInstancesListCall) Do(opts ...googleapi.CallOption) (*ListInstancesResponse, error) {
-	gensupport.SetOptions(c.urlParams_, opts...)
-	res, err := c.doRequest("json")
-	if res != nil && res.StatusCode == http.StatusNotModified {
-		if res.Body != nil {
-			res.Body.Close()
-		}
-		return nil, &googleapi.Error{
-			Code:   res.StatusCode,
-			Header: res.Header,
-		}
-	}
-	if err != nil {
-		return nil, err
-	}
-	defer googleapi.CloseBody(res)
-	if err := googleapi.CheckResponse(res); err != nil {
-		return nil, err
-	}
-	ret := &ListInstancesResponse{
-		ServerResponse: googleapi.ServerResponse{
-			Header:         res.Header,
-			HTTPStatusCode: res.StatusCode,
-		},
-	}
-	target := &ret
-	if err := gensupport.DecodeResponse(target, res); err != nil {
-		return nil, err
-	}
-	return ret, nil
-	// {
-	//   "description": "Lists all instances in a project for either a specified location\nor for all locations.",
-	//   "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/instances",
-	//   "httpMethod": "GET",
-	//   "id": "file.projects.locations.instances.list",
-	//   "parameterOrder": [
-	//     "parent"
-	//   ],
-	//   "parameters": {
-	//     "filter": {
-	//       "description": "List filter.",
-	//       "location": "query",
-	//       "type": "string"
-	//     },
-	//     "orderBy": {
-	//       "description": "Sort results. Supported values are \"name\", \"name desc\" or \"\" (unsorted).",
-	//       "location": "query",
-	//       "type": "string"
-	//     },
-	//     "pageSize": {
-	//       "description": "The maximum number of items to return.",
-	//       "format": "int32",
-	//       "location": "query",
-	//       "type": "integer"
-	//     },
-	//     "pageToken": {
-	//       "description": "The next_page_token value to use if there are additional\nresults to retrieve for this list request.",
-	//       "location": "query",
-	//       "type": "string"
-	//     },
-	//     "parent": {
-	//       "description": "The project and location for which to retrieve instance information,\nin the format projects/{project_id}/locations/{location}. In Cloud\nFilestore, locations map to GCP zones, for example **us-west1-b**. To\nretrieve instance information for all locations, use \"-\" for the {location}\nvalue.",
-	//       "location": "path",
-	//       "pattern": "^projects/[^/]+/locations/[^/]+$",
-	//       "required": true,
-	//       "type": "string"
-	//     }
-	//   },
-	//   "path": "v1/{+parent}/instances",
-	//   "response": {
-	//     "$ref": "ListInstancesResponse"
-	//   },
-	//   "scopes": [
-	//     "https://www.googleapis.com/auth/cloud-platform"
-	//   ]
-	// }
-
-}
-
-// Pages invokes f for each page of results.
-// A non-nil error returned from f will halt the iteration.
-// The provided context supersedes any context provided to the Context method.
-func (c *ProjectsLocationsInstancesListCall) Pages(ctx context.Context, f func(*ListInstancesResponse) error) error {
-	c.ctx_ = ctx
-	defer c.PageToken(c.urlParams_.Get("pageToken")) // reset paging to original point
-	for {
-		x, err := c.Do()
-		if err != nil {
-			return err
-		}
-		if err := f(x); err != nil {
-			return err
-		}
-		if x.NextPageToken == "" {
-			return nil
-		}
-		c.PageToken(x.NextPageToken)
-	}
-}
-
-// method id "file.projects.locations.instances.patch":
-
-type ProjectsLocationsInstancesPatchCall struct {
-	s          *Service
-	name       string
-	instance   *Instance
-	urlParams_ gensupport.URLParams
-	ctx_       context.Context
-	header_    http.Header
-}
-
-// Patch: Updates the settings of a specific instance.
-func (r *ProjectsLocationsInstancesService) Patch(name string, instance *Instance) *ProjectsLocationsInstancesPatchCall {
-	c := &ProjectsLocationsInstancesPatchCall{s: r.s, urlParams_: make(gensupport.URLParams)}
-	c.name = name
-	c.instance = instance
-	return c
-}
-
-// UpdateMask sets the optional parameter "updateMask": Mask of fields
-// to update.  At least one path must be supplied in this
-// field.  The elements of the repeated paths field may only include
-// these
-// fields:
-// "description"
-func (c *ProjectsLocationsInstancesPatchCall) UpdateMask(updateMask string) *ProjectsLocationsInstancesPatchCall {
-	c.urlParams_.Set("updateMask", updateMask)
-	return c
-}
-
-// Fields allows partial responses to be retrieved. See
-// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
-// for more information.
-func (c *ProjectsLocationsInstancesPatchCall) Fields(s ...googleapi.Field) *ProjectsLocationsInstancesPatchCall {
-	c.urlParams_.Set("fields", googleapi.CombineFields(s))
-	return c
-}
-
-// Context sets the context to be used in this call's Do method. Any
-// pending HTTP request will be aborted if the provided context is
-// canceled.
-func (c *ProjectsLocationsInstancesPatchCall) Context(ctx context.Context) *ProjectsLocationsInstancesPatchCall {
-	c.ctx_ = ctx
-	return c
-}
-
-// Header returns an http.Header that can be modified by the caller to
-// add HTTP headers to the request.
-func (c *ProjectsLocationsInstancesPatchCall) Header() http.Header {
-	if c.header_ == nil {
-		c.header_ = make(http.Header)
-	}
-	return c.header_
-}
-
-func (c *ProjectsLocationsInstancesPatchCall) doRequest(alt string) (*http.Response, error) {
-	reqHeaders := make(http.Header)
-	for k, v := range c.header_ {
-		reqHeaders[k] = v
-	}
-	reqHeaders.Set("User-Agent", c.s.userAgent())
-	var body io.Reader = nil
-	body, err := googleapi.WithoutDataWrapper.JSONReader(c.instance)
-	if err != nil {
-		return nil, err
-	}
-	reqHeaders.Set("Content-Type", "application/json")
-	c.urlParams_.Set("alt", alt)
-	c.urlParams_.Set("prettyPrint", "false")
-	urls := googleapi.ResolveRelative(c.s.BasePath, "v1/{+name}")
-	urls += "?" + c.urlParams_.Encode()
-	req, err := http.NewRequest("PATCH", urls, body)
-	if err != nil {
-		return nil, err
-	}
-	req.Header = reqHeaders
-	googleapi.Expand(req.URL, map[string]string{
-		"name": c.name,
-	})
-	return gensupport.SendRequest(c.ctx_, c.s.client, req)
-}
-
-// Do executes the "file.projects.locations.instances.patch" call.
-// Exactly one of *Operation or error will be non-nil. Any non-2xx
-// status code is an error. Response headers are in either
-// *Operation.ServerResponse.Header or (if a response was returned at
-// all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified
-// to check whether the returned error was because
-// http.StatusNotModified was returned.
-func (c *ProjectsLocationsInstancesPatchCall) Do(opts ...googleapi.CallOption) (*Operation, error) {
-	gensupport.SetOptions(c.urlParams_, opts...)
-	res, err := c.doRequest("json")
-	if res != nil && res.StatusCode == http.StatusNotModified {
-		if res.Body != nil {
-			res.Body.Close()
-		}
-		return nil, &googleapi.Error{
-			Code:   res.StatusCode,
-			Header: res.Header,
-		}
-	}
-	if err != nil {
-		return nil, err
-	}
-	defer googleapi.CloseBody(res)
-	if err := googleapi.CheckResponse(res); err != nil {
-		return nil, err
-	}
-	ret := &Operation{
-		ServerResponse: googleapi.ServerResponse{
-			Header:         res.Header,
-			HTTPStatusCode: res.StatusCode,
-		},
-	}
-	target := &ret
-	if err := gensupport.DecodeResponse(target, res); err != nil {
-		return nil, err
-	}
-	return ret, nil
-	// {
-	//   "description": "Updates the settings of a specific instance.",
-	//   "flatPath": "v1/projects/{projectsId}/locations/{locationsId}/instances/{instancesId}",
-	//   "httpMethod": "PATCH",
-	//   "id": "file.projects.locations.instances.patch",
-	//   "parameterOrder": [
-	//     "name"
-	//   ],
-	//   "parameters": {
-	//     "name": {
-	//       "description": "Output only.\nThe resource name of the instance, in the format\nprojects/{project_id}/locations/{location_id}/instances/{instance_id}.",
-	//       "location": "path",
-	//       "pattern": "^projects/[^/]+/locations/[^/]+/instances/[^/]+$",
-	//       "required": true,
-	//       "type": "string"
-	//     },
-	//     "updateMask": {
-	//       "description": "Mask of fields to update.  At least one path must be supplied in this\nfield.  The elements of the repeated paths field may only include these\nfields:\n\"description\"",
-	//       "format": "google-fieldmask",
-	//       "location": "query",
-	//       "type": "string"
-	//     }
-	//   },
-	//   "path": "v1/{+name}",
-	//   "request": {
-	//     "$ref": "Instance"
-	//   },
-	//   "response": {
-	//     "$ref": "Operation"
-	//   },
-	//   "scopes": [
-	//     "https://www.googleapis.com/auth/cloud-platform"
-	//   ]
-	// }
-
-}
-
 // method id "file.projects.locations.operations.cancel":
 
 type ProjectsLocationsOperationsCancelCall struct {
diff --git a/jobs/v3/jobs-api.json b/jobs/v3/jobs-api.json
index d8ac540..c6e7eae 100644
--- a/jobs/v3/jobs-api.json
+++ b/jobs/v3/jobs-api.json
@@ -185,6 +185,39 @@
         }
       },
       "resources": {
+        "clientEvents": {
+          "methods": {
+            "create": {
+              "description": "Report events issued when end user interacts with customer's application\nthat uses Cloud Talent Solution. You may inspect the created events in\n[self service\ntools](https://console.cloud.google.com/talent-solution/overview).\n[Learn\nmore](https://cloud.google.com/talent-solution/job-search/docs/management-tools)\nabout self service tools.",
+              "flatPath": "v3/projects/{projectsId}/clientEvents",
+              "httpMethod": "POST",
+              "id": "jobs.projects.clientEvents.create",
+              "parameterOrder": [
+                "parent"
+              ],
+              "parameters": {
+                "parent": {
+                  "description": "Parent project name.",
+                  "location": "path",
+                  "pattern": "^projects/[^/]+$",
+                  "required": true,
+                  "type": "string"
+                }
+              },
+              "path": "v3/{+parent}/clientEvents",
+              "request": {
+                "$ref": "CreateClientEventRequest"
+              },
+              "response": {
+                "$ref": "ClientEvent"
+              },
+              "scopes": [
+                "https://www.googleapis.com/auth/cloud-platform",
+                "https://www.googleapis.com/auth/jobs"
+              ]
+            }
+          }
+        },
         "companies": {
           "methods": {
             "create": {
@@ -599,7 +632,7 @@
       }
     }
   },
-  "revision": "20181210",
+  "revision": "20190130",
   "rootUrl": "https://jobs.googleapis.com/",
   "schemas": {
     "ApplicationInfo": {
@@ -671,6 +704,41 @@
       },
       "type": "object"
     },
+    "ClientEvent": {
+      "description": "An event issued when an end user interacts with the application that\nimplements Cloud Talent Solution. Providing this information improves the\nquality of search and recommendation for the API clients, enabling the\nservice to perform optimally. The number of events sent must be consistent\nwith other calls, such as job searches, issued to the service by the client.",
+      "id": "ClientEvent",
+      "properties": {
+        "createTime": {
+          "description": "Required.\n\nThe timestamp of the event.",
+          "format": "google-datetime",
+          "type": "string"
+        },
+        "eventId": {
+          "description": "Required.\n\nA unique identifier, generated by the client application. This `event_id`\nis used to establish the relationship between different events\n(see parent_event_id).",
+          "type": "string"
+        },
+        "extraInfo": {
+          "additionalProperties": {
+            "type": "string"
+          },
+          "description": "Optional.\n\nExtra information about this event. Used for storing information with no\nmatching field in event payload, for example, user application specific\ncontext or details.\n\nAt most 20 keys are supported. The maximum total size of all keys and\nvalues is 2 KB.",
+          "type": "object"
+        },
+        "jobEvent": {
+          "$ref": "JobEvent",
+          "description": "A event issued when a job seeker interacts with the application that\nimplements Cloud Talent Solution."
+        },
+        "parentEventId": {
+          "description": "Required except the first event.\n\nThe event_id of an event that resulted in the current event. For example, a\nJob view event usually follows a parent\nimpression event: A job seeker first does a\nsearch where a list of jobs appears\n(impression). The job seeker then selects a\nresult and views the description of a particular job (Job\nview).",
+          "type": "string"
+        },
+        "requestId": {
+          "description": "Required.\n\nA unique ID generated in the API responses. It can be found in\nResponseMetadata.request_id.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
     "CommuteFilter": {
       "description": "Input only.\n\nParameters needed for commute search.",
       "id": "CommuteFilter",
@@ -695,7 +763,7 @@
         },
         "departureTime": {
           "$ref": "TimeOfDay",
-          "description": "Optional.\n\nThe departure time used to calculate traffic impact, represented as\n.google.type.TimeOfDay in local time zone.\n\nCurrently traffic model is restricted to hour level resolution."
+          "description": "Optional.\n\nThe departure time used to calculate traffic impact, represented as\ngoogle.type.TimeOfDay in local time zone.\n\nCurrently traffic model is restricted to hour level resolution."
         },
         "roadTraffic": {
           "description": "Optional.\n\nSpecifies the traffic density to use when calculating commute time.",
@@ -1106,6 +1174,17 @@
       },
       "type": "object"
     },
+    "CreateClientEventRequest": {
+      "description": "The report event request.",
+      "id": "CreateClientEventRequest",
+      "properties": {
+        "clientEvent": {
+          "$ref": "ClientEvent",
+          "description": "Required.\n\nEvents issued when end user interacts with customer's application that\nuses Cloud Talent Solution."
+        }
+      },
+      "type": "object"
+    },
     "CreateCompanyRequest": {
       "description": "Input only.\n\nThe Request of the CreateCompany method.",
       "id": "CreateCompanyRequest",
@@ -1587,7 +1666,7 @@
           "type": "string"
         },
         "postingRegion": {
-          "description": "Optional.\n\nThe job PostingRegion (for example, state, country) throughout which\nthe job is available. If this field is set, a\nLocationFilter in a search query within the job region\nfinds this job posting if an exact location match is not specified.\nIf this field is set to PostingRegion.NATION_WIDE or\n[PostingRegion.ADMINISTRATIVE_AREA], setting job addresses\nto the same location level as this field is strongly recommended.",
+          "description": "Optional.\n\nThe job PostingRegion (for example, state, country) throughout which\nthe job is available. If this field is set, a\nLocationFilter in a search query within the job region\nfinds this job posting if an exact location match isn't specified.\nIf this field is set to PostingRegion.NATION or\nPostingRegion.ADMINISTRATIVE_AREA, setting job Job.addresses\nto the same location level as this field is strongly recommended.",
           "enum": [
             "POSTING_REGION_UNSPECIFIED",
             "ADMINISTRATIVE_AREA",
@@ -1738,6 +1817,62 @@
       },
       "type": "object"
     },
+    "JobEvent": {
+      "description": "An event issued when a job seeker interacts with the application that\nimplements Cloud Talent Solution.",
+      "id": "JobEvent",
+      "properties": {
+        "jobs": {
+          "description": "Required.\n\nThe job name(s) associated with this event.\nFor example, if this is an impression event,\nthis field contains the identifiers of all jobs shown to the job seeker.\nIf this was a view event, this field contains the\nidentifier of the viewed job.",
+          "items": {
+            "type": "string"
+          },
+          "type": "array"
+        },
+        "type": {
+          "description": "Required.\n\nThe type of the event (see JobEventType).",
+          "enum": [
+            "JOB_EVENT_TYPE_UNSPECIFIED",
+            "IMPRESSION",
+            "VIEW",
+            "VIEW_REDIRECT",
+            "APPLICATION_START",
+            "APPLICATION_FINISH",
+            "APPLICATION_QUICK_SUBMISSION",
+            "APPLICATION_REDIRECT",
+            "APPLICATION_START_FROM_SEARCH",
+            "APPLICATION_REDIRECT_FROM_SEARCH",
+            "APPLICATION_COMPANY_SUBMIT",
+            "BOOKMARK",
+            "NOTIFICATION",
+            "HIRED",
+            "SENT_CV",
+            "INTERVIEW_GRANTED",
+            "NOT_INTERESTED"
+          ],
+          "enumDescriptions": [
+            "The event is unspecified by other provided values.",
+            "The job seeker or other entity interacting with the service has\nhad a job rendered in their view, such as in a list of search results in\na compressed or clipped format. This event is typically associated with\nthe viewing of a jobs list on a single page by a job seeker.",
+            "The job seeker, or other entity interacting with the service, has\nviewed the details of a job, including the full description. This\nevent doesn't apply to the viewing a snippet of a job appearing as a\npart of the job search results. Viewing a snippet is associated with an\nimpression).",
+            "The job seeker or other entity interacting with the service\nperformed an action to view a job and was redirected to a different\nwebsite for job.",
+            "The job seeker or other entity interacting with the service\nbegan the process or demonstrated the intention of applying for a job.",
+            "The job seeker or other entity interacting with the service\nsubmitted an application for a job.",
+            "The job seeker or other entity interacting with the service\nsubmitted an application for a job with a single click without\nentering information. If a job seeker performs this action, send only\nthis event to the service. Do not also send\nJobEventType.APPLICATION_START or JobEventType.APPLICATION_FINISH\nevents.",
+            "The job seeker or other entity interacting with the service\nperformed an action to apply to a job and was redirected to a different\nwebsite to complete the application.",
+            "The job seeker or other entity interacting with the service began the\nprocess or demonstrated the intention of applying for a job from the\nsearch results page without viewing the details of the job posting.\nIf sending this event, JobEventType.VIEW event shouldn't be sent.",
+            "The job seeker, or other entity interacting with the service, performs an\naction with a single click from the search results page to apply to a job\n(without viewing the details of the job posting), and is redirected\nto a different website to complete the application. If a candidate\nperforms this action, send only this event to the service. Do not also\nsend JobEventType.APPLICATION_START,\nJobEventType.APPLICATION_FINISH or JobEventType.VIEW events.",
+            "This event should be used when a company submits an application\non behalf of a job seeker. This event is intended for use by staffing\nagencies attempting to place candidates.",
+            "The job seeker or other entity interacting with the service demonstrated\nan interest in a job by bookmarking or saving it.",
+            "The job seeker or other entity interacting with the service was\nsent a notification, such as an email alert or device notification,\ncontaining one or more jobs listings generated by the service.",
+            "The job seeker or other entity interacting with the service was\nemployed by the hiring entity (employer). Send this event\nonly if the job seeker was hired through an application that was\ninitiated by a search conducted through the Cloud Talent Solution\nservice.",
+            "A recruiter or staffing agency submitted an application on behalf of the\ncandidate after interacting with the service to identify a suitable job\nposting.",
+            "The entity interacting with the service (for example, the job seeker),\nwas granted an initial interview by the hiring entity (employer). This\nevent should only be sent if the job seeker was granted an interview as\npart of an application that was initiated by a search conducted through /\nrecommendation provided by the Cloud Talent Solution service.",
+            "The job seeker or other entity interacting with the service showed\nno interest in the job."
+          ],
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
     "JobQuery": {
       "description": "Input only.\n\nThe query required to perform a search query.",
       "id": "JobQuery",
diff --git a/jobs/v3/jobs-gen.go b/jobs/v3/jobs-gen.go
index 06f39ed..ce05228 100644
--- a/jobs/v3/jobs-gen.go
+++ b/jobs/v3/jobs-gen.go
@@ -85,6 +85,7 @@
 
 func NewProjectsService(s *Service) *ProjectsService {
 	rs := &ProjectsService{s: s}
+	rs.ClientEvents = NewProjectsClientEventsService(s)
 	rs.Companies = NewProjectsCompaniesService(s)
 	rs.Jobs = NewProjectsJobsService(s)
 	return rs
@@ -93,11 +94,22 @@
 type ProjectsService struct {
 	s *Service
 
+	ClientEvents *ProjectsClientEventsService
+
 	Companies *ProjectsCompaniesService
 
 	Jobs *ProjectsJobsService
 }
 
+func NewProjectsClientEventsService(s *Service) *ProjectsClientEventsService {
+	rs := &ProjectsClientEventsService{s: s}
+	return rs
+}
+
+type ProjectsClientEventsService struct {
+	s *Service
+}
+
 func NewProjectsCompaniesService(s *Service) *ProjectsCompaniesService {
 	rs := &ProjectsCompaniesService{s: s}
 	return rs
@@ -301,6 +313,94 @@
 	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
 }
 
+// ClientEvent: An event issued when an end user interacts with the
+// application that
+// implements Cloud Talent Solution. Providing this information improves
+// the
+// quality of search and recommendation for the API clients, enabling
+// the
+// service to perform optimally. The number of events sent must be
+// consistent
+// with other calls, such as job searches, issued to the service by the
+// client.
+type ClientEvent struct {
+	// CreateTime: Required.
+	//
+	// The timestamp of the event.
+	CreateTime string `json:"createTime,omitempty"`
+
+	// EventId: Required.
+	//
+	// A unique identifier, generated by the client application. This
+	// `event_id`
+	// is used to establish the relationship between different events
+	// (see parent_event_id).
+	EventId string `json:"eventId,omitempty"`
+
+	// ExtraInfo: Optional.
+	//
+	// Extra information about this event. Used for storing information with
+	// no
+	// matching field in event payload, for example, user application
+	// specific
+	// context or details.
+	//
+	// At most 20 keys are supported. The maximum total size of all keys
+	// and
+	// values is 2 KB.
+	ExtraInfo map[string]string `json:"extraInfo,omitempty"`
+
+	// JobEvent: A event issued when a job seeker interacts with the
+	// application that
+	// implements Cloud Talent Solution.
+	JobEvent *JobEvent `json:"jobEvent,omitempty"`
+
+	// ParentEventId: Required except the first event.
+	//
+	// The event_id of an event that resulted in the current event. For
+	// example, a
+	// Job view event usually follows a parent
+	// impression event: A job seeker first does a
+	// search where a list of jobs appears
+	// (impression). The job seeker then selects a
+	// result and views the description of a particular job (Job
+	// view).
+	ParentEventId string `json:"parentEventId,omitempty"`
+
+	// RequestId: Required.
+	//
+	// A unique ID generated in the API responses. It can be found
+	// in
+	// ResponseMetadata.request_id.
+	RequestId string `json:"requestId,omitempty"`
+
+	// ServerResponse contains the HTTP response code and headers from the
+	// server.
+	googleapi.ServerResponse `json:"-"`
+
+	// ForceSendFields is a list of field names (e.g. "CreateTime") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "CreateTime") to include in
+	// API requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *ClientEvent) MarshalJSON() ([]byte, error) {
+	type NoMethod ClientEvent
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
 // CommuteFilter: Input only.
 //
 // Parameters needed for commute search.
@@ -332,7 +432,7 @@
 	//
 	// The departure time used to calculate traffic impact, represented
 	// as
-	// .google.type.TimeOfDay in local time zone.
+	// google.type.TimeOfDay in local time zone.
 	//
 	// Currently traffic model is restricted to hour level resolution.
 	DepartureTime *TimeOfDay `json:"departureTime,omitempty"`
@@ -1106,6 +1206,38 @@
 	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
 }
 
+// CreateClientEventRequest: The report event request.
+type CreateClientEventRequest struct {
+	// ClientEvent: Required.
+	//
+	// Events issued when end user interacts with customer's application
+	// that
+	// uses Cloud Talent Solution.
+	ClientEvent *ClientEvent `json:"clientEvent,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "ClientEvent") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "ClientEvent") to include
+	// in API requests with the JSON null value. By default, fields with
+	// empty values are omitted from API requests. However, any field with
+	// an empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *CreateClientEventRequest) MarshalJSON() ([]byte, error) {
+	type NoMethod CreateClientEventRequest
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
 // CreateCompanyRequest: Input only.
 //
 // The Request of the CreateCompany method.
@@ -2050,11 +2182,10 @@
 	// which
 	// the job is available. If this field is set, a
 	// LocationFilter in a search query within the job region
-	// finds this job posting if an exact location match is not
-	// specified.
-	// If this field is set to PostingRegion.NATION_WIDE
+	// finds this job posting if an exact location match isn't specified.
+	// If this field is set to PostingRegion.NATION
 	// or
-	// [PostingRegion.ADMINISTRATIVE_AREA], setting job addresses
+	// PostingRegion.ADMINISTRATIVE_AREA, setting job Job.addresses
 	// to the same location level as this field is strongly recommended.
 	//
 	// Possible values:
@@ -2300,6 +2431,153 @@
 	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
 }
 
+// JobEvent: An event issued when a job seeker interacts with the
+// application that
+// implements Cloud Talent Solution.
+type JobEvent struct {
+	// Jobs: Required.
+	//
+	// The job name(s) associated with this event.
+	// For example, if this is an impression event,
+	// this field contains the identifiers of all jobs shown to the job
+	// seeker.
+	// If this was a view event, this field contains the
+	// identifier of the viewed job.
+	Jobs []string `json:"jobs,omitempty"`
+
+	// Type: Required.
+	//
+	// The type of the event (see JobEventType).
+	//
+	// Possible values:
+	//   "JOB_EVENT_TYPE_UNSPECIFIED" - The event is unspecified by other
+	// provided values.
+	//   "IMPRESSION" - The job seeker or other entity interacting with the
+	// service has
+	// had a job rendered in their view, such as in a list of search results
+	// in
+	// a compressed or clipped format. This event is typically associated
+	// with
+	// the viewing of a jobs list on a single page by a job seeker.
+	//   "VIEW" - The job seeker, or other entity interacting with the
+	// service, has
+	// viewed the details of a job, including the full description.
+	// This
+	// event doesn't apply to the viewing a snippet of a job appearing as
+	// a
+	// part of the job search results. Viewing a snippet is associated with
+	// an
+	// impression).
+	//   "VIEW_REDIRECT" - The job seeker or other entity interacting with
+	// the service
+	// performed an action to view a job and was redirected to a
+	// different
+	// website for job.
+	//   "APPLICATION_START" - The job seeker or other entity interacting
+	// with the service
+	// began the process or demonstrated the intention of applying for a
+	// job.
+	//   "APPLICATION_FINISH" - The job seeker or other entity interacting
+	// with the service
+	// submitted an application for a job.
+	//   "APPLICATION_QUICK_SUBMISSION" - The job seeker or other entity
+	// interacting with the service
+	// submitted an application for a job with a single click
+	// without
+	// entering information. If a job seeker performs this action, send
+	// only
+	// this event to the service. Do not also
+	// send
+	// JobEventType.APPLICATION_START or
+	// JobEventType.APPLICATION_FINISH
+	// events.
+	//   "APPLICATION_REDIRECT" - The job seeker or other entity interacting
+	// with the service
+	// performed an action to apply to a job and was redirected to a
+	// different
+	// website to complete the application.
+	//   "APPLICATION_START_FROM_SEARCH" - The job seeker or other entity
+	// interacting with the service began the
+	// process or demonstrated the intention of applying for a job from
+	// the
+	// search results page without viewing the details of the job
+	// posting.
+	// If sending this event, JobEventType.VIEW event shouldn't be sent.
+	//   "APPLICATION_REDIRECT_FROM_SEARCH" - The job seeker, or other
+	// entity interacting with the service, performs an
+	// action with a single click from the search results page to apply to a
+	// job
+	// (without viewing the details of the job posting), and is
+	// redirected
+	// to a different website to complete the application. If a
+	// candidate
+	// performs this action, send only this event to the service. Do not
+	// also
+	// send JobEventType.APPLICATION_START,
+	// JobEventType.APPLICATION_FINISH or JobEventType.VIEW events.
+	//   "APPLICATION_COMPANY_SUBMIT" - This event should be used when a
+	// company submits an application
+	// on behalf of a job seeker. This event is intended for use by
+	// staffing
+	// agencies attempting to place candidates.
+	//   "BOOKMARK" - The job seeker or other entity interacting with the
+	// service demonstrated
+	// an interest in a job by bookmarking or saving it.
+	//   "NOTIFICATION" - The job seeker or other entity interacting with
+	// the service was
+	// sent a notification, such as an email alert or device
+	// notification,
+	// containing one or more jobs listings generated by the service.
+	//   "HIRED" - The job seeker or other entity interacting with the
+	// service was
+	// employed by the hiring entity (employer). Send this event
+	// only if the job seeker was hired through an application that
+	// was
+	// initiated by a search conducted through the Cloud Talent
+	// Solution
+	// service.
+	//   "SENT_CV" - A recruiter or staffing agency submitted an application
+	// on behalf of the
+	// candidate after interacting with the service to identify a suitable
+	// job
+	// posting.
+	//   "INTERVIEW_GRANTED" - The entity interacting with the service (for
+	// example, the job seeker),
+	// was granted an initial interview by the hiring entity (employer).
+	// This
+	// event should only be sent if the job seeker was granted an interview
+	// as
+	// part of an application that was initiated by a search conducted
+	// through /
+	// recommendation provided by the Cloud Talent Solution service.
+	//   "NOT_INTERESTED" - The job seeker or other entity interacting with
+	// the service showed
+	// no interest in the job.
+	Type string `json:"type,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "Jobs") to
+	// unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "Jobs") to include in API
+	// requests with the JSON null value. By default, fields with empty
+	// values are omitted from API requests. However, any field with an
+	// empty value appearing in NullFields will be sent to the server as
+	// null. It is an error if a field in this list has a non-empty value.
+	// This may be used to include null fields in Patch requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *JobEvent) MarshalJSON() ([]byte, error) {
+	type NoMethod JobEvent
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
 // JobQuery: Input only.
 //
 // The query required to perform a search query.
@@ -4410,6 +4688,157 @@
 
 }
 
+// method id "jobs.projects.clientEvents.create":
+
+type ProjectsClientEventsCreateCall struct {
+	s                        *Service
+	parent                   string
+	createclienteventrequest *CreateClientEventRequest
+	urlParams_               gensupport.URLParams
+	ctx_                     context.Context
+	header_                  http.Header
+}
+
+// Create: Report events issued when end user interacts with customer's
+// application
+// that uses Cloud Talent Solution. You may inspect the created events
+// in
+// [self
+// service
+// tools](https://console.cloud.google.com/talent-solution/overvi
+// ew).
+// [Learn
+// more](https://cloud.google.com/talent-solution/job-search/
+// docs/management-tools)
+// about self service tools.
+func (r *ProjectsClientEventsService) Create(parent string, createclienteventrequest *CreateClientEventRequest) *ProjectsClientEventsCreateCall {
+	c := &ProjectsClientEventsCreateCall{s: r.s, urlParams_: make(gensupport.URLParams)}
+	c.parent = parent
+	c.createclienteventrequest = createclienteventrequest
+	return c
+}
+
+// Fields allows partial responses to be retrieved. See
+// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
+// for more information.
+func (c *ProjectsClientEventsCreateCall) Fields(s ...googleapi.Field) *ProjectsClientEventsCreateCall {
+	c.urlParams_.Set("fields", googleapi.CombineFields(s))
+	return c
+}
+
+// Context sets the context to be used in this call's Do method. Any
+// pending HTTP request will be aborted if the provided context is
+// canceled.
+func (c *ProjectsClientEventsCreateCall) Context(ctx context.Context) *ProjectsClientEventsCreateCall {
+	c.ctx_ = ctx
+	return c
+}
+
+// Header returns an http.Header that can be modified by the caller to
+// add HTTP headers to the request.
+func (c *ProjectsClientEventsCreateCall) Header() http.Header {
+	if c.header_ == nil {
+		c.header_ = make(http.Header)
+	}
+	return c.header_
+}
+
+func (c *ProjectsClientEventsCreateCall) doRequest(alt string) (*http.Response, error) {
+	reqHeaders := make(http.Header)
+	for k, v := range c.header_ {
+		reqHeaders[k] = v
+	}
+	reqHeaders.Set("User-Agent", c.s.userAgent())
+	var body io.Reader = nil
+	body, err := googleapi.WithoutDataWrapper.JSONReader(c.createclienteventrequest)
+	if err != nil {
+		return nil, err
+	}
+	reqHeaders.Set("Content-Type", "application/json")
+	c.urlParams_.Set("alt", alt)
+	c.urlParams_.Set("prettyPrint", "false")
+	urls := googleapi.ResolveRelative(c.s.BasePath, "v3/{+parent}/clientEvents")
+	urls += "?" + c.urlParams_.Encode()
+	req, err := http.NewRequest("POST", urls, body)
+	if err != nil {
+		return nil, err
+	}
+	req.Header = reqHeaders
+	googleapi.Expand(req.URL, map[string]string{
+		"parent": c.parent,
+	})
+	return gensupport.SendRequest(c.ctx_, c.s.client, req)
+}
+
+// Do executes the "jobs.projects.clientEvents.create" call.
+// Exactly one of *ClientEvent or error will be non-nil. Any non-2xx
+// status code is an error. Response headers are in either
+// *ClientEvent.ServerResponse.Header or (if a response was returned at
+// all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified
+// to check whether the returned error was because
+// http.StatusNotModified was returned.
+func (c *ProjectsClientEventsCreateCall) Do(opts ...googleapi.CallOption) (*ClientEvent, error) {
+	gensupport.SetOptions(c.urlParams_, opts...)
+	res, err := c.doRequest("json")
+	if res != nil && res.StatusCode == http.StatusNotModified {
+		if res.Body != nil {
+			res.Body.Close()
+		}
+		return nil, &googleapi.Error{
+			Code:   res.StatusCode,
+			Header: res.Header,
+		}
+	}
+	if err != nil {
+		return nil, err
+	}
+	defer googleapi.CloseBody(res)
+	if err := googleapi.CheckResponse(res); err != nil {
+		return nil, err
+	}
+	ret := &ClientEvent{
+		ServerResponse: googleapi.ServerResponse{
+			Header:         res.Header,
+			HTTPStatusCode: res.StatusCode,
+		},
+	}
+	target := &ret
+	if err := gensupport.DecodeResponse(target, res); err != nil {
+		return nil, err
+	}
+	return ret, nil
+	// {
+	//   "description": "Report events issued when end user interacts with customer's application\nthat uses Cloud Talent Solution. You may inspect the created events in\n[self service\ntools](https://console.cloud.google.com/talent-solution/overview).\n[Learn\nmore](https://cloud.google.com/talent-solution/job-search/docs/management-tools)\nabout self service tools.",
+	//   "flatPath": "v3/projects/{projectsId}/clientEvents",
+	//   "httpMethod": "POST",
+	//   "id": "jobs.projects.clientEvents.create",
+	//   "parameterOrder": [
+	//     "parent"
+	//   ],
+	//   "parameters": {
+	//     "parent": {
+	//       "description": "Parent project name.",
+	//       "location": "path",
+	//       "pattern": "^projects/[^/]+$",
+	//       "required": true,
+	//       "type": "string"
+	//     }
+	//   },
+	//   "path": "v3/{+parent}/clientEvents",
+	//   "request": {
+	//     "$ref": "CreateClientEventRequest"
+	//   },
+	//   "response": {
+	//     "$ref": "ClientEvent"
+	//   },
+	//   "scopes": [
+	//     "https://www.googleapis.com/auth/cloud-platform",
+	//     "https://www.googleapis.com/auth/jobs"
+	//   ]
+	// }
+
+}
+
 // method id "jobs.projects.companies.create":
 
 type ProjectsCompaniesCreateCall struct {
diff --git a/jobs/v3p1beta1/jobs-api.json b/jobs/v3p1beta1/jobs-api.json
index 2f3f35a..9836c77 100644
--- a/jobs/v3p1beta1/jobs-api.json
+++ b/jobs/v3p1beta1/jobs-api.json
@@ -662,7 +662,7 @@
       }
     }
   },
-  "revision": "20190110",
+  "revision": "20190130",
   "rootUrl": "https://jobs.googleapis.com/",
   "schemas": {
     "ApplicationInfo": {
@@ -793,7 +793,7 @@
         },
         "departureTime": {
           "$ref": "TimeOfDay",
-          "description": "Optional.\n\nThe departure time used to calculate traffic impact, represented as\n.google.type.TimeOfDay in local time zone.\n\nCurrently traffic model is restricted to hour level resolution."
+          "description": "Optional.\n\nThe departure time used to calculate traffic impact, represented as\ngoogle.type.TimeOfDay in local time zone.\n\nCurrently traffic model is restricted to hour level resolution."
         },
         "roadTraffic": {
           "description": "Optional.\n\nSpecifies the traffic density to use when calculating commute time.",
@@ -1759,7 +1759,7 @@
           "type": "string"
         },
         "postingRegion": {
-          "description": "Optional.\n\nThe job PostingRegion (for example, state, country) throughout which\nthe job is available. If this field is set, a\nLocationFilter in a search query within the job region\nfinds this job posting if an exact location match is not specified.\nIf this field is set to PostingRegion.NATION_WIDE or\n[PostingRegion.ADMINISTRATIVE_AREA], setting job addresses\nto the same location level as this field is strongly recommended.",
+          "description": "Optional.\n\nThe job PostingRegion (for example, state, country) throughout which\nthe job is available. If this field is set, a\nLocationFilter in a search query within the job region\nfinds this job posting if an exact location match isn't specified.\nIf this field is set to PostingRegion.NATION or\nPostingRegion.ADMINISTRATIVE_AREA, setting job Job.addresses\nto the same location level as this field is strongly recommended.",
           "enum": [
             "POSTING_REGION_UNSPECIFIED",
             "ADMINISTRATIVE_AREA",
diff --git a/jobs/v3p1beta1/jobs-gen.go b/jobs/v3p1beta1/jobs-gen.go
index 70a1e03..2cc39d6 100644
--- a/jobs/v3p1beta1/jobs-gen.go
+++ b/jobs/v3p1beta1/jobs-gen.go
@@ -444,7 +444,7 @@
 	//
 	// The departure time used to calculate traffic impact, represented
 	// as
-	// .google.type.TimeOfDay in local time zone.
+	// google.type.TimeOfDay in local time zone.
 	//
 	// Currently traffic model is restricted to hour level resolution.
 	DepartureTime *TimeOfDay `json:"departureTime,omitempty"`
@@ -2493,11 +2493,10 @@
 	// which
 	// the job is available. If this field is set, a
 	// LocationFilter in a search query within the job region
-	// finds this job posting if an exact location match is not
-	// specified.
-	// If this field is set to PostingRegion.NATION_WIDE
+	// finds this job posting if an exact location match isn't specified.
+	// If this field is set to PostingRegion.NATION
 	// or
-	// [PostingRegion.ADMINISTRATIVE_AREA], setting job addresses
+	// PostingRegion.ADMINISTRATIVE_AREA, setting job Job.addresses
 	// to the same location level as this field is strongly recommended.
 	//
 	// Possible values:
diff --git a/ml/v1/ml-api.json b/ml/v1/ml-api.json
index e9c7d0a..0cec194 100644
--- a/ml/v1/ml-api.json
+++ b/ml/v1/ml-api.json
@@ -1019,7 +1019,7 @@
       }
     }
   },
-  "revision": "20190123",
+  "revision": "20190126",
   "rootUrl": "https://ml.googleapis.com/",
   "schemas": {
     "GoogleApi__HttpBody": {
@@ -1082,6 +1082,7 @@
             "NVIDIA_TESLA_K80",
             "NVIDIA_TESLA_P100",
             "NVIDIA_TESLA_V100",
+            "NVIDIA_TESLA_P4",
             "TPU_V2"
           ],
           "enumDescriptions": [
@@ -1089,6 +1090,7 @@
             "Nvidia Tesla K80 GPU.",
             "Nvidia Tesla P100 GPU.",
             "Nvidia Tesla V100 GPU.",
+            "Nvidia Tesla P4 GPU.",
             "TPU V2"
           ],
           "type": "string"
@@ -1124,6 +1126,7 @@
             "Nvidia Tesla K80 GPU.",
             "Nvidia Tesla P100 GPU.",
             "Nvidia Tesla V100 GPU.",
+            "Nvidia Tesla P4 GPU.",
             "TPU V2"
           ],
           "items": {
@@ -1132,6 +1135,7 @@
               "NVIDIA_TESLA_K80",
               "NVIDIA_TESLA_P100",
               "NVIDIA_TESLA_V100",
+              "NVIDIA_TESLA_P4",
               "TPU_V2"
             ],
             "type": "string"
@@ -1776,6 +1780,20 @@
       },
       "type": "object"
     },
+    "GoogleCloudMlV1__ReplicaConfig": {
+      "description": "Represents the configration for a replica in a cluster.",
+      "id": "GoogleCloudMlV1__ReplicaConfig",
+      "properties": {
+        "acceleratorConfig": {
+          "$ref": "GoogleCloudMlV1__AcceleratorConfig"
+        },
+        "imageUri": {
+          "description": "The docker image to run on worker.\nThis image must be in Google Container Registry.",
+          "type": "string"
+        }
+      },
+      "type": "object"
+    },
     "GoogleCloudMlV1__SetDefaultVersionRequest": {
       "description": "Request message for the SetDefaultVersion request.",
       "id": "GoogleCloudMlV1__SetDefaultVersionRequest",
@@ -1801,6 +1819,10 @@
           "description": "Optional. A Google Cloud Storage path in which to store training outputs\nand other data needed for training. This path is passed to your TensorFlow\nprogram as the '--job-dir' command-line argument. The benefit of specifying\nthis field is that Cloud ML validates the path for use in training.",
           "type": "string"
         },
+        "masterConfig": {
+          "$ref": "GoogleCloudMlV1__ReplicaConfig",
+          "description": "Optional. The configuration for master.\n\nOnly one of `masterConfig.imageUri` and `runtimeVersion` should be\nset."
+        },
         "masterType": {
           "description": "Optional. Specifies the type of virtual machine to use for your training\njob's master worker.\n\nThe following types are supported:\n\n\u003cdl\u003e\n  \u003cdt\u003estandard\u003c/dt\u003e\n  \u003cdd\u003e\n  A basic machine configuration suitable for training simple models with\n  small to moderate datasets.\n  \u003c/dd\u003e\n  \u003cdt\u003elarge_model\u003c/dt\u003e\n  \u003cdd\u003e\n  A machine with a lot of memory, specially suited for parameter servers\n  when your model is large (having many hidden layers or layers with very\n  large numbers of nodes).\n  \u003c/dd\u003e\n  \u003cdt\u003ecomplex_model_s\u003c/dt\u003e\n  \u003cdd\u003e\n  A machine suitable for the master and workers of the cluster when your\n  model requires more computation than the standard machine can handle\n  satisfactorily.\n  \u003c/dd\u003e\n  \u003cdt\u003ecomplex_model_m\u003c/dt\u003e\n  \u003cdd\u003e\n  A machine with roughly twice the number of cores and roughly double the\n  memory of \u003ci\u003ecomplex_model_s\u003c/i\u003e.\n  \u003c/dd\u003e\n  \u003cdt\u003ecomplex_model_l\u003c/dt\u003e\n  \u003cdd\u003e\n  A machine with roughly twice the number of cores and roughly double the\n  memory of \u003ci\u003ecomplex_model_m\u003c/i\u003e.\n  \u003c/dd\u003e\n  \u003cdt\u003estandard_gpu\u003c/dt\u003e\n  \u003cdd\u003e\n  A machine equivalent to \u003ci\u003estandard\u003c/i\u003e that\n  also includes a single NVIDIA Tesla K80 GPU. See more about\n  \u003ca href=\"/ml-engine/docs/tensorflow/using-gpus\"\u003eusing GPUs to\n  train your model\u003c/a\u003e.\n  \u003c/dd\u003e\n  \u003cdt\u003ecomplex_model_m_gpu\u003c/dt\u003e\n  \u003cdd\u003e\n  A machine equivalent to \u003ci\u003ecomplex_model_m\u003c/i\u003e that also includes\n  four NVIDIA Tesla K80 GPUs.\n  \u003c/dd\u003e\n  \u003cdt\u003ecomplex_model_l_gpu\u003c/dt\u003e\n  \u003cdd\u003e\n  A machine equivalent to \u003ci\u003ecomplex_model_l\u003c/i\u003e that also includes\n  eight NVIDIA Tesla K80 GPUs.\n  \u003c/dd\u003e\n  \u003cdt\u003estandard_p100\u003c/dt\u003e\n  \u003cdd\u003e\n  A machine equivalent to \u003ci\u003estandard\u003c/i\u003e that\n  also includes a single NVIDIA Tesla P100 GPU.\n  \u003c/dd\u003e\n  \u003cdt\u003ecomplex_model_m_p100\u003c/dt\u003e\n  \u003cdd\u003e\n  A machine equivalent to \u003ci\u003ecomplex_model_m\u003c/i\u003e that also includes\n  four NVIDIA Tesla P100 GPUs.\n  \u003c/dd\u003e\n  \u003cdt\u003estandard_v100\u003c/dt\u003e\n  \u003cdd\u003e\n  A machine equivalent to \u003ci\u003estandard\u003c/i\u003e that\n  also includes a single NVIDIA Tesla V100 GPU.\n  \u003c/dd\u003e\n  \u003cdt\u003elarge_model_v100\u003c/dt\u003e\n  \u003cdd\u003e\n  A machine equivalent to \u003ci\u003elarge_model\u003c/i\u003e that\n  also includes a single NVIDIA Tesla V100 GPU.\n  \u003c/dd\u003e\n  \u003cdt\u003ecomplex_model_m_v100\u003c/dt\u003e\n  \u003cdd\u003e\n  A machine equivalent to \u003ci\u003ecomplex_model_m\u003c/i\u003e that\n  also includes four NVIDIA Tesla V100 GPUs.\n  \u003c/dd\u003e\n  \u003cdt\u003ecomplex_model_l_v100\u003c/dt\u003e\n  \u003cdd\u003e\n  A machine equivalent to \u003ci\u003ecomplex_model_l\u003c/i\u003e that\n  also includes eight NVIDIA Tesla V100 GPUs.\n  \u003c/dd\u003e\n  \u003cdt\u003ecloud_tpu\u003c/dt\u003e\n  \u003cdd\u003e\n  A TPU VM including one Cloud TPU. See more about\n  \u003ca href=\"/ml-engine/docs/tensorflow/using-tpus\"\u003eusing TPUs to train\n  your model\u003c/a\u003e.\n  \u003c/dd\u003e\n\u003c/dl\u003e\n\nYou must set this value when `scaleTier` is set to `CUSTOM`.",
           "type": "string"
@@ -1812,6 +1834,10 @@
           },
           "type": "array"
         },
+        "parameterServerConfig": {
+          "$ref": "GoogleCloudMlV1__ReplicaConfig",
+          "description": "Optional. The config of parameter servers.\n\nIf `parameterServerConfig.imageUri` has not been set, the value of\n`masterConfig.imageUri` will be used."
+        },
         "parameterServerCount": {
           "description": "Optional. The number of parameter server replicas to use for the training\njob. Each replica in the cluster will be of the type specified in\n`parameter_server_type`.\n\nThis value can only be used when `scale_tier` is set to `CUSTOM`.If you\nset this value, you must also set `parameter_server_type`.\n\nThe default value is zero.",
           "format": "int64",
@@ -1857,6 +1883,10 @@
           ],
           "type": "string"
         },
+        "workerConfig": {
+          "$ref": "GoogleCloudMlV1__ReplicaConfig",
+          "description": "Optional. The configrations for workers.\n\nIf `workerConfig.imageUri` has not been set, the value of\n`masterConfig.imageUri` will be used."
+        },
         "workerCount": {
           "description": "Optional. The number of worker replicas to use for the training job. Each\nreplica in the cluster will be of the type specified in `worker_type`.\n\nThis value can only be used when `scale_tier` is set to `CUSTOM`. If you\nset this value, you must also set `worker_type`.\n\nThe default value is zero.",
           "format": "int64",
diff --git a/ml/v1/ml-gen.go b/ml/v1/ml-gen.go
index 58d3fcc..62aadbb 100644
--- a/ml/v1/ml-gen.go
+++ b/ml/v1/ml-gen.go
@@ -309,6 +309,7 @@
 	//   "NVIDIA_TESLA_K80" - Nvidia Tesla K80 GPU.
 	//   "NVIDIA_TESLA_P100" - Nvidia Tesla P100 GPU.
 	//   "NVIDIA_TESLA_V100" - Nvidia Tesla V100 GPU.
+	//   "NVIDIA_TESLA_P4" - Nvidia Tesla P4 GPU.
 	//   "TPU_V2" - TPU V2
 	Type string `json:"type,omitempty"`
 
@@ -424,6 +425,7 @@
 	//   "NVIDIA_TESLA_K80" - Nvidia Tesla K80 GPU.
 	//   "NVIDIA_TESLA_P100" - Nvidia Tesla P100 GPU.
 	//   "NVIDIA_TESLA_V100" - Nvidia Tesla V100 GPU.
+	//   "NVIDIA_TESLA_P4" - Nvidia Tesla P4 GPU.
 	//   "TPU_V2" - TPU V2
 	AvailableAccelerators []string `json:"availableAccelerators,omitempty"`
 
@@ -1504,6 +1506,39 @@
 	return nil
 }
 
+// GoogleCloudMlV1__ReplicaConfig: Represents the configration for a
+// replica in a cluster.
+type GoogleCloudMlV1__ReplicaConfig struct {
+	AcceleratorConfig *GoogleCloudMlV1__AcceleratorConfig `json:"acceleratorConfig,omitempty"`
+
+	// ImageUri: The docker image to run on worker.
+	// This image must be in Google Container Registry.
+	ImageUri string `json:"imageUri,omitempty"`
+
+	// ForceSendFields is a list of field names (e.g. "AcceleratorConfig")
+	// to unconditionally include in API requests. By default, fields with
+	// empty values are omitted from API requests. However, any non-pointer,
+	// non-interface field appearing in ForceSendFields will be sent to the
+	// server regardless of whether the field is empty or not. This may be
+	// used to include empty fields in Patch requests.
+	ForceSendFields []string `json:"-"`
+
+	// NullFields is a list of field names (e.g. "AcceleratorConfig") to
+	// include in API requests with the JSON null value. By default, fields
+	// with empty values are omitted from API requests. However, any field
+	// with an empty value appearing in NullFields will be sent to the
+	// server as null. It is an error if a field in this list has a
+	// non-empty value. This may be used to include null fields in Patch
+	// requests.
+	NullFields []string `json:"-"`
+}
+
+func (s *GoogleCloudMlV1__ReplicaConfig) MarshalJSON() ([]byte, error) {
+	type NoMethod GoogleCloudMlV1__ReplicaConfig
+	raw := NoMethod(*s)
+	return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
+}
+
 // GoogleCloudMlV1__SetDefaultVersionRequest: Request message for the
 // SetDefaultVersion request.
 type GoogleCloudMlV1__SetDefaultVersionRequest struct {
@@ -1535,6 +1570,13 @@
 	// this field is that Cloud ML validates the path for use in training.
 	JobDir string `json:"jobDir,omitempty"`
 
+	// MasterConfig: Optional. The configuration for master.
+	//
+	// Only one of `masterConfig.imageUri` and `runtimeVersion` should
+	// be
+	// set.
+	MasterConfig *GoogleCloudMlV1__ReplicaConfig `json:"masterConfig,omitempty"`
+
 	// MasterType: Optional. Specifies the type of virtual machine to use
 	// for your training
 	// job's master worker.
@@ -1641,6 +1683,13 @@
 	// The maximum number of package URIs is 100.
 	PackageUris []string `json:"packageUris,omitempty"`
 
+	// ParameterServerConfig: Optional. The config of parameter servers.
+	//
+	// If `parameterServerConfig.imageUri` has not been set, the value
+	// of
+	// `masterConfig.imageUri` will be used.
+	ParameterServerConfig *GoogleCloudMlV1__ReplicaConfig `json:"parameterServerConfig,omitempty"`
+
 	// ParameterServerCount: Optional. The number of parameter server
 	// replicas to use for the training
 	// job. Each replica in the cluster will be of the type specified
@@ -1750,6 +1799,13 @@
 	// different from your worker type and master type.
 	ScaleTier string `json:"scaleTier,omitempty"`
 
+	// WorkerConfig: Optional. The configrations for workers.
+	//
+	// If `workerConfig.imageUri` has not been set, the value
+	// of
+	// `masterConfig.imageUri` will be used.
+	WorkerConfig *GoogleCloudMlV1__ReplicaConfig `json:"workerConfig,omitempty"`
+
 	// WorkerCount: Optional. The number of worker replicas to use for the
 	// training job. Each
 	// replica in the cluster will be of the type specified in
diff --git a/redis/v1/redis-api.json b/redis/v1/redis-api.json
index 6adcca8..3cb4231 100644
--- a/redis/v1/redis-api.json
+++ b/redis/v1/redis-api.json
@@ -458,7 +458,7 @@
       }
     }
   },
-  "revision": "20181203",
+  "revision": "20190128",
   "rootUrl": "https://redis.googleapis.com/",
   "schemas": {
     "Empty": {
@@ -610,7 +610,7 @@
             "Redis instance has been created and is fully usable.",
             "Redis instance configuration is being updated. Certain kinds of updates\nmay cause the instance to become unusable while the update is in\nprogress.",
             "Redis instance is being deleted.",
-            "Redis instance is being repaired and may be unusable. Details can be\nfound in the `status_message` field.",
+            "Redis instance is being repaired and may be unusable.",
             "Maintenance is being performed on this Redis instance."
           ],
           "type": "string"
diff --git a/redis/v1/redis-gen.go b/redis/v1/redis-gen.go
index 6c925dd..7d82260 100644
--- a/redis/v1/redis-gen.go
+++ b/redis/v1/redis-gen.go
@@ -358,8 +358,6 @@
 	// progress.
 	//   "DELETING" - Redis instance is being deleted.
 	//   "REPAIRING" - Redis instance is being repaired and may be unusable.
-	// Details can be
-	// found in the `status_message` field.
 	//   "MAINTENANCE" - Maintenance is being performed on this Redis
 	// instance.
 	State string `json:"state,omitempty"`
diff --git a/redis/v1beta1/redis-api.json b/redis/v1beta1/redis-api.json
index ec76c5f..a5a071a 100644
--- a/redis/v1beta1/redis-api.json
+++ b/redis/v1beta1/redis-api.json
@@ -458,7 +458,7 @@
       }
     }
   },
-  "revision": "20181203",
+  "revision": "20190128",
   "rootUrl": "https://redis.googleapis.com/",
   "schemas": {
     "Empty": {
@@ -574,7 +574,7 @@
           "type": "string"
         },
         "persistenceIamIdentity": {
-          "description": "Output only. IAM identity used by import / export operations to transfer\ndata to/from GCS.  Format is \"serviceAccount:\u003cservice_account_email\u003e\".  The\nvalue may change over time for a given instance so should be checked before\neach import/export operation.",
+          "description": "Output only. Cloud IAM identity used by import / export operations to\ntransfer data to/from Cloud Storage. Format is\n\"serviceAccount:\u003cservice_account_email\u003e\". The value may change over time\nfor a given instance so should be checked before each import/export\noperation.",
           "type": "string"
         },
         "port": {
@@ -615,7 +615,7 @@
             "Redis instance has been created and is fully usable.",
             "Redis instance configuration is being updated. Certain kinds of updates\nmay cause the instance to become unusable while the update is in\nprogress.",
             "Redis instance is being deleted.",
-            "Redis instance is being repaired and may be unusable. Details can be\nfound in the `status_message` field.",
+            "Redis instance is being repaired and may be unusable.",
             "Maintenance is being performed on this Redis instance.",
             "Redis instance is importing data (availability may be affected)."
           ],
diff --git a/redis/v1beta1/redis-gen.go b/redis/v1beta1/redis-gen.go
index 626768a..a012579 100644
--- a/redis/v1beta1/redis-gen.go
+++ b/redis/v1beta1/redis-gen.go
@@ -323,13 +323,15 @@
 	// [alternative_location_id] fields for more details.
 	Name string `json:"name,omitempty"`
 
-	// PersistenceIamIdentity: Output only. IAM identity used by import /
-	// export operations to transfer
-	// data to/from GCS.  Format is
-	// "serviceAccount:<service_account_email>".  The
-	// value may change over time for a given instance so should be checked
-	// before
-	// each import/export operation.
+	// PersistenceIamIdentity: Output only. Cloud IAM identity used by
+	// import / export operations to
+	// transfer data to/from Cloud Storage. Format
+	// is
+	// "serviceAccount:<service_account_email>". The value may change over
+	// time
+	// for a given instance so should be checked before each
+	// import/export
+	// operation.
 	PersistenceIamIdentity string `json:"persistenceIamIdentity,omitempty"`
 
 	// Port: Output only. The port number of the exposed Redis endpoint.
@@ -374,8 +376,6 @@
 	// progress.
 	//   "DELETING" - Redis instance is being deleted.
 	//   "REPAIRING" - Redis instance is being repaired and may be unusable.
-	// Details can be
-	// found in the `status_message` field.
 	//   "MAINTENANCE" - Maintenance is being performed on this Redis
 	// instance.
 	//   "IMPORTING" - Redis instance is importing data (availability may be
diff --git a/remotebuildexecution/v1/remotebuildexecution-api.json b/remotebuildexecution/v1/remotebuildexecution-api.json
index 186190b..9f15720 100644
--- a/remotebuildexecution/v1/remotebuildexecution-api.json
+++ b/remotebuildexecution/v1/remotebuildexecution-api.json
@@ -337,7 +337,7 @@
       }
     }
   },
-  "revision": "20190116",
+  "revision": "20190122",
   "rootUrl": "https://remotebuildexecution.googleapis.com/",
   "schemas": {
     "BuildBazelRemoteExecutionV2Action": {
@@ -1115,7 +1115,7 @@
           "type": "string"
         },
         "machineType": {
-          "description": "Required. Machine type of the worker, such as n1-standard-2.\nSee https://cloud.google.com/compute/docs/machine-types for a list of\nsupported machine types.",
+          "description": "Required. Machine type of the worker, such as `n1-standard-2`.\nSee https://cloud.google.com/compute/docs/machine-types for a list of\nsupported machine types. Note that `f1-micro` and `g1-small` are not yet\nsupported.",
           "type": "string"
         },
         "minCpuPlatform": {
diff --git a/remotebuildexecution/v1/remotebuildexecution-gen.go b/remotebuildexecution/v1/remotebuildexecution-gen.go
index fb5583e..91ef03d 100644
--- a/remotebuildexecution/v1/remotebuildexecution-gen.go
+++ b/remotebuildexecution/v1/remotebuildexecution-gen.go
@@ -2115,10 +2115,12 @@
 	DiskType string `json:"diskType,omitempty"`
 
 	// MachineType: Required. Machine type of the worker, such as
-	// n1-standard-2.
+	// `n1-standard-2`.
 	// See https://cloud.google.com/compute/docs/machine-types for a list
 	// of
-	// supported machine types.
+	// supported machine types. Note that `f1-micro` and `g1-small` are not
+	// yet
+	// supported.
 	MachineType string `json:"machineType,omitempty"`
 
 	// MinCpuPlatform: Minimum CPU platform to use when creating the
diff --git a/remotebuildexecution/v1alpha/remotebuildexecution-api.json b/remotebuildexecution/v1alpha/remotebuildexecution-api.json
index 4c0ca8c..e05ff31 100644
--- a/remotebuildexecution/v1alpha/remotebuildexecution-api.json
+++ b/remotebuildexecution/v1alpha/remotebuildexecution-api.json
@@ -382,7 +382,7 @@
       }
     }
   },
-  "revision": "20190116",
+  "revision": "20190122",
   "rootUrl": "https://admin-remotebuildexecution.googleapis.com/",
   "schemas": {
     "BuildBazelRemoteExecutionV2Action": {
@@ -1149,7 +1149,7 @@
           "type": "string"
         },
         "machineType": {
-          "description": "Required. Machine type of the worker, such as n1-standard-2.\nSee https://cloud.google.com/compute/docs/machine-types for a list of\nsupported machine types.",
+          "description": "Required. Machine type of the worker, such as `n1-standard-2`.\nSee https://cloud.google.com/compute/docs/machine-types for a list of\nsupported machine types. Note that `f1-micro` and `g1-small` are not yet\nsupported.",
           "type": "string"
         },
         "minCpuPlatform": {
diff --git a/remotebuildexecution/v1alpha/remotebuildexecution-gen.go b/remotebuildexecution/v1alpha/remotebuildexecution-gen.go
index 7f61995..8708332 100644
--- a/remotebuildexecution/v1alpha/remotebuildexecution-gen.go
+++ b/remotebuildexecution/v1alpha/remotebuildexecution-gen.go
@@ -2083,10 +2083,12 @@
 	DiskType string `json:"diskType,omitempty"`
 
 	// MachineType: Required. Machine type of the worker, such as
-	// n1-standard-2.
+	// `n1-standard-2`.
 	// See https://cloud.google.com/compute/docs/machine-types for a list
 	// of
-	// supported machine types.
+	// supported machine types. Note that `f1-micro` and `g1-small` are not
+	// yet
+	// supported.
 	MachineType string `json:"machineType,omitempty"`
 
 	// MinCpuPlatform: Minimum CPU platform to use when creating the
diff --git a/remotebuildexecution/v2/remotebuildexecution-api.json b/remotebuildexecution/v2/remotebuildexecution-api.json
index 77d1d25..774b0a9 100644
--- a/remotebuildexecution/v2/remotebuildexecution-api.json
+++ b/remotebuildexecution/v2/remotebuildexecution-api.json
@@ -430,7 +430,7 @@
       }
     }
   },
-  "revision": "20190116",
+  "revision": "20190122",
   "rootUrl": "https://remotebuildexecution.googleapis.com/",
   "schemas": {
     "BuildBazelRemoteExecutionV2Action": {
@@ -1578,7 +1578,7 @@
           "type": "string"
         },
         "machineType": {
-          "description": "Required. Machine type of the worker, such as n1-standard-2.\nSee https://cloud.google.com/compute/docs/machine-types for a list of\nsupported machine types.",
+          "description": "Required. Machine type of the worker, such as `n1-standard-2`.\nSee https://cloud.google.com/compute/docs/machine-types for a list of\nsupported machine types. Note that `f1-micro` and `g1-small` are not yet\nsupported.",
           "type": "string"
         },
         "minCpuPlatform": {
diff --git a/remotebuildexecution/v2/remotebuildexecution-gen.go b/remotebuildexecution/v2/remotebuildexecution-gen.go
index 4ceb87b..a01905f 100644
--- a/remotebuildexecution/v2/remotebuildexecution-gen.go
+++ b/remotebuildexecution/v2/remotebuildexecution-gen.go
@@ -2856,10 +2856,12 @@
 	DiskType string `json:"diskType,omitempty"`
 
 	// MachineType: Required. Machine type of the worker, such as
-	// n1-standard-2.
+	// `n1-standard-2`.
 	// See https://cloud.google.com/compute/docs/machine-types for a list
 	// of
-	// supported machine types.
+	// supported machine types. Note that `f1-micro` and `g1-small` are not
+	// yet
+	// supported.
 	MachineType string `json:"machineType,omitempty"`
 
 	// MinCpuPlatform: Minimum CPU platform to use when creating the
diff --git a/servicenetworking/v1beta/servicenetworking-api.json b/servicenetworking/v1beta/servicenetworking-api.json
index 662af27..2b54ee8 100644
--- a/servicenetworking/v1beta/servicenetworking-api.json
+++ b/servicenetworking/v1beta/servicenetworking-api.json
@@ -168,11 +168,40 @@
             "https://www.googleapis.com/auth/service.management"
           ]
         },
-        "patch": {
+        "searchRange": {
+          "description": "Service producers can use this method to find a currently unused range\nwithin consumer allocated ranges.   This returned range is not reserved,\nand not guaranteed to remain unused.\nIt will validate previously provided allocated ranges, find\nnon-conflicting sub-range of requested size (expressed in\nnumber of leading bits of ipv4 network mask, as in CIDR range\nnotation).\nOperation\u003cresponse: Range\u003e",
+          "flatPath": "v1beta/services/{servicesId}:searchRange",
+          "httpMethod": "POST",
+          "id": "servicenetworking.services.searchRange",
+          "parameterOrder": [
+            "parent"
+          ],
+          "parameters": {
+            "parent": {
+              "description": "Required. This is in a form services/{service}.\n{service} the name of the private access management service, for example\n'service-peering.example.com'.",
+              "location": "path",
+              "pattern": "^services/[^/]+$",
+              "required": true,
+              "type": "string"
+            }
+          },
+          "path": "v1beta/{+parent}:searchRange",
+          "request": {
+            "$ref": "SearchRangeRequest"
+          },
+          "response": {
+            "$ref": "Operation"
+          },
+          "scopes": [
+            "https://www.googleapis.com/auth/cloud-platform",
+            "https://www.googleapis.com/auth/service.management"
+          ]
+        },
+        "updateConnections": {
           "description": "Updates the allocated ranges that are assigned to a connection.\nThe response from the `get` operation will be of type `Connection` if the\noperation successfully completes.",
-          "flatPath": "v1beta/services/{servicesId}",
+          "flatPath": "v1beta/services/{servicesId}/connections",
           "httpMethod": "PATCH",
-          "id": "servicenetworking.services.patch",
+          "id": "servicenetworking.services.updateConnections",
           "parameterOrder": [
             "name"
           ],
@@ -196,7 +225,7 @@
               "type": "string"
             }
           },
-          "path": "v1beta/{+name}",
+          "path": "v1beta/{+name}/connections",
           "request": {
             "$ref": "Connection"
           },
@@ -207,35 +236,6 @@
             "https://www.googleapis.com/auth/cloud-platform",
             "https://www.googleapis.com/auth/service.management"
           ]
-        },
-        "searchRange": {
-          "description": "Service producers can use this method to find a currently unused range\nwithin consumer allocated ranges.   This returned range is not reserved,\nand not guaranteed to remain unused.\nIt will validate previously provided allocated ranges, find\nnon-conflicting sub-range of requested size (expressed in\nnumber of leading bits of ipv4 network mask, as in CIDR range\nnotation).\nOperation\u003cresponse: Range\u003e",
-          "flatPath": "v1beta/services/{servicesId}:searchRange",
-          "httpMethod": "POST",
-          "id": "servicenetworking.services.searchRange",
-          "parameterOrder": [
-            "parent"
-          ],
-          "parameters": {
-            "parent": {
-              "description": "Required. This is in a form services/{service}.\n{service} the name of the private access management service, for example\n'service-peering.example.com'.",
-              "location": "path",
-              "pattern": "^services/[^/]+$",
-              "required": true,
-              "type": "string"
-            }
-          },
-          "path": "v1beta/{+parent}:searchRange",
-          "request": {
-            "$ref": "SearchRangeRequest"
-          },
-          "response": {
-            "$ref": "Operation"
-          },
-          "scopes": [
-            "https://www.googleapis.com/auth/cloud-platform",
-            "https://www.googleapis.com/auth/service.management"
-          ]
         }
       },
       "resources": {
@@ -306,7 +306,7 @@
       }
     }
   },
-  "revision": "20190114",
+  "revision": "20190128",
   "rootUrl": "https://servicenetworking.googleapis.com/",
   "schemas": {
     "AddSubnetworkRequest": {
diff --git a/servicenetworking/v1beta/servicenetworking-gen.go b/servicenetworking/v1beta/servicenetworking-gen.go
index b7c4fb2..5f8b78a 100644
--- a/servicenetworking/v1beta/servicenetworking-gen.go
+++ b/servicenetworking/v1beta/servicenetworking-gen.go
@@ -4722,177 +4722,6 @@
 
 }
 
-// method id "servicenetworking.services.patch":
-
-type ServicesPatchCall struct {
-	s          *APIService
-	name       string
-	connection *Connection
-	urlParams_ gensupport.URLParams
-	ctx_       context.Context
-	header_    http.Header
-}
-
-// Patch: Updates the allocated ranges that are assigned to a
-// connection.
-// The response from the `get` operation will be of type `Connection` if
-// the
-// operation successfully completes.
-func (r *ServicesService) Patch(name string, connection *Connection) *ServicesPatchCall {
-	c := &ServicesPatchCall{s: r.s, urlParams_: make(gensupport.URLParams)}
-	c.name = name
-	c.connection = connection
-	return c
-}
-
-// Force sets the optional parameter "force": If a previously defined
-// allocated range is removed, force flag must be
-// set to true.
-func (c *ServicesPatchCall) Force(force bool) *ServicesPatchCall {
-	c.urlParams_.Set("force", fmt.Sprint(force))
-	return c
-}
-
-// UpdateMask sets the optional parameter "updateMask": The update mask.
-// If this is omitted, it defaults to "*". You can only
-// update the listed peering ranges.
-func (c *ServicesPatchCall) UpdateMask(updateMask string) *ServicesPatchCall {
-	c.urlParams_.Set("updateMask", updateMask)
-	return c
-}
-
-// Fields allows partial responses to be retrieved. See
-// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
-// for more information.
-func (c *ServicesPatchCall) Fields(s ...googleapi.Field) *ServicesPatchCall {
-	c.urlParams_.Set("fields", googleapi.CombineFields(s))
-	return c
-}
-
-// Context sets the context to be used in this call's Do method. Any
-// pending HTTP request will be aborted if the provided context is
-// canceled.
-func (c *ServicesPatchCall) Context(ctx context.Context) *ServicesPatchCall {
-	c.ctx_ = ctx
-	return c
-}
-
-// Header returns an http.Header that can be modified by the caller to
-// add HTTP headers to the request.
-func (c *ServicesPatchCall) Header() http.Header {
-	if c.header_ == nil {
-		c.header_ = make(http.Header)
-	}
-	return c.header_
-}
-
-func (c *ServicesPatchCall) doRequest(alt string) (*http.Response, error) {
-	reqHeaders := make(http.Header)
-	for k, v := range c.header_ {
-		reqHeaders[k] = v
-	}
-	reqHeaders.Set("User-Agent", c.s.userAgent())
-	var body io.Reader = nil
-	body, err := googleapi.WithoutDataWrapper.JSONReader(c.connection)
-	if err != nil {
-		return nil, err
-	}
-	reqHeaders.Set("Content-Type", "application/json")
-	c.urlParams_.Set("alt", alt)
-	c.urlParams_.Set("prettyPrint", "false")
-	urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+name}")
-	urls += "?" + c.urlParams_.Encode()
-	req, err := http.NewRequest("PATCH", urls, body)
-	if err != nil {
-		return nil, err
-	}
-	req.Header = reqHeaders
-	googleapi.Expand(req.URL, map[string]string{
-		"name": c.name,
-	})
-	return gensupport.SendRequest(c.ctx_, c.s.client, req)
-}
-
-// Do executes the "servicenetworking.services.patch" call.
-// Exactly one of *Operation or error will be non-nil. Any non-2xx
-// status code is an error. Response headers are in either
-// *Operation.ServerResponse.Header or (if a response was returned at
-// all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified
-// to check whether the returned error was because
-// http.StatusNotModified was returned.
-func (c *ServicesPatchCall) Do(opts ...googleapi.CallOption) (*Operation, error) {
-	gensupport.SetOptions(c.urlParams_, opts...)
-	res, err := c.doRequest("json")
-	if res != nil && res.StatusCode == http.StatusNotModified {
-		if res.Body != nil {
-			res.Body.Close()
-		}
-		return nil, &googleapi.Error{
-			Code:   res.StatusCode,
-			Header: res.Header,
-		}
-	}
-	if err != nil {
-		return nil, err
-	}
-	defer googleapi.CloseBody(res)
-	if err := googleapi.CheckResponse(res); err != nil {
-		return nil, err
-	}
-	ret := &Operation{
-		ServerResponse: googleapi.ServerResponse{
-			Header:         res.Header,
-			HTTPStatusCode: res.StatusCode,
-		},
-	}
-	target := &ret
-	if err := gensupport.DecodeResponse(target, res); err != nil {
-		return nil, err
-	}
-	return ret, nil
-	// {
-	//   "description": "Updates the allocated ranges that are assigned to a connection.\nThe response from the `get` operation will be of type `Connection` if the\noperation successfully completes.",
-	//   "flatPath": "v1beta/services/{servicesId}",
-	//   "httpMethod": "PATCH",
-	//   "id": "servicenetworking.services.patch",
-	//   "parameterOrder": [
-	//     "name"
-	//   ],
-	//   "parameters": {
-	//     "force": {
-	//       "description": "If a previously defined allocated range is removed, force flag must be\nset to true.",
-	//       "location": "query",
-	//       "type": "boolean"
-	//     },
-	//     "name": {
-	//       "description": "The service producer peering service that is managing peering connectivity\nfor a service producer organization.\nFor Google services that support this functionality, this is\n`services/servicenetworking.googleapis.com`.",
-	//       "location": "path",
-	//       "pattern": "^services/[^/]+$",
-	//       "required": true,
-	//       "type": "string"
-	//     },
-	//     "updateMask": {
-	//       "description": "The update mask. If this is omitted, it defaults to \"*\". You can only\nupdate the listed peering ranges.",
-	//       "format": "google-fieldmask",
-	//       "location": "query",
-	//       "type": "string"
-	//     }
-	//   },
-	//   "path": "v1beta/{+name}",
-	//   "request": {
-	//     "$ref": "Connection"
-	//   },
-	//   "response": {
-	//     "$ref": "Operation"
-	//   },
-	//   "scopes": [
-	//     "https://www.googleapis.com/auth/cloud-platform",
-	//     "https://www.googleapis.com/auth/service.management"
-	//   ]
-	// }
-
-}
-
 // method id "servicenetworking.services.searchRange":
 
 type ServicesSearchRangeCall struct {
@@ -5044,6 +4873,177 @@
 
 }
 
+// method id "servicenetworking.services.updateConnections":
+
+type ServicesUpdateConnectionsCall struct {
+	s          *APIService
+	name       string
+	connection *Connection
+	urlParams_ gensupport.URLParams
+	ctx_       context.Context
+	header_    http.Header
+}
+
+// UpdateConnections: Updates the allocated ranges that are assigned to
+// a connection.
+// The response from the `get` operation will be of type `Connection` if
+// the
+// operation successfully completes.
+func (r *ServicesService) UpdateConnections(name string, connection *Connection) *ServicesUpdateConnectionsCall {
+	c := &ServicesUpdateConnectionsCall{s: r.s, urlParams_: make(gensupport.URLParams)}
+	c.name = name
+	c.connection = connection
+	return c
+}
+
+// Force sets the optional parameter "force": If a previously defined
+// allocated range is removed, force flag must be
+// set to true.
+func (c *ServicesUpdateConnectionsCall) Force(force bool) *ServicesUpdateConnectionsCall {
+	c.urlParams_.Set("force", fmt.Sprint(force))
+	return c
+}
+
+// UpdateMask sets the optional parameter "updateMask": The update mask.
+// If this is omitted, it defaults to "*". You can only
+// update the listed peering ranges.
+func (c *ServicesUpdateConnectionsCall) UpdateMask(updateMask string) *ServicesUpdateConnectionsCall {
+	c.urlParams_.Set("updateMask", updateMask)
+	return c
+}
+
+// Fields allows partial responses to be retrieved. See
+// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
+// for more information.
+func (c *ServicesUpdateConnectionsCall) Fields(s ...googleapi.Field) *ServicesUpdateConnectionsCall {
+	c.urlParams_.Set("fields", googleapi.CombineFields(s))
+	return c
+}
+
+// Context sets the context to be used in this call's Do method. Any
+// pending HTTP request will be aborted if the provided context is
+// canceled.
+func (c *ServicesUpdateConnectionsCall) Context(ctx context.Context) *ServicesUpdateConnectionsCall {
+	c.ctx_ = ctx
+	return c
+}
+
+// Header returns an http.Header that can be modified by the caller to
+// add HTTP headers to the request.
+func (c *ServicesUpdateConnectionsCall) Header() http.Header {
+	if c.header_ == nil {
+		c.header_ = make(http.Header)
+	}
+	return c.header_
+}
+
+func (c *ServicesUpdateConnectionsCall) doRequest(alt string) (*http.Response, error) {
+	reqHeaders := make(http.Header)
+	for k, v := range c.header_ {
+		reqHeaders[k] = v
+	}
+	reqHeaders.Set("User-Agent", c.s.userAgent())
+	var body io.Reader = nil
+	body, err := googleapi.WithoutDataWrapper.JSONReader(c.connection)
+	if err != nil {
+		return nil, err
+	}
+	reqHeaders.Set("Content-Type", "application/json")
+	c.urlParams_.Set("alt", alt)
+	c.urlParams_.Set("prettyPrint", "false")
+	urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+name}/connections")
+	urls += "?" + c.urlParams_.Encode()
+	req, err := http.NewRequest("PATCH", urls, body)
+	if err != nil {
+		return nil, err
+	}
+	req.Header = reqHeaders
+	googleapi.Expand(req.URL, map[string]string{
+		"name": c.name,
+	})
+	return gensupport.SendRequest(c.ctx_, c.s.client, req)
+}
+
+// Do executes the "servicenetworking.services.updateConnections" call.
+// Exactly one of *Operation or error will be non-nil. Any non-2xx
+// status code is an error. Response headers are in either
+// *Operation.ServerResponse.Header or (if a response was returned at
+// all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified
+// to check whether the returned error was because
+// http.StatusNotModified was returned.
+func (c *ServicesUpdateConnectionsCall) Do(opts ...googleapi.CallOption) (*Operation, error) {
+	gensupport.SetOptions(c.urlParams_, opts...)
+	res, err := c.doRequest("json")
+	if res != nil && res.StatusCode == http.StatusNotModified {
+		if res.Body != nil {
+			res.Body.Close()
+		}
+		return nil, &googleapi.Error{
+			Code:   res.StatusCode,
+			Header: res.Header,
+		}
+	}
+	if err != nil {
+		return nil, err
+	}
+	defer googleapi.CloseBody(res)
+	if err := googleapi.CheckResponse(res); err != nil {
+		return nil, err
+	}
+	ret := &Operation{
+		ServerResponse: googleapi.ServerResponse{
+			Header:         res.Header,
+			HTTPStatusCode: res.StatusCode,
+		},
+	}
+	target := &ret
+	if err := gensupport.DecodeResponse(target, res); err != nil {
+		return nil, err
+	}
+	return ret, nil
+	// {
+	//   "description": "Updates the allocated ranges that are assigned to a connection.\nThe response from the `get` operation will be of type `Connection` if the\noperation successfully completes.",
+	//   "flatPath": "v1beta/services/{servicesId}/connections",
+	//   "httpMethod": "PATCH",
+	//   "id": "servicenetworking.services.updateConnections",
+	//   "parameterOrder": [
+	//     "name"
+	//   ],
+	//   "parameters": {
+	//     "force": {
+	//       "description": "If a previously defined allocated range is removed, force flag must be\nset to true.",
+	//       "location": "query",
+	//       "type": "boolean"
+	//     },
+	//     "name": {
+	//       "description": "The service producer peering service that is managing peering connectivity\nfor a service producer organization.\nFor Google services that support this functionality, this is\n`services/servicenetworking.googleapis.com`.",
+	//       "location": "path",
+	//       "pattern": "^services/[^/]+$",
+	//       "required": true,
+	//       "type": "string"
+	//     },
+	//     "updateMask": {
+	//       "description": "The update mask. If this is omitted, it defaults to \"*\". You can only\nupdate the listed peering ranges.",
+	//       "format": "google-fieldmask",
+	//       "location": "query",
+	//       "type": "string"
+	//     }
+	//   },
+	//   "path": "v1beta/{+name}/connections",
+	//   "request": {
+	//     "$ref": "Connection"
+	//   },
+	//   "response": {
+	//     "$ref": "Operation"
+	//   },
+	//   "scopes": [
+	//     "https://www.googleapis.com/auth/cloud-platform",
+	//     "https://www.googleapis.com/auth/service.management"
+	//   ]
+	// }
+
+}
+
 // method id "servicenetworking.services.connections.create":
 
 type ServicesConnectionsCreateCall struct {
diff --git a/testing/v1/testing-api.json b/testing/v1/testing-api.json
index c8a0b1c..66a1b19 100644
--- a/testing/v1/testing-api.json
+++ b/testing/v1/testing-api.json
@@ -272,7 +272,7 @@
       }
     }
   },
-  "revision": "20190107",
+  "revision": "20190129",
   "rootUrl": "https://testing.googleapis.com/",
   "schemas": {
     "Account": {
@@ -1537,6 +1537,7 @@
             "MALFORMED_TEST_APK",
             "NO_MANIFEST",
             "NO_PACKAGE_NAME",
+            "INVALID_PACKAGE_NAME",
             "TEST_SAME_AS_APP",
             "NO_INSTRUMENTATION",
             "NO_SIGNATURE",
@@ -1569,6 +1570,7 @@
             "The input test APK could not be parsed.",
             "The AndroidManifest.xml could not be found.",
             "The APK manifest does not declare a package name.",
+            "The APK application ID (aka package name) is invalid.\nSee also\nhttps://developer.android.com/studio/build/application-id",
             "The test package and app package are the same.",
             "The test apk does not declare an instrumentation.",
             "The input app apk does not have a signature.",
diff --git a/testing/v1/testing-gen.go b/testing/v1/testing-gen.go
index ba39bd8..8eb41b1 100644
--- a/testing/v1/testing-gen.go
+++ b/testing/v1/testing-gen.go
@@ -2431,6 +2431,10 @@
 	//   "NO_MANIFEST" - The AndroidManifest.xml could not be found.
 	//   "NO_PACKAGE_NAME" - The APK manifest does not declare a package
 	// name.
+	//   "INVALID_PACKAGE_NAME" - The APK application ID (aka package name)
+	// is invalid.
+	// See also
+	// https://developer.android.com/studio/build/application-id
 	//   "TEST_SAME_AS_APP" - The test package and app package are the same.
 	//   "NO_INSTRUMENTATION" - The test apk does not declare an
 	// instrumentation.
diff --git a/toolresults/v1beta3/toolresults-api.json b/toolresults/v1beta3/toolresults-api.json
index c8f557e..85d2303 100644
--- a/toolresults/v1beta3/toolresults-api.json
+++ b/toolresults/v1beta3/toolresults-api.json
@@ -15,7 +15,7 @@
   "description": "Reads and publishes results from Firebase Test Lab.",
   "discoveryVersion": "v1",
   "documentationLink": "https://firebase.google.com/docs/test-lab/",
-  "etag": "\"J3WqvAcMk4eQjJXvfSI4Yr8VouA/y92ZBD_TKKKguL_TSM7yuUk3ht0\"",
+  "etag": "\"J3WqvAcMk4eQjJXvfSI4Yr8VouA/3PU0tfPO0Ff5odyEdFP_aystsQs\"",
   "icons": {
     "x16": "https://www.gstatic.com/images/branding/product/1x/googleg_16dp.png",
     "x32": "https://www.gstatic.com/images/branding/product/1x/googleg_32dp.png"
@@ -1161,7 +1161,7 @@
       }
     }
   },
-  "revision": "20181128",
+  "revision": "20190128",
   "rootUrl": "https://www.googleapis.com/",
   "schemas": {
     "AndroidAppInfo": {
@@ -1812,6 +1812,7 @@
           "description": "The simplest way to interpret a result.\n\nRequired",
           "enum": [
             "failure",
+            "flaky",
             "inconclusive",
             "skipped",
             "success",
@@ -1822,6 +1823,7 @@
             "",
             "",
             "",
+            "",
             ""
           ],
           "type": "string"
diff --git a/toolresults/v1beta3/toolresults-gen.go b/toolresults/v1beta3/toolresults-gen.go
index d42fae2..e45eebc 100644
--- a/toolresults/v1beta3/toolresults-gen.go
+++ b/toolresults/v1beta3/toolresults-gen.go
@@ -1526,6 +1526,7 @@
 	//
 	// Possible values:
 	//   "failure"
+	//   "flaky"
 	//   "inconclusive"
 	//   "skipped"
 	//   "success"