Mercurial > hg > dml-open-cliopatria
comparison cpack/dml/lib/spotify/echonest.pl @ 0:718306e29690 tip
commiting public release
author | Daniel Wolff |
---|---|
date | Tue, 09 Feb 2016 21:05:06 +0100 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:718306e29690 |
---|---|
1 /* Part of DML (Digital Music Laboratory) | |
2 Copyright 2014-2015 Samer Abdallah, University of London | |
3 | |
4 This program is free software; you can redistribute it and/or | |
5 modify it under the terms of the GNU General Public License | |
6 as published by the Free Software Foundation; either version 2 | |
7 of the License, or (at your option) any later version. | |
8 | |
9 This program is distributed in the hope that it will be useful, | |
10 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
12 GNU General Public License for more details. | |
13 | |
14 You should have received a copy of the GNU General Public | |
15 License along with this library; if not, write to the Free Software | |
16 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |
17 */ | |
18 | |
19 :- module(echonest, | |
20 [ echocall/4 | |
21 ]). | |
22 | |
23 /** <module> Interface to echonest Web API | |
24 */ | |
25 | |
26 :- use_module(library(fileutils)). | |
27 :- use_module(library(http/json)). | |
28 :- use_module(library(jpath)). | |
29 :- use_module(library(webby)). | |
30 :- use_module(library(state)). | |
31 | |
32 :- set_prolog_flag(double_quotes,string). | |
33 | |
34 :- setting(min_wait,number,3,"Minimum time between echonest requests"). | |
35 :- initialization set_state(next_request_time,0). | |
36 | |
37 wait_respectfully :- | |
38 get_time(Now), | |
39 setting(min_wait,TMin), | |
40 get_state(next_request_time,T0), T1 is max(Now,T0) + TMin, | |
41 set_state(next_request_time,T1), | |
42 ( Now>=T0 -> true | |
43 ; DT is T0-Now, | |
44 debug(echonest,"Sleeping for ~f seconds to respect rate limit",[DT]), | |
45 sleep(DT) | |
46 ). | |
47 | |
48 echocall(Key,PathParts,Params,Response) :- | |
49 debug(echonest,"Echonest call: ~q, ~q...",[PathParts,Params]), | |
50 parts_path([api,v4|PathParts],Path), | |
51 wait_respectfully, | |
52 catch( restcall(get([api_key=Key, format=json | Params]), json(Response), | |
53 [protocol(http), host('developer.echonest.com'), path(Path)], []), | |
54 Ex, handle(Ex)). | |
55 | |
56 handle(http_bad_status(SC,codes(Doc))) :- !, | |
57 with_input_from(codes(Doc),json_read_dict(current_input,Dict)), | |
58 jpath(response:status:(code:Code,message:Msg),Dict), | |
59 throw(echonest_error(SC,Code,Msg)). | |
60 handle(Ex) :- throw(Ex). | |
61 | |
62 | |
63 prolog:message(echonest_error(SC,Code,Msg)) --> | |
64 {http_status(SC,Meaning)}, | |
65 ["(HTTP ~w: ~w) Echonest error ~w: '~s'."-[SC,Meaning,Code,Msg]]. |