delete method
Marks the project identified by the specified name
(for example,
projects/415104041262
) for deletion.
This method will only affect the project if it has a lifecycle state of
ACTIVE. This method changes the Project's lifecycle state from ACTIVE to
DELETE_REQUESTED. The deletion starts at an unspecified time, at which
point the Project is no longer accessible. Until the deletion completes,
you can check the lifecycle state checked by retrieving the project with
GetProject, and the project remains visible to ListProjects. However, you
cannot update the project. After the deletion completes, the project is
not retrievable by the GetProject, ListProjects, and SearchProjects
methods. This method behaves idempotently, such that deleting a
DELETE_REQUESTED
project will not cause an error, but also won't do
anything. The caller must have resourcemanager.projects.delete
permissions for this project.
Request parameters:
name
- Required. The name of the Project (for example,
projects/415104041262
).
Value must have pattern ^projects/\[^/\]+$
.
$fields
- Selector specifying which fields to include in a partial
response.
Completes with a Operation.
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<Operation> delete(
core.String name, {
core.String? $fields,
}) async {
final queryParams_ = <core.String, core.List<core.String>>{
if ($fields != null) 'fields': [$fields],
};
final url_ = 'v3/' + core.Uri.encodeFull('$name');
final response_ = await _requester.request(
url_,
'DELETE',
queryParams: queryParams_,
);
return Operation.fromJson(response_ as core.Map<core.String, core.dynamic>);
}