VOM: support for pipes
[vpp.git] / extras / vom / vom / gbp_endpoint_group_cmds.cpp
1 /*
2  * Copyright (c) 2018 Cisco and/or its affiliates.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at:
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15
16 #include "vom/gbp_endpoint_group_cmds.hpp"
17
18 namespace VOM {
19 namespace gbp_endpoint_group_cmds {
20
21 create_cmd::create_cmd(HW::item<bool>& item,
22                        epg_id_t epg_id,
23                        uint32_t bd_id,
24                        route::table_id_t rd_id,
25                        const handle_t& itf)
26   : rpc_cmd(item)
27   , m_epg_id(epg_id)
28   , m_bd_id(bd_id)
29   , m_rd_id(rd_id)
30   , m_itf(itf)
31 {
32 }
33
34 bool
35 create_cmd::operator==(const create_cmd& other) const
36 {
37   return ((m_itf == other.m_itf) && (m_bd_id == other.m_bd_id) &&
38           (m_rd_id == other.m_rd_id) && (m_epg_id == other.m_epg_id));
39 }
40
41 rc_t
42 create_cmd::issue(connection& con)
43 {
44   msg_t req(con.ctx(), std::ref(*this));
45
46   auto& payload = req.get_request().get_payload();
47   payload.is_add = 1;
48   payload.epg.uplink_sw_if_index = m_itf.value();
49   payload.epg.epg_id = m_epg_id;
50   payload.epg.bd_id = m_bd_id;
51   payload.epg.ip4_table_id = m_rd_id;
52   payload.epg.ip6_table_id = m_rd_id;
53
54   VAPI_CALL(req.execute());
55
56   return (wait());
57 }
58
59 std::string
60 create_cmd::to_string() const
61 {
62   std::ostringstream s;
63   s << "gbp-endpoint-group-create: " << m_hw_item.to_string()
64     << " epg-id:" << m_epg_id << " bd-id:" << m_bd_id << " rd-id:" << m_rd_id
65     << " itf:" << m_itf;
66
67   return (s.str());
68 }
69
70 delete_cmd::delete_cmd(HW::item<bool>& item, epg_id_t epg_id)
71   : rpc_cmd(item)
72   , m_epg_id(epg_id)
73 {
74 }
75
76 bool
77 delete_cmd::operator==(const delete_cmd& other) const
78 {
79   return (m_epg_id == other.m_epg_id);
80 }
81
82 rc_t
83 delete_cmd::issue(connection& con)
84 {
85   msg_t req(con.ctx(), std::ref(*this));
86
87   auto& payload = req.get_request().get_payload();
88   payload.is_add = 0;
89   payload.epg.epg_id = m_epg_id;
90
91   VAPI_CALL(req.execute());
92
93   return (wait());
94 }
95
96 std::string
97 delete_cmd::to_string() const
98 {
99   std::ostringstream s;
100   s << "gbp-endpoint-group-delete: " << m_hw_item.to_string()
101     << " epg:" << m_epg_id;
102
103   return (s.str());
104 }
105
106 dump_cmd::dump_cmd()
107 {
108 }
109
110 bool
111 dump_cmd::operator==(const dump_cmd& other) const
112 {
113   return (true);
114 }
115
116 rc_t
117 dump_cmd::issue(connection& con)
118 {
119   m_dump.reset(new msg_t(con.ctx(), std::ref(*this)));
120
121   VAPI_CALL(m_dump->execute());
122
123   wait();
124
125   return rc_t::OK;
126 }
127
128 std::string
129 dump_cmd::to_string() const
130 {
131   return ("gbp-endpoint-group-dump");
132 }
133
134 }; // namespace gbp_endpoint_group_cmds
135 }; // namespace VOM
136
137 /*
138  * fd.io coding-style-patch-verification: ON
139  *
140  * Local Variables:
141  * eval: (c-set-style "mozilla")
142  * End:
143  */