Class ConfigServiceV2Client (1.15.1)

ConfigServiceV2Client(
    transport=None,
    channel=None,
    credentials=None,
    client_config=None,
    client_info=None,
    client_options=None,
)

Service for configuring sinks used to route log entries.

Inheritance

builtins.object > google.cloud.logging_v2.gapic.config_service_v2_client.ConfigServiceV2Client > ConfigServiceV2Client

Methods

ConfigServiceV2Client

ConfigServiceV2Client(
    transport=None,
    channel=None,
    credentials=None,
    client_config=None,
    client_info=None,
    client_options=None,
)

Constructor.

Parameters
NameDescription
channel grpc.Channel

DEPRECATED. A Channel instance through which to make calls. This argument is mutually exclusive with credentials; providing both will raise an exception.

credentials google.auth.credentials.Credentials

The authorization credentials to attach to requests. These credentials identify this application to the service. If none are specified, the client will attempt to ascertain the credentials from the environment. This argument is mutually exclusive with providing a transport instance to transport; doing so will raise an exception.

client_config dict

DEPRECATED. A dictionary of call options for each method. If not specified, the default configuration is used.

client_info google.api_core.gapic_v1.client_info.ClientInfo

The client info used to send a user-agent string along with API requests. If None, then default info will be used. Generally, you only need to set this if you're developing your own client library.

client_options Union[dict, google.api_core.client_options.ClientOptions]

Client options used to set user options on the client. API Endpoint should be set through client_options.

billing_exclusion_path

billing_exclusion_path(billing_account, exclusion)

Return a fully-qualified billing_exclusion string.

billing_path

billing_path(billing_account)

Return a fully-qualified billing string.

billing_sink_path

billing_sink_path(billing_account, sink)

Return a fully-qualified billing_sink string.

create_exclusion

create_exclusion(parent, exclusion, retry=<object object>, timeout=<object object>, metadata=None)

Creates a new exclusion in a specified parent resource. Only log entries belonging to that resource can be excluded. You can have up to 10 exclusions in a resource.

.. rubric:: Example

from google.cloud import logging_v2

client = logging_v2.ConfigServiceV2Client()

parent = client.project_path('[PROJECT]')

TODO: Initialize exclusion:

exclusion = {}

response = client.create_exclusion(parent, exclusion)

Parameters
NameDescription
parent str

Required. The parent resource in which to create the exclusion: :: "projects/[PROJECT_ID]" "organizations/[ORGANIZATION_ID]" "billingAccounts/[BILLING_ACCOUNT_ID]" "folders/[FOLDER_ID]" Examples: "projects/my-logging-project", "organizations/123456789".

exclusion Union[dict, LogExclusion]

Required. The new exclusion, whose name parameter is an exclusion name that is not already used in the parent resource. If a dict is provided, it must be of the same form as the protobuf message LogExclusion

retry Optional[google.api_core.retry.Retry]

A retry object used to retry requests. If None is specified, requests will be retried using a default configuration.

timeout Optional[float]

The amount of time, in seconds, to wait for the request to complete. Note that if retry is specified, the timeout applies to each individual attempt.

metadata Optional[Sequence[Tuple[str, str]]]

Additional metadata that is provided to the method.

Exceptions
TypeDescription
google.api_core.exceptions.GoogleAPICallErrorIf the request failed for any reason.
google.api_core.exceptions.RetryErrorIf the request failed due to a retryable error and retry attempts failed.
ValueErrorIf the parameters are invalid.

create_sink

create_sink(parent, sink, unique_writer_identity=None, retry=<object object>, timeout=<object object>, metadata=None)

Creates a sink that exports specified log entries to a destination. The export of newly-ingested log entries begins immediately, unless the sink's writer_identity is not permitted to write to the destination. A sink can export log entries only from the resource owning the sink.

.. rubric:: Example

from google.cloud import logging_v2

client = logging_v2.ConfigServiceV2Client()

parent = client.project_path('[PROJECT]')

TODO: Initialize sink:

sink = {}

response = client.create_sink(parent, sink)

Parameters
NameDescription
parent str

Required. The resource in which to create the sink: :: "projects/[PROJECT_ID]" "organizations/[ORGANIZATION_ID]" "billingAccounts/[BILLING_ACCOUNT_ID]" "folders/[FOLDER_ID]" Examples: "projects/my-logging-project", "organizations/123456789".

sink Union[dict, LogSink]

Required. The new sink, whose name parameter is a sink identifier that is not already in use. If a dict is provided, it must be of the same form as the protobuf message LogSink

unique_writer_identity bool

Optional. Determines the kind of IAM identity returned as writer_identity in the new sink. If this value is omitted or set to false, and if the sink's parent is a project, then the value returned as writer_identity is the same group or service account used by Logging before the addition of writer identities to this API. The sink's destination must be in the same project as the sink itself. If this field is set to true, or if the sink is owned by a non-project resource such as an organization, then the value of writer_identity will be a unique service account used only for exports from the new sink. For more information, see writer_identity in LogSink.

retry Optional[google.api_core.retry.Retry]

A retry object used to retry requests. If None is specified, requests will be retried using a default configuration.

timeout Optional[float]

The amount of time, in seconds, to wait for the request to complete. Note that if retry is specified, the timeout applies to each individual attempt.

metadata Optional[Sequence[Tuple[str, str]]]

Additional metadata that is provided to the method.

Exceptions
TypeDescription
google.api_core.exceptions.GoogleAPICallErrorIf the request failed for any reason.
google.api_core.exceptions.RetryErrorIf the request failed due to a retryable error and retry attempts failed.
ValueErrorIf the parameters are invalid.

delete_exclusion

delete_exclusion(name, retry=<object object>, timeout=<object object>, metadata=None)

Deletes an exclusion.

.. rubric:: Example

from google.cloud import logging_v2

client = logging_v2.ConfigServiceV2Client()

name = client.exclusion_path('[PROJECT]', '[EXCLUSION]')

client.delete_exclusion(name)

Parameters
NameDescription
name str

Required. The resource name of an existing exclusion to delete: :: "projects/[PROJECT_ID]/exclusions/[EXCLUSION_ID]" "organizations/[ORGANIZATION_ID]/exclusions/[EXCLUSION_ID]" "billingAccounts/[BILLING_ACCOUNT_ID]/exclusions/[EXCLUSION_ID]" "folders/[FOLDER_ID]/exclusions/[EXCLUSION_ID]" Example: "projects/my-project-id/exclusions/my-exclusion-id".

retry Optional[google.api_core.retry.Retry]

A retry object used to retry requests. If None is specified, requests will be retried using a default configuration.

timeout Optional[float]

The amount of time, in seconds, to wait for the request to complete. Note that if retry is specified, the timeout applies to each individual attempt.

metadata Optional[Sequence[Tuple[str, str]]]

Additional metadata that is provided to the method.

Exceptions
TypeDescription
google.api_core.exceptions.GoogleAPICallErrorIf the request failed for any reason.
google.api_core.exceptions.RetryErrorIf the request failed due to a retryable error and retry attempts failed.
ValueErrorIf the parameters are invalid.

delete_sink

delete_sink(sink_name, retry=<object object>, timeout=<object object>, metadata=None)

Deletes a sink. If the sink has a unique writer_identity, then that service account is also deleted.

.. rubric:: Example

from google.cloud import logging_v2

client = logging_v2.ConfigServiceV2Client()

sink_name = client.sink_path('[PROJECT]', '[SINK]')

client.delete_sink(sink_name)

Parameters
NameDescription
sink_name str

Required. The full resource name of the sink to delete, including the parent resource and the sink identifier: :: "projects/[PROJECT_ID]/sinks/[SINK_ID]" "organizations/[ORGANIZATION_ID]/sinks/[SINK_ID]" "billingAccounts/[BILLING_ACCOUNT_ID]/sinks/[SINK_ID]" "folders/[FOLDER_ID]/sinks/[SINK_ID]" Example: "projects/my-project-id/sinks/my-sink-id".

retry Optional[google.api_core.retry.Retry]

A retry object used to retry requests. If None is specified, requests will be retried using a default configuration.

timeout Optional[float]

The amount of time, in seconds, to wait for the request to complete. Note that if retry is specified, the timeout applies to each individual attempt.

metadata Optional[Sequence[Tuple[str, str]]]

Additional metadata that is provided to the method.

Exceptions
TypeDescription
google.api_core.exceptions.GoogleAPICallErrorIf the request failed for any reason.
google.api_core.exceptions.RetryErrorIf the request failed due to a retryable error and retry attempts failed.
ValueErrorIf the parameters are invalid.

