com.pulumi.azurenative.authorization.outputs.GetManagementLockByScopeResult Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of azure-native Show documentation
Show all versions of azure-native Show documentation
A native Pulumi package for creating and managing Azure resources.
// *** WARNING: this file was generated by pulumi-java-gen. ***
// *** Do not edit by hand unless you're certain you know what you are doing! ***
package com.pulumi.azurenative.authorization.outputs;
import com.pulumi.azurenative.authorization.outputs.ManagementLockOwnerResponse;
import com.pulumi.azurenative.authorization.outputs.SystemDataResponse;
import com.pulumi.core.annotations.CustomType;
import com.pulumi.exceptions.MissingRequiredPropertyException;
import java.lang.String;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import javax.annotation.Nullable;
@CustomType
public final class GetManagementLockByScopeResult {
/**
* @return The resource ID of the lock.
*
*/
private String id;
/**
* @return The level of the lock. Possible values are: NotSpecified, CanNotDelete, ReadOnly. CanNotDelete means authorized users are able to read and modify the resources, but not delete. ReadOnly means authorized users can only read from a resource, but they can't modify or delete it.
*
*/
private String level;
/**
* @return The name of the lock.
*
*/
private String name;
/**
* @return Notes about the lock. Maximum of 512 characters.
*
*/
private @Nullable String notes;
/**
* @return The owners of the lock.
*
*/
private @Nullable List owners;
/**
* @return Metadata pertaining to creation and last modification of the resource.
*
*/
private SystemDataResponse systemData;
/**
* @return The resource type of the lock - Microsoft.Authorization/locks.
*
*/
private String type;
private GetManagementLockByScopeResult() {}
/**
* @return The resource ID of the lock.
*
*/
public String id() {
return this.id;
}
/**
* @return The level of the lock. Possible values are: NotSpecified, CanNotDelete, ReadOnly. CanNotDelete means authorized users are able to read and modify the resources, but not delete. ReadOnly means authorized users can only read from a resource, but they can't modify or delete it.
*
*/
public String level() {
return this.level;
}
/**
* @return The name of the lock.
*
*/
public String name() {
return this.name;
}
/**
* @return Notes about the lock. Maximum of 512 characters.
*
*/
public Optional notes() {
return Optional.ofNullable(this.notes);
}
/**
* @return The owners of the lock.
*
*/
public List owners() {
return this.owners == null ? List.of() : this.owners;
}
/**
* @return Metadata pertaining to creation and last modification of the resource.
*
*/
public SystemDataResponse systemData() {
return this.systemData;
}
/**
* @return The resource type of the lock - Microsoft.Authorization/locks.
*
*/
public String type() {
return this.type;
}
public static Builder builder() {
return new Builder();
}
public static Builder builder(GetManagementLockByScopeResult defaults) {
return new Builder(defaults);
}
@CustomType.Builder
public static final class Builder {
private String id;
private String level;
private String name;
private @Nullable String notes;
private @Nullable List owners;
private SystemDataResponse systemData;
private String type;
public Builder() {}
public Builder(GetManagementLockByScopeResult defaults) {
Objects.requireNonNull(defaults);
this.id = defaults.id;
this.level = defaults.level;
this.name = defaults.name;
this.notes = defaults.notes;
this.owners = defaults.owners;
this.systemData = defaults.systemData;
this.type = defaults.type;
}
@CustomType.Setter
public Builder id(String id) {
if (id == null) {
throw new MissingRequiredPropertyException("GetManagementLockByScopeResult", "id");
}
this.id = id;
return this;
}
@CustomType.Setter
public Builder level(String level) {
if (level == null) {
throw new MissingRequiredPropertyException("GetManagementLockByScopeResult", "level");
}
this.level = level;
return this;
}
@CustomType.Setter
public Builder name(String name) {
if (name == null) {
throw new MissingRequiredPropertyException("GetManagementLockByScopeResult", "name");
}
this.name = name;
return this;
}
@CustomType.Setter
public Builder notes(@Nullable String notes) {
this.notes = notes;
return this;
}
@CustomType.Setter
public Builder owners(@Nullable List owners) {
this.owners = owners;
return this;
}
public Builder owners(ManagementLockOwnerResponse... owners) {
return owners(List.of(owners));
}
@CustomType.Setter
public Builder systemData(SystemDataResponse systemData) {
if (systemData == null) {
throw new MissingRequiredPropertyException("GetManagementLockByScopeResult", "systemData");
}
this.systemData = systemData;
return this;
}
@CustomType.Setter
public Builder type(String type) {
if (type == null) {
throw new MissingRequiredPropertyException("GetManagementLockByScopeResult", "type");
}
this.type = type;
return this;
}
public GetManagementLockByScopeResult build() {
final var _resultValue = new GetManagementLockByScopeResult();
_resultValue.id = id;
_resultValue.level = level;
_resultValue.name = name;
_resultValue.notes = notes;
_resultValue.owners = owners;
_resultValue.systemData = systemData;
_resultValue.type = type;
return _resultValue;
}
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy