Blame gdata/services/freebase/gdata-freebase-topic-query.c

Packit 4b6dd7
/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */
Packit 4b6dd7
/*
Packit 4b6dd7
 * GData Client
Packit 4b6dd7
 * Copyright (C) 2014 Carlos Garnacho <carlosg@gnome.org>
Packit 4b6dd7
 *
Packit 4b6dd7
 * GData Client is free software; you can redistribute it and/or
Packit 4b6dd7
 * modify it under the terms of the GNU Lesser General Public
Packit 4b6dd7
 * License as published by the Free Software Foundation; either
Packit 4b6dd7
 * version 2.1 of the License, or (at your option) any later version.
Packit 4b6dd7
 *
Packit 4b6dd7
 * GData Client is distributed in the hope that it will be useful,
Packit 4b6dd7
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 4b6dd7
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 4b6dd7
 * Lesser General Public License for more details.
Packit 4b6dd7
 *
Packit 4b6dd7
 * You should have received a copy of the GNU Lesser General Public
Packit 4b6dd7
 * License along with GData Client.  If not, see <http://www.gnu.org/licenses/>.
Packit 4b6dd7
 */
Packit 4b6dd7
Packit 4b6dd7
/**
Packit 4b6dd7
 * SECTION:gdata-freebase-topic-query
Packit 4b6dd7
 * @short_description: GData Freebase topic query object
Packit 4b6dd7
 * @stability: Stable
Packit 4b6dd7
 * @include: gdata/services/freebase/gdata-freebase-topic-query.h
Packit 4b6dd7
 *
Packit 4b6dd7
 * #GDataFreebaseTopicQuery represents a Freebase topic query. The topic query happens on a single Freebase ID,
Packit 4b6dd7
 * given in gdata_freebase_topic_query_new(), the reply returns all known information in Freebase for that given ID.
Packit 4b6dd7
 * For more documentation and examples, see the <ulink type="http" url="https://developers.google.com/freebase/v1/topic-response">
Packit 4b6dd7
 * Topic response API documentation</ulink>
Packit 4b6dd7
 *
Packit 4b6dd7
 * This implementation of #GDataQuery respects the gdata_query_set_max_results() and gdata_query_set_updated_max() calls.
Packit 4b6dd7
 *
Packit 4b6dd7
 * For more details of Google Freebase API, see the <ulink type="http" url="https://developers.google.com/freebase/v1/">
Packit 4b6dd7
 * online documentation</ulink>.
Packit 4b6dd7
 *
Packit 4b6dd7
 * Since: 0.15.1
Packit 4b6dd7
 * Deprecated: 0.17.7: Google Freebase has been permanently shut down.
Packit 4b6dd7
 */