exclusion_path

exclusion_path(project, exclusion)

Return a fully-qualified exclusion string.

folder_exclusion_path

folder_exclusion_path(folder, exclusion)

Return a fully-qualified folder_exclusion string.

folder_path

folder_path(folder)

Return a fully-qualified folder string.

folder_sink_path

folder_sink_path(folder, sink)

Return a fully-qualified folder_sink string.

from_service_account_file

from_service_account_file(filename, *args, **kwargs)

Creates an instance of this client using the provided credentials file.

Parameter
NameDescription
filename str

The path to the service account private key json file.

Returns
TypeDescription
ConfigServiceV2ClientThe constructed client.

from_service_account_json

from_service_account_json(filename, *args, **kwargs)

Creates an instance of this client using the provided credentials file.

Parameter
NameDescription
filename str

The path to the service account private key json file.

Returns
TypeDescription
ConfigServiceV2ClientThe constructed client.

get_cmek_settings

get_cmek_settings(name=None, retry=<object object>, timeout=<object object>, metadata=None)

Gets the Logs Router CMEK settings for the given resource.

Note: CMEK for the Logs Router can currently only be configured for GCP organizations. Once configured, it applies to all projects and folders in the GCP organization.

See Enabling CMEK for Logs Router <https://cloud.google.com/logging/docs/routing/managed-encryption>__ for more information.

.. rubric:: Example

from google.cloud import logging_v2

client = logging_v2.ConfigServiceV2Client()

response = client.get_cmek_settings()

Parameters
NameDescription
name str

Required. The resource for which to retrieve CMEK settings. :: "projects/[PROJECT_ID]/cmekSettings" "organizations/[ORGANIZATION_ID]/cmekSettings" "billingAccounts/[BILLING_ACCOUNT_ID]/cmekSettings" "folders/[FOLDER_ID]/cmekSettings" Example: "organizations/12345/cmekSettings". Note: CMEK for the Logs Router can currently only be configured for GCP organizations. Once configured, it applies to all projects and folders in the GCP organization.

retry Optional[google.api_core.retry.Retry]

A retry object used to retry requests. If None is specified, requests will be retried using a default configuration.

timeout Optional[float]

The amount of time, in seconds, to wait for the request to complete. Note that if retry is specified, the timeout applies to each individual attempt.

metadata Optional[Sequence[Tuple[str, str]]]

Additional metadata that is provided to the method.

Exceptions
TypeDescription
google.api_core.exceptions.GoogleAPICallErrorIf the request failed for any reason.
google.api_core.exceptions.RetryErrorIf the request failed due to a retryable error and retry attempts failed.
ValueErrorIf the parameters are invalid.

get_exclusion

get_exclusion(name, retry=<object object>, timeout=<object object>, metadata=None)

Gets the description of an exclusion.

.. rubric:: Example

from google.cloud import logging_v2

client = logging_v2.ConfigServiceV2Client()

name = client.exclusion_path('[PROJECT]', '[EXCLUSION]')

response = client.get_exclusion(name)

Parameters
NameDescription
name str

Required. The resource name of an existing exclusion: :: "projects/[PROJECT_ID]/exclusions/[EXCLUSION_ID]" "organizations/[ORGANIZATION_ID]/exclusions/[EXCLUSION_ID]" "billingAccounts/[BILLING_ACCOUNT_ID]/exclusions/[EXCLUSION_ID]" "folders/[FOLDER_ID]/exclusions/[EXCLUSION_ID]" Example: "projects/my-project-id/exclusions/my-exclusion-id".

retry Optional[google.api_core.retry.Retry]

A retry object used to retry requests. If None is specified, requests will be retried using a default configuration.

timeout Optional[float]

The amount of time, in seconds, to wait for the request to complete. Note that if retry is specified, the timeout applies to each individual attempt.

metadata Optional[Sequence[Tuple[str, str]]]

Additional metadata that is provided to the method.

Exceptions
TypeDescription
google.api_core.exceptions.GoogleAPICallErrorIf the request failed for any reason.
google.api_core.exceptions.RetryErrorIf the request failed due to a retryable error and retry attempts failed.
ValueErrorIf the parameters are invalid.

get_sink

