<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://docbook.org/xml/4.5/docbookx.dtd" [
<!ENTITY legal SYSTEM "legal.xml">
<!ENTITY url_refdocs_base "http://developer.gnome.org/grilo/unstable/">
<!ENTITY url_examples_base "http://git.gnome.org/browse/grilo-plugins/tree/help/examples/">
<!ENTITY uuml "ü">
<!ENTITY szlig "ß">
<!ENTITY verbar "|">
<!ENTITY copy "©">
<!ENTITY nbsp " ">
]>
<!-- The XSL for developer.gnome.org requires this id. -->
<book id="index" lang="es">
<bookinfo>
<title>Complementos de Grilo</title>
<authorgroup>
<author><firstname>Murray</firstname> <surname>Cumming</surname></author>
</authorgroup>
<abstract>
<!-- This text is copied from the introduction. -->
<para>Grilo es un entorno de trabajo para examinar y buscar contenido multimedia de varias fuentes usando una única API. Los complementos de Grilo para el entorno de trabajo proporcionan acceso a varias fuentes de medios y metadatos.</para>
</abstract>
<copyright><year>2012</year> <holder>Openismus GmbH</holder></copyright>
<legalnotice>
<para>Se concede permiso para copiar, distribuir o modificar este documento según las condiciones de la GNU Free documentation License (GFDL), Versión 1.2 o cualquier versión posterior publicada por la Free Software Foundation sin Secciones invariantes, Textos de portada y Textos de contraportada. Encontrará una copia de la GFDL visitando su página web o escribiendo a: Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301, USA.</para>
</legalnotice>
<othercredit class="translator">
<personname>
<firstname>Daniel Mustieles</firstname>
</personname>
<email>[email protected]</email>
</othercredit>
<copyright>
<year>2018</year>
<year>2020</year>
<holder>Daniel Mustieles</holder>
</copyright>
</bookinfo>
<chapter id="chapter-introduction">
<title>Introducción</title>
<para>Grilo es un entorno de trabajo para examinar y buscar contenido multimedia de varias fuentes usando una única API. Los complementos de Grilo para el entorno de trabajo proporcionan acceso a varias fuentes de medios y metadatos.</para>
</chapter>
<chapter id="chapter-plugins">
<title>Complementos de Grilo</title>
<sect1 id="sec-plugin-apple-trailers">
<title>Tráilers de Apple</title>
<para>Esto es un complemento para los tráilers de Apple. El ID de este complemento es <literal>"grl-apple-trailers"</literal></para>
</sect1>
<sect1 id="sec-plugin-bookmarks">
<title>Marcadores</title>
<para>Esto es un complemento para los marcadores. El ID de este complemento es <literal>"grl-bookmarks"</literal></para>
</sect1>
<sect1 id="sec-plugin-dmap">
<title>DMap</title>
<para>Esto es un complemento para DMap. El ID de este complemento es <literal>"grl-dmap"</literal></para>
</sect1>
<sect1 id="sec-plugin-filesystem">
<title>Sistema de archivos</title>
<para>Esto es un complemento para el sistema de archivos. El ID de este complemento es <literal>"grl-filesystem"</literal></para>
</sect1>
<sect1 id="sec-plugin-flickr">
<title>Flickr</title>
<para>Esto es un complemento para Flickr. El ID de este complemento es <literal>"grl-flickr"</literal></para>
</sect1>
<sect1 id="sec-plugin-gravatar">
<title>Gravatar</title>
<para>Esto es un complemento de Grilo para Gravatar. El ID de este complemento es <literal>"grl-gravatar"</literal></para>
</sect1>
<sect1 id="sec-plugin-jamendo">
<title>Jamendo</title>
<para>Esto es un complemento para Jamendo. El ID de este complemento es <literal>"grl-jamendo"</literal></para>
</sect1>
<sect1 id="sec-plugin-local-metadata">
<title>Metadatos locales</title>
<para>Esto es un complemento para metadatos locales. El ID de este complemento es <literal>"grl-local-metadata"</literal></para>
</sect1>
<sect1 id="sec-plugin-metadata-store">
<title>Almacén de metadatos</title>
<para>Esto es un complemento para almacén de metadatos. El ID de este complemento es <literal>"grl-metadata-store"</literal></para>
</sect1>
<sect1 id="sec-plugin-optical-media">
<title>Soporte óptico</title>
<para>Esto es un complemento para soporte óptico. El ID de este complemento es <literal>"grl-optical-media"</literal></para>
</sect1>
<sect1 id="sec-plugin-podcasts">
<title>Podcasts</title>
<para>Esto es un complemento para podcasts. El ID de este complemento es <literal>"grl-podcasts"</literal></para>
</sect1>
<sect1 id="sec-plugin-shoutcast">
<title>Shoutcast</title>
<para>Esto es un complemento de Grilo para Shoutcast. Su ID de complemento es <literal>"grl-shoutcast"</literal></para>
</sect1>
<sect1 id="sec-plugin-tmdb">
<title>Complemento TMDb</title>
<para>El complemento TMDb recupera información sobre películas desde el <ulink url="http://themoviedb.org">servicio en línea TMDb</ulink>, que es una base de datos de películas mantenida por la comunidad. Su ID de complemento es <literal>"grl-tmdb"</literal></para>
<para>Antes de usar este complemento debe establecer la clave de API TMDB con <ulink url="http://developer.gnome.org/grilo/unstable/GrlConfig.html#grl-config-set-api-key"><function>grl_config_set_api_key()</function></ulink>.</para>
<para>Puede usar <ulink url="http://developer.gnome.org/grilo/unstable/GrlSource.html#grl-source-resolve"><function>grl_source_resolve()</function></ulink> para descubrir detalles sobre un GrlMediaItem existente.</para>
<para>Este complemento no soporta búsquedas mediante <ulink url="http://developer.gnome.org/grilo/unstable/GrlSource.html#grl-source-search"><function>grl_source_search()</function></ulink> o consultas mediante <ulink url="http://developer.gnome.org/grilo/unstable/GrlSource.html#grl-source-query"><function>grl_source_query()</function></ulink>.</para>
<para>Esto es un sencillo ejemplo de uso del complemento TMDb de Grilo:</para>
<para>Archivo: <ulink url="http://git.gnome.org/browse/grilo-plugins/tree/help/examples/example-tmdb.c"><filename>example-tmdb.c</filename></ulink></para>
<programlisting>
/*
* Copyright (C) 2012 Canonical Ltd.
*
* Author: Jens Georg <[email protected]>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public License
* as published by the Free Software Foundation; version 2.1 of
* the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA
*
*/
#include <grilo.h>
#include <stdio.h>
/**
* This TMDB key is just for testing.
* For real-world use, please request your own key from
* http://api.themoviedb.org
*/
#define TMDB_KEY "719b9b296835b04cd919c4bf5220828a"
#define TMDB_PLUGIN_ID "grl-tmdb"
GMainLoop *loop = NULL;
GrlKeyID director_key = 0;
static void
resolve_cb (GrlSource *src, guint operation_id, GrlMedia *media, gpointer user_data, const GError *error)
{
const char *title, *studio;
g_assert_no_error (error);
g_assert (media);
title = grl_media_get_title (media);
studio = grl_media_get_studio (media);
printf ("Media: Title='%s', Studio='%s'\n",
title, studio);
if (director_key != 0) {
const gchar *director =
grl_data_get_string (GRL_DATA (media), director_key);
printf (" Director=%s\n", director);
}
g_main_loop_quit (loop);
}
int main (int argc, char *argv[])
{
GrlRegistry *reg;
GrlConfig *config;
GError *error = NULL;
GrlSource *src;
gboolean plugin_activated;
GrlCaps *caps;
GrlOperationOptions *options;
GrlMedia *media;
const GList *keys;
const GList* l;
grl_init (&argc, &argv);
/*
* Set the TMDB API key:
* You must use your own TMDB API key in your own application.
*/
reg = grl_registry_get_default ();
config = grl_config_new (TMDB_PLUGIN_ID, NULL);
grl_config_set_api_key (config, TMDB_KEY);
grl_registry_add_config (reg, config, NULL);
grl_registry_load_all_plugins (reg, FALSE, NULL);
/*
* Get the plugin:
*/
error = NULL;
plugin_activated =
grl_registry_activate_plugin_by_id (reg, TMDB_PLUGIN_ID, &error);
g_assert (plugin_activated);
g_assert_no_error (error);
/*
* Get the Grilo source:
*/
src = grl_registry_lookup_source (reg, TMDB_PLUGIN_ID);
/*
* Check that it has the expected capability:
*/
g_assert (grl_source_supported_operations (src) & GRL_OP_RESOLVE);
caps = grl_source_get_caps (src, GRL_OP_RESOLVE);
g_assert (caps);
options = grl_operation_options_new (caps);
/*
* A media item that we will give to the TMDB plugin,
* to discover its details.
*/
media = grl_media_video_new ();
grl_media_set_title (media, "Sherlock Holmes");
/*
* Discover what keys are provided by the source:
*/
keys = grl_source_supported_keys (src);
for (l = keys; l != NULL; l = l->next) {
const gchar *name;
GrlKeyID id = GPOINTER_TO_INT (l->data);
g_assert (id);
name = grl_metadata_key_get_name (id);
printf ("Supported key: %s\n", name);
/*
* Remember this for later use:
* You may instead use grl_registry_lookup_metadata_key_name().
*/
if (g_strcmp0 (name, "tmdb-director") == 0) {
director_key = id;
}
}
/*
* Ask the TMDB plugin for the media item's details,
* from the TMDB online service:
*/
grl_source_resolve (src, media,
keys, options,
resolve_cb, NULL);
/*
* Start the main loop so our callback can be called:
*/
loop = g_main_loop_new (NULL, FALSE);
g_main_loop_run (loop);
/*
* Release objects:
*/
g_object_unref (media);
g_object_unref (config);
g_object_unref (options);
/*
* Deinitialize Grilo:
*/
grl_deinit ();
}
</programlisting>
</sect1>
<sect1 id="sec-plugin-tracker">
<title>Tracker</title>
<para>Esto es un complemento para Tracker. El ID de este complemento es <literal>"grl-tracker"</literal></para>
</sect1>
<sect1 id="sec-plugin-vimeo">
<title>Vimeo</title>
<para>Esto es un complemento para Vimeo. El ID de este complemento es <literal>"grl-vimeo"</literal></para>
</sect1>
<sect1 id="sec-plugin-youtube">
<title>YouTube</title>
<para>Esto es un complemento para Youtube. El ID de este complemento es <literal>"grl-youtube"</literal></para>
</sect1>
<sect1 id="sec-plugin-dleyna">
<title>DLeyna</title>
<para>Esto es un complemento para UPnP/DLNA. El ID de este complemento es <literal>"grl-dleyna"</literal></para>
</sect1>
</chapter>
</book>