2 * Copyright (c) 2017 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:
7 * http://www.apache.org/licenses/LICENSE-2.0
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.
16 #ifndef __VOM_ACL_LIST_CMDS_H__
17 #define __VOM_ACL_LIST_CMDS_H__
19 #include "vom/acl_list.hpp"
20 #include "vom/dump_cmd.hpp"
21 #include "vom/rpc_cmd.hpp"
23 #include <vapi/acl.api.vapi.hpp>
29 * A command class that Create the list
31 template <typename RULE, typename UPDATE>
33 : public rpc_cmd<HW::item<handle_t>, HW::item<handle_t>, UPDATE>
36 typedef typename list<RULE>::rules_t cmd_rules_t;
37 typedef typename list<RULE>::key_t cmd_key_t;
42 update_cmd(HW::item<handle_t>& item,
44 const cmd_rules_t& rules)
45 : rpc_cmd<HW::item<handle_t>, HW::item<handle_t>, UPDATE>(item)
52 * Issue the command to VPP/HW
54 rc_t issue(connection& con);
57 * convert to string format for debug purposes
59 std::string to_string() const
62 s << "ACL-list-update:[ " << this->item().to_string() << " rule-list:[";
63 for (auto rule : m_rules) {
64 s << " " << rule.to_string();
72 * Comparison operator - only used for UT
74 bool operator==(const update_cmd& other) const
76 return ((m_key == other.m_key) && (m_rules == other.m_rules));
81 std::shared_ptr<list<RULE>> sp = list<RULE>::find(m_key);
82 if (sp && this->item()) {
83 list<RULE>::add(this->item().data(), sp);
89 rpc_cmd<HW::item<handle_t>, HW::item<handle_t>, UPDATE>::succeeded();
94 * A callback function for handling ACL creates
96 virtual vapi_error_e operator()(UPDATE& reply)
98 int acl_index = reply.get_response().get_payload().acl_index;
99 int retval = reply.get_response().get_payload().retval;
101 VOM_LOG(log_level_t::DEBUG) << this->to_string() << " " << retval;
103 HW::item<handle_t> res(acl_index, rc_t::from_vpp_retval(retval));
114 const cmd_key_t& m_key;
119 const cmd_rules_t& m_rules;
123 * A cmd class that Deletes an ACL
125 template <typename DELETE>
126 class delete_cmd : public rpc_cmd<HW::item<handle_t>, rc_t, DELETE>
132 delete_cmd(HW::item<handle_t>& item)
133 : rpc_cmd<HW::item<handle_t>, rc_t, DELETE>(item)
138 * Issue the command to VPP/HW
140 rc_t issue(connection& con) { return (rc_t::INVALID); }
143 * convert to string format for debug purposes
145 std::string to_string() const
147 std::ostringstream s;
148 s << "ACL-list-delete: " << this->item().to_string();
154 * Comparison operator - only used for UT
156 bool operator==(const delete_cmd& other) const
158 return (this->item().data() == other.item().data());
163 * A cmd class that Dumps all the ACLs
165 template <typename DUMP>
166 class dump_cmd : public VOM::dump_cmd<DUMP>
172 dump_cmd() = default;
173 dump_cmd(const dump_cmd& d) = default;
176 * Issue the command to VPP/HW
178 rc_t issue(connection& con) { return rc_t::INVALID; }
181 * convert to string format for debug purposes
183 std::string to_string() const { return ("acl-list-dump"); }
193 * Typedef the L3 ACL commands
195 typedef update_cmd<l3_rule, vapi::Acl_add_replace> l3_update_cmd;
196 typedef delete_cmd<vapi::Acl_del> l3_delete_cmd;
197 typedef dump_cmd<vapi::Acl_dump> l3_dump_cmd;
200 * Typedef the L2 ACL commands
202 typedef update_cmd<l2_rule, vapi::Macip_acl_add> l2_update_cmd;
203 typedef delete_cmd<vapi::Macip_acl_del> l2_delete_cmd;
204 typedef dump_cmd<vapi::Macip_acl_dump> l2_dump_cmd;
206 }; // namespace list_cmds
211 * fd.io coding-style-patch-verification: ON
214 * eval: (c-set-style "mozilla")