blob: bb158bfa8458f520ddbc939a1dea9ae01ca1edd1 [file] [log] [blame]
wei wei89ddc322015-03-22 16:29:04 -05001/*
2 * Copyright 2015 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 */
Thomas Vachuskabf916ea2015-05-20 18:24:34 -070016
17package org.onosproject.incubator.net.tunnel;
wei wei89ddc322015-03-22 16:29:04 -050018
Brian O'Connor2bed5ce2015-06-25 15:10:28 -040019import com.google.common.annotations.Beta;
wei wei89ddc322015-03-22 16:29:04 -050020import org.onosproject.net.provider.ProviderService;
21
22/**
23 * APIs for tunnel provider to notify the tunnel subSystem.
24 */
Brian O'Connor2bed5ce2015-06-25 15:10:28 -040025@Beta
wei wei89ddc322015-03-22 16:29:04 -050026public interface TunnelProviderService extends ProviderService<TunnelProvider> {
27
28 /**
29 * Signals that the provider has added a tunnel.
30 *
31 * @param tunnel tunnel information
jcc4a20a5f2015-04-30 15:43:39 +080032 * @return tunnel identity
wei wei89ddc322015-03-22 16:29:04 -050033 */
jcc4a20a5f2015-04-30 15:43:39 +080034 TunnelId tunnelAdded(TunnelDescription tunnel);
wei wei89ddc322015-03-22 16:29:04 -050035
36 /**
37 * Signals that the provider has removed a tunnel.
38 *
39 * @param tunnel tunnel information
40 */
41 void tunnelRemoved(TunnelDescription tunnel);
42
43 /**
44 * Signals that the a tunnel was changed (e.g., sensing changes of tunnel).
45 *
46 * @param tunnel tunnel information
47 */
48 void tunnelUpdated(TunnelDescription tunnel);
49
samuel7a5691a2015-05-23 00:36:32 +080050 /**
51 * Signals that the a tunnel was queried.
52 *
53 * @param tunnelId tunnel identity
54 * @return tunnel entity
55 */
56 Tunnel tunnelQueryById(TunnelId tunnelId);
57
wei wei89ddc322015-03-22 16:29:04 -050058}