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 12:55 | Nová verze

Byla vydána verze 17.12.0 KDE Aplikací (KDE Applications). Přehled novinek v kompletním seznamu změn a na stránce s dalšími informacemi. Aplikace, které nebyly dosud portovány na KDE Frameworks 5, byly z KDE Aplikací odstraněny.

Ladislav Hagara | Komentářů: 24
včera 03:00 | Komunita

Na Humble Bundle lze získat počítačovou hru Company of Heroes 2 (Wikipedie, YouTube) běžící také v Linuxu zdarma. Speciální akce končí v sobotu v 19:00.

Ladislav Hagara | Komentářů: 0
včera 02:00 | Zajímavý software

Christian Kellner představil na svém blogu projekt Bolt řešící bezpečnost rozhraní Thunderbolt 3 na Linuxu. Pomocí příkazu boltctl nebo rozšíření GNOME Shellu lze komunikovat s démonem boltd a například zakázat neznámá zařízení a předejít tak útokům typu Thunderstrike nebo DMA.

Ladislav Hagara | Komentářů: 6
včera 01:00 | Nová verze

Po půl roce vývoje od vydání verze 11.0 byla vydána verze 11.1 svobodného softwaru pro vytváření datových úložišť na síti FreeNAS (Wikipedie). Nejnovější FreeNAS je postaven na FreeBSD 11.1. Přehled novinek v příspěvku na blogu. Zdůraznit lze zvýšení výkonu OpenZFS, počáteční podporu Dockeru nebo synchronizaci s cloudovými službami Amazon S3 (Simple Storage Services), Backblaze B2 Cloud, Google Cloud a Microsoft Azure

Ladislav Hagara | Komentářů: 0
14.12. 23:55 | Nová verze

Po dvou měsících vývoje od vydání verze 235 oznámil Lennart Poettering vydání verze 236 správce systému a služeb systemd (GitHub, NEWS).

Ladislav Hagara | Komentářů: 6
14.12. 20:00 | Nová verze Ladislav Hagara | Komentářů: 0
14.12. 19:33 | Pozvánky

Pražská Fedora 27 Release Party, oslava nedávného vydání Fedory 27, se uskuteční 19. prosince od 19:00 v prostorách společnosti Etnetera (Jankovcova 1037/49). Na programu budou přednášky o novinkách, diskuse, neřízený networking atd.

Ladislav Hagara | Komentářů: 0
14.12. 18:11 | Nová verze

Byla vydána verze 2.11.0 QEMU (Wikipedie). Přispělo 165 vývojářů. Provedeno bylo více než 2 000 commitů. Přehled úprav a nových vlastností v seznamu změn.

Ladislav Hagara | Komentářů: 0
14.12. 17:44 | Komunita

Canonical oznámil dostupnost kryptografických balíčků s certifikací FIPS 140-2 úrovně 1 pro Ubuntu 16.04 LTS pro předplatitele podpory Ubuntu Advantage Advanced. Certifikace FIPS (Federal Information Processing Standards) jsou vyžadovány (nejenom) vládními institucemi USA.

Ladislav Hagara | Komentářů: 3
14.12. 16:11 | Zajímavý software

Společnost Avast uvolnila zdrojové kódy svého dekompilátoru RetDec (Retargetable Decompiler) založeného na LLVM. Vyzkoušet lze RetDec jako webovou službu nebo plugin pro interaktivní disassembler IDA. Zdrojové kódy RetDec jsou k dispozici na GitHubu pod open source licencí MIT.

Ladislav Hagara | Komentářů: 3
Jak se vás potenciálně dotkne trend odstraňování analogového audio konektoru typu 3,5mm jack z „chytrých telefonů“?
 (8%)
 (1%)
 (1%)
 (1%)
 (76%)
 (14%)
Celkem 997 hlasů
 Komentářů: 45, poslední 1.12. 19:00
    Rozcestník

    Dotaz: zjisteni aktivity

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

    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.