// 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.model.transfer; import static com.google.domain.registry.util.CollectionUtils.nullToEmptyImmutableCopy; import com.google.common.collect.ImmutableSet; import com.google.domain.registry.model.Buildable; import com.google.domain.registry.model.EppResource; import com.google.domain.registry.model.billing.BillingEvent; import com.google.domain.registry.model.eppcommon.Trid; import com.google.domain.registry.model.poll.PollMessage; import com.googlecode.objectify.Key; import com.googlecode.objectify.Ref; import com.googlecode.objectify.annotation.Embed; import com.googlecode.objectify.annotation.IgnoreSave; import com.googlecode.objectify.annotation.Unindex; import com.googlecode.objectify.condition.IfNull; import java.util.Set; /** * Common transfer data for {@link EppResource} types. Only applies to domains and contacts; * hosts are implicitly transferred with their superordinate domain. */ @Embed @Unindex public class TransferData extends BaseTransferObject implements Buildable { public static final TransferData EMPTY = new TransferData(); /** * The billing event and poll messages associated with a server-approved transfer. *
* This field should be null if there is not currently a pending transfer or if the object being * transferred is not a domain. If there is a pending transfer for a domain there should be a * number of poll messages and billing events for both the gaining and losing registrars. If the * pending transfer is explicitly approved, rejected or cancelled, the referenced entities should * be deleted. *
* Keys are stored here instead of references to facilitate bulk deletion (the typical use case,
* as described above), since Objectify allows bulk deletion by key but not by reference.
*/
@IgnoreSave(IfNull.class)
Set
* This field should be null if there is not currently a pending transfer or if the object being
* transferred is not a domain.
*/
@IgnoreSave(IfNull.class)
Ref
* This field should be null if there is not currently a pending transfer or if the object being
* transferred is not a domain.
*/
@IgnoreSave(IfNull.class)
Ref
* This field should be null if there is not currently a pending transfer or if the object being
* transferred is not a domain.
*/
@IgnoreSave(IfNull.class)
Ref