Scroll to navigation

Search::Elasticsearch::Client::8_0::Direct::Security(3pm) User Contributed Perl Documentation Search::Elasticsearch::Client::8_0::Direct::Security(3pm)

NAME

Search::Elasticsearch::Client::8_0::Direct::Security - Plugin providing Security API for Search::Elasticsearch 8.x

VERSION

version 8.00

SYNOPSIS

    my $response = $es->security->authenticate();

DESCRIPTION

This class extends the Search::Elasticsearch client with a "security" namespace, to support the Security APIs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api.html>.

The full documentation for the Security feature is available here: <https://www.elastic.co/guide/en/x-pack/current/xpack-security.html>

GENERAL METHODS

"authenticate()"

    $response = $es->security->authenticate()

The "authenticate()" method checks that the "userinfo" is correct and returns a list of which roles are assigned to the user.

See the authenticate docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-authenticate.html> for more information.

Query string parameters:
"error_trace",
"human"

"clear_cached_realms()"

    $response = $es->security->clear_cached_realms(
        realms => $realms       # required  (comma-separated string)
    );

The "clear_cached_realms()" method clears the caches for the specified realms

Query string parameters:
"error_trace",
"human",
"usernames"

See the clear_cached_realms docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-clear-cache.html> for more information.

USER METHODS

"put_user()"

    $response = $es->security->put_user(
        username => $username,     # required
        body     => {...}          # required
    );

The "put_user()" method creates a new user or updates an existing user.

See the User Management docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-users.html> for more information.

Query string parameters:
"error_trace",
"human"

"get_user()"

    $response = $es->security->get_user(
        username => $username | \@usernames     # optional
    );

The "get_user()" method retrieves info for the specified users (or all users).

See the User Management docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-users.html> for more information.

Query string parameters:
"error_trace",
"human"

"delete_user()"

    $response = $es->security->delete_user(
        username => $username       # required
    );

The "delete_user()" method deletes the specified user.

See the User Management docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-users.html> for more information.

Query string parameters:
"error_trace",
"human"

"change_password()"

    $response = $es->security->change_password(
        username => $username       # optional
        body => {
            password => $password   # required
        }
    )

The "change_password()" method changes the password for the specified user.

See the User Management docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-users.html> for more information.

"disable_user()"

    $response = $es->security->disable_user(
        username => $username       # required
    );

The "disable_user()" method disables the specified user.

See the User Management docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-users.html> for more information.

Query string parameters:
"error_trace",
"human"

"enable_user()"

    $response = $es->security->enable_user(
        username => $username       # required
    );

The "enable_user()" method enables the specified user.

See the User Management docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-users.html> for more information.

Query string parameters:
"error_trace",
"human"

ROLE METHODS

"put_role()"

    $response = $es->security->put_role(
        name => $name,             # required
        body     => {...}          # required
    );

The "put_role()" method creates a new role or updates an existing role.

See the Role Management docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-roles.html> for more information.

Query string parameters:
"error_trace",
"human"

"get_role()"

    $response = $es->security->get_role(
        name => $name | \@names     # optional
    );

The "get_role()" method retrieves info for the specified roles (or all roles).

See the Role Management docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-roles.html> for more information.

Query string parameters:
"error_trace",
"human"

"delete_role()"

    $response = $es->security->delete_role(
        name => $name       # required
    );

The "delete_role()" method deletes the specified role.

See the Role Management docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-roles.html> for more information.

Query string parameters:
"error_trace",
"human"

"clear_cached_roles()"

    $response = $es->security->clear_cached_roles(
        names => $names       # required  (comma-separated string)
    );

The "clear_cached_roles()" method clears the caches for the specified roles.

See the Role Management docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-roles.html> for more information.

Query string parameters:
"error_trace",
"human"

ROLE MAPPING METHODS

"put_role_mapping()"

    $response = $es->security->put_role_mapping(
        name => $name,             # required
        body     => {...}          # required
    );

The "put_role_mapping()" method creates a new role mapping or updates an existing role mapping.

See the Role Mapping docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-role-mapping.html> for more information.

Query string parameters:
"error_trace",
"human"

"get_role_mapping()"

    $response = $es->security->get_role_mapping(
        name => $name,             # optional
    );

The "get_role_mapping()" method retrieves one or more role mappings.

