All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.azure.core.credential.AzureNamedKeyCredential Maven / Gradle / Ivy

// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.

package com.azure.core.credential;

import com.azure.core.util.logging.ClientLogger;

import java.util.Objects;

/**
 * Represents a credential with a key name and the key and uses the key to authenticate to an Azure Service.
 *
 * 

The named credential can be created for keys which have a name identifier associated with them.

* *

Code Samples

* *

Create a named credential for a service specific sas key.

* * *
 * AzureNamedKeyCredential azureNamedKeyCredential =
 *     new AzureNamedKeyCredential("AZURE-SERVICE-SAS-KEY-NAME", "AZURE-SERVICE-SAS-KEY");
 * 
* * */ public final class AzureNamedKeyCredential { // AzureNamedKeyCredential is a commonly used credential type, use a static logger. private static final ClientLogger LOGGER = new ClientLogger(AzureNamedKeyCredential.class); private volatile AzureNamedKey credentials; /** * Creates a credential with specified {@code name} that authorizes request with the given {@code key}. * * @param name The name of the key credential. * @param key The key used to authorize requests. * @throws NullPointerException If {@code key} or {@code name} is {@code null}. * @throws IllegalArgumentException If {@code key} or {@code name} is an empty string. */ public AzureNamedKeyCredential(String name, String key) { validateInputParameters(name, key); this.credentials = new AzureNamedKey(name, key); } /** * Retrieves the {@link AzureNamedKey} containing the name and key associated with this credential. * * @return The {@link AzureNamedKey} containing the name and key . */ public AzureNamedKey getAzureNamedKey() { return this.credentials; } /** * Rotates the {@code name} and {@code key} associated to this credential. * * @param name The new name of the key credential. * @param key The new key to be associated with this credential. * @return The updated {@code AzureNamedKeyCredential} object. * @throws NullPointerException If {@code key} or {@code name} is {@code null}. * @throws IllegalArgumentException If {@code key} or {@code name} is an empty string. */ public AzureNamedKeyCredential update(String name, String key) { validateInputParameters(name, key); this.credentials = new AzureNamedKey(name, key); return this; } private void validateInputParameters(String name, String key) { Objects.requireNonNull(name, "'name' cannot be null."); Objects.requireNonNull(key, "'key' cannot be null."); if (name.isEmpty()) { throw LOGGER.logExceptionAsError(new IllegalArgumentException("'name' cannot be empty.")); } if (key.isEmpty()) { throw LOGGER.logExceptionAsError(new IllegalArgumentException("'key' cannot be empty.")); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy