mirror of
https://github.com/google/nomulus.git
synced 2025-05-13 07:57:13 +02:00
mv com/google/domain/registry google/registry
This change renames directories in preparation for the great package rename. The repository is now in a broken state because the code itself hasn't been updated. However this should ensure that git correctly preserves history for each file.
This commit is contained in:
parent
a41677aea1
commit
5012893c1d
2396 changed files with 0 additions and 0 deletions
104
java/google/registry/flows/SingleResourceFlow.java
Normal file
104
java/google/registry/flows/SingleResourceFlow.java
Normal file
|
@ -0,0 +1,104 @@
|
|||
// Copyright 2016 The Domain Registry 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 com.google.domain.registry.flows;
|
||||
|
||||
import static com.google.domain.registry.model.EppResourceUtils.loadByUniqueId;
|
||||
|
||||
import com.google.common.base.Joiner;
|
||||
import com.google.common.collect.ImmutableSet;
|
||||
import com.google.common.collect.Sets;
|
||||
import com.google.domain.registry.flows.EppException.StatusProhibitsOperationException;
|
||||
import com.google.domain.registry.model.EppResource;
|
||||
import com.google.domain.registry.model.domain.launch.ApplicationIdTargetExtension;
|
||||
import com.google.domain.registry.model.eppcommon.StatusValue;
|
||||
import com.google.domain.registry.model.eppinput.ResourceCommand.SingleResourceCommand;
|
||||
|
||||
import java.util.Set;
|
||||
|
||||
/**
|
||||
* An EPP flow that manipulates a single stored resource.
|
||||
*
|
||||
* @param <R> the resource type being manipulated
|
||||
* @param <C> the command type doing the manipulation.
|
||||
*/
|
||||
public abstract class SingleResourceFlow<R extends EppResource, C extends SingleResourceCommand>
|
||||
extends ResourceFlow<R, C> {
|
||||
|
||||
protected R existingResource;
|
||||
protected String targetId;
|
||||
|
||||
@Override
|
||||
protected final void initResourceFlow() throws EppException {
|
||||
targetId = getTargetId();
|
||||
// In a transactional flow, loading the resource will be expensive because it can't be cached.
|
||||
// Allow flows to optionally fail fast here before loading.
|
||||
failfast();
|
||||
// Loads the target resource if it exists
|
||||
// Some flows such as DomainApplicationInfoFlow have the id marked as optional in the schema.
|
||||
// We require it by policy in the relevant flow, but here we need to make sure not to NPE when
|
||||
// initializing the (obviously nonexistent) existing resource.
|
||||
existingResource = (targetId == null || !tryToLoadExisting())
|
||||
? null
|
||||
: loadByUniqueId(resourceClass, targetId, now);
|
||||
if (existingResource != null) {
|
||||
Set<StatusValue> problems = Sets.intersection(
|
||||
existingResource.getStatusValues(), getDisallowedStatuses());
|
||||
if (!problems.isEmpty()) {
|
||||
throw new ResourceStatusProhibitsOperationException(problems);
|
||||
}
|
||||
}
|
||||
initSingleResourceFlow();
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns whether the resource flow should attempt to load an existing resource with the
|
||||
* matching targetId. Defaults to true, but overriding flows can set to false to bypass loading
|
||||
* of existing resources.
|
||||
*/
|
||||
protected boolean tryToLoadExisting() {
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the target id from {@link SingleResourceCommand}. If there is a launch extension present,
|
||||
* it overrides that target id with its application id, so return that instead. There will never
|
||||
* be more than one launch extension.
|
||||
*/
|
||||
protected final String getTargetId() {
|
||||
ApplicationIdTargetExtension extension =
|
||||
eppInput.getSingleExtension(ApplicationIdTargetExtension.class);
|
||||
return extension == null ? command.getTargetId() : extension.getApplicationId();
|
||||
}
|
||||
|
||||
/** Subclasses can optionally override this to fail before loading {@link #existingResource}. */
|
||||
@SuppressWarnings("unused")
|
||||
protected void failfast() throws EppException {}
|
||||
|
||||
/** Subclasses can optionally override this for further initialization. */
|
||||
@SuppressWarnings("unused")
|
||||
protected void initSingleResourceFlow() throws EppException {}
|
||||
|
||||
protected Set<StatusValue> getDisallowedStatuses() {
|
||||
return ImmutableSet.of();
|
||||
}
|
||||
|
||||
/** Resource status prohibits this operation. */
|
||||
public static class ResourceStatusProhibitsOperationException
|
||||
extends StatusProhibitsOperationException {
|
||||
public ResourceStatusProhibitsOperationException(Set<StatusValue> status) {
|
||||
super("Operation disallowed by status: " + Joiner.on(", ").join(status));
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue