create method

Future<Change> create (
  1. Change request,
  2. String project,
  3. String managedZone,
  4. {String clientOperationId,
  5. String $fields}
)

Atomically update the ResourceRecordSet collection.

request - The metadata request object.

Request parameters:

project - Identifies the project addressed by this request.

managedZone - Identifies the managed zone addressed by this request. Can be the managed zone name or id.

clientOperationId - For mutating operation requests only. An optional identifier specified by the client. Must be unique for operation resources in the Operations collection.

$fields - Selector specifying which fields to include in a partial response.

Completes with a Change.

Completes with a commons.ApiRequestError if the API endpoint returned an error.

If the used http.Client completes with an error when making a REST call, this method will complete with the same error.

Implementation

async.Future<Change> create(
    Change request, core.String project, core.String managedZone,
    {core.String clientOperationId, core.String $fields}) {
  var _url;
  var _queryParams = new core.Map<core.String, core.List<core.String>>();
  var _uploadMedia;
  var _uploadOptions;
  var _downloadOptions = commons.DownloadOptions.Metadata;
  var _body;

  if (request != null) {
    _body = convert.json.encode((request).toJson());
  }
  if (project == null) {
    throw new core.ArgumentError("Parameter project is required.");
  }
  if (managedZone == null) {
    throw new core.ArgumentError("Parameter managedZone is required.");
  }
  if (clientOperationId != null) {
    _queryParams["clientOperationId"] = [clientOperationId];
  }
  if ($fields != null) {
    _queryParams["fields"] = [$fields];
  }

  _url = commons.Escaper.ecapeVariable('$project') +
      '/managedZones/' +
      commons.Escaper.ecapeVariable('$managedZone') +
      '/changes';

  var _response = _requester.request(_url, "POST",
      body: _body,
      queryParams: _queryParams,
      uploadOptions: _uploadOptions,
      uploadMedia: _uploadMedia,
      downloadOptions: _downloadOptions);
  return _response.then((data) => new Change.fromJson(data));
}