mirror of
https://github.com/google/nomulus.git
synced 2025-06-28 07:13:34 +02:00
Remove the util package's dependency on the config package
This allows us to use util methods from within config, which is a useful thing to be able to do for, e.g., being able to log errors while loading configuration. It makes sense that the util package should be at the very base of the class inheritance hierarchy; config seems logically higher than it. ------------- Created by MOE: https://github.com/google/moe MOE_MIGRATED_REVID=144324273
This commit is contained in:
parent
b0bcc1bb3d
commit
9f142c6767
15 changed files with 29 additions and 38 deletions
|
@ -8,7 +8,6 @@ java_library(
|
|||
name = "util",
|
||||
srcs = glob(["*.java"]),
|
||||
deps = [
|
||||
"//java/google/registry/config",
|
||||
"//third_party/java/objectify:objectify-v4_1",
|
||||
"@com_google_appengine_api_1_0_sdk",
|
||||
"@com_google_code_findbugs_jsr305",
|
||||
|
|
|
@ -1,57 +0,0 @@
|
|||
// Copyright 2016 The Nomulus Authors. All Rights Reserved.
|
||||
//
|
||||
// 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
|
||||
//
|
||||
// http://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 google.registry.util;
|
||||
|
||||
import static com.google.common.base.Suppliers.memoizeWithExpiration;
|
||||
import static google.registry.config.RegistryConfig.getSingletonCachePersistDuration;
|
||||
import static google.registry.config.RegistryConfig.getSingletonCacheRefreshDuration;
|
||||
import static java.util.concurrent.TimeUnit.MILLISECONDS;
|
||||
import static org.joda.time.Duration.ZERO;
|
||||
|
||||
import com.google.common.base.Supplier;
|
||||
import org.joda.time.Duration;
|
||||
|
||||
/** Utility methods related to caching. */
|
||||
public class CacheUtils {
|
||||
|
||||
/**
|
||||
* Memoize a supplier, with a short expiration specified in the environment config.
|
||||
*
|
||||
* <p>Use this for things that might change while code is running. (For example, the various
|
||||
* lists downloaded from the TMCH get updated in datastore and the caches need to be refreshed.)
|
||||
*/
|
||||
public static <T> Supplier<T> memoizeWithShortExpiration(Supplier<T> original) {
|
||||
return memoizeForDuration(original, getSingletonCacheRefreshDuration());
|
||||
}
|
||||
|
||||
/**
|
||||
* Memoize a supplier, with a long expiration specified in the environment config.
|
||||
*
|
||||
* <p>Use this for things that are loaded lazily but then will never change. This allows the test
|
||||
* config to set the expiration time to zero so that different test values can be substituted in,
|
||||
* while allowing the production config to set the expiration to forever.
|
||||
*/
|
||||
public static <T> Supplier<T> memoizeWithLongExpiration(Supplier<T> original) {
|
||||
return memoizeForDuration(original, getSingletonCachePersistDuration());
|
||||
}
|
||||
|
||||
/** Memoize a supplier, with a given expiration. */
|
||||
private static <T> Supplier<T> memoizeForDuration(Supplier<T> original, Duration expiration) {
|
||||
return expiration.isEqual(ZERO)
|
||||
? original // memoizeWithExpiration won't accept 0 as a refresh duration.
|
||||
: memoizeWithExpiration(original, expiration.getMillis(), MILLISECONDS);
|
||||
}
|
||||
}
|
||||
|
|
@ -21,11 +21,11 @@ import static google.registry.util.PredicateUtils.supertypeOf;
|
|||
|
||||
import com.google.common.base.Predicate;
|
||||
import com.google.common.collect.ImmutableSet;
|
||||
import google.registry.config.RegistryConfig.Config;
|
||||
import java.io.Serializable;
|
||||
import java.util.Set;
|
||||
import java.util.concurrent.Callable;
|
||||
import javax.inject.Inject;
|
||||
import javax.inject.Named;
|
||||
import org.joda.time.Duration;
|
||||
|
||||
/** Wrapper that does retry with exponential backoff. */
|
||||
|
@ -39,7 +39,7 @@ public class Retrier implements Serializable {
|
|||
private final int attempts;
|
||||
|
||||
@Inject
|
||||
public Retrier(Sleeper sleeper, @Config("transientFailureRetries") int transientFailureRetries) {
|
||||
public Retrier(Sleeper sleeper, @Named("transientFailureRetries") int transientFailureRetries) {
|
||||
this.sleeper = sleeper;
|
||||
checkArgument(transientFailureRetries > 0, "Number of attempts must be positive");
|
||||
this.attempts = transientFailureRetries;
|
||||
|
|
|
@ -1,96 +0,0 @@
|
|||
// Copyright 2016 The Nomulus Authors. All Rights Reserved.
|
||||
//
|
||||
// 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
|
||||
//
|
||||
// http://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 google.registry.util;
|
||||
|
||||
import static com.google.common.collect.Iterables.toArray;
|
||||
|
||||
import com.google.common.base.Function;
|
||||
import com.google.common.base.Joiner;
|
||||
import com.google.common.base.Predicates;
|
||||
import com.google.common.collect.FluentIterable;
|
||||
import google.registry.config.RegistryConfig.Config;
|
||||
import java.util.List;
|
||||
import javax.inject.Inject;
|
||||
import javax.mail.Message;
|
||||
import javax.mail.internet.AddressException;
|
||||
import javax.mail.internet.InternetAddress;
|
||||
|
||||
/**
|
||||
* Utility class for sending emails from the app.
|
||||
*/
|
||||
public class SendEmailUtils {
|
||||
|
||||
private static final FormattingLogger logger = FormattingLogger.getLoggerForCallerClass();
|
||||
|
||||
private final String googleAppsSendFromEmailAddress;
|
||||
private final String googleAppsAdminEmailDisplayName;
|
||||
|
||||
@Inject
|
||||
public SendEmailUtils(
|
||||
@Config("googleAppsSendFromEmailAddress") String googleAppsSendFromEmailAddress,
|
||||
@Config("googleAppsAdminEmailDisplayName") String googleAppsAdminEmailDisplayName) {
|
||||
this.googleAppsSendFromEmailAddress = googleAppsSendFromEmailAddress;
|
||||
this.googleAppsAdminEmailDisplayName = googleAppsAdminEmailDisplayName;
|
||||
}
|
||||
|
||||
@NonFinalForTesting
|
||||
private static SendEmailService emailService = new SendEmailService();
|
||||
|
||||
/**
|
||||
* Sends an email from Nomulus to the specified recipient(s). Returns true iff sending was
|
||||
* successful.
|
||||
*/
|
||||
public boolean sendEmail(Iterable<String> addresses, final String subject, String body) {
|
||||
try {
|
||||
Message msg = emailService.createMessage();
|
||||
msg.setFrom(
|
||||
new InternetAddress(googleAppsSendFromEmailAddress, googleAppsAdminEmailDisplayName));
|
||||
List<InternetAddress> emails = FluentIterable
|
||||
.from(addresses)
|
||||
.transform(new Function<String, InternetAddress>() {
|
||||
@Override
|
||||
public InternetAddress apply(String emailAddress) {
|
||||
try {
|
||||
return new InternetAddress(emailAddress);
|
||||
} catch (AddressException e) {
|
||||
logger.severefmt(
|
||||
e,
|
||||
"Could not send email to %s with subject '%s'.",
|
||||
emailAddress,
|
||||
subject);
|
||||
// Returning null excludes this address from the list of recipients on the email.
|
||||
return null;
|
||||
}
|
||||
}})
|
||||
.filter(Predicates.notNull())
|
||||
.toList();
|
||||
if (emails.isEmpty()) {
|
||||
return false;
|
||||
}
|
||||
msg.addRecipients(Message.RecipientType.TO, toArray(emails, InternetAddress.class));
|
||||
msg.setSubject(subject);
|
||||
msg.setText(body);
|
||||
emailService.sendMessage(msg);
|
||||
} catch (Throwable t) {
|
||||
logger.severefmt(
|
||||
t,
|
||||
"Could not email to addresses %s with subject '%s'.",
|
||||
Joiner.on(", ").join(addresses),
|
||||
subject);
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue