X-Git-Url: http://dolda2000.com/gitweb/?a=blobdiff_plain;f=daemon%2Fui.c;h=4918b74b4ebbedc475659b6f6769fddf3aa4b47c;hb=e03e1e7c23b2f527d43ec72b01c93185ebc63008;hp=af5bd99c42938234b78cd8d8ffa901837dafd1d0;hpb=f7292a8b27d1ea458ece778207afbb8f386e9003;p=doldaconnect.git diff --git a/daemon/ui.c b/daemon/ui.c index af5bd99..4918b74 100644 --- a/daemon/ui.c +++ b/daemon/ui.c @@ -324,7 +324,7 @@ static int haspriv(struct uidata *data, int perm) /* Useful macros for the command functions: */ #define haveargs(n) do { if(argc < n) { sq(sk, 0, L"501", L"Wrong number of arguments", NULL); return; } } while(0) -#define havepriv(p) do { if((data->userinfo == NULL) || ((data->userinfo->perms & (p)) != (p))) { sq(sk, 0, L"502", L"Unauthorized request", L"needed", L"%x", (p), L"had", L"%x", data->userinfo->perms, NULL); return; } } while(0) +#define havepriv(p) do { if((data->userinfo == NULL) || ((data->userinfo->perms & (p)) != (p))) { sq(sk, 0, L"502", L"Unauthorized request", L"needed", L"%x", (p), NULL); return; } } while(0) static void cmd_connect(struct socket *sk, struct uidata *data, int argc, wchar_t **argv) { @@ -361,7 +361,7 @@ static void cmd_connect(struct socket *sk, struct uidata *data, int argc, wchar_ return; } } - sq(sk, 0, L"201", L"1", L"1", L"Dolda Connect daemon v" VERSION, NULL); + sq(sk, 0, L"201", L"1", L"2", L"Dolda Connect daemon v" VERSION, NULL); } static void cmd_notfound(struct socket *sk, struct uidata *data, int argc, wchar_t **argv) @@ -839,6 +839,26 @@ static void cmd_cancel(struct socket *sk, struct uidata *data, int argc, wchar_t sq(sk, 0, L"200", L"Transfer cancelled", NULL); } +static void cmd_reset(struct socket *sk, struct uidata *data, int argc, wchar_t **argv) +{ + struct transfer *transfer; + + haveargs(2); + havepriv(PERM_TRANS); + if((transfer = findtransfer(wcstol(argv[1], NULL, 0))) == NULL) + { + sq(sk, 0, L"512", L"No such transfer", NULL); + return; + } + if(transfer->dir == TRNSD_UP) + { + sq(sk, 0, L"512", L"Only applicable to downloads", NULL); + return; + } + resettransfer(transfer); + sq(sk, 0, L"200", L"Transfer reset", NULL); +} + static void cmd_notify(struct socket *sk, struct uidata *data, int argc, wchar_t **argv) { int i, val; @@ -1143,9 +1163,9 @@ static void cmd_filtercmd(struct socket *sk, struct uidata *data, int argc, wcha sq(sk, 0, L"505", L"System error - Could not fork session", "Internal error", NULL); return; } - filtercmd = findfile(icswcstombs(confgetstr("ui", "filtercmd"), NULL, NULL), NULL, 0); + filtercmd = findfile("dc-filtercmd", pwent->pw_dir, 0); if(filtercmd == NULL) - filtercmd = findfile("dc-filtercmd", pwent->pw_dir, 0); + filtercmd = findfile(icswcstombs(confgetstr("ui", "filtercmd"), NULL, NULL), NULL, 0); if(filtercmd == NULL) { flog(LOG_WARNING, "could not find filtercmd executable for user %s", pwent->pw_name); @@ -1318,6 +1338,16 @@ static void cmd_uptime(struct socket *sk, struct uidata *data, int argc, wchar_t sq(sk, 0, L"200", L"%i", time(NULL) - starttime, NULL); } +static void cmd_hup(struct socket *sk, struct uidata *data, int argc, wchar_t **argv) +{ + extern volatile int reinit; + + havepriv(PERM_ADMIN); + flog(LOG_NOTICE, "UI HUP request from %ls", data->username); + reinit = 1; + sq(sk, 0, L"200", L"Will reinit", NULL); +} + #undef haveargs #undef havepriv @@ -1344,6 +1374,7 @@ static struct command commands[] = {L"download", cmd_download}, {L"lstrans", cmd_lstrans}, {L"cancel", cmd_cancel}, + {L"reset", cmd_reset}, {L"notify", cmd_notify}, {L"sendchat", cmd_sendchat}, {L"search", cmd_search}, @@ -1357,6 +1388,7 @@ static struct command commands[] = {L"register", cmd_register}, {L"sendmsg", cmd_sendmsg}, {L"uptime", cmd_uptime}, + {L"hup", cmd_hup}, {NULL, NULL} };