1
0
mirror of https://github.com/SuperBFG7/ympd synced 2024-11-13 01:29:54 +00:00
ympd/src/mympd.c

202 lines
7.0 KiB
C
Raw Normal View History

2018-05-24 18:17:54 +00:00
/* myMPD
(c) 2018 Juergen Mang <mail@jcgames.de>
This project's homepage is: https://github.com/jcorporation/ympd
myMPD ist fork of:
ympd
(c) 2013-2014 Andrew Karpow <andy@ndyk.de>
This project's homepage is: http://www.ympd.org
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; version 2 of the License.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License along
with this program; if not, write to the Free Software Foundation, Inc.,
Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include <unistd.h>
#include <getopt.h>
#include <sys/time.h>
#include <pthread.h>
2018-06-11 20:35:11 +00:00
#include "mongoose/mongoose.h"
2018-05-24 18:17:54 +00:00
#include "mpd_client.h"
#include "config.h"
extern char *optarg;
2018-06-12 00:07:03 +00:00
static sig_atomic_t s_signal_received = 0;
static struct mg_serve_http_opts s_http_server_opts;
2018-05-24 18:17:54 +00:00
2018-06-12 00:07:03 +00:00
static void signal_handler(int sig_num) {
signal(sig_num, signal_handler); // Reinstantiate signal handler
s_signal_received = sig_num;
2018-05-24 18:17:54 +00:00
}
2018-06-12 00:07:03 +00:00
static void ev_handler(struct mg_connection *nc, int ev, void *ev_data) {
2018-05-24 18:17:54 +00:00
switch(ev) {
case MG_EV_WEBSOCKET_HANDSHAKE_DONE: {
fprintf(stdout,"New Websocket connection\n");
struct mg_str d = {(char *) "MPD_API_GET_SETTINGS", 20 };
callback_mpd(nc, d);
d.p="MPD_API_GET_OUTPUTS";
d.len=19;
callback_mpd(nc, d);
break;
2018-06-12 00:07:03 +00:00
}
case MG_EV_WEBSOCKET_FRAME: {
struct websocket_message *wm = (struct websocket_message *) ev_data;
2018-06-12 01:09:24 +00:00
wm->data[wm->size]='\0';
2018-06-12 00:07:03 +00:00
struct mg_str d = {(char *) wm->data, wm->size};
fprintf(stdout,"Websocket request: %s\n",wm->data);
2018-06-12 00:07:03 +00:00
callback_mpd(nc, d);
break;
}
case MG_EV_HTTP_REQUEST: {
struct http_message *hm = (struct http_message *) ev_data;
printf("HTTP request: %.*s\n",hm->uri.len,hm->uri.p);
mg_serve_http(nc, hm, s_http_server_opts);
2018-06-11 20:35:11 +00:00
break;
2018-06-12 00:07:03 +00:00
}
case MG_EV_CLOSE: {
if (is_websocket(nc)) {
fprintf(stdout,"Websocket connection closed\n");
mpd_close_handler(nc);
}
else {
fprintf(stdout,"HTTP Close\n");
}
break;
}
2018-05-24 18:17:54 +00:00
}
}
int main(int argc, char **argv)
{
int n, option_index = 0;
2018-06-12 00:07:03 +00:00
struct mg_mgr mgr;
struct mg_connection *nc;
2018-05-24 18:17:54 +00:00
unsigned int current_timer = 0, last_timer = 0;
2018-06-12 00:07:03 +00:00
signal(SIGTERM, signal_handler);
signal(SIGINT, signal_handler);
setvbuf(stdout, NULL, _IOLBF, 0);
setvbuf(stderr, NULL, _IOLBF, 0);
mg_mgr_init(&mgr, NULL);
2018-05-24 18:17:54 +00:00
char *run_as_user = NULL;
char const *error_msg = NULL;
char *webport = "8080";
mpd.port = 6600;
mpd.local_port = 0;
mpd.gpass = NULL;
strcpy(mpd.host, "127.0.0.1");
streamport = 8000;
2018-05-27 14:13:42 +00:00
strcpy(coverimage, "folder.jpg");
2018-05-24 18:17:54 +00:00
static struct option long_options[] = {
{"digest", required_argument, 0, 'D'},
{"host", required_argument, 0, 'h'},
{"port", required_argument, 0, 'p'},
{"localport", required_argument, 0, 'l'},
{"webport", required_argument, 0, 'w'},
{"user", required_argument, 0, 'u'},
{"version", no_argument, 0, 'v'},
{"help", no_argument, 0, 0 },
{"mpdpass", required_argument, 0, 'm'},
{"streamport", required_argument, 0, 's'},
2018-05-27 14:13:42 +00:00
{"coverimage", required_argument, 0, 'i'},
2018-05-24 18:17:54 +00:00
{0, 0, 0, 0 }
};
2018-05-29 21:28:11 +00:00
while((n = getopt_long(argc, argv, "D:h:p:l:w:u:d:vm:s:i:",
2018-05-24 18:17:54 +00:00
long_options, &option_index)) != -1) {
switch (n) {
case 'D':
mpd.gpass = strdup(optarg);
break;
case 'h':
strncpy(mpd.host, optarg, sizeof(mpd.host));
break;
case 'p':
mpd.port = atoi(optarg);
break;
case 'l':
mpd.local_port = atoi(optarg);
break;
case 'w':
webport = strdup(optarg);
break;
case 'u':
run_as_user = strdup(optarg);
break;
case 'm':
if (strlen(optarg) > 0)
mpd.password = strdup(optarg);
break;
case 's':
streamport = atoi(optarg);
break;
2018-05-27 14:13:42 +00:00
case 'i':
strncpy(coverimage, optarg, sizeof(coverimage));
break;
2018-05-24 18:17:54 +00:00
case 'v':
fprintf(stdout, "myMPD %d.%d.%d\n"
"Copyright (C) 2018 Juergen Mang <mail@jcgames.de>\n"
2018-05-29 21:28:11 +00:00
"Built " __DATE__ " "__TIME__ "\n",
MYMPD_VERSION_MAJOR, MYMPD_VERSION_MINOR, MYMPD_VERSION_PATCH);
2018-05-24 18:17:54 +00:00
return EXIT_SUCCESS;
break;
default:
fprintf(stderr, "Usage: %s [OPTION]...\n\n"
" -D, --digest <htdigest>\tpath to htdigest file for authorization\n"
" \t(realm ympd) [no authorization]\n"
" -h, --host <host>\t\tconnect to mpd at host [localhost]\n"
" -p, --port <port>\t\tconnect to mpd at port [6600]\n"
" -l, --localport <port>\t\tskip authorization for local port\n"
" -w, --webport [ip:]<port>\tlisten interface/port for webserver [8080]\n"
" -u, --user <username>\t\tdrop priviliges to user after socket bind\n"
" -v, --version\t\t\tget version\n"
" -m, --mpdpass <password>\tspecifies the password to use when connecting to mpd\n"
" -s, --streamport <port>\tconnect to mpd http stream at port [8000]\n"
2018-05-27 14:13:42 +00:00
" -i, --coverimage <filename>\tfilename for coverimage [folder.jpg]\n"
2018-05-24 18:17:54 +00:00
" --help\t\t\t\tthis help\n"
, argv[0]);
return EXIT_FAILURE;
}
}
2018-06-12 00:07:03 +00:00
nc = mg_bind(&mgr, webport, ev_handler);
mg_set_protocol_http_websocket(nc);
s_http_server_opts.document_root = SRC_PATH;
2018-05-24 18:17:54 +00:00
2018-06-12 00:07:03 +00:00
printf("Started on port %s\n", webport);
while (s_signal_received == 0) {
mg_mgr_poll(&mgr, 200);
2018-05-24 18:17:54 +00:00
current_timer = time(NULL);
if(current_timer - last_timer)
{
last_timer = current_timer;
2018-06-12 00:07:03 +00:00
mpd_poll(&mgr);
2018-05-24 18:17:54 +00:00
}
}
2018-06-12 00:07:03 +00:00
mg_mgr_free(&mgr);
2018-05-24 18:17:54 +00:00
mpd_disconnect();
return EXIT_SUCCESS;
}