[gnome-maps/wip/mlundblad/osm-oauth-external: 1/4] maps-osm: Add function to parse OSM user details
- From: Marcus Lundblad <mlundblad src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-maps/wip/mlundblad/osm-oauth-external: 1/4] maps-osm: Add function to parse OSM user details
- Date: Wed, 27 Apr 2022 20:43:16 +0000 (UTC)
commit e97a3314d245c990d34069b3d89f4e49829d4f71
Author: Marcus Lundblad <ml dfupdate se>
Date: Sun Apr 24 23:26:08 2022 +0200
maps-osm: Add function to parse OSM user details
Adds a function to parse the logged in user name
from the user_details OSM REST API call result.
lib/maps-osm.c | 47 ++++++++++++++++++++++++++++++++++++++++++++++-
lib/maps-osm.h | 2 ++
2 files changed, 48 insertions(+), 1 deletion(-)
---
diff --git a/lib/maps-osm.c b/lib/maps-osm.c
index 307a9361..1164001c 100644
--- a/lib/maps-osm.c
+++ b/lib/maps-osm.c
@@ -169,7 +169,8 @@ get_sub_node (xmlDoc *doc)
xmlXPathObject * xpath_obj;
xpath_ctx = xmlXPathNewContext (doc);
- xpath_obj = xmlXPathEvalExpression ((xmlChar *) "/osm/node|/osm/way|/osm/relation",
+ xpath_obj = xmlXPathEvalExpression ((xmlChar *)
+ "/osm/node|/osm/way|/osm/relation|/osm/user",
xpath_ctx);
if (xpath_obj && xpath_obj->nodesetval && xpath_obj->nodesetval->nodeNr > 0)
@@ -469,3 +470,47 @@ maps_osm_parse (const char *content, guint length, GError **error)
return object;
}
+
+/**
+ * maps_osm_parse_user_details:
+ * @content: XML data
+ * @error: Error handle
+ * Returns: (transfer full) Logged in user name
+ */
+char *
+maps_osm_parse_user_details (const char *content, GError **error)
+{
+ xmlDocPtr doc;
+ xmlNodePtr sub_node;
+ char *ret;
+
+ doc = read_xml_doc (content, strlen (content), error);
+ sub_node = get_sub_node (doc);
+
+ if (!sub_node)
+ {
+ xmlFreeDoc (doc);
+ *error = g_error_new_literal (MAPS_OSM_ERROR, 0,
+ _("Could not find OSM element"));
+ return NULL;
+ }
+
+ if (g_str_equal (sub_node->name, "user"))
+ {
+ g_autoptr (GHashTable) attributes;
+
+ attributes = parse_attributes (sub_node);
+ ret = g_strdup (g_hash_table_lookup (attributes, "display_name"));
+ }
+ else
+ {
+ *error = g_error_new_literal (MAPS_OSM_ERROR, 0,
+ _("Could not find user element"));
+ ret = NULL;
+ }
+
+ xmlFreeDoc (doc);
+ xmlFreeNode (sub_node);
+
+ return ret;
+}
diff --git a/lib/maps-osm.h b/lib/maps-osm.h
index faca7404..b3202479 100644
--- a/lib/maps-osm.h
+++ b/lib/maps-osm.h
@@ -32,4 +32,6 @@ void maps_osm_finalize (void);
MapsOSMObject *maps_osm_parse (const char *content, guint length,
GError **error);
+
+char *maps_osm_parse_user_details(const char *content, GError **error);
#endif
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]