blob: c7ae7b46d85c51b8dfdc480dc345adb341d030f8 [file] [log] [blame]
Jian Licaa03922021-02-26 18:15:20 +09001/*
2 * Copyright 2021-present Open Networking Foundation
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 */
16package org.onosproject.kubevirtnetworking.api;
17
Jian Licaa03922021-02-26 18:15:20 +090018import java.util.Map;
19import java.util.Set;
20
21/**
22 * Representation of virtual router.
23 */
24public interface KubevirtRouter {
25
26 /**
27 * Returns the router name.
28 *
29 * @return router name
30 */
31 String name();
32
33 /**
34 * Returns the router description.
35 *
36 * @return router description
37 */
38 String description();
39
40 /**
41 * Returns the SNAT enable flag.
42 *
43 * @return true if the router support SNAT, false otherwise
44 */
45 boolean enableSnat();
46
47 /**
48 * Returns a set of internal networks.
49 *
50 * @return a set of internal networks
51 */
52 Set<String> internal();
53
54 /**
55 * Returns external network along with external router IP address.
56 * We use IP address as the key, and external network name as the value.
57 *
58 * @return external network paired with external router IP address
59 */
Jian Li810f58c2021-02-27 01:10:50 +090060 Map<String, String> external();
Jian Licaa03922021-02-26 18:15:20 +090061
62 /**
63 * Returns external peer router.
64 *
65 * @return peer router
66 */
67 KubevirtPeerRouter peerRouter();
68
Jian Li810f58c2021-02-27 01:10:50 +090069 /**
Daniel Park2884b232021-03-04 18:58:47 +090070 * Returns elected gateway node hostname.
71 *
72 * @return gateway node hostname.
73 */
74 String electedGateway();
75
76 /**
Jian Li810f58c2021-02-27 01:10:50 +090077 * Updates the peer router.
78 *
79 * @param updated updated peer router
Daniel Park2884b232021-03-04 18:58:47 +090080 * @return kubevirt router with updated peer router
Jian Li810f58c2021-02-27 01:10:50 +090081 */
82 KubevirtRouter updatePeerRouter(KubevirtPeerRouter updated);
83
Daniel Park2884b232021-03-04 18:58:47 +090084 /**
85 * Updates the elected gateway node host name.
86 *
87 * @param updated updated elected gateway node hostname
88 * @return kubevirt router with the updated gateway node hostname
89 */
90 KubevirtRouter updatedElectedGateway(String updated);
91
92
Jian Licaa03922021-02-26 18:15:20 +090093 interface Builder {
94
95 /**
Jian Li073f1ba2021-02-28 03:50:15 +090096 * Builds an immutable router instance.
Jian Licaa03922021-02-26 18:15:20 +090097 *
98 * @return kubevirt router
99 */
100 KubevirtRouter build();
101
102 /**
103 * Returns kubevirt router builder with supplied router name.
104 *
105 * @param name router name
106 * @return router builder
107 */
108 Builder name(String name);
109
110 /**
111 * Returns kubevirt router builder with supplied router description.
112 *
113 * @param description router description
114 * @return router builder
115 */
116 Builder description(String description);
117
118 /**
119 * Returns kubevirt router builder with supplied enable SNAT flag.
120 *
121 * @param flag router flag
122 * @return router builder
123 */
124 Builder enableSnat(boolean flag);
125
126 /**
127 * Returns kubevirt router builder with supplied internal networks.
128 *
129 * @param internal internal network set
130 * @return router builder
131 */
132 Builder internal(Set<String> internal);
133
134 /**
135 * Returns kubevirt router builder with supplied external network with IP.
136 *
137 * @param external external network with IP
138 * @return router builder
139 */
Jian Li810f58c2021-02-27 01:10:50 +0900140 Builder external(Map<String, String> external);
Jian Licaa03922021-02-26 18:15:20 +0900141
142 /**
143 * Returns kubevirt router builder with supplied peer router.
144 *
145 * @param router peer router
146 * @return router builder
147 */
148 Builder peerRouter(KubevirtPeerRouter router);
Daniel Park2884b232021-03-04 18:58:47 +0900149
150 /**
151 * Returns kubevirt router builder with supplied elected gateway node hostname.
152 *
153 * @param gateway gateway node hostname
154 * @return router builder
155 */
156 Builder electedGateway(String gateway);
Jian Licaa03922021-02-26 18:15:20 +0900157 }
158}