annotate src/scrobbler/hatena.c @ 637:a1687bd302ce trunk

[svn] - aosd: completed volume change trigger, works now
author giacomo
date Mon, 12 Feb 2007 07:20:56 -0800
parents 192004e2a1b7
children a3ca00f30af5
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
1 #include "settings.h"
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
2
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
3 #include <pthread.h>
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
4 #include <limits.h>
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
5 #include <stdlib.h>
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
6 #include <string.h>
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
7 #include <stdarg.h>
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
8 #include <curl/curl.h>
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
9 #include <stdio.h>
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
10 #include "fmt.h"
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
11 #include "md5.h"
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
12 #include "scrobbler.h"
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
13 #include "config.h"
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
14 #include <glib.h>
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
15
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
16 #include <audacious/titlestring.h>
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
17
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
18 #define SCROBBLER_HS_URL "http://music.hatelabo.jp/trackauth"
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
19 #define SCROBBLER_CLI_ID "aud"
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
20 #define SCROBBLER_HS_WAIT 1800
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
21 #define SCROBBLER_SB_WAIT 10
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
22 #define SCROBBLER_VERSION "1.1"
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
23 #define SCROBBLER_IMPLEMENTATION "0.1" /* This is the implementation, not the player version. */
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
24 #define SCROBBLER_SB_MAXLEN 1024
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
25 #define CACHE_SIZE 1024
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
26
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
27 #define HATENA_SUBMIT_INTERVAL 60
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
28
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
29 /* Scrobblerbackend for xmms plugin, first draft */
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
30
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
31 static int hatena_sc_hs_status,
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
32 hatena_sc_hs_timeout,
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
33 hatena_sc_hs_errors,
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
34 hatena_sc_sb_errors,
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
35 hatena_sc_bad_users,
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
36 hatena_sc_submit_interval = HATENA_SUBMIT_INTERVAL,
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
37 hatena_sc_submit_timeout,
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
38 hatena_sc_srv_res_size,
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
39 hatena_sc_giveup,
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
40 hatena_sc_major_error_present;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
41
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
42 static char *hatena_sc_submit_url,
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
43 *hatena_sc_username = NULL,
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
44 *hatena_sc_password = NULL,
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
45 *hatena_sc_challenge_hash,
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
46 hatena_sc_response_hash[33],
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
47 *hatena_sc_srv_res,
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
48 hatena_sc_curl_errbuf[CURL_ERROR_SIZE],
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
49 *hatena_sc_major_error;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
50
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
51 static void dump_queue();
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
52
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
53 /**** Queue stuff ****/
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
54
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
55 #define I_ARTIST(i) i->artist
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
56 #define I_TITLE(i) i->title
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
57 #define I_TIME(i) i->utctime
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
58 #define I_LEN(i) i->len
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
59 #define I_MB(i) i->mb
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
60 #define I_ALBUM(i) i->album
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
61
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
62 typedef struct {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
63 char *artist,
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
64 *title,
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
65 *mb,
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
66 *album,
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
67 *utctime,
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
68 len[16];
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
69 int numtries;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
70 void *next;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
71 } item_t;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
72
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
73 static item_t *q_queue = NULL;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
74 static item_t *q_queue_last = NULL;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
75 static int q_nitems;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
76
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
77 static void q_item_free(item_t *item)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
78 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
79 if (item == NULL)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
80 return;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
81 curl_free(item->artist);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
82 curl_free(item->title);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
83 curl_free(item->utctime);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
84 curl_free(item->mb);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
85 curl_free(item->album);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
86 free(item);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
87 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
88
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
89 static void q_put(TitleInput *tuple, int len)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
90 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
91 item_t *item;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
92
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
93 item = malloc(sizeof(item_t));
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
94
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
95 item->artist = fmt_escape(tuple->performer);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
96 item->title = fmt_escape(tuple->track_name);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
97 item->utctime = fmt_escape(fmt_timestr(time(NULL), 1));
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
98 snprintf(item->len, sizeof(item->len), "%d", len);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
99
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
100 #ifdef NOTYET
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
101 if(tuple->mb == NULL)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
102 #endif
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
103 item->mb = fmt_escape("");
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
104 #ifdef NOTYET
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
105 else
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
106 item->mb = fmt_escape((char*)tuple->mb);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
107 #endif
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
108
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
109 if(tuple->album_name == NULL)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
110 item->album = fmt_escape("");
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
111 else
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
112 item->album = fmt_escape((char*)tuple->album_name);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
113
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
114 q_nitems++;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
115
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
116 item->next = NULL;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
117
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
118 if(q_queue_last == NULL)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
119 q_queue = q_queue_last = item;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
120 else
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
121 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
122 q_queue_last->next = item;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
123 q_queue_last = item;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
124 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
125 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
126
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
127 static item_t *q_put2(char *artist, char *title, char *len, char *time,
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
128 char *album, char *mb)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
129 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
130 char *temp = NULL;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
131 item_t *item;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
132
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
133 item = calloc(1, sizeof(item_t));
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
134 temp = fmt_unescape(artist);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
135 item->artist = fmt_escape(temp);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
136 curl_free(temp);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
137 temp = fmt_unescape(title);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
138 item->title = fmt_escape(temp);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
139 curl_free(temp);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
140 memcpy(item->len, len, sizeof(len));
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
141 temp = fmt_unescape(time);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
142 item->utctime = fmt_escape(temp);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
143 curl_free(temp);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
144 temp = fmt_unescape(album);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
145 item->album = fmt_escape(temp);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
146 curl_free(temp);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
147 temp = fmt_unescape(mb);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
148 item->mb = fmt_escape(temp);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
149 curl_free(temp);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
150
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
151 q_nitems++;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
152
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
153 item->next = NULL;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
154 if(q_queue_last == NULL)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
155 q_queue = q_queue_last = item;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
156 else
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
157 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
158 q_queue_last->next = item;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
159 q_queue_last = item;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
160 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
161
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
162 return item;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
163 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
164
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
165 static item_t *q_peek(void)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
166 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
167 if (q_nitems == 0)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
168 return NULL;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
169 return q_queue;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
170 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
171
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
172 static item_t *q_peekall(int rewind)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
173 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
174 static item_t *citem = NULL;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
175 item_t *temp_item;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
176
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
177 if (rewind) {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
178 citem = q_queue;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
179 return NULL;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
180 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
181
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
182 temp_item = citem;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
183
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
184 if(citem != NULL)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
185 citem = citem->next;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
186
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
187 return temp_item;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
188 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
189
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
190 static int q_get(void)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
191 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
192 item_t *item;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
193
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
194 if (q_nitems == 0)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
195 return 0;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
196
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
197 item = q_queue;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
198
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
199 if(item == NULL)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
200 return 0;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
201
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
202 q_nitems--;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
203 q_queue = q_queue->next;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
204
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
205 q_item_free(item);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
206
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
207 if (q_nitems == 0)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
208 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
209 q_queue_last = NULL;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
210 return 0;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
211 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
212
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
213 return -1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
214 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
215
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
216 static void q_free(void)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
217 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
218 while (q_get());
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
219 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
220
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
221 static int q_len(void)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
222 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
223 return q_nitems;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
224 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
225
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
226 /* Error functions */
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
227
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
228 static void hatena_sc_throw_error(char *errortxt)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
229 {
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
230 hatena_sc_major_error_present = 1;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
231 if(hatena_sc_major_error == NULL)
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
232 hatena_sc_major_error = strdup(errortxt);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
233
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
234 return;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
235 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
236
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
237 int hatena_sc_catch_error(void)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
238 {
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
239 return hatena_sc_major_error_present;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
240 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
241
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
242 char *hatena_sc_fetch_error(void)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
243 {
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
244 return hatena_sc_major_error;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
245 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
246
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
247 void hatena_sc_clear_error(void)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
248 {
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
249 hatena_sc_major_error_present = 0;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
250 if(hatena_sc_major_error != NULL)
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
251 free(hatena_sc_major_error);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
252 hatena_sc_major_error = NULL;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
253
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
254 return;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
255 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
256
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
257 static size_t hatena_sc_store_res(void *ptr, size_t size,
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
258 size_t nmemb,
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
259 void *stream __attribute__((unused)))
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
260 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
261 int len = size * nmemb;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
262
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
263 hatena_sc_srv_res = realloc(hatena_sc_srv_res, hatena_sc_srv_res_size + len + 1);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
264 memcpy(hatena_sc_srv_res + hatena_sc_srv_res_size,
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
265 ptr, len);
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
266 hatena_sc_srv_res_size += len;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
267 return len;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
268 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
269
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
270 static void hatena_sc_free_res(void)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
271 {
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
272 if(hatena_sc_srv_res != NULL)
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
273 free(hatena_sc_srv_res);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
274 hatena_sc_srv_res = NULL;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
275 hatena_sc_srv_res_size = 0;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
276 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
277
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
278 static int hatena_sc_parse_hs_res(void)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
279 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
280 char *interval;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
281
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
282 if (!hatena_sc_srv_res_size) {
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
283 pdebug("No reply from server", DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
284 return -1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
285 }
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
286 *(hatena_sc_srv_res + hatena_sc_srv_res_size) = 0;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
287
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
288 if (!strncmp(hatena_sc_srv_res, "FAILED ", 7)) {
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
289
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
290 /* Throwing a major error, just in case */
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
291 /* hatena_sc_throw_error(fmt_vastr("%s", hatena_sc_srv_res));
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
292 hatena_sc_hs_errors++; */
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
293 pdebug(fmt_vastr("error: %s", hatena_sc_srv_res), DEBUG);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
294
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
295 return -1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
296 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
297
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
298 if (!strncmp(hatena_sc_srv_res, "UPDATE ", 7)) {
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
299
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
300 hatena_sc_submit_url = strchr(strchr(hatena_sc_srv_res, '\n') + 1, '\n') + 1;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
301 *(hatena_sc_submit_url - 1) = 0;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
302 hatena_sc_submit_url = strdup(hatena_sc_submit_url);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
303 hatena_sc_challenge_hash = strchr(hatena_sc_srv_res, '\n') + 1;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
304 *(hatena_sc_challenge_hash - 1) = 0;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
305 hatena_sc_challenge_hash = strdup(hatena_sc_challenge_hash);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
306
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
307 /* Throwing major error. Need to alert client to update. */
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
308 hatena_sc_throw_error(fmt_vastr("Please update Audacious.\n"
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
309 "Update available at: http://audacious-media-player.org"));
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
310 pdebug(fmt_vastr("update client: %s", hatena_sc_srv_res + 7), DEBUG);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
311
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
312 /*
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
313 * Russ isn't clear on whether we can submit with a not-updated
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
314 * client. Neither is RJ. I use what we did before.
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
315 */
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
316 hatena_sc_giveup = -1;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
317 return -1;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
318 }
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
319 if (!strncmp(hatena_sc_srv_res, "UPTODATE\n", 9)) {
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
320 hatena_sc_bad_users = 0;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
321
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
322 hatena_sc_submit_url = strchr(strchr(hatena_sc_srv_res, '\n') + 1, '\n') + 1;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
323 *(hatena_sc_submit_url - 1) = 0;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
324 hatena_sc_submit_url = strdup(hatena_sc_submit_url);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
325 hatena_sc_challenge_hash = strchr(hatena_sc_srv_res, '\n') + 1;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
326 *(hatena_sc_challenge_hash - 1) = 0;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
327 hatena_sc_challenge_hash = strdup(hatena_sc_challenge_hash);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
328
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
329 return 0;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
330 }
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
331 if(!strncmp(hatena_sc_srv_res, "BADUSER", 7)) {
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
332 /* Throwing major error. */
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
333 hatena_sc_throw_error("Incorrect username/password.\n"
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
334 "Please fix in configuration.");
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
335 pdebug("incorrect username/password", DEBUG);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
336
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
337 interval = strstr(hatena_sc_srv_res, "INTERVAL");
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
338 if(!interval)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
339 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
340 pdebug("missing INTERVAL", DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
341 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
342 else
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
343 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
344 *(interval - 1) = 0;
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
345 hatena_sc_submit_interval = strtol(interval + 8, NULL, 10);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
346 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
347
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
348 return -1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
349 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
350
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
351 pdebug(fmt_vastr("unknown server-reply '%s'", hatena_sc_srv_res), DEBUG);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
352 return -1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
353 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
354
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
355 static void hexify(char *pass, int len)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
356 {
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
357 char *bp = hatena_sc_response_hash;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
358 char hexchars[] = "0123456789abcdef";
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
359 int i;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
360
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
361 memset(hatena_sc_response_hash, 0, sizeof(hatena_sc_response_hash));
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
362
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
363 for(i = 0; i < len; i++) {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
364 *(bp++) = hexchars[(pass[i] >> 4) & 0x0f];
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
365 *(bp++) = hexchars[pass[i] & 0x0f];
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
366 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
367 *bp = 0;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
368
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
369 return;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
370 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
371
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
372 static int hatena_sc_handshake(void)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
373 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
374 int status;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
375 char buf[4096];
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
376 CURL *curl;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
377
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
378 snprintf(buf, sizeof(buf), "%s/?hs=true&p=%s&c=%s&v=%s&u=%s",
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
379 SCROBBLER_HS_URL, SCROBBLER_VERSION,
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
380 SCROBBLER_CLI_ID, SCROBBLER_IMPLEMENTATION, hatena_sc_username);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
381
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
382 curl = curl_easy_init();
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
383 curl_easy_setopt(curl, CURLOPT_NOPROGRESS, 1);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
384 curl_easy_setopt(curl, CURLOPT_URL, buf);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
385 curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION,
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
386 hatena_sc_store_res);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
387 memset(hatena_sc_curl_errbuf, 0, sizeof(hatena_sc_curl_errbuf));
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
388 curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, hatena_sc_curl_errbuf);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
389 curl_easy_setopt(curl, CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_1_0);
401
192004e2a1b7 [svn] - add connection timeout option to curl_easy_perform(). hopefully, audacious can quit smoothly even though last.fm server goes down.
yaz
parents: 350
diff changeset
390 curl_easy_setopt(curl, CURLOPT_NOSIGNAL, 1);
192004e2a1b7 [svn] - add connection timeout option to curl_easy_perform(). hopefully, audacious can quit smoothly even though last.fm server goes down.
yaz
parents: 350
diff changeset
391 curl_easy_setopt(curl, CURLOPT_CONNECTTIMEOUT, SC_CURL_TIMEOUT);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
392 status = curl_easy_perform(curl);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
393 curl_easy_cleanup(curl);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
394
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
395 hatena_sc_hs_timeout = time(NULL) + SCROBBLER_HS_WAIT;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
396
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
397 if (status) {
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
398 pdebug(hatena_sc_curl_errbuf, DEBUG);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
399 hatena_sc_hs_errors++;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
400 hatena_sc_free_res();
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
401 return -1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
402 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
403
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
404 if (hatena_sc_parse_hs_res()) {
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
405 hatena_sc_hs_errors++;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
406 hatena_sc_free_res();
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
407 return -1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
408 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
409
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
410 if (hatena_sc_challenge_hash != NULL) {
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
411 md5_state_t md5state;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
412 unsigned char md5pword[16];
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
413
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
414 md5_init(&md5state);
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
415 /*pdebug(fmt_vastr("Pass Hash: %s", hatena_sc_password), DEBUG);*/
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
416 md5_append(&md5state, (unsigned const char *)hatena_sc_password,
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
417 strlen(hatena_sc_password));
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
418 /*pdebug(fmt_vastr("Challenge Hash: %s", hatena_sc_challenge_hash), DEBUG);*/
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
419 md5_append(&md5state, (unsigned const char *)hatena_sc_challenge_hash,
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
420 strlen(hatena_sc_challenge_hash));
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
421 md5_finish(&md5state, md5pword);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
422 hexify((char*)md5pword, sizeof(md5pword));
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
423 /*pdebug(fmt_vastr("Response Hash: %s", hatena_sc_response_hash), DEBUG);*/
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
424 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
425
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
426 hatena_sc_hs_errors = 0;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
427 hatena_sc_hs_status = 1;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
428
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
429 hatena_sc_free_res();
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
430
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
431 pdebug(fmt_vastr("submiturl: %s - interval: %d",
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
432 hatena_sc_submit_url, hatena_sc_submit_interval), DEBUG);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
433
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
434 return 0;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
435 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
436
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
437 static int hatena_sc_parse_sb_res(void)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
438 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
439 char *ch, *ch2;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
440
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
441 if (!hatena_sc_srv_res_size) {
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
442 pdebug("No response from server", DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
443 return -1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
444 }
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
445 *(hatena_sc_srv_res + hatena_sc_srv_res_size) = 0;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
446
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
447 if (!strncmp(hatena_sc_srv_res, "OK", 2)) {
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
448 if ((ch = strstr(hatena_sc_srv_res, "INTERVAL"))) {
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
449 hatena_sc_submit_interval = strtol(ch + 8, NULL, 10);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
450 pdebug(fmt_vastr("got new interval: %d",
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
451 hatena_sc_submit_interval), DEBUG);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
452 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
453
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
454 pdebug(fmt_vastr("submission ok: %s", hatena_sc_srv_res), DEBUG);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
455
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
456 return 0;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
457 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
458
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
459 if (!strncmp(hatena_sc_srv_res, "BADAUTH", 7)) {
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
460 if ((ch = strstr(hatena_sc_srv_res, "INTERVAL"))) {
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
461 hatena_sc_submit_interval = strtol(ch + 8, NULL, 10);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
462 pdebug(fmt_vastr("got new interval: %d",
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
463 hatena_sc_submit_interval), DEBUG);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
464 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
465
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
466 pdebug("incorrect username/password", DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
467
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
468 hatena_sc_giveup = 0;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
469
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
470 /*
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
471 * We obviously aren't authenticated. The server might have
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
472 * lost our handshake status though, so let's try
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
473 * re-handshaking... This might not be proper.
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
474 * (we don't give up)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
475 */
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
476 hatena_sc_hs_status = 0;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
477
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
478 if(hatena_sc_challenge_hash != NULL)
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
479 free(hatena_sc_challenge_hash);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
480 if(hatena_sc_submit_url != NULL)
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
481 free(hatena_sc_submit_url);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
482
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
483 hatena_sc_challenge_hash = hatena_sc_submit_url = NULL;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
484 hatena_sc_bad_users++;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
485
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
486 if(hatena_sc_bad_users > 2)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
487 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
488 pdebug("3 BADAUTH returns on submission. Halting "
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
489 "submissions until login fixed.", DEBUG)
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
490 hatena_sc_throw_error("Incorrect username/password.\n"
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
491 "Please fix in configuration.");
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
492 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
493
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
494 return -1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
495 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
496
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
497 if (!strncmp(hatena_sc_srv_res, "FAILED", 6)) {
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
498
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
499 /* This could be important. (Such as FAILED - Get new plugin) */
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
500 /*hatena_sc_throw_error(fmt_vastr("%s", hatena_sc_srv_res));*/
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
501
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
502 pdebug(hatena_sc_srv_res, DEBUG);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
503
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
504 return -1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
505 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
506
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
507 if (!strncmp(hatena_sc_srv_res, "<!DOCTYPE HTML PUBLIC \"-//IETF//DTD HTML 2.0//EN\">", 50)) {
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
508 ch = strstr(hatena_sc_srv_res, "<TITLE>") + 7;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
509 ch2 = strstr(hatena_sc_srv_res, "</TITLE>");
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
510 *ch2 = '\0';
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
511
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
512 pdebug(fmt_vastr("HTTP Error (%d): '%s'",
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
513 atoi(ch), ch + 4), DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
514 *ch2 = '<';
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
515
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
516 return -1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
517 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
518
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
519 pdebug(fmt_vastr("unknown server-reply %s", hatena_sc_srv_res), DEBUG);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
520
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
521 return -1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
522 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
523
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
524 static gchar *hatena_sc_itemtag(char c, int n, char *str)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
525 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
526 static char buf[SCROBBLER_SB_MAXLEN];
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
527 snprintf(buf, SCROBBLER_SB_MAXLEN, "&%c[%d]=%s", c, n, str);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
528 return buf;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
529 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
530
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
531 #define cfa(f, l, n, v) \
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
532 curl_formadd(f, l, CURLFORM_COPYNAME, n, \
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
533 CURLFORM_PTRCONTENTS, v, CURLFORM_END)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
534
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
535 static int hatena_sc_generateentry(GString *submission)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
536 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
537 int i;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
538 item_t *item;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
539
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
540 i = 0;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
541 #ifdef ALLOW_MULTIPLE
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
542 q_peekall(1);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
543 while ((item = q_peekall(0)) && i < 10) {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
544 #else
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
545 item = q_peek();
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
546 #endif
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
547 if (!item)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
548 return i;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
549
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
550 g_string_append(submission,hatena_sc_itemtag('a',i,I_ARTIST(item)));
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
551 g_string_append(submission,hatena_sc_itemtag('t',i,I_TITLE(item)));
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
552 g_string_append(submission,hatena_sc_itemtag('l',i,I_LEN(item)));
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
553 g_string_append(submission,hatena_sc_itemtag('i',i,I_TIME(item)));
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
554 g_string_append(submission,hatena_sc_itemtag('m',i,I_MB(item)));
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
555 g_string_append(submission,hatena_sc_itemtag('b',i,I_ALBUM(item)));
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
556
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
557 pdebug(fmt_vastr("a[%d]=%s t[%d]=%s l[%d]=%s i[%d]=%s m[%d]=%s b[%d]=%s",
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
558 i, I_ARTIST(item),
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
559 i, I_TITLE(item),
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
560 i, I_LEN(item),
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
561 i, I_TIME(item),
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
562 i, I_MB(item),
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
563 i, I_ALBUM(item)), DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
564 #ifdef ALLOW_MULTIPLE
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
565 i++;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
566 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
567 #endif
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
568
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
569 return i;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
570 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
571
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
572 static int hatena_sc_submitentry(gchar *entry)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
573 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
574 CURL *curl;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
575 /* struct HttpPost *post = NULL , *last = NULL; */
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
576 int status;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
577 GString *submission;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
578
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
579 curl = curl_easy_init();
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
580 curl_easy_setopt(curl, CURLOPT_NOPROGRESS, 1);
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
581 curl_easy_setopt(curl, CURLOPT_URL, hatena_sc_submit_url);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
582 curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION,
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
583 hatena_sc_store_res);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
584 curl_easy_setopt(curl, CURLOPT_USERAGENT, USER_AGENT);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
585 curl_easy_setopt(curl, CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_1_0);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
586 /*cfa(&post, &last, "debug", "failed");*/
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
587
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
588 /*pdebug(fmt_vastr("Username: %s", hatena_sc_username), DEBUG);*/
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
589 submission = g_string_new("u=");
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
590 g_string_append(submission,(gchar *)hatena_sc_username);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
591
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
592 /*pdebug(fmt_vastr("Response Hash: %s", hatena_sc_response_hash), DEBUG);*/
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
593 g_string_append(submission,"&s=");
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
594 g_string_append(submission,(gchar *)hatena_sc_response_hash);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
595
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
596 g_string_append(submission, entry);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
597
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
598 curl_easy_setopt(curl, CURLOPT_POSTFIELDS, (char *)submission->str);
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
599 memset(hatena_sc_curl_errbuf, 0, sizeof(hatena_sc_curl_errbuf));
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
600 curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, hatena_sc_curl_errbuf);
401
192004e2a1b7 [svn] - add connection timeout option to curl_easy_perform(). hopefully, audacious can quit smoothly even though last.fm server goes down.
yaz
parents: 350
diff changeset
601 curl_easy_setopt(curl, CURLOPT_NOSIGNAL, 1);
192004e2a1b7 [svn] - add connection timeout option to curl_easy_perform(). hopefully, audacious can quit smoothly even though last.fm server goes down.
yaz
parents: 350
diff changeset
602 curl_easy_setopt(curl, CURLOPT_CONNECTTIMEOUT, SC_CURL_TIMEOUT);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
603
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
604 /*
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
605 curl_easy_setopt(curl, CURLOPT_NOSIGNAL, 1);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
606 curl_easy_setopt(curl, CURLOPT_TIMEOUT, SCROBBLER_SB_WAIT);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
607 */
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
608
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
609 status = curl_easy_perform(curl);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
610
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
611 curl_easy_cleanup(curl);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
612
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
613 g_string_free(submission,TRUE);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
614
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
615 if (status) {
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
616 pdebug(hatena_sc_curl_errbuf, DEBUG);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
617 hatena_sc_sb_errors++;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
618 hatena_sc_free_res();
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
619 return -1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
620 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
621
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
622 if (hatena_sc_parse_sb_res()) {
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
623 hatena_sc_sb_errors++;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
624 hatena_sc_free_res();
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
625 pdebug(fmt_vastr("Retrying in %d secs, %d elements in queue",
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
626 hatena_sc_submit_interval, q_len()), DEBUG);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
627 return -1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
628 }
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
629 hatena_sc_free_res();
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
630 return 0;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
631 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
632
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
633 static void hatena_sc_handlequeue(GMutex *mutex)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
634 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
635 GString *submitentry;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
636 int nsubmit;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
637 int wait;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
638
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
639 if(hatena_sc_submit_timeout < time(NULL) && hatena_sc_bad_users < 3)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
640 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
641 submitentry = g_string_new("");
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
642
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
643 g_mutex_lock(mutex);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
644
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
645 nsubmit = hatena_sc_generateentry(submitentry);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
646
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
647 g_mutex_unlock(mutex);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
648
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
649 if (nsubmit > 0)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
650 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
651 pdebug(fmt_vastr("Number submitting: %d", nsubmit), DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
652 pdebug(fmt_vastr("Submission: %s", submitentry->str), DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
653
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
654 if(!hatena_sc_submitentry(submitentry->str))
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
655 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
656 g_mutex_lock(mutex);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
657
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
658 #ifdef ALLOW_MULTIPLE
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
659 q_free();
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
660 #else
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
661 q_get();
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
662 #endif
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
663 /*
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
664 * This should make sure that the queue doesn't
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
665 * get submitted multiple times on a nasty
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
666 * segfault...
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
667 */
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
668 dump_queue();
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
669
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
670 g_mutex_unlock(mutex);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
671
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
672 hatena_sc_sb_errors = 0;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
673 }
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
674 if(hatena_sc_sb_errors)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
675 {
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
676 if(hatena_sc_sb_errors < 5)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
677 /* Retry after 1 min */
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
678 wait = 60;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
679 else
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
680 wait = /* hatena_sc_submit_interval + */
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
681 ( ((hatena_sc_sb_errors - 5) < 7) ?
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
682 (60 << (hatena_sc_sb_errors-5)) :
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
683 7200 );
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
684
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
685 hatena_sc_submit_timeout = time(NULL) + wait;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
686
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
687 pdebug(fmt_vastr("Error while submitting. "
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
688 "Retrying after %d seconds.", wait),
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
689 DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
690 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
691 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
692
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
693 g_string_free(submitentry, TRUE);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
694 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
695 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
696
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
697 static void read_cache(void)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
698 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
699 FILE *fd;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
700 char buf[PATH_MAX], *cache = NULL, *ptr1, *ptr2;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
701 int cachesize, written, i = 0;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
702 item_t *item;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
703
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
704 cachesize = written = 0;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
705
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
706 snprintf(buf, sizeof(buf), "%s/.audacious/gerpokqueue.txt", g_get_home_dir());
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
707
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
708 if (!(fd = fopen(buf, "r")))
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
709 return;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
710 pdebug(fmt_vastr("Opening %s", buf), DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
711 while(!feof(fd))
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
712 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
713 cachesize += CACHE_SIZE;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
714 cache = realloc(cache, cachesize + 1);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
715 written += fread(cache + written, 1, CACHE_SIZE, fd);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
716 cache[written] = '\0';
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
717 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
718 fclose(fd);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
719 ptr1 = cache;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
720 while(ptr1 < cache + written - 1)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
721 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
722 char *artist, *title, *len, *time, *album, *mb;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
723
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
724 pdebug("Pushed:", DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
725 ptr2 = strchr(ptr1, ' ');
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
726 artist = calloc(1, ptr2 - ptr1 + 1);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
727 strncpy(artist, ptr1, ptr2 - ptr1);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
728 ptr1 = ptr2 + 1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
729 ptr2 = strchr(ptr1, ' ');
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
730 title = calloc(1, ptr2 - ptr1 + 1);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
731 strncpy(title, ptr1, ptr2 - ptr1);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
732 ptr1 = ptr2 + 1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
733 ptr2 = strchr(ptr1, ' ');
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
734 len = calloc(1, ptr2 - ptr1 + 1);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
735 strncpy(len, ptr1, ptr2 - ptr1);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
736 ptr1 = ptr2 + 1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
737 ptr2 = strchr(ptr1, ' ');
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
738 time = calloc(1, ptr2 - ptr1 + 1);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
739 strncpy(time, ptr1, ptr2 - ptr1);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
740 ptr1 = ptr2 + 1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
741 ptr2 = strchr(ptr1, ' ');
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
742 album = calloc(1, ptr2 - ptr1 + 1);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
743 strncpy(album, ptr1, ptr2 - ptr1);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
744 ptr1 = ptr2 + 1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
745 ptr2 = strchr(ptr1, '\n');
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
746 if(ptr2 != NULL)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
747 *ptr2 = '\0';
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
748 mb = calloc(1, strlen(ptr1) + 1);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
749 strncpy(mb, ptr1, strlen(ptr1));
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
750 if(ptr2 != NULL)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
751 *ptr2 = '\n';
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
752 /* Why is our save printing out CR/LF? */
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
753 ptr1 = ptr2 + 1;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
754
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
755 item = q_put2(artist, title, len, time, album, mb);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
756 pdebug(fmt_vastr("a[%d]=%s t[%d]=%s l[%d]=%s i[%d]=%s m[%d]=%s b[%d]=%s",
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
757 i, I_ARTIST(item),
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
758 i, I_TITLE(item),
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
759 i, I_LEN(item),
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
760 i, I_TIME(item),
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
761 i, I_MB(item),
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
762 i, I_ALBUM(item)), DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
763 free(artist);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
764 free(title);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
765 free(len);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
766 free(time);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
767 free(album);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
768 free(mb);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
769
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
770 i++;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
771 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
772 pdebug("Done loading cache.", DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
773 free(cache);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
774 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
775
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
776 static void dump_queue(void)
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
777 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
778 FILE *fd;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
779 item_t *item;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
780 char *home, buf[PATH_MAX];
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
781
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
782 /*pdebug("Entering dump_queue();", DEBUG);*/
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
783
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
784 if (!(home = getenv("HOME")))
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
785 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
786 pdebug("No HOME directory found. Cannot dump queue.", DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
787 return;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
788 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
789
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
790 snprintf(buf, sizeof(buf), "%s/.audacious/gerpokqueue.txt", home);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
791
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
792 if (!(fd = fopen(buf, "w")))
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
793 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
794 pdebug(fmt_vastr("Failure opening %s", buf), DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
795 return;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
796 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
797
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
798 pdebug(fmt_vastr("Opening %s", buf), DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
799
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
800 q_peekall(1);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
801
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
802 while ((item = q_peekall(0))) {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
803 fprintf(fd, "%s %s %s %s %s %s\n",
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
804 I_ARTIST(item),
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
805 I_TITLE(item),
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
806 I_LEN(item),
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
807 I_TIME(item),
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
808 I_ALBUM(item),
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
809 I_MB(item));
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
810 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
811
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
812 fclose(fd);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
813 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
814
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
815 /* This was made public */
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
816
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
817 void hatena_sc_cleaner(void)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
818 {
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
819 if(hatena_sc_submit_url != NULL)
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
820 free(hatena_sc_submit_url);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
821 if(hatena_sc_username != NULL)
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
822 free(hatena_sc_username);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
823 if(hatena_sc_password != NULL)
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
824 free(hatena_sc_password);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
825 if(hatena_sc_challenge_hash != NULL)
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
826 free(hatena_sc_challenge_hash);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
827 if(hatena_sc_srv_res != NULL)
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
828 free(hatena_sc_srv_res);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
829 if(hatena_sc_major_error != NULL)
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
830 free(hatena_sc_major_error);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
831 dump_queue();
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
832 q_free();
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
833 pdebug("scrobbler shutting down", DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
834 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
835
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
836 static void hatena_sc_checkhandshake(void)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
837 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
838 int wait;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
839
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
840 if (!hatena_sc_username || !hatena_sc_password)
348
314b7ac7f771 [svn] - handle no account data gracefully (e.g. you only use one of the
nenolod
parents: 344
diff changeset
841 return;
314b7ac7f771 [svn] - handle no account data gracefully (e.g. you only use one of the
nenolod
parents: 344
diff changeset
842
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
843 if (hatena_sc_hs_status)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
844 return;
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
845 if (hatena_sc_hs_timeout < time(NULL))
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
846 {
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
847 hatena_sc_handshake();
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
848
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
849 if(hatena_sc_hs_errors)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
850 {
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
851 if(hatena_sc_hs_errors < 5)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
852 /* Retry after 60 seconds */
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
853 wait = 60;
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
854 else
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
855 wait = /* hatena_sc_submit_interval + */
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
856 ( ((hatena_sc_hs_errors - 5) < 7) ?
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
857 (60 << (hatena_sc_hs_errors-5)) :
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
858 7200 );
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
859 hatena_sc_hs_timeout = time(NULL) + wait;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
860 pdebug(fmt_vastr("Error while handshaking. Retrying "
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
861 "after %d seconds.", wait), DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
862 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
863 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
864 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
865
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
866 /**** Public *****/
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
867
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
868 /* Called at session startup*/
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
869
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
870 void hatena_sc_init(char *uname, char *pwd)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
871 {
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
872 hatena_sc_hs_status = hatena_sc_hs_timeout = hatena_sc_hs_errors = hatena_sc_submit_timeout =
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
873 hatena_sc_srv_res_size = hatena_sc_giveup = hatena_sc_major_error_present =
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
874 hatena_sc_bad_users = hatena_sc_sb_errors = 0;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
875 hatena_sc_submit_interval = 100;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
876
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
877 hatena_sc_submit_url = hatena_sc_username = hatena_sc_password = hatena_sc_srv_res =
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
878 hatena_sc_challenge_hash = hatena_sc_major_error = NULL;
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
879 hatena_sc_username = strdup(uname);
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
880 hatena_sc_password = strdup(pwd);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
881 read_cache();
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
882 pdebug("scrobbler starting up", DEBUG);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
883 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
884
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
885 void hatena_sc_addentry(GMutex *mutex, TitleInput *tuple, int len)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
886 {
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
887 g_mutex_lock(mutex);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
888 q_put(tuple, len);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
889 /*
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
890 * This will help make sure the queue will be saved on a nasty
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
891 * segfault...
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
892 */
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
893 dump_queue();
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
894 g_mutex_unlock(mutex);
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
895 }
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
896
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
897 /* Call periodically from the plugin */
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
898 int hatena_sc_idle(GMutex *mutex)
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
899 {
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
900 hatena_sc_checkhandshake();
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
901 if (hatena_sc_hs_status)
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
902 hatena_sc_handlequeue(mutex);
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
903
350
b4f1ad07fcd9 [svn] - add support for hatena (experimental)
nenolod
parents: 348
diff changeset
904 return hatena_sc_giveup;
344
03c1ae10bc8d [svn] - Merge audacious-scrobbler III, new features include:
nenolod
parents:
diff changeset
905 }