abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 23:33 | Nová verze

    Richard Biener oznámil vydání verze 16.1 (16.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 16. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.

    Ladislav Hagara | Komentářů: 0
    včera 23:11 | Nová verze

    Zulip Server z open source komunikační platformy Zulip (Wikipedie, GitHub) byl vydán ve verzi 12.0. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    včera 12:11 | IT novinky

    Před 30 lety, tj. v úterý 30. dubna 1996, byl spuštěn Seznam.cz.

    Ladislav Hagara | Komentářů: 4
    včera 11:44 | Komunita

    Byly zpracovány a zveřejněny všechny videozáznamy, které stojí za zveřejnění, z konference FOSDEM 2026.

    Ladislav Hagara | Komentářů: 0
    včera 01:11 | IT novinky

    Od úterý 28. dubna musí nově uváděné notebooky v Evropské unii podporovat nabíjení přes USB-C. Jednotná nabíječka byla schválena Evropským parlamentem v říjnu 2022.

    Ladislav Hagara | Komentářů: 53
    29.4. 23:44 | Bezpečnostní upozornění

    Byly publikovány informace o kritické zranitelnosti CVE-2026-31431 pojmenované Copy Fail v Linuxu, konkrétně v kryptografii (AF_ALG). Běžný uživatel může získat práva roota (lokální eskalaci práv). Na všech distribucích Linuxu vydaných od roku 2017. Pomocí 732bajtového skriptu. V upstreamu je již opraveno. Zranitelnost byla nalezena pomocí AI Xint Code.

    Ladislav Hagara | Komentářů: 4
    29.4. 17:44 | Nová verze

    Textový editor Zed dospěl do verze 1.0. Představení v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    29.4. 04:44 | Komunita

    Vývojáři svobodného 3D softwaru Blender představili (𝕏, Mastodon, Bluesky) nejnovějšího firemního sponzora Blenderu. Je ním společnost Anthropic stojící za AI Claude a úroveň sponzoringu je Patron, tj. minimálně 240 tisíc eur ročně. Anthropic oznámil sponzorství v tiskové zprávě Claude for Creative Work.

    Ladislav Hagara | Komentářů: 7
    29.4. 03:55 | Nová verze

    VNC server wayvnc pro Wayland kompozitory postavené nad wlroots - ne GNOME, KDE nebo Weston - byl vydán ve verzi 0.10.0. Vydána byla také verze 1.0.0 související knihovny neatvnc.

    Ladislav Hagara | Komentářů: 0
    28.4. 16:22 | Nová verze

    Bylo oznámeno vydání Fedora Linuxu 44. Ve finální verzi vychází šest oficiálních edic: Fedora Workstation a Fedora KDE Plasma Desktop pro desktopové, Fedora Server pro serverové, Fedora IoT pro internet věcí, Fedora Cloud pro cloudové nasazení a Fedora CoreOS pro ty, kteří preferují neměnné systémy. Vedle nich jsou k dispozici také další atomické desktopy, spiny a laby. Podrobný přehled novinek v samostatných článcích na stránkách

    … více »
    Ladislav Hagara | Komentářů: 7
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (2%)
     (13%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (24%)
    Celkem 1467 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: zjisteni aktivity

    7.5.2009 12:03 filbar | skóre: 36 | blog: Denicek_programatora | Ostrava
    zjisteni aktivity
    Přečteno: 267×

    Protože už delší dobu dělám v PHPku, tak jsem se rozhodnul, že bych zkusil i něco jiného třeba v Pythonu, nebo C.

    Chtěl bych si naprogramovat daemona powersave(v případě úspěchu bych ho samozřejmě zveřejnil), který by kontroloval aktivitu myši a klávesnice, prostě nějak jako fungujou gnome-power-manager, nebo kpowersave, aby po určité době něčinnosti spustil skript na uspani PC.

    Tyto dva nástroje nepoužívám, protože si nechci na Gentoo instalovat gnome, nebo KDE knihovny. Takze jsem se rozhodnul napsat něco vlastního, ale nevím od čeho se mám odpíchnout, jestli existují nějaké funkce, na zjištění aktivity uživatele, jestli to jde nějak zjistit.

    Odpovědi

    Fuky avatar 7.5.2009 16:24 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: zjisteni aktivity

    Neaktivitu uživatele lze zjistit např. pomocí fce XScreenSaverQueryInfo, tady máš ukázku v Pythonu, která využívá přímo C knihovny libX11.so a libXss.so.1 (tz. je z toho vidět i jak by se to dělalo přímo v C), get X idle time with python:

    #!/usr/bin/python
    
    
    import ctypes, os
    
    class XScreenSaverInfo(ctypes.Structure):
        """ typedef struct { ... } XScreenSaverInfo; """
        _fields_ = [('window',      ctypes.c_ulong), # screen saver window
                    ('state',       ctypes.c_int),   # off,on,disabled
                    ('kind',        ctypes.c_int),   # blanked,internal,external
                    ('since',       ctypes.c_ulong), # milliseconds
                    ('idle',        ctypes.c_ulong), # milliseconds
                    ('event_mask',  ctypes.c_ulong)] # events
    
    class XScreenSaverSession(object):
        def __init__( self):
            self.xlib = ctypes.cdll.LoadLibrary( 'libX11.so')
            self.dpy = self.xlib.XOpenDisplay( os.environ['DISPLAY'])
            if not self.dpy:
                raise Exception('Cannot open display')
            self.root = self.xlib.XDefaultRootWindow( self.dpy)
            self.xss = ctypes.cdll.LoadLibrary( 'libXss.so.1')
            self.xss.XScreenSaverAllocInfo.restype = ctypes.POINTER(XScreenSaverInfo)
            self.xss_info = self.xss.XScreenSaverAllocInfo()
    
        def get_idle( self):
            self.xss.XScreenSaverQueryInfo( self.dpy, self.root, self.xss_info)
            return self.xss_info.contents.idle / 1000
    
    if __name__ == "__main__":
        s = XScreenSaverSession()
        print s.get_idle()
    

    Ovšem získanou hodnotu musíš ještě dále zpracovat kvůli chybě v X serveru, viz kpowersave/src/inactivity.cpp:

    /*!
     * This function workaround a fucking XServer idleTime bug in the 
     * XScreenSaverExtension, if dpms is running. In this case always the
     * current dpms-state time is extracted from the current idletime.
     * This mean: XScreenSaverInfo->idle is not the time since the last
     * user activity, as descriped in the header file of the extension.
     * This result in SUSE bug # and sf.net bug #
     *
     * Workaround: check if if XServer is in a dpms state, check the 
     *             current timeout for this state and add this value to 
     * 	       the current idle time and return.
     *
     * \param _idleTime a unsigned long value with the current ideletime fromm
     *                  XScreenSaverInfo->idle
     * \return a unsigned long with the corrected idletime
     */
    unsigned long inactivity::workaroundCreepyXServer( unsigned long _idleTime ){
    	kdDebugFuncOut(trace);
    
    	int dummy;
    	CARD16 standby, suspend, off;
    	CARD16 state;
    	BOOL onoff;
    
    	Display *dpy = qt_xdisplay();
    
    	kdDebug() << "Current idleTime: " << _idleTime << endl;
    
    	if (DPMSQueryExtension(dpy, &dummy, &dummy)) {
    		if (DPMSCapable(dpy)) {
    			DPMSGetTimeouts(dpy, &standby, &suspend, &off);
    			DPMSInfo(dpy, &state, &onoff);
    
    			if (onoff) {
    				switch (state) {
    					case DPMSModeStandby:
    						kdDebug() << "DPMS enabled. Monitor in Standby. Standby: "
    							  << standby << " sec" << endl;
    						// this check is a littlebit paranoid, but be sure
    						if (_idleTime < (unsigned) (standby * 1000))
    							_idleTime += (standby * 1000);
    						break;
    					case DPMSModeSuspend:
    						kdDebug() << "DPMS enabled. Monitor in Suspend. Suspend: "
    							  << suspend << " sec" << endl;
    						if (_idleTime < (unsigned) ((suspend + standby) * 1000))
    							_idleTime += ((suspend + standby) * 1000);
    						break;
    					case DPMSModeOff:
    						kdDebug() << "DPMS enabled. Monitor is Off. Off: "
    							  << off << " sec" << endl;
    						if (_idleTime < (unsigned) ((off + suspend + standby) * 1000))
    							_idleTime += ((off + suspend + standby) * 1000);
    						break;
    					case DPMSModeOn:
    					default:
    						break;
    				}
    			}
    		} 
    	}
    
    	kdDebug() << "Corrected idleTime: " << _idleTime << endl;
    	kdDebugFuncOut(trace);
    	return _idleTime;
    }
    

    16.6.2009 19:37 filbar | skóre: 36 | blog: Denicek_programatora | Ostrava
    Rozbalit Rozbalit vše Re: zjisteni aktivity
    Když se pokouším DPMS část přepsat do Pythonu, tak mi do po prvním volání DPMS funkce hlásí Segmentation fault:
    	def get_idle_worlkaround(self):
    		dpms=ctypes.cdll.LoadLibrary('libXext.so');
    		if dpms.DPMSQueryExtension(self.dpy,None,None):
    			if dpms.DPMSCapable(self.dpy)==1:
    				standby=suspend=off=state=0;
    				onoff=False;
    				dpms.DPMSGetTimeouts(self.dpy,standby,suspend,off);
    				dpms.DPMSInfo(self.dpy,state,onoff);
    				print "STATE";
    				print state;
    
    
    Co dělám špatně?

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.