Packit 4b6dd7
Packit 4b6dd7
#include <config.h>
Packit 4b6dd7
#include <glib.h>
Packit 4b6dd7
#include <glib/gi18n-lib.h>
Packit 4b6dd7
#include <string.h>
Packit 4b6dd7
#include <json-glib/json-glib.h>
Packit 4b6dd7
Packit 4b6dd7
#include "gdata-freebase-topic-query.h"
Packit 4b6dd7
#include "gdata-query.h"
Packit 4b6dd7
#include "gdata-parser.h"
Packit 4b6dd7
Packit 4b6dd7
G_GNUC_BEGIN_IGNORE_DEPRECATIONS
Packit 4b6dd7
Packit 4b6dd7
static void gdata_freebase_topic_query_finalize (GObject *self);
Packit 4b6dd7
static void gdata_freebase_topic_query_set_property (GObject *self, guint prop_id, const GValue *value, GParamSpec *pspec);
Packit 4b6dd7
static void gdata_freebase_topic_query_get_property (GObject *self, guint prop_id, GValue *value, GParamSpec *pspec);
Packit 4b6dd7
static void get_query_uri (GDataQuery *self, const gchar *feed_uri, GString *query_uri, gboolean *params_started);
Packit 4b6dd7
Packit 4b6dd7
struct _GDataFreebaseTopicQueryPrivate {
Packit 4b6dd7
	gchar *lang;
Packit 4b6dd7
	gchar **filter;
Packit 4b6dd7
};
Packit 4b6dd7
Packit 4b6dd7
enum {
Packit 4b6dd7
	PROP_LANGUAGE = 1,
Packit 4b6dd7
	PROP_FILTER
Packit 4b6dd7
};
Packit 4b6dd7
Packit 4b6dd7
G_DEFINE_TYPE (GDataFreebaseTopicQuery, gdata_freebase_topic_query, GDATA_TYPE_QUERY)
Packit 4b6dd7
Packit 4b6dd7
static void
Packit 4b6dd7
gdata_freebase_topic_query_class_init (GDataFreebaseTopicQueryClass *klass)
Packit 4b6dd7
{
Packit 4b6dd7
	GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
Packit 4b6dd7
	GDataQueryClass *query_class = GDATA_QUERY_CLASS (klass);
Packit 4b6dd7
Packit 4b6dd7
	g_type_class_add_private (klass, sizeof (GDataFreebaseTopicQueryPrivate));
Packit 4b6dd7
Packit 4b6dd7
	gobject_class->finalize = gdata_freebase_topic_query_finalize;
Packit 4b6dd7
	gobject_class->set_property = gdata_freebase_topic_query_set_property;
Packit 4b6dd7
	gobject_class->get_property = gdata_freebase_topic_query_get_property;
Packit 4b6dd7
Packit 4b6dd7
	query_class->get_query_uri = get_query_uri;
Packit 4b6dd7
Packit 4b6dd7
	/**
Packit 4b6dd7
	 * GDataFreebaseTopicQuery:language:
Packit 4b6dd7
	 *
Packit 4b6dd7
	 * Language used for topic values in the result, in ISO-639-1 format.
Packit 4b6dd7
	 *
Packit 4b6dd7
	 * Since: 0.15.1
Packit 4b6dd7
	 * Deprecated: 0.17.7: Google Freebase has been permanently shut down.
Packit 4b6dd7
	 */
Packit 4b6dd7
	g_object_class_install_property (gobject_class, PROP_LANGUAGE,
Packit 4b6dd7
	                                 g_param_spec_string ("language",
Packit 4b6dd7
							      "Language used for results",
Packit 4b6dd7
							      "Language in ISO-639-1 format.",
Packit 4b6dd7
							      NULL,
Packit 4b6dd7
							      G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS |
Packit 4b6dd7
							      G_PARAM_DEPRECATED));
Packit 4b6dd7
Packit 4b6dd7
	/**
Packit 4b6dd7
	 * GDataFreebaseTopicQuery:filter:
Packit 4b6dd7
	 *
Packit 4b6dd7
	 * Array of properties (eg. "/common/topic/description", or "/computer/software/first_released"), or property
Packit 4b6dd7
	 * domains (eg. "/common/topic", or "/computer") to be used as filter.
Packit 4b6dd7
	 *
Packit 4b6dd7
	 * Since: 0.15.1
Packit 4b6dd7
	 * Deprecated: 0.17.7: Google Freebase has been permanently shut down.
Packit 4b6dd7
	 */
Packit 4b6dd7
	g_object_class_install_property (gobject_class, PROP_FILTER,
Packit 4b6dd7
					 g_param_spec_boxed ("filter",
Packit 4b6dd7
							     "Filter",
Packit 4b6dd7
							     "Property domain to be used as filter",
Packit 4b6dd7
							     G_TYPE_STRV,
Packit 4b6dd7
							     G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
Packit 4b6dd7
}
Packit 4b6dd7
Packit 4b6dd7
static void
Packit 4b6dd7
gdata_freebase_topic_query_init (GDataFreebaseTopicQuery *self)
Packit 4b6dd7
{
Packit 4b6dd7
	self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self, GDATA_TYPE_FREEBASE_TOPIC_QUERY, GDataFreebaseTopicQueryPrivate);
Packit 4b6dd7
}
Packit 4b6dd7
Packit 4b6dd7
static void
Packit 4b6dd7
gdata_freebase_topic_query_finalize (GObject *self)
Packit 4b6dd7
{
Packit 4b6dd7
	GDataFreebaseTopicQueryPrivate *priv = GDATA_FREEBASE_TOPIC_QUERY (self)->priv;
Packit 4b6dd7
Packit 4b6dd7
	g_free (priv->lang);
Packit 4b6dd7
	g_free (priv->filter);
Packit 4b6dd7
Packit 4b6dd7
	/* Chain up to the parent class */
Packit 4b6dd7
	G_OBJECT_CLASS (gdata_freebase_topic_query_parent_class)->finalize (self);
Packit 4b6dd7
}
Packit 4b6dd7
Packit 4b6dd7
static void
Packit 4b6dd7
gdata_freebase_topic_query_set_property (GObject *self, guint prop_id, const GValue *value, GParamSpec *pspec)
Packit 4b6dd7
{
Packit 4b6dd7
	GDataFreebaseTopicQuery *query = GDATA_FREEBASE_TOPIC_QUERY (self);
Packit 4b6dd7
Packit 4b6dd7
	switch (prop_id) {
Packit 4b6dd7
	case PROP_LANGUAGE:
Packit 4b6dd7
		gdata_freebase_topic_query_set_language (query, g_value_get_string (value));
Packit 4b6dd7
		break;
Packit 4b6dd7
	case PROP_FILTER:
Packit 4b6dd7
		gdata_freebase_topic_query_set_filter (query, g_value_get_boxed (value));
Packit 4b6dd7
		break;
Packit 4b6dd7
	default:
Packit 4b6dd7
		G_OBJECT_WARN_INVALID_PROPERTY_ID (self, prop_id, pspec);
Packit 4b6dd7
		break;
Packit 4b6dd7
	}
Packit 4b6dd7
}
Packit 4b6dd7
Packit 4b6dd7
static void
Packit 4b6dd7
gdata_freebase_topic_query_get_property (GObject *self, guint prop_id, GValue *value, GParamSpec *pspec)
Packit 4b6dd7
{
Packit 4b6dd7
	GDataFreebaseTopicQueryPrivate *priv = GDATA_FREEBASE_TOPIC_QUERY (self)->priv;
Packit 4b6dd7
Packit 4b6dd7
	switch (prop_id) {
Packit 4b6dd7
	case PROP_LANGUAGE:
Packit 4b6dd7
		g_value_set_string (value, priv->lang);
Packit 4b6dd7
		break;
Packit 4b6dd7
	case PROP_FILTER:
Packit 4b6dd7
		g_value_set_boxed (value, priv->filter);
Packit 4b6dd7
		break;
Packit 4b6dd7
	default:
Packit 4b6dd7
		G_OBJECT_WARN_INVALID_PROPERTY_ID (self, prop_id, pspec);
Packit 4b6dd7
		break;
Packit 4b6dd7
	}
Packit 4b6dd7
}
Packit 4b6dd7
Packit 4b6dd7
static void
Packit 4b6dd7
get_query_uri (GDataQuery *self, const gchar *feed_uri, GString *query_uri, gboolean *params_started)
Packit 4b6dd7
{
Packit 4b6dd7
	GDataFreebaseTopicQueryPrivate *priv = GDATA_FREEBASE_TOPIC_QUERY (self)->priv;
Packit 4b6dd7
	const gchar *lang = NULL;
Packit 4b6dd7
	gint64 updated_max;
Packit 4b6dd7
	guint limit;
Packit 4b6dd7
Packit 4b6dd7
	g_string_append (query_uri, gdata_query_get_q (self));
Packit 4b6dd7
Packit 4b6dd7
#define APPEND_SEP g_string_append_c (query_uri, (*params_started == FALSE) ? '?' : '&';; *params_started = TRUE;
Packit 4b6dd7
Packit 4b6dd7
	if (priv->lang != NULL) {
Packit 4b6dd7
		lang = priv->lang;
Packit 4b6dd7
	} else {
Packit 4b6dd7
		const gchar * const *user_languages;
Packit 4b6dd7
		guint i;
Packit 4b6dd7
Packit 4b6dd7
		user_languages = g_get_language_names ();
Packit 4b6dd7
Packit 4b6dd7
		/* Pick the first user language */
Packit 4b6dd7
		for (i = 0; user_languages[i] != NULL; i++) {
Packit 4b6dd7
			if (strlen (user_languages[i]) == 2) {
Packit 4b6dd7
				lang = user_languages[i];
Packit 4b6dd7
				break;
Packit 4b6dd7
			}
Packit 4b6dd7
		}
Packit 4b6dd7
	}
Packit 4b6dd7
Packit 4b6dd7
	APPEND_SEP;
Packit 4b6dd7
	g_string_append (query_uri, "lang=");
Packit 4b6dd7
	g_string_append (query_uri, lang);
Packit 4b6dd7
Packit 4b6dd7
	if (priv->filter) {
Packit 4b6dd7
		guint i;
Packit 4b6dd7
Packit 4b6dd7
		for (i = 0; priv->filter[i] != NULL; i++) {
Packit 4b6dd7
			APPEND_SEP;
Packit 4b6dd7
			g_string_append (query_uri, "filter=");
Packit 4b6dd7
			g_string_append (query_uri, priv->filter[i]);
Packit 4b6dd7
		}
Packit 4b6dd7
	}
Packit 4b6dd7
Packit 4b6dd7
	updated_max = gdata_query_get_updated_max (self);
Packit 4b6dd7
Packit 4b6dd7
	if (updated_max > -1) {
Packit 4b6dd7
		APPEND_SEP;
Packit 4b6dd7
		g_string_append_printf (query_uri, "dateline=%" G_GINT64_FORMAT, updated_max);
Packit 4b6dd7
	}
Packit 4b6dd7
Packit 4b6dd7
	limit = gdata_query_get_max_results (self);
Packit 4b6dd7
Packit 4b6dd7
	if (limit > 0) {
Packit 4b6dd7
		APPEND_SEP;
Packit 4b6dd7
		g_string_append_printf (query_uri, "limit=%d", limit);
Packit 4b6dd7
	}
Packit 4b6dd7
Packit 4b6dd7
	/* We don't chain up with parent class get_query_uri because it uses
Packit 4b6dd7
	 *  GData protocol parameters and they aren't compatible with newest API family
Packit 4b6dd7
	 */
Packit 4b6dd7
#undef APPEND_SEP
Packit 4b6dd7
}
Packit 4b6dd7
Packit 4b6dd7
/**
Packit 4b6dd7
 * gdata_freebase_topic_query_new:
Packit 4b6dd7
 * @id: a Freebase ID or MID
Packit 4b6dd7
 *
Packit 4b6dd7
 * Creates a new #GDataFreebaseTopicQuery for the given Freebase ID. Those can be
Packit 4b6dd7
 * obtained programmatically through gdata_freebase_search_result_item_get_id() or
Packit 4b6dd7
 * embedded in the result of a gdata_freebase_service_query() call.
Packit 4b6dd7
 *
Packit 4b6dd7
 * Return value: (transfer full): a new #GDataFreebaseTopicQuery
Packit 4b6dd7
 *
Packit 4b6dd7
 * Since: 0.15.1
Packit 4b6dd7
 * Deprecated: 0.17.7: Google Freebase has been permanently shut down.
Packit 4b6dd7
 */
Packit 4b6dd7
GDataFreebaseTopicQuery *
Packit 4b6dd7
gdata_freebase_topic_query_new (const gchar *id)
Packit 4b6dd7
{
Packit 4b6dd7
	g_return_val_if_fail (id != NULL, NULL);
Packit 4b6dd7
	return g_object_new (GDATA_TYPE_FREEBASE_TOPIC_QUERY, "q", id, NULL);
Packit 4b6dd7
}
Packit 4b6dd7
Packit 4b6dd7
/**
Packit 4b6dd7
 * gdata_freebase_topic_query_set_language:
Packit 4b6dd7
 * @self: a #GDataFreebaseTopicQuery
Packit 4b6dd7
 * @lang: (allow-none): language used on the topic query, in ISO-639-1 format, or %NULL to unset the language
Packit 4b6dd7
 *
Packit 4b6dd7
 * Sets the language used in the topic query. If unset,
Packit 4b6dd7
 * the locale preferences will be respected.
Packit 4b6dd7
 *
Packit 4b6dd7
 * Since: 0.15.1
Packit 4b6dd7
 * Deprecated: 0.17.7: Google Freebase has been permanently shut down.
Packit 4b6dd7
 */
Packit 4b6dd7
void
Packit 4b6dd7
gdata_freebase_topic_query_set_language (GDataFreebaseTopicQuery *self,
Packit 4b6dd7
					 const gchar             *lang)
Packit 4b6dd7
{
Packit 4b6dd7
	GDataFreebaseTopicQueryPrivate *priv;
Packit 4b6dd7
Packit 4b6dd7
	g_return_if_fail (GDATA_IS_FREEBASE_TOPIC_QUERY (self));
Packit 4b6dd7
	g_return_if_fail (lang == NULL || strlen (lang) == 2);
Packit 4b6dd7
Packit 4b6dd7
	priv = self->priv;
Packit 4b6dd7
Packit 4b6dd7
	if (g_strcmp0 (priv->lang, lang) == 0)
Packit 4b6dd7
		return;
Packit 4b6dd7
Packit 4b6dd7
	g_free (priv->lang);
Packit 4b6dd7
	priv->lang = g_strdup (lang);
Packit 4b6dd7
	g_object_notify (G_OBJECT (self), "language");
Packit 4b6dd7
}
Packit 4b6dd7
Packit 4b6dd7
/**
Packit 4b6dd7
 * gdata_freebase_topic_query_get_language:
Packit 4b6dd7
 * @self: a #GDataFreebaseTopicQuery
Packit 4b6dd7
 *
Packit 4b6dd7
 * Gets the language set on the topic query, or %NULL if unset.
Packit 4b6dd7
 *
Packit 4b6dd7
 * Return value: (allow-none): The language used on the query.
Packit 4b6dd7
 *
Packit 4b6dd7
 * Since: 0.15.1
Packit 4b6dd7
 * Deprecated: 0.17.7: Google Freebase has been permanently shut down.
Packit 4b6dd7
 */
Packit 4b6dd7
const gchar *
Packit 4b6dd7
gdata_freebase_topic_query_get_language (GDataFreebaseTopicQuery *self)
Packit 4b6dd7
{
Packit 4b6dd7
	g_return_val_if_fail (GDATA_IS_FREEBASE_TOPIC_QUERY (self), NULL);
Packit 4b6dd7
Packit 4b6dd7
	return self->priv->lang;
Packit 4b6dd7
}
Packit 4b6dd7
Packit 4b6dd7
/**
Packit 4b6dd7
 * gdata_freebase_topic_query_set_filter:
Packit 4b6dd7
 * @self: a #GDataFreebaseTopicQuery
Packit 4b6dd7
 * @filter:  (array zero-terminated=1) (allow-none): %NULL-terminated array of filter strings, or %NULL to unset
Packit 4b6dd7
 *
Packit 4b6dd7
 * Sets a filter on the properties to be returned by the #GDataFreebaseTopicQuery, a filter string usually contains either
Packit 4b6dd7
 * a specific property (eg. "/common/topic/description", or "/computer/software/first_released"), or a property domain
Packit 4b6dd7
 * (eg. "/common/topic", or "/computer"), all properties pertaining to the domain will be returned through the
Packit 4b6dd7
 * #GDataFreebaseTopicResult in the latter case. Other special strings can be passed as filter strings, those are documented
Packit 4b6dd7
 * in the <ulink type="http" url="https://developers.google.com/freebase/v1/topic-overview#filter">Topic API overview</ulink>
Packit 4b6dd7
 *
Packit 4b6dd7
 * If multiple filter strings are set, the result will contain all information necessary to satisfy each of those individually.
Packit 4b6dd7
 * If no filter is set, the "commons" special value will be implicitly assumed, which returns a reasonably complete data set.
Packit 4b6dd7
 *
Packit 4b6dd7
 * Since: 0.15.1
Packit 4b6dd7
 * Deprecated: 0.17.7: Google Freebase has been permanently shut down.
Packit 4b6dd7
 */
Packit 4b6dd7
void
Packit 4b6dd7
gdata_freebase_topic_query_set_filter (GDataFreebaseTopicQuery *self, const gchar * const *filter)
Packit 4b6dd7
{
Packit 4b6dd7
	GDataFreebaseTopicQueryPrivate *priv;
Packit 4b6dd7
Packit 4b6dd7
	g_return_if_fail (GDATA_IS_FREEBASE_TOPIC_QUERY (self));
Packit 4b6dd7
	priv = self->priv;
Packit 4b6dd7
Packit 4b6dd7
	g_strfreev (priv->filter);
Packit 4b6dd7
	priv->filter = g_strdupv ((gchar **) filter);
Packit 4b6dd7
	g_object_notify (G_OBJECT (self), "filter");
Packit 4b6dd7
}
Packit 4b6dd7
Packit 4b6dd7
/**
Packit 4b6dd7
 * gdata_freebase_topic_query_get_filter:
Packit 4b6dd7
 * @self: a #GDataFreebaseTopicQuery
Packit 4b6dd7
 *
Packit 4b6dd7
 * Gets the filter set on the topic query, or %NULL if unset.
Packit 4b6dd7
 *
Packit 4b6dd7
 * Return value: (array zero-terminated=1) (transfer none) (allow-none): The filter used on the query.
Packit 4b6dd7
 *
Packit 4b6dd7
 * Since: 0.15.1
Packit 4b6dd7
 * Deprecated: 0.17.7: Google Freebase has been permanently shut down.
Packit 4b6dd7
 */
Packit 4b6dd7
const gchar * const *
Packit 4b6dd7
gdata_freebase_topic_query_get_filter (GDataFreebaseTopicQuery *self)
Packit 4b6dd7
{
Packit 4b6dd7
	g_return_val_if_fail (GDATA_IS_FREEBASE_TOPIC_QUERY (self), NULL);
Packit 4b6dd7
Packit 4b6dd7
	return (const gchar * const *) self->priv->filter;
Packit 4b6dd7
}
Packit 4b6dd7
Packit 4b6dd7
G_GNUC_END_IGNORE_DEPRECATIONS