Skip to content

Latest commit

 

History

History
258 lines (222 loc) · 5.37 KB

README.md

File metadata and controls

258 lines (222 loc) · 5.37 KB

python-inotify

python binding for linux inotify

  • License :MIT

Demo

#! /usr/bin/env python

"""
backup your file automatically.  
"""

import os
import time
import shutil
import sys
import errno 
import os.path
try:
    import _inotify
except:
    print "install _inotify please, url:  https://github.com/maliubiao/python_inotify"
    exit(0)


backup_dst = "/dropbox/path/backup"

backup_list = [
        "/home/user/.vimrc",
        "/home/user/.bashrc"
        ] 


#ident -> file
wds = {}

#inotify fd
fd = 0

#log
log_path = "/tmp/backup.log"

#touch down wd
twd = 0

#touch down path
tpath = "/tmp/backup.down"

def recv(event): 
    mask = event["mask"] 
    wd = event["wd"]            
    f = wds[wd] 
    if (mask & _inotify.MODIFY) or (mask & _inotify.CLOSE_WRITE) or (mask & _inotify.ATTRIB): 
        if wd == twd:
            print "yes, exit....."
            exit(0) 
        print "backup:", time.ctime(), f 
        try:
            shutil.copyfile(f,  backup_dst + os.path.basename(f))
        except OSError as e:
            print e 
    if mask & _inotify.DELETE_SELF:
        print f, " was itself deleted, add it again"
        try:
            wd2 = _inotify.add(fd, f, _inotify.ALL_EVENTS) 
            wds[wd2] = f 
        except OSError as e:
            print e 
    if mask & _inotify.IGNORED:
        del wds[wd]


def touch_down():
    global twd 
    f = open(tpath, "w+")
    f.close()
    try:
        twd = _inotify.add(fd, tpath, _inotify.ALL_EVENTS)
        wds[twd] = tpath
    except OSError:
        print i, e


def backup(*args):
    global fd
    fd = _inotify.create() 
    for i in backup_list: 
        try:
            wd = _inotify.add(fd, i, _inotify.ALL_EVENTS)
            wds[wd] = i 
        except OSError as e:
            print i, e
    touch_down()
    while True:
        time.sleep(0.5)
        try:
            _inotify.read_event(fd, recv)
        except OSError as e: 
            if e.errno == errno.EAGAIN:
                pass 


def background_backup(*args): 
    if os.fork() == 0:
        os.setsid()        
        sys.stdin = open('/dev/null', "r")
        output = open(log_path, "w+", buffering=0)
        sys.stdout = output
        sys.stderr = output
        if os.fork() == 0:
            backup(*args)
        else:
            exit(0)
    else:
        exit(0)

if __name__ == "__main__": 
    backup()

Examples

see examples/ 

API

####inotify_fd = _inotify.create() initializes a new inotify instance and returns a file descriptor associated with a new inotify event queue. You can use os.close(inotify_fd) to close this fd;

####wd = _inotify.add(inotify_fd, path, flags) adds a new watch, or modifies an existing watch, for the file whose locaion is specified in pathname. ###Flags

####_inotify.remove(inotify_fd, wd) removes the watch associated with the watch descriptor wd from the inotify instance associated with the file descriptor fd. Removing a watch causes an IGNORED event.

####_inotify.read_event(inotify_fd, callback) raise IOError with errno = EAGAIN if there is no event in the queue, otherwise invoke callback with a dict: {wd, mask, cookie, name, len}, see examples/;

Flag Meaning
_inotify.ACCESS File was accessed (read).
_inotify.ATTRIB Metadata changed .
_inotify.CLOSE_WRITE File opened for writing was closed.
_inotify.CLOSE_NOWRITE File not opened for writing was closed.
_inotify.CREATE File/directory created in wached directory.
_inotify.DELETE File/directory deleted from watched directory.
_inotify.DELETE_SELF Watched file/directory was itself deleted.
_inotify.MODIFY File was modified.
_inotify.MOVE_SELF Watched file/directory was itself moved.
_inotify.MOVED_FROM File moved out of watched directory.
_inotify.MOVED_TO File moved into watched directory.
_inotify.OPEN File was opened.
_inotify.ALL_EVENTS all above.

###Special Flags

Flag Meaning
_inotify.Q_OVERFLOW Event queue overflowed.
_inotify.ISDIR Subject of this event is a directory.
_inotify.IGNORED Watch was removed explictly or automatically.
_inotify.UNMOUNT File system containing watched object was unmounted. _inotify.DONT_FOLLOW
_inotify.EXCL_UNLINK Don't generate events for children after they have been unlinked from the watched directory.
_inotify.IN_MASK_ADD Add (bitwise OR) events for this path if it already exists(instead of replacing mask).
_inotify.ONESHOT Monitor path for one event, then remove from watch list.
_inotify.ONLYDIR Only watch path if it is a directory.

Install

#git clone https://github.com/maliubiao/python-inotify.git
#cd python-inotify
#sudo python setup.py install