當前位置: 首頁>>代碼示例>>Python>>正文


Python bencode.bencode方法代碼示例

本文整理匯總了Python中bencode.bencode方法的典型用法代碼示例。如果您正苦於以下問題:Python bencode.bencode方法的具體用法?Python bencode.bencode怎麽用?Python bencode.bencode使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在bencode的用法示例。


在下文中一共展示了bencode.bencode方法的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: from_torrent_url

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bencode [as 別名]
def from_torrent_url(url):
    import base64
    import bencode
    import hashlib
    import urllib
    from kmediatorrent.utils import url_get
    torrent_data = url_get(url)
    metadata = bencode.bdecode(torrent_data)
    hashcontents = bencode.bencode(metadata['info'])
    digest = hashlib.sha1(hashcontents).digest()
    b32hash = base64.b32encode(digest)
    params = {
        'dn': metadata['info']['name'],
        'tr': metadata['announce'],
    }
    plugin.log.info(params)
    paramstr = urllib.urlencode(params)
    return 'magnet:?%s&%s' % ('xt=urn:btih:%s' % b32hash, paramstr) 
開發者ID:jmarth,項目名稱:plugin.video.kmediatorrent,代碼行數:20,代碼來源:magnet.py

示例2: torrent2magnet

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bencode [as 別名]
def torrent2magnet(self, paths):
        def trans(tpath):
            if tpath.lower().endswith('torrent'):
                string = open(tpath).read()
                try:
                    dd = bencode.bdecode(string)
                except Exception as e:
                    print s % (1, 91, '  !! torrent is wrong:'), e
                    return None
                info = bencode.bencode(dd['info'])
                hh = sha1(info).hexdigest()
                print '# %s' % tpath
                print 'magnet:?xt=urn:btih:%s' % hh, '\n'

        for path in paths:
            if os.path.exists(path):
                if os.path.isdir(path):
                    for a, b, c in os.walk(path):
                        for i in c:
                            tpath = os.path.join(a, i)
                            trans(tpath)
                elif os.path.isfile(path):
                    tpath = path
                    trans(tpath)
            else:
                print s % (1, 91, '  !! file doesn\'t existed'), \
                    s % (1, 93, '--'), path 
開發者ID:PeterDing,項目名稱:iScript,代碼行數:29,代碼來源:bt.py

示例3: serialize

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bencode [as 別名]
def serialize(self,
                  use_bencode: bool=True,
                  include_suffix: bool=False,
                  include_moves: bool=False,
                  include_hash: bool=False):
        """
        This function serialize block.

        :param    use_bencode: check if you want to encode using bencode.
        :param include_suffix: check if you want to include suffix.
        :param  include_moves: check if you want to include linked moves.
        :param   include_hash: check if you want to include block hash.
        """
        binary = (lambda x: x) if use_bencode else bytes.hex
        serialized = dict(
            id=self.id,
            creator=self.creator,
            prev_hash=self.prev_hash,
            difficulty=self.difficulty,
            root_hash=self.root_hash,
            created_at=str(self.created_at),
            version=self.version,
        )
        if include_suffix:
            serialized['suffix'] = binary(self.suffix)

        if include_moves:
            serialized['moves'] = [m.serialize(
                use_bencode=False,
                include_signature=True,
                include_id=True,
            ) for m in self.moves]

        if include_hash:
            serialized['hash'] = self.hash

        if use_bencode:
            if self.prev_hash is None:
                del serialized['prev_hash']
            serialized = bencode(serialized)
        return serialized 
開發者ID:nekoyume,項目名稱:nekoyume,代碼行數:43,代碼來源:block.py

示例4: serialize

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bencode [as 別名]
def serialize(self,
                  use_bencode=True,
                  include_signature=False,
                  include_id=False,
                  include_block=False):
        """
        This function serialize block.

        :param       use_bencode: check if you want to encode using bencode.
        :param include_signature: check if you want to include signature.
        :param        include_id: check if you want to include linked moves.
        :param     include_block: check if you want to include block.
        """
        binary = (lambda x: x) if use_bencode else bytes.hex
        serialized = dict(
            user_address=self.user_address,
            name=self.name,
            details={k: str(v) for k, v in dict(self.details).items()},
            tax=self.tax,
            created_at=str(self.created_at),
        )
        if include_signature:
            serialized.update(
                signature=binary(self.signature),
                user_public_key=binary(self.user_public_key),
            )
        if include_id:
            serialized['id'] = self.id
        if include_block:
            if self.block:
                serialized['block'] = self.block.serialize(False)
            else:
                serialized['block'] = None
        if use_bencode:
            serialized = bencode(serialized)
        return serialized 
