mirror of
https://gitlab.xiph.org/xiph/icecast-common.git
synced 2024-09-22 04:15:55 -04:00
Added support for shoutcast login protocol (ewww...)
svn path=/trunk/httpp/; revision=4444
This commit is contained in:
parent
f5c688d43b
commit
8dec7ae9d5
@ -270,6 +270,42 @@ static void parse_query(http_parser_t *parser, char *query)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* The old shoutcast procotol. Don't look at this, it's really nasty */
|
||||||
|
int httpp_parse_icy(http_parser_t *parser, char *http_data, unsigned long len)
|
||||||
|
{
|
||||||
|
char *data;
|
||||||
|
char *line[MAX_HEADERS];
|
||||||
|
int lines;
|
||||||
|
|
||||||
|
if(http_data == NULL)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
data = malloc(len + 1);
|
||||||
|
memcpy(data, http_data, len);
|
||||||
|
data[len] = 0;
|
||||||
|
|
||||||
|
lines = split_headers(data, len, line);
|
||||||
|
|
||||||
|
/* Now, this protocol looks like:
|
||||||
|
* sourcepassword\n
|
||||||
|
* headers: as normal\n"
|
||||||
|
* \n
|
||||||
|
*/
|
||||||
|
|
||||||
|
parser->req_type = httpp_req_source;
|
||||||
|
httpp_setvar(parser, HTTPP_VAR_URI, "/");
|
||||||
|
httpp_setvar(parser, HTTPP_VAR_ICYPASSWORD, line[0]);
|
||||||
|
httpp_setvar(parser, HTTPP_VAR_PROTOCOL, "ICY");
|
||||||
|
/* This protocol is evil */
|
||||||
|
httpp_setvar(parser, HTTPP_VAR_VERSION, "666");
|
||||||
|
|
||||||
|
parse_headers(parser, line, lines);
|
||||||
|
|
||||||
|
free(data);
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
int httpp_parse(http_parser_t *parser, char *http_data, unsigned long len)
|
int httpp_parse(http_parser_t *parser, char *http_data, unsigned long len)
|
||||||
{
|
{
|
||||||
char *data, *tmp;
|
char *data, *tmp;
|
||||||
@ -348,8 +384,10 @@ int httpp_parse(http_parser_t *parser, char *http_data, unsigned long len)
|
|||||||
}
|
}
|
||||||
|
|
||||||
parser->uri = strdup(uri);
|
parser->uri = strdup(uri);
|
||||||
} else
|
} else {
|
||||||
parser->uri = NULL;
|
free(data);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
if ((version != NULL) && ((tmp = strchr(version, '/')) != NULL)) {
|
if ((version != NULL) && ((tmp = strchr(version, '/')) != NULL)) {
|
||||||
tmp[0] = '\0';
|
tmp[0] = '\0';
|
||||||
|
@ -14,6 +14,7 @@
|
|||||||
#define HTTPP_VAR_REQ_TYPE "__req_type"
|
#define HTTPP_VAR_REQ_TYPE "__req_type"
|
||||||
#define HTTPP_VAR_ERROR_MESSAGE "__errormessage"
|
#define HTTPP_VAR_ERROR_MESSAGE "__errormessage"
|
||||||
#define HTTPP_VAR_ERROR_CODE "__errorcode"
|
#define HTTPP_VAR_ERROR_CODE "__errorcode"
|
||||||
|
#define HTTPP_VAR_ICYPASSWORD "__icy_password"
|
||||||
|
|
||||||
typedef enum httpp_request_type_tag {
|
typedef enum httpp_request_type_tag {
|
||||||
httpp_req_none, httpp_req_get, httpp_req_post, httpp_req_head,
|
httpp_req_none, httpp_req_get, httpp_req_post, httpp_req_head,
|
||||||
@ -40,6 +41,7 @@ typedef struct http_parser_tag {
|
|||||||
http_parser_t *httpp_create_parser(void);
|
http_parser_t *httpp_create_parser(void);
|
||||||
void httpp_initialize(http_parser_t *parser, http_varlist_t *defaults);
|
void httpp_initialize(http_parser_t *parser, http_varlist_t *defaults);
|
||||||
int httpp_parse(http_parser_t *parser, char *http_data, unsigned long len);
|
int httpp_parse(http_parser_t *parser, char *http_data, unsigned long len);
|
||||||
|
int httpp_parse_icy(http_parser_t *parser, char *http_data, unsigned long len);
|
||||||
int httpp_parse_response(http_parser_t *parser, char *http_data, unsigned long len, char *uri);
|
int httpp_parse_response(http_parser_t *parser, char *http_data, unsigned long len, char *uri);
|
||||||
void httpp_setvar(http_parser_t *parser, char *name, char *value);
|
void httpp_setvar(http_parser_t *parser, char *name, char *value);
|
||||||
char *httpp_getvar(http_parser_t *parser, char *name);
|
char *httpp_getvar(http_parser_t *parser, char *name);
|
||||||
|
Loading…
Reference in New Issue
Block a user