Move Adapter for Binding EntityOwnershipService
[mdsal.git] / entityownership / mdsal-eos-common-api / src / main / java / org / opendaylight / mdsal / eos / common / api / CandidateAlreadyRegisteredException.java
1 /*
2  * Copyright (c) 2015 Cisco Systems, Inc. and others.  All rights reserved.
3  *
4  * This program and the accompanying materials are made available under the
5  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6  * and is available at http://www.eclipse.org/legal/epl-v10.html
7  */
8
9 package org.opendaylight.mdsal.eos.common.api;
10
11 import com.google.common.base.Preconditions;
12 import javax.annotation.Nonnull;
13 import org.opendaylight.yangtools.concepts.Path;
14
15 /**
16  * Thrown when a Candidate has already been registered for a given Entity. This could be due to a component doing a
17  * duplicate registration or two different components within the same process trying to register a Candidate.
18  */
19 public class CandidateAlreadyRegisteredException extends Exception {
20     private static final long serialVersionUID = 1L;
21
22     private final GenericEntity<?> entity;
23
24     public <T extends Path<T>> CandidateAlreadyRegisteredException(@Nonnull GenericEntity<T> entity) {
25         super(String.format("Candidate has already been registered for %s",
26                 Preconditions.checkNotNull(entity, "entity should not be null")));
27         this.entity = entity;
28     }
29
30     /**
31      * @return the entity for which a Candidate has already been registered in the current process.
32      *
33      * @param <T> the instance identifier path type
34      */
35     @SuppressWarnings("unchecked")
36     @Nonnull
37     public <T extends Path<T>> GenericEntity<T> getEntity() {
38         return (GenericEntity<T>) entity;
39     }
40 }