開發者ID:nekoyume,項目名稱:nekoyume,代碼行數:38,代碼來源:move.py

示例5: playlistdata

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bencode [as 別名]
def playlistdata(self):
        self.playlist = []
        try:
            filelist = [x for x in os.listdir(str(config.directory)) if x.endswith(('.torrent','.torrent.added'))]
        except:
            self.logger.error("Can't load torrent files from %s" % config.directory)
            return False

        for filename in filelist:
            infohash = None
            idx = 0
            try:
               with open('%s/%s' % (config.directory, filename), "rb") as torrent_file: metainfo = bencode.bdecode(torrent_file.read())
               infohash = hashlib.sha1(bencode.bencode(metainfo['info'])).hexdigest()
            except: self.logger.error('The file %s may be corrupted. BencodeDecodeError!' % filename)
            else:
               self.logger.debug('%s' % filename)
               if 'files'in metainfo['info']:
                  try:
                     for files in metainfo['info']['files']:
                        if ''.join(files['path']).endswith(self.videoextdefaults):
                           self.playlist.append([''.join(files['path']).translate({ord(c): None for c in '%~}{][^$#@*,-!?&`|><+='}), infohash, str(idx), metainfo['info']['name']])
                           idx+=1
                  except Exception as e:
                     self.logger.error("Can't decode content of: %s\r\n%s" % (filename,repr(e)))
               else:
                    try:
                       self.playlist.append([metainfo['info']['name'].translate({ord(c): None for c in '%~}{][^$#@*,-!?&`|><+='}), infohash, '0', 'Other'])
                    except:
                       try:
                           self.playlist.append([filename.decode('utf-8').translate({ord(c): None for c in '%~}{][^$#@*,-!?&`|><+='}), infohash, '0', 'Other'])
                       except AttributeError:
                           self.playlist.append([filename.translate({ord(c): None for c in '%~}{][^$#@*,-!?&`|><+='}), infohash, '0', 'Other'])

        self.playlist.sort(key=lambda data: (data[3], data[0]))
        return True 
開發者ID:pepsik-kiev,項目名稱:HTTPAceProxy,代碼行數:38,代碼來源:torrentfilms_plugin.py

示例6: send_ext_handshake

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bencode [as 別名]
def send_ext_handshake(the_socket):
    msg = chr(BT_MSG_ID) + chr(EXT_HANDSHAKE_ID) + bencode({"m": {"ut_metadata": 1}})
    send_message(the_socket, msg) 
開發者ID:xgfone,項目名稱:snippet,代碼行數:5,代碼來源:downloadTorrent.py

示例7: request_metadata

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bencode [as 別名]
def request_metadata(the_socket, ut_metadata, piece):
    """bep_0009"""
    msg = chr(BT_MSG_ID) + chr(ut_metadata) + bencode({"msg_type": 0, "piece": piece})
    send_message(the_socket, msg) 
開發者ID:xgfone,項目名稱:snippet,代碼行數:6,代碼來源:downloadTorrent.py

示例8: send_krpc

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bencode [as 別名]
def send_krpc(self, msg, address):
        try:
            self.ufd.sendto(bencode(msg), address)
        except Exception:
            pass 
開發者ID:xgfone,項目名稱:snippet,代碼行數:7,代碼來源:startCrawler.py

示例9: mask

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bencode [as 別名]
def mask(torrent_data):
    '''
    混淆種子內容
    :param torrent_data: 種子文件內容
    :return: (混淆後的種子文件內容,混淆字典)
    '''
    name_dict = _mask_filename(torrent_data)
    torrent_data = bencode.bencode(torrent_data)
    return torrent_data, name_dict 
