
com.google.cloud.logging.LogDestinationName Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of google-cloud-logging Show documentation
Show all versions of google-cloud-logging Show documentation
Java idiomatic client for Cloud Logging
/*
* Copyright 2021 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.google.cloud.logging;
import static com.google.common.base.Preconditions.checkArgument;
import static com.google.common.base.Preconditions.checkNotNull;
import com.google.logging.v2.LogName;
import java.util.Map;
/**
* Class for specifying resource name of the log to which this log entry belongs (see 'logName'
* parameter in https://cloud.google.com/logging/docs/reference/v2/rest/v2/LogEntry)
*/
public final class LogDestinationName extends Option {
private static final long serialVersionUID = 7944256748441111191L;
public enum DestinationType implements Option.OptionType {
PROJECT,
FOLDER,
ORGANIZATION,
BILLINGACCOUNT;
@SuppressWarnings("unchecked")
T get(Map options) {
return (T) options.get(this);
}
}
private LogDestinationName(Option.OptionType option, Object value) {
super(option, value);
checkArgument(!checkNotNull(value).toString().trim().isEmpty());
}
/**
* Returns an option which sets and validates project ID resource name for log entries.
*
* @param id corresponds to PROJECT_ID token in 'logName' field described in
* https://cloud.google.com/logging/docs/reference/v2/rest/v2/LogEntry
*/
public static LogDestinationName project(String id) {
return new LogDestinationName(DestinationType.PROJECT, id);
}
/**
* Returns an option which sets and validates project ID resource name for log entries.
*
* @param id corresponds to FOLDER_ID token in 'logName' field described in
* https://cloud.google.com/logging/docs/reference/v2/rest/v2/LogEntry
*/
public static LogDestinationName folder(String id) {
return new LogDestinationName(DestinationType.FOLDER, id);
}
/**
* Returns an option which sets and validates project ID resource name for log entries.
*
* @param id corresponds to ORGANIZATION_ID token in 'logName' field described in
* https://cloud.google.com/logging/docs/reference/v2/rest/v2/LogEntry
*/
public static LogDestinationName organization(String id) {
return new LogDestinationName(DestinationType.ORGANIZATION, id);
}
/**
* Returns an option which sets and validates project ID resource name for log entries.
*
* @param id corresponds to BILLING_ACCOUNT_ID token in 'logName' field described in
* https://cloud.google.com/logging/docs/reference/v2/rest/v2/LogEntry
*/
public static LogDestinationName billingAccount(String id) {
return new LogDestinationName(DestinationType.BILLINGACCOUNT, id);
}
/** Creates a {@code LogEntry} object for given log ID. */
public LogName toLogName(String logId) {
if (logId == null) {
return null;
}
switch ((DestinationType) getOptionType()) {
case PROJECT:
return LogName.ofProjectLogName(getValue().toString(), logId);
case FOLDER:
return LogName.ofFolderLogName(getValue().toString(), logId);
case ORGANIZATION:
return LogName.ofOrganizationLogName(getValue().toString(), logId);
case BILLINGACCOUNT:
return LogName.ofBillingAccountLogName(getValue().toString(), logId);
}
return null;
}
/** Returns ID value associated with {@code LogDestinationName} object */
public String getDestinationId() {
return getValue().toString();
}
/** Returns destination type option value associated with {@code LogDestinationName} object */
public DestinationType getDestinationType() {
return getOptionType();
}
/** Creates a {@code LogDestinationName} object from given {@code LogName}. */
public static LogDestinationName fromLogName(LogName logName) {
if (logName == null) {
return null;
}
if (logName.getProject() != null) {
return project(logName.getProject());
} else if (logName.getBillingAccount() != null) {
return billingAccount(logName.getBillingAccount());
} else if (logName.getFolder() != null) {
return folder(logName.getFolder());
} else if (logName.getOrganization() != null) {
return organization(logName.getOrganization());
}
return null;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy