Add route information to link variant 23/195523/2
authorYu <jiung.yu@samsung.com>
Fri, 14 Dec 2018 02:16:33 +0000 (11:16 +0900)
committerYu <jiung.yu@samsung.com>
Fri, 14 Dec 2018 09:08:40 +0000 (18:08 +0900)
Change-Id: I5b75460842f57dd1b1e37093047e471ed269dd7d
Signed-off-by: Yu Jiung <jiung.yu@samsung.com>
src/inm-rtnl.c

index d2f8ca16d91763b071c328f1db210e88a4b5b53b..98cdbf5f0792d296617800d3eb0130bcce072e52 100644 (file)
@@ -1317,6 +1317,97 @@ static GVariant *__inm_rtnl_link_get_neighbors(inm_rtnl_link_s *p_link)
        return gvar_neighbors;
 }
 
+static GVariant *__inm_rtnl_route_get_destination(inm_rtnl_route_s *p_route)
+{
+       GVariant *ret = NULL;
+
+       ret = g_variant_new_string(p_route->dest);
+
+       return ret;
+}
+
+static GVariant *__inm_rtnl_route_get_gateway(inm_rtnl_route_s *p_route)
+{
+       GVariant *ret = NULL;
+
+       ret = g_variant_new_string(p_route->gateway);
+
+       return ret;
+}
+
+static GVariant *__inm_rtnl_route_get_ifidx(inm_rtnl_route_s *p_route)
+{
+       GVariant *ret = NULL;
+
+       ret = g_variant_new_int32(p_route->if_idx);
+
+       return ret;
+}
+
+static GVariant *__inm_rtnl_route_get_type(inm_rtnl_route_s *p_route)
+{
+       GVariant *ret = NULL;
+
+       ret = g_variant_new_int32(p_route->type);
+
+       return ret;
+}
+
+static void __inm_rtnl_get_route_variant(gpointer data, gpointer user_data)
+{
+       GVariantBuilder *outer = NULL;
+       GVariantBuilder *inner = NULL;
+       inm_rtnl_route_s *p_route = NULL;
+
+       outer = (GVariantBuilder *)user_data;
+       p_route = (inm_rtnl_route_s *)data;
+
+       inner = g_variant_builder_new(G_VARIANT_TYPE("a{sv}"));
+
+       if (p_route->dest)
+               g_variant_builder_add(inner,
+                                         "{sv}",
+                                         "Destination",
+                                         __inm_rtnl_route_get_destination(p_route));
+       if (p_route->gateway)
+               g_variant_builder_add(inner,
+                                         "{sv}",
+                                         "Gateway",
+                                         __inm_rtnl_route_get_gateway(p_route));
+       g_variant_builder_add(inner,
+                             "{sv}",
+                             "IfIdx",
+                                 __inm_rtnl_route_get_ifidx(p_route));
+       g_variant_builder_add(inner,
+                             "{sv}",
+                             "Type",
+                                 __inm_rtnl_route_get_type(p_route));
+
+       g_variant_builder_add(outer,
+                             "(a{sv})",
+                             inner);
+
+       g_variant_builder_unref(inner);
+}
+static GVariant *__inm_rtnl_link_get_routes(inm_rtnl_link_s *p_link)
+{
+       GVariantBuilder *builder = NULL;
+       GVariant *gvar_routes = NULL;
+
+       __INM_FUNC_ENTER__;
+
+       builder = g_variant_builder_new(G_VARIANT_TYPE("a(a{sv})"));
+       g_list_foreach(p_link->list_route,
+                       __inm_rtnl_get_route_variant,
+                       builder);
+
+       gvar_routes = g_variant_new("(a(a{sv}))", builder);
+       g_variant_builder_unref(builder);
+
+       __INM_FUNC_EXIT__;
+       return gvar_routes;
+}
+
 static void __inm_rtnl_link_build(inm_rtnl_link_s *p_link, GVariantBuilder *gb_link)
 {
        if (p_link->iface_name)
@@ -1352,6 +1443,10 @@ static void __inm_rtnl_link_build(inm_rtnl_link_s *p_link, GVariantBuilder *gb_l
                              "{sv}",
                              "Neighbors",
                                  __inm_rtnl_link_get_neighbors(p_link));
+       g_variant_builder_add(gb_link,
+                             "{sv}",
+                             "Routes",
+                                 __inm_rtnl_link_get_routes(p_link));
 }
 
 static void __inm_rtnl_get_link_variant(gpointer data, gpointer user_data)