blob: d0211e26b20e71df398ae6a85eb19874ff465b16 [file] [log] [blame]
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07001/*
2 * Copyright 2014 Open Networking Laboratory
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
Brian O'Connor6de2e202015-05-21 14:30:41 -070016package org.onosproject.net.resource.link;
Toshio Koide485b4782014-10-20 19:34:21 -070017
Sho SHIMIZUc4d56612015-07-02 13:54:09 -070018import java.util.Collection;
Toshio Koided707d7a2014-10-23 12:37:51 -070019import java.util.Set;
20
Brian O'Connorabafb502014-12-02 22:26:20 -080021import org.onosproject.net.Link;
Sho SHIMIZUc4d56612015-07-02 13:54:09 -070022import org.onosproject.net.intent.IntentId;
Brian O'Connor6de2e202015-05-21 14:30:41 -070023import org.onosproject.net.resource.ResourceAllocation;
Sho SHIMIZUc4d56612015-07-02 13:54:09 -070024import org.onosproject.net.resource.ResourceRequest;
Toshio Koide485b4782014-10-20 19:34:21 -070025
26/**
27 * Representation of allocated link resources.
Sho SHIMIZU364cbac2015-10-29 15:47:35 -070028 *
29 * @deprecated
Toshio Koide485b4782014-10-20 19:34:21 -070030 */
Sho SHIMIZU364cbac2015-10-29 15:47:35 -070031@Deprecated
Sho SHIMIZUc4d56612015-07-02 13:54:09 -070032public interface LinkResourceAllocations extends ResourceAllocation {
33
34 /**
35 * Returns the {@link IntentId} associated with the request.
36 *
37 * @return the {@link IntentId} associated with the request
38 */
39 IntentId intentId();
40
41 /**
42 * Returns the set of target links.
43 *
44 * @return the set of target links
45 */
46 Collection<Link> links();
47
48 /**
49 * Returns the set of resource requests.
50 *
51 * @return the set of resource requests
52 */
53 Set<ResourceRequest> resources();
54
Toshio Koide485b4782014-10-20 19:34:21 -070055 /**
56 * Returns allocated resource for the given link.
57 *
58 * @param link the target link
59 * @return allocated resource for the link
60 */
Toshio Koided707d7a2014-10-23 12:37:51 -070061 Set<ResourceAllocation> getResourceAllocation(Link link);
Toshio Koide485b4782014-10-20 19:34:21 -070062}