get_sink(sink_name, retry=<object object>, timeout=<object object>, metadata=None)

Gets a sink.

.. rubric:: Example

from google.cloud import logging_v2

client = logging_v2.ConfigServiceV2Client()

sink_name = client.sink_path('[PROJECT]', '[SINK]')

response = client.get_sink(sink_name)

Parameters
NameDescription
sink_name str

Required. The resource name of the sink: :: "projects/[PROJECT_ID]/sinks/[SINK_ID]" "organizations/[ORGANIZATION_ID]/sinks/[SINK_ID]" "billingAccounts/[BILLING_ACCOUNT_ID]/sinks/[SINK_ID]" "folders/[FOLDER_ID]/sinks/[SINK_ID]" Example: "projects/my-project-id/sinks/my-sink-id".

retry Optional[google.api_core.retry.Retry]

A retry object used to retry requests. If None is specified, requests will be retried using a default configuration.

timeout Optional[float]

The amount of time, in seconds, to wait for the request to complete. Note that if retry is specified, the timeout applies to each individual attempt.

metadata Optional[Sequence[Tuple[str, str]]]

Additional metadata that is provided to the method.

Exceptions
TypeDescription
google.api_core.exceptions.GoogleAPICallErrorIf the request failed for any reason.
google.api_core.exceptions.RetryErrorIf the request failed due to a retryable error and retry attempts failed.
ValueErrorIf the parameters are invalid.

list_exclusions

list_exclusions(parent, page_size=None, retry=<object object>, timeout=<object object>, metadata=None)

Lists all the exclusions in a parent resource.

.. rubric:: Example

from google.cloud import logging_v2

client = logging_v2.ConfigServiceV2Client()

parent = client.project_path('[PROJECT]')

Iterate over all results

for element in client.list_exclusions(parent): ... # process element ... pass

Alternatively:

Iterate over results one page at a time

for page in client.list_exclusions(parent).pages: ... for element in page: ... # process element ... pass

Parameters
NameDescription
parent str

Required. The parent resource whose exclusions are to be listed. :: "projects/[PROJECT_ID]" "organizations/[ORGANIZATION_ID]" "billingAccounts/[BILLING_ACCOUNT_ID]" "folders/[FOLDER_ID]"

page_size int

The maximum number of resources contained in the underlying API response. If page streaming is performed per- resource, this parameter does not affect the return value. If page streaming is performed per-page, this determines the maximum number of resources in a page.

retry Optional[google.api_core.retry.Retry]

A retry object used to retry requests. If None is specified, requests will be retried using a default configuration.

timeout Optional[float]

The amount of time, in seconds, to wait for the request to complete. Note that if retry is specified, the timeout applies to each individual attempt.

metadata Optional[Sequence[Tuple[str, str]]]

Additional metadata that is provided to the method.

Exceptions
TypeDescription
google.api_core.exceptions.GoogleAPICallErrorIf the request failed for any reason.
google.api_core.exceptions.RetryErrorIf the request failed due to a retryable error and retry attempts failed.
ValueErrorIf the parameters are invalid.

list_sinks

list_sinks(parent, page_size=None, retry=<object object>, timeout=<object object>, metadata=None)

Lists sinks.

.. rubric:: Example

from google.cloud import logging_v2

client = logging_v2.ConfigServiceV2Client()

parent = client.project_path('[PROJECT]')

Iterate over all results

for element in client.list_sinks(parent): ... # process element ... pass

Alternatively:

Iterate over results one page at a time

for page in client.list_sinks(parent).pages: ... for element in page: ... # process element ... pass

Parameters
NameDescription
parent str

Required. The parent resource whose sinks are to be listed: :: "projects/[PROJECT_ID]" "organizations/[ORGANIZATION_ID]" "billingAccounts/[BILLING_ACCOUNT_ID]" "folders/[FOLDER_ID]"

page_size int

The maximum number of resources contained in the underlying API response. If page streaming is performed per- resource, this parameter does not affect the return value. If page streaming is performed per-page, this determines the maximum number of resources in a page.

retry Optional[google.api_core.retry.Retry]

A retry object used to retry requests. If None is specified, requests will be retried using a default configuration.

timeout Optional[float]

The amount of time, in seconds, to wait for the request to complete. Note that if retry is specified, the timeout applies to each individual attempt.

metadata Optional[Sequence[Tuple[str, str]]]

Additional metadata that is provided to the method.

Exceptions
TypeDescription
google.api_core.exceptions.GoogleAPICallErrorIf the request failed for any reason.
google.api_core.exceptions.RetryErrorIf the request failed due to a retryable error and retry attempts failed.
ValueErrorIf the parameters are invalid.

organization_exclusion_path

organization_exclusion_path(organization, exclusion)

Return a fully-qualified organization_exclusion string.

organization_path

organization_path(organization)

Return a fully-qualified organization string.

organization_sink_path

organization_sink_path(organization, sink)

Return a fully-qualified organization_sink string.

project_path

project_path(project)

Return a fully-qualified project string.

sink_path

sink_path(project, sink)

Return a fully-qualified sink string.

update_cmek_settings

update_cmek_settings(name=None, cmek_settings=None, update_mask=None, retry=<object object>, timeout=<object object>, metadata=None)

Updates the Logs Router CMEK settings for the given resource.

Note: CMEK for the Logs Router can currently only be configured for GCP organizations. Once configured, it applies to all projects and folders in the GCP organization.

UpdateCmekSettings will fail if 1) kms_key_name is invalid, or 2) the associated service account does not have the required roles/cloudkms.cryptoKeyEncrypterDecrypter role assigned for the key, or

3) access to the key is disabled.

See Enabling CMEK for Logs Router <https://cloud.google.com/logging/docs/routing/managed-encryption>__ for more information.

.. rubric:: Example

from google.cloud import logging_v2

client = logging_v2.ConfigServiceV2Client()

response = client.update_cmek_settings()

Parameters
NameDescription
name str

Required. The resource name for the CMEK settings to update. :: "projects/[PROJECT_ID]/cmekSettings" "organizations/[ORGANIZATION_ID]/cmekSettings" "billingAccounts/[BILLING_ACCOUNT_ID]/cmekSettings" "folders/[FOLDER_ID]/cmekSettings" Example: "organizations/12345/cmekSettings". Note: CMEK for the Logs Router can currently only be configured for GCP organizations. Once configured, it applies to all projects and folders in the GCP organization.

cmek_settings Union[dict, CmekSettings]

Required. The CMEK settings to update. See Enabling CMEK for Logs Router <https://cloud.google.com/logging/docs/routing/managed-encryption>__ for more information. If a dict is provided, it must be of the same form as the protobuf message CmekSettings

update_mask Union[dict, FieldMask]

Optional. Field mask identifying which fields from cmek_settings should be updated. A field will be overwritten if and only if it is in the update mask. Output only fields cannot be updated. See FieldMask for more information. Example: "updateMask=kmsKeyName" If a dict is provided, it must be of the same form as the protobuf message FieldMask

retry Optional[google.api_core.retry.Retry]

A retry object used to retry requests. If None is specified, requests will be retried using a default configuration.

timeout Optional[float]

The amount of time, in seconds, to wait for the request to complete. Note that if retry is specified, the timeout applies to each individual attempt.

metadata Optional[Sequence[Tuple[str, str]]]

Additional metadata that is provided to the method.

Exceptions
TypeDescription
google.api_core.exceptions.GoogleAPICallErrorIf the request failed for any reason.
google.api_core.exceptions.RetryErrorIf the request failed due to a retryable error and retry attempts failed.
ValueErrorIf the parameters are invalid.

update_exclusion

update_exclusion(name, exclusion, update_mask, retry=<object object>, timeout=<object object>, metadata=None)

Changes one or more properties of an existing exclusion.

.. rubric:: Example

from google.cloud import logging_v2

client = logging_v2.ConfigServiceV2Client()

name = client.exclusion_path('[PROJECT]', '[EXCLUSION]')

TODO: Initialize exclusion:

exclusion = {}

TODO: Initialize update_mask:

update_mask = {}

response = client.update_exclusion(name, exclusion, update_mask)

Parameters
NameDescription
name str

Required. The resource name of the exclusion to update: :: "projects/[PROJECT_ID]/exclusions/[EXCLUSION_ID]" "organizations/[ORGANIZATION_ID]/exclusions/[EXCLUSION_ID]" "billingAccounts/[BILLING_ACCOUNT_ID]/exclusions/[EXCLUSION_ID]" "folders/[FOLDER_ID]/exclusions/[EXCLUSION_ID]" Example: "projects/my-project-id/exclusions/my-exclusion-id".

exclusion Union[dict, LogExclusion]

Required. New values for the existing exclusion. Only the fields specified in update_mask are relevant. If a dict is provided, it must be of the same form as the protobuf message LogExclusion

update_mask Union[dict, FieldMask]

Required. A non-empty list of fields to change in the existing exclusion. New values for the fields are taken from the corresponding fields in the LogExclusion included in this request. Fields not mentioned in update_mask are not changed and are ignored in the request. For example, to change the filter and description of an exclusion, specify an update_mask of "filter,description". If a dict is provided, it must be of the same form as the protobuf message FieldMask

retry Optional[google.api_core.retry.Retry]

A retry object used to retry requests. If None is specified, requests will be retried using a default configuration.

timeout Optional[float]

The amount of time, in seconds, to wait for the request to complete. Note that if retry is specified, the timeout applies to each individual attempt.

metadata Optional[Sequence[Tuple[str, str]]]

Additional metadata that is provided to the method.

Exceptions
TypeDescription
google.api_core.exceptions.GoogleAPICallErrorIf the request failed for any reason.
google.api_core.exceptions.RetryErrorIf the request failed due to a retryable error and retry attempts failed.
ValueErrorIf the parameters are invalid.

update_sink

update_sink(sink_name, sink, unique_writer_identity=None, update_mask=None, retry=<object object>, timeout=<object object>, metadata=None)

Updates a sink. This method replaces the following fields in the existing sink with values from the new sink: destination, and filter.

The updated sink might also have a new writer_identity; see the unique_writer_identity field.

.. rubric:: Example

from google.cloud import logging_v2

client = logging_v2.ConfigServiceV2Client()

sink_name = client.sink_path('[PROJECT]', '[SINK]')

TODO: Initialize sink:

sink = {}

response = client.update_sink(sink_name, sink)

Parameters
NameDescription
sink_name str

Required. The full resource name of the sink to update, including the parent resource and the sink identifier: :: "projects/[PROJECT_ID]/sinks/[SINK_ID]" "organizations/[ORGANIZATION_ID]/sinks/[SINK_ID]" "billingAccounts/[BILLING_ACCOUNT_ID]/sinks/[SINK_ID]" "folders/[FOLDER_ID]/sinks/[SINK_ID]" Example: "projects/my-project-id/sinks/my-sink-id".

sink Union[dict, LogSink]

Required. The updated sink, whose name is the same identifier that appears as part of sink_name. If a dict is provided, it must be of the same form as the protobuf message LogSink

unique_writer_identity bool

Optional. See sinks.create for a description of this field. When updating a sink, the effect of this field on the value of writer_identity in the updated sink depends on both the old and new values of this field: - If the old and new values of this field are both false or both true, then there is no change to the sink's writer_identity. - If the old value is false and the new value is true, then writer_identity is changed to a unique service account. - It is an error if the old value is true and the new value is set to false or defaulted to false.

update_mask Union[dict, FieldMask]

Optional. Field mask that specifies the fields in sink that need an update. A sink field will be overwritten if, and only if, it is in the update mask. name and output only fields cannot be updated. An empty updateMask is temporarily treated as using the following mask for backwards compatibility purposes: destination,filter,includeChildren At some point in the future, behavior will be removed and specifying an empty updateMask will be an error. For a detailed FieldMask definition, see https://developers.google.com/protocol-buffers/docs/reference/google.protobuf#google.protobuf.FieldMask Example: updateMask=filter. If a dict is provided, it must be of the same form as the protobuf message FieldMask

retry Optional[google.api_core.retry.Retry]

A retry object used to retry requests. If None is specified, requests will be retried using a default configuration.

timeout Optional[float]

The amount of time, in seconds, to wait for the request to complete. Note that if retry is specified, the timeout applies to each individual attempt.

metadata Optional[Sequence[Tuple[str, str]]]

Additional metadata that is provided to the method.

Exceptions
TypeDescription
google.api_core.exceptions.GoogleAPICallErrorIf the request failed for any reason.
google.api_core.exceptions.RetryErrorIf the request failed due to a retryable error and retry attempts failed.
ValueErrorIf the parameters are invalid.