OK, I patched it myself, this works for me, see attachment (full file + diff)

(will put a copy in g.c.m.g.devel too))

HTH.

Le 31/03/2012 16:00, CinéphOli a écrit :
Hi,

Le 27/03/2012 14:22, jpok a écrit :
Hi,
Since a couple of days, Allocine plugin doesn't functioning correctly,
always responding "no match"...
I guess Allocine had modified his web site. Could someone correct this
plugin ?
Thanks a lot


For the developers:

Actually, there is now a version 3 for the specs of the Allociné API
that can be found here : http://wiki.gromez.fr/dev/api/allocine_v3

It's in French, but the keywords are in English, so I think it is
straightforward.
The main change is the partner code, which is YW5kcm9pZC12M3M for an
Android application. I don't know if it is alright to use that code.
Also, the URL is no longer the same: http://api.allocine.fr/rest/v3/...

A search looks like this:
http://api.allocine.fr/rest/v3/search?partner=YW5kcm9pZC12M3M&filter=movie&q=avatar&format=xml


A result looks like this (Ben-Hur):
http://api.allocine.fr/rest/v3/movie?partner=YW5kcm9pZC12M3M&profile=large&code=5000


Use format=json if this format is preferred.

HTH.
CinéphOli

# -*- coding: UTF-8 -*-

__revision__ = '$Id: PluginMovieIMDB.py 176 2006-02-01 12:07:26Z iznogoud $'

# Copyright (c) 2005-2011 Vasco Nunes, Piotr Ozarowski
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, orprint
# (at your option) any later version.
#
# This program 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 Library General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA

# You may use and distribute this software under the terms of the
# GNU General Public License, version 2 or later

import movie
try:
    import simplejson as json
except:
    import json
import logging
log = logging.getLogger("Griffith")

plugin_name         = "Allocine"
plugin_description  = "Internet Movie Database"
plugin_url          = "www.allocine.fr"
plugin_language     = _("French")
plugin_author       = "Pierre-Luc Levy, Michael Jahn (JSON api)"
plugin_author_email = ""
plugin_version      = "1.0"


class Plugin(movie.Movie):
    def __init__(self, id):
        self.movie_id = id
        self.url      = "http://api.allocine.fr/rest/v3/movie?partner=YW5kcm9pZC12M3M&format=json&profile=large&code=%s"; % str(self.movie_id)
        self.encode   = 'utf-8'

    def initialize(self):
        self.movie = json.JSONDecoder().decode(self.page)['movie']

    def get_image(self):
        self.image_url = ''
        if 'poster' in self.movie:
            self.image_url = self.movie['poster']['href']

    def get_o_title(self):
        self.o_title = ''
        if 'originalTitle' in self.movie:
            self.o_title = self.movie['originalTitle']
        elif 'title' in self.movie:
            self.o_title = self.movie['title']

    def get_title(self):
        self.title = ''
        if 'title' in self.movie:
            self.title = self.movie['title']
        elif 'originalTitle' in self.movie:
            self.title = self.movie['originalTitle']

    def get_director(self):
        self.director = self.buildfromcast(8002)

    def get_plot(self):
        self.plot = ''
        if 'synopsis' in self.movie:
            self.plot = self.movie['synopsis']

    def get_year(self):
        self.year = ''
        if 'productionYear' in self.movie:
            self.year = self.movie['productionYear']

    def get_runtime(self):
        self.runtime = ''
        if 'runtime' in self.movie:
            self.runtime = self.movie['runtime'] / 60

    def get_genre(self):
        self.genre = ''
        if 'genre' in self.movie:
            for genre in self.movie['genre']:
                self.genre = self.genre + genre['$'] + ', '
        if self.genre:
            self.genre = self.genre[:-2]

    def get_cast(self):
        self.cast = ''
        if 'castMember' in self.movie:
            for cast in self.movie['castMember']:
                if 'activity' in cast:
                    activity = cast['activity']
                    if 'code' in activity:
                        if activity['code'] == 8001:
                            if 'role' in cast:
                                self.cast = self.cast + cast['person']['name'] + _(' as ') + cast['role'] + '\n'
                            else:
                                self.cast = self.cast + cast['person']['name'] + '\n'

    def get_classification(self):
        self.classification = ""
        if 'movieCertificate' in self.movie:
            self.classification = self.movie['movieCertificate']['$']

    def get_studio(self):
        self.studio = ""

    def get_o_site(self):
        self.o_site = ""

    def get_site(self):
        self.site = "http://www.allocine.fr/film/fichefilm_gen_cfilm=%s.html"; % self.movie_id
        if 'link' in self.movie:
            for link in self.movie['link']:
                if link['rel'] == 'aco:more':
                    self.site = link['href']

    def get_trailer(self):
        self.trailer = "http://www.allocine.fr/film/video_gen_cfilm=%s.html"; % self.movie_id
        if 'trailer' in self.movie:
            self.trailer = self.movie['trailer']['href']

    def get_country(self):
        self.country = ''
        if 'nationality' in self.movie:
            for country in self.movie['nationality']:
                self.country = self.country + country['$'] + ', '
        if self.country:
            self.country = self.country[:-2]

    def get_rating(self):
        self.rating = 0
        if 'statistics' in self.movie:
            statistics = self.movie['statistics']
            if 'pressRating' in statistics:
                self.rating = statistics['pressRating'] * 2
            elif 'userRating' in statistics:
                self.rating = statistics['userRating'] * 2

    def get_screenplay(self):
        self.screenplay = self.buildfromcast(8004)

    def get_cameraman(self):
        self.cameraman = self.buildfromcast(8037)

    def buildfromcast(self, code):
        result = ''
        if 'castMember' in self.movie:
            for cast in self.movie['castMember']:
                if 'activity' in cast:
                    activity = cast['activity']
                    if 'code' in activity:
                        if activity['code'] == code:
                            result = result + cast['person']['name'] + ', '
        if result:
            result = result[:-2]
        return result


