X-Git-Url: https://git.danieliu.xyz/?p=slock.git;a=blobdiff_plain;f=slock.c;h=12cd8ee865244fe53d2c0cb8f886c492f8a1acdc;hp=47231021ced0cb9416d45979ce145786cee0b54f;hb=cc36050e44faa01b2783640ffb2323329d15f97d;hpb=a430a647e48a894499143b03da86e5707b4127df diff --git a/slock.c b/slock.c index 4723102..12cd8ee 100644 --- a/slock.c +++ b/slock.c @@ -1,5 +1,4 @@ -/* © 2006-2007 Anselm R. Garbe - * See LICENSE file for license details. */ +/* See LICENSE file for license details. */ #define _XOPEN_SOURCE 500 #if HAVE_SHADOW_H #include @@ -16,6 +15,12 @@ #include #include #include +#include + +#if HAVE_BSD_AUTH +#include +#include +#endif void eprint(const char *errstr, ...) { @@ -27,6 +32,7 @@ eprint(const char *errstr, ...) { exit(EXIT_FAILURE); } +#ifndef HAVE_BSD_AUTH const char * get_password() { /* only run as root */ const char *rval; @@ -46,18 +52,23 @@ get_password() { /* only run as root */ rval = sp->sp_pwdp; } #endif + /* drop privileges */ if(setgid(pw->pw_gid) < 0 || setuid(pw->pw_uid) < 0) eprint("slock: cannot drop privileges\n"); return rval; } +#endif int main(int argc, char **argv) { char curs[] = {0, 0, 0, 0, 0, 0, 0, 0}; char buf[32], passwd[256]; int num, screen; + +#ifndef HAVE_BSD_AUTH const char *pws; +#endif unsigned int len; Bool running = True; Cursor invisible; @@ -70,10 +81,14 @@ main(int argc, char **argv) { XSetWindowAttributes wa; if((argc == 2) && !strcmp("-v", argv[1])) - eprint("slock-"VERSION", © 2006-2007 Anselm R. Garbe\n"); + eprint("slock-"VERSION", © 2006-2008 Anselm R Garbe\n"); else if(argc != 1) eprint("usage: slock [-v]\n"); + +#ifndef HAVE_BSD_AUTH pws = get_password(); +#endif + if(!(dpy = XOpenDisplay(0))) eprint("slock: cannot open display\n"); screen = DefaultScreen(dpy); @@ -109,10 +124,19 @@ main(int argc, char **argv) { XSync(dpy, False); /* main event loop */ - while(running && !XNextEvent(dpy, &ev)) + while(running && !XNextEvent(dpy, &ev)) { + if(len == 0 && DPMSCapable(dpy)) { + DPMSEnabled(dpy); + DPMSForceLevel(dpy, DPMSModeOff); + } if(ev.type == KeyPress) { buf[0] = 0; num = XLookupString(&ev.xkey, buf, sizeof buf, &ksym, 0); + if(IsKeypadKey(ksym)) + if(ksym == XK_KP_Enter) + ksym = XK_Return; + else if(ksym >= XK_KP_0 && ksym <= XK_KP_9) + ksym = (ksym - XK_KP_0) + XK_0; if(IsFunctionKey(ksym) || IsKeypadKey(ksym) || IsMiscFunctionKey(ksym) || IsPFKey(ksym) || IsPrivateKeypadKey(ksym)) @@ -120,7 +144,14 @@ main(int argc, char **argv) { switch(ksym) { case XK_Return: passwd[len] = 0; - if((running = strcmp(crypt(passwd, pws), pws)) != 0) + +#ifdef HAVE_BSD_AUTH + running = !auth_userokay(getlogin(), NULL, "auth-xlock", passwd); +#else + running = strcmp(crypt(passwd, pws), pws); +#endif + + if (running != 0) XBell(dpy, 100); len = 0; break; @@ -139,6 +170,7 @@ main(int argc, char **argv) { break; } } + } XUngrabPointer(dpy, CurrentTime); XFreePixmap(dpy, pmap); XDestroyWindow(dpy, w);