/* * Copyright (c) 2018 Cisco and/or its affiliates. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at: * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include namespace VOM { void to_api(const ip_address_t& a, vapi_type_address& v) { if (a.is_v4()) { v.af = ADDRESS_IP4; memcpy(v.un.ip4, a.to_v4().to_bytes().data(), 4); } else { v.af = ADDRESS_IP6; memcpy(v.un.ip6, a.to_v6().to_bytes().data(), 16); } } ip_address_t from_api(const vapi_type_address& v) { boost::asio::ip::address addr; if (ADDRESS_IP6 == v.af) { std::array a; std::copy(v.un.ip6, v.un.ip6 + 16, std::begin(a)); boost::asio::ip::address_v6 v6(a); addr = v6; } else { std::array a; std::copy(v.un.ip6, v.un.ip6 + 4, std::begin(a)); boost::asio::ip::address_v4 v4(a); addr = v4; } return addr; } vapi_type_mac_address to_api(const mac_address_t& a) { vapi_type_mac_address v; std::copy(std::begin(a.bytes), std::end(a.bytes), v.bytes); return (v); } mac_address_t from_api(const vapi_type_mac_address& v) { return mac_address_t(v.bytes); } route::prefix_t from_api(const vapi_type_prefix& v) { return route::prefix_t(from_api(v.address), v.address_length); } void to_api(const route::prefix_t& p, vapi_type_prefix& v) { to_api(p.address(), v.address); v.address_length = p.mask_width(); } }; /* * fd.io coding-style-patch-verification: ON * * Local Variables: * eval: (c-set-style "mozilla") * End: */