class SearchPlugin(movie.SearchMovie):

    def __init__(self):
        self.original_url_search   = "http://api.allocine.fr/rest/v3/search?partner=YW5kcm9pZC12M3M&format=json&count=100&q=";
        self.translated_url_search = "http://api.allocine.fr/rest/v3/search?partner=YW5kcm9pZC12M3M&format=json&count=100&q=";
        self.encode                = 'utf-8'
        self.remove_accents        = True

    def search(self, parent_window):
        if not self.open_search(parent_window):
            return None
        return self.page

    def get_searches(self):
        result = json.JSONDecoder().decode(self.page)
        try:
            movies = result['feed']['movie']
            for movie in movies:
                try:
                    title = ''
                    year = ''
                    if 'title' in movie:
                        title = movie['title']
                    elif 'originalTitle' in movie:
                        title = movie['originalTitle']
                    if 'productionYear' in movie:
                        year = '(%s)' % movie['productionYear']
                    self.titles.append('%s %s' % (title, year))
                    self.ids.append(movie['code'])
                except:
                    log.exception('')
        except:
            log.exception('')


#
# Plugin Test
#


class SearchPluginTest(SearchPlugin):
    #
    # Configuration for automated tests:
    # dict { movie_id -> [ expected result count for original url, expected result count for translated url ] }
    #
    test_configuration = {
        'Le Prix à payer' : [ 4, 4 ],
    }