開發者ID:deadblue,項目名稱:baidupan_shell,代碼行數:11,代碼來源:bt.py

示例10: mask_file

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bencode [as 別名]
def mask_file(torrent_file):
    '''
    混淆種子文件
    :param torrent_file: 種子文件
    :return: (混淆後的種子文件內容,混淆字典)
    '''
    with open(torrent_file, 'r') as fp:
        torrent_data = bencode.bdecode(fp.read())
    return mask(torrent_data) 
開發者ID:deadblue,項目名稱:baidupan_shell,代碼行數:11,代碼來源:bt.py

示例11: send_ext_handshake

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bencode [as 別名]
def send_ext_handshake(the_socket):
    msg = chr(BT_MSG_ID) + chr(EXT_HANDSHAKE_ID) + bencode({"m":{"ut_metadata": 1}})
    send_message(the_socket, msg) 
開發者ID:CreateChen,項目名稱:simDownloader,代碼行數:5,代碼來源:simMetadata.py

示例12: sendKRPC

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bencode [as 別名]
def sendKRPC(self, msg, address):
        """
        發送數據
        """
        try:
            self.transport.write(bencode(msg), address)
        except socket.error:
            pass 
開發者ID:wuzhenda,項目名稱:simDHT,代碼行數:10,代碼來源:krpc.py

示例13: __init__

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bencode [as 別名]
def __init__(self, trackerFile):
        self.peer_id = '0987654321098765432-'
        self.peers = []
        self.pieces = deque([])
        self.tracker = bencode.bdecode(open(trackerFile,'rb').read())
        bencodeInfo = bencode.bencode(self.tracker['info'])
        self.infoHash = hashlib.sha1(bencodeInfo).digest()
        self.getPeers()
        self.generatePieces()
        self.numPiecesSoFar = 0 
開發者ID:alyakhtar,項目名稱:Katastrophe,代碼行數:12,代碼來源:peers.py

示例14: transfer

# 需要導入模塊: import bencode [as 別名]
# 或者: from bencode import bencode [as 別名]
def transfer(self, string, tpath, foo=None, bar=None):
        self.dir_dict = {}
        self.sub_dir_index = 0

        dstring = bencode.bdecode(string)
        files = []
        file_index = 0

        ## change files' name
        if dstring['info'].get('files'):
            for fl in dstring['info']['files']:
                filename = fl['path'][-1]
                if args.type_ == 'n':
                    newfilename = re.sub(foo, bar, filename, re.I) \
                        if foo and bar else filename
                    if filename != newfilename:
                        print filename, s % (1, 92, '==>'), newfilename
                        path = [self._get_sub_dir_index(i) \
                                for i in fl['path'][:-1]]  + [newfilename]
                    else:
                        ext = os.path.splitext(filename)[-1]
                        ext = self._check_ext(ext)
                        path = [self._get_sub_dir_index(i) \
                                for i in fl['path'][:-1]] \
                                + ['%s%s' % (file_index, ext)]
                    file_index += 1
                    fl['path'] = path

                elif args.type_ == 'be64':
                    fn, ext = os.path.splitext(filename)
                    ext = self._check_ext(ext)
                    tfn = '/'.join(fl['path'][:-1] + [fn])
                    e_fn = base64.urlsafe_b64encode(tfn)
                    fl['path'] = [e_fn + '.base64' + ext]

                for item in fl.keys():
                    #if item not in ['path', 'length', 'filehash', 'ed2k']:
                    if item not in ['path', 'length', 'filehash']:
                        del fl[item]

                files.append(fl)
            dstring['info']['files'] = files

        ## change top directory
        for i in dstring['info'].keys():
            if i not in ['files', 'piece length', 'pieces', 'name', 'length']:
                del dstring['info'][i]
            elif 'name' in i:
                if args.name:
                    dstring['info'][i] = args.name

        ## delete comment and creator
        for i in dstring.keys():
            if i not in ['creation date', 'announce', 'info', 'encoding']:
                del dstring[i]

        c = bencode.bencode(dstring)
        with open(tpath, 'w') as g:
            g.write(c) 
開發者ID:PeterDing,項目名稱:iScript,代碼行數:61,代碼來源:bt.py


注:本文中的bencode.bencode方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。