blob: 9f53bee848fa625f386554575f78217d951f0a7a [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 */
tom0eb04ca2014-08-25 14:34:51 -070016package org.onlab.onos.net.host;
17
tome33cc1a2014-08-25 21:59:41 -070018import org.onlab.onos.net.Host;
tomc1a38d32014-08-25 23:01:32 -070019import org.onlab.onos.net.provider.Provider;
tom0eb04ca2014-08-25 14:34:51 -070020
21/**
22 * Provider of information about hosts and their location on the network.
23 */
24public interface HostProvider extends Provider {
tome33cc1a2014-08-25 21:59:41 -070025
tome33cc1a2014-08-25 21:59:41 -070026 /**
27 * Triggers an asynchronous probe of the specified host, intended to
28 * determine whether the host is present or not. An indirect result of this
tom326b71a2014-09-09 14:49:17 -070029 * should be invocation of {@link org.onlab.onos.net.host.HostProviderService#hostDetected}
30 * or {@link org.onlab.onos.net.host.HostProviderService#hostVanished}
tome33cc1a2014-08-25 21:59:41 -070031 * at some later point in time.
32 *
33 * @param host host to probe
34 */
35 void triggerProbe(Host host);
36
tom0eb04ca2014-08-25 14:34:51 -070037}