class PluginTest:
    #
    # Configuration for automated tests:
    # dict { movie_id -> dict { arribute -> value } }
    #
    # value: * True/False if attribute only should be tested for any value
    #        * or the expected value
    #
    test_configuration = {
        '110585' : {
            'title'               : u'Le Prix à payer',
            'o_title'             : u'Le Prix à payer',
            'director'            : u'Alexandra Leclère',
            'plot'                : True,
            'cast'                : u'Christian Clavier' + _(' as ') + 'Jean-Pierre Ménard\n\
Nathalie Baye' + _(' as ') + 'Odile Ménard\n\
Gérard Lanvin' + _(' as ') + 'Richard\n\
Géraldine Pailhas' + _(' as ') + 'Caroline\n\
Patrick Chesnais' + _(' as ') + 'Grégoire l\'amant\n\
Anaïs Demoustier' + _(' as ') + 'Justine\n\
Maud Buquet' + _(' as ') + 'la prostituée\n\
Francis Leplay' + _(' as ') + 'l\'agent immobilier',
            'country'             : u'France',
            'genre'               : u'Comédie',
            'classification'      : False,
            'studio'              : False,
            'o_site'              : False,
            'site'                : 'http://www.allocine.fr/film/fichefilm_gen_cfilm=110585.html',
            'trailer'             : 'http://www.allocine.fr/blogvision/18726250',
            'year'                : 2007,
            'notes'               : False,
            'runtime'             : 95,
            'image'               : True,
            'rating'              : 4,
            'cameraman'           : u'Jean-François Robin',
            'screenplay'          : u'Alexandra Leclère',
            'barcode'             : False
        },
        '309' : {
            'title'               : u'Terminator',
            'o_title'             : u'Terminator, The',
            'director'            : u'James Cameron',
            'plot'                : True,
            'cast'                : u'Arnold Schwarzenegger' + _(' as ') + 'le Terminator\n\
Michael Biehn' + _(' as ') + 'Kyle Reese\n\
Linda Hamilton' + _(' as ') + 'Sarah Connor\n\
Lance Henriksen' + _(' as ') + 'l\'inspecteur Vukovich\n\
Paul Winfield' + _(' as ') + 'le lieutenant Ed Traxler\n\
Bess Motta' + _(' as ') + 'Ginger Ventura\n\
Rick Rossovich' + _(' as ') + 'Matt Buchanan\n\
Earl Boen' + _(' as ') + 'le Dr Peter Silberman\n\
Dick Miller' + _(' as ') + 'le marchand d\'armes\n\
Shawn Schepps' + _(' as ') + 'Nancy\n\
Bill Paxton' + _(' as ') + 'le chef des punks\n\
Brian Thompson' + _(' as ') + 'un punk\n\
Marianne Muellerleile' + _(' as ') + 'la \'mauvaise\' Sarah Connor\n\
Franco Columbu' + _(' as ') + 'le Terminator infiltrant le bunker dans le futur\n\
Ken Fritz' + _(' as ') + 'Policeman\n\
Stan Yale' + _(' as ') + 'Derelict in Alley\n\
Brad Rearden' + _(' as ') + 'Punk\n\
Joe Farago' + _(' as ') + 'TV Anchorman\n\
Anthony Trujillo' + _(' as ') + 'Mexican Boy (close-ups)\n\
Harriet Medin' + _(' as ') + 'Customer\n\
Hugh Farrington' + _(' as ') + 'Customer\n\
Philip Gordon' + _(' as ') + 'Mexican Boy (long shots)\n\
Patrick Pinney' + _(' as ') + 'Bar Customer\n\
Wayne Stone' + _(' as ') + 'Tanker Driver\n\
Norman Friedman' + _(' as ') + 'Cleaning Man at Flophouse\n\
Hettie Lynne Hurtes' + _(' as ') + 'TV Anchorwoman\n\
Al Kahn' + _(' as ') + 'Customer\n\
Bill W. Richmond' + _(' as ') + 'Barman\n\
Bruce M. Kerner' + _(' as ') + 'Desk Sergeant\n\
David Pierce' + _(' as ') + 'Tanker Partner\n\
Barbara Powers' + _(' as ') + 'Ticket Taker at Club Technoir\n\
Ed Dogans' + _(' as ') + 'Cop in Alley\n\
Tony Mirelez' + _(' as ') + 'Gas Station Attendant\n\
Webster Williams' + _(' as ') + 'Reporter\n\
John E. Bristol' + _(' as ') + 'Biker at Phone Booth\n\
Gregory Robbins' + _(' as ') + 'Tiki Motel Customer\n\
Chino \'Fats\' Williams' + _(' as ') + 'Truck Driver',
            'country'             : 'U.S.A.',
            'genre'               : 'Science fiction, Thriller',
            'classification'      : 'Interdit aux moins de 12 ans',
            'studio'              : False,
            'o_site'              : False,
            'site'                : 'http://www.allocine.fr/film/fichefilm_gen_cfilm=309.html',
            'trailer'             : 'http://www.allocine.fr/blogvision/18895020',
            'year'                : 1984,
            'notes'               : False,
            'runtime'             : 108,
            'image'               : True,
            'rating'              : 8,
            'cameraman'           : u'Adam Greenberg',
            'screenplay'          : u'James Cameron, Gale Anne Hurd, Harlan Ellison, William Wisher',
            'barcode'             : False
        },
    }
Index: PluginMovieAllocine.py
===================================================================
--- PluginMovieAllocine.py	(révision 1601)
+++ PluginMovieAllocine.py	(copie de travail)
@@ -41,7 +41,7 @@
 class Plugin(movie.Movie):
     def __init__(self, id):
         self.movie_id = id
-        self.url      = "http://api.allocine.fr/xml/movie?partner=3&json=1&profile=large&code=%s"; % str(self.movie_id)
+        self.url      = "http://api.allocine.fr/rest/v3/movie?partner=YW5kcm9pZC12M3M&format=json&profile=large&code=%s"; % str(self.movie_id)
         self.encode   = 'utf-8'
 
     def initialize(self):
@@ -101,9 +101,9 @@
                     if 'code' in activity:
                         if activity['code'] == 8001:
                             if 'role' in cast:
-                                self.cast = self.cast + cast['person']['$'] + _(' as ') + cast['role'] + '\n'
+                                self.cast = self.cast + cast['person']['name'] + _(' as ') + cast['role'] + '\n'
                             else:
-                                self.cast = self.cast + cast['person']['$'] + '\n'
+                                self.cast = self.cast + cast['person']['name'] + '\n'
 
     def get_classification(self):
         self.classification = ""
@@ -159,7 +159,7 @@
                     activity = cast['activity']
                     if 'code' in activity:
                         if activity['code'] == code:
-                            result = result + cast['person']['$'] + ', '
+                            result = result + cast['person']['name'] + ', '
         if result:
             result = result[:-2]
         return result
@@ -168,8 +168,8 @@
 class SearchPlugin(movie.SearchMovie):
 
     def __init__(self):
-        self.original_url_search   = "http://api.allocine.fr/xml/search?partner=3&json=1&count=100&profile=small&q=";
-        self.translated_url_search = "http://api.allocine.fr/xml/search?partner=3&json=1&count=100&profile=small&q=";
+        self.original_url_search   = "http://api.allocine.fr/rest/v3/search?partner=YW5kcm9pZC12M3M&format=json&count=100&q=";
+        self.translated_url_search = "http://api.allocine.fr/rest/v3/search?partner=YW5kcm9pZC12M3M&format=json&count=100&q=";
         self.encode                = 'utf-8'
         self.remove_accents        = True
 

Reply via email to