See the Role Mapping docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-role-mapping.html> for more information.

Query string parameters:
"error_trace",
"human"

"delete_role_mapping()"

    $response = $es->security->delete_role_mapping(
        name => $name,             # required
    );

The "delete_role_mapping()" method deletes a role mapping.

See the Role Mapping docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-role-mapping.html> for more information.

Query string parameters:
"error_trace",
"human"

TOKEN METHODS

"get_token()"

    $response = $es->security->get_token(
        body     => {...}          # required
    );

The "get_token()" method enables you to create bearer tokens for access without requiring basic authentication.

See the Token Management docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-tokens.html> for more information.

Query string parameters:
"error_trace",
"human"

"invalidate_token()"

    $response = $es->security->invalidate_token(
        body     => {...}          # required
    );

The "invalidate_token()" method enables you to invalidate bearer tokens for access without requiring basic authentication.

See the Token Management docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-tokens.html> for more information.

Query string parameters:
"error_trace",
"human"

API KEY METHODS

"create_api_key()"

    $response = $es->security->create_api_key(
        body    => {...}            # required
    )

The "create_api_key()" API is used to create API keys which can be used for access instead of basic authentication.

Query string parameters:
"error_trace",
"filter_path",
"human",
"refresh"

See the Create API Key docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-create-api-key.html> for more.

"get_api_key()"

    $response = $es->security->get_api_key(
        id          => $id,         # optional
        name        => $name,       # optional
        realm_name  => $realm,      # optional
        username    => $username    # optional
    )

The "get_api_key()" API is used to get information about an API key.

Query string parameters:
"error_trace",
"filter_path",
"human",
"id",
"name",
"realm_name",
"username"

See the Get API Key docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-get-api-key.html> for more.

"invalidate_api_key()"

    $response = $es->security->invalidate_api_key(
        id          => $id,         # optional
        name        => $name,       # optional
        realm_name  => $realm,      # optional
        username    => $username    # optional
    )

The "invalidate_api_key()" API is used to invalidate an API key.

Query string parameters:
"error_trace",
"filter_path",
"human",
"id",
"name",
"realm_name",
"username"

See the Invalidate API Key docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-invalidate-api-key.html> for more.

USER PRIVILEGE METHODS

"get_user_privileges()"

    $response = $es->get_user_privileges();
 The C<get_user_privileges()> method retrieves the privileges granted to the current user.
 Query string parameters:
    C<error_trace>,
    C<filter_path>,
    C<human>

"has_privileges()" $response = $es->has_privileges( user => $user, # optional body => {...} # required );

 The C<has_privileges()> method checks whether the current or specified user has the listed privileges.
 Query string parameters:
    C<error_trace>,
    C<filter_path>,
    C<human>

See the Has Privileges docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-has-privileges.html> for more.

APPLICATION PRIVILEGE METHODS

"put_privileges()"

    $response = $es->put_privileges(
        application     => $application,    # required
        name            => $name,           # required
        body            => {...}            # required
    );
 The C<put_privileges()> method creates or updates the named privilege for a particular application.
 Query string parameters:
    C<error_trace>,
    C<filter_path>,
    C<human>,
    C<refresh>

See the Create or Update Application Privileges docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-put-privileges.html> for more.

"get_privileges()"

    $response = $es->get_privileges(
        application     => $application,    # required
        name            => $name,           # required
    );
 The C<get_privileges()> method retrieves the named privilege for a particular application.
 Query string parameters:
    C<error_trace>,
    C<filter_path>,
    C<human>

See the Get Application Privileges docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-get-privileges.html> for more.

"delete_privileges()"

    $response = $es->delete_privileges(
        application     => $application,    # required
        name            => $name,           # required
    );
 The C<delete_privileges()> method deletes the named privilege for a particular application.
 Query string parameters:
    C<error_trace>,
    C<filter_path>,
    C<human>,
    C<refresh>

See the Delete Application Privileges docs <https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-delete-privilege.html> for more.

AUTHOR

Enrico Zimuel <enrico.zimuel@elastic.co>

COPYRIGHT AND LICENSE

This software is Copyright (c) 2022 by Elasticsearch BV.

This is free software, licensed under:

  The Apache License, Version 2.0, January 2004
2023-02-11 perl v5.36.0