在局域网中发布共享文件

#!/usr/bin/env python
#coding:utf8
# Author          : tuxpy
# Email           : q8886888@qq.com
# Last modified   : 2014-10-03 19:22:22
# Filename        : client.py
# Description     : 
from xmlrpclib import ServerProxy, Fault
from cmd import Cmd
from random import choice
from string import lowercase
from core.server import Node, UNHANDLED
from core.data import get_port, get_host
from threading import Thread
from time import sleep

import sys

HEAD_START = 0.1
SECRET_LENGTH = 100


def randomString(length):
    chars = []
    for i in range(length):
        chars.append(choice(lowercase))

    return ''.join(chars)

class Client(Cmd):
    prompt = '> '
    def __init__(self, url , dirname):
        Cmd.__init__(self)
        self.url = url
        self.port = get_port(url)  # 这个要当信息广播出去
        self.secret = randomString(SECRET_LENGTH)
        node = Node(url, dirname, self.secret)
        t_node = Thread(target = node._start)
        t_node.setDaemon(True)
        t_node.start()

        sleep(HEAD_START)
        self.server = ServerProxy(url)
        t_update_known = Thread(target = self.update_known)
        t_update_known.setDaemon(True)
        t_update_known.start()
        
    def do_fetch(self, arg):
        try:
            self.server.fetch(arg, self.secret)
        except Fault, f:
            if f.faultCode != UNHANDLED:raise
            print "Couldn't find the file", arg

    def do_ls(self, path):
        for url,files in self.server.ls().items():
            print '%s\n\t%s' % (get_host(url), '\n\t'.join(files))
        
    def update_known(self):
        from core.sock import sock
        sock = sock()
        sock.broadcast(str(self.port))  # 把自己的xml-rpc端口广播给别人
        while True:
            url = sock.recv_url()
            self.server.hello(url, self.secret) # 当收到节点信息时,更新节点

    def do_exit(self, arg):
        print
        sys.exit()

    do_EOR = do_exit

def main():
    import os
    cwd = os.path.dirname(os.path.abspath(sys.argv[0]))
    os.chdir(cwd) #  切换成程序所在目录

    from core.config import config
    cfg = config()
    directory = cfg.get('global', 'share_dir') 
    if not os.path.isdir(directory):
        sys.stderr.write("%s not is exist\n" % directory)
        sys.exit(1)
        
    url = 'http://localhost:' + cfg.get('global', 'data_port')

    client = Client(url, directory) 
    client.cmdloop()

if __name__ == "__main__":
    main()

编程技巧