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


Python ZMapTransformOutput.certificates方法代碼示例

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


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

示例1: encode

# 需要導入模塊: from ztag.transform import ZMapTransformOutput [as 別名]
# 或者: from ztag.transform.ZMapTransformOutput import certificates [as 別名]
 def encode(self, obj):
     pb_out = super(RecordEncoder, self).encode(obj)
     out = ZMapTransformOutput()
     out.transformed = pb_out.transformed.SerializeToString()
     out.certificates = [c.SerializeToString() for c in pb_out.certificates]
     out.public_keys = [pk.SerializeToString() for pk in pb_out.public_keys]
     return out
開發者ID:zmap,項目名稱:ztag,代碼行數:9,代碼來源:protobuf.py

示例2: _transform_object

# 需要導入模塊: from ztag.transform import ZMapTransformOutput [as 別名]
# 或者: from ztag.transform.ZMapTransformOutput import certificates [as 別名]
 def _transform_object(self, obj):
     tls = obj['data']['tls']
     out, certificates = HTTPSTransform.make_tls_obj(tls)
     zout = ZMapTransformOutput()
     zout.transformed = out
     zout.certificates = certificates
     return zout
開發者ID:xtalentfeng,項目名稱:ztag,代碼行數:9,代碼來源:https.py

示例3: _transform_object

# 需要導入模塊: from ztag.transform import ZMapTransformOutput [as 別名]
# 或者: from ztag.transform.ZMapTransformOutput import certificates [as 別名]
    def _transform_object(self, obj):
        wrapped = Transformable(obj['data'])
        ciphers = wrapped['sslv2']['server_hello']['ciphers'].resolve()
        certificate = wrapped['sslv2']['server_hello']['certificate'].resolve()
        sslv2_support = bool(wrapped['sslv2']['server_verify'].resolve())
        sslv2_export = bool(wrapped['sslv2_export']['server_verify'].resolve())
        sslv2_extra_clear = bool(wrapped['sslv2_extra_clear']['server_verify']
                ['extra_clear'].resolve())
        out = {
            'support': sslv2_support,
            'export': sslv2_export,
            'extra_clear': sslv2_extra_clear,
        }
        if ciphers is not None:
            out['ciphers'] = ciphers
        if certificate is not None:
            out['certificate'] = {
                'parsed': certificate['parsed']
            }
            certificates = [certificate]
        else:
            certificates = list()

        zout = ZMapTransformOutput()
        zout.transformed = out
        zout.certificates = certificates
        return zout
開發者ID:LubyRuffy,項目名稱:ztag,代碼行數:29,代碼來源:sslv2.py

示例4: _transform_object

# 需要導入模塊: from ztag.transform import ZMapTransformOutput [as 別名]
# 或者: from ztag.transform.ZMapTransformOutput import certificates [as 別名]
    def _transform_object(self, obj):

        wrapped = Transformable(obj)
        error_component = wrapped['error_component'].resolve()
        if error_component is not None and error_component == 'connect':
            raise errors.IgnoreObject("Error connecting")

        banner = wrapped['data']['banner'].resolve()
        ehlo = wrapped['data']['ehlo'].resolve()
        starttls = wrapped['data']['starttls'].resolve()

        zout = ZMapTransformOutput()
        try:
            tls_handshake = obj['data']['tls']
            out, certificates  = https.HTTPSTransform.make_tls_obj(tls_handshake)
            zout.transformed['tls'] = out
            zout.certificates = certificates
        except (KeyError, TypeError, IndexError):
            pass

        if banner is not None:
            zout.transformed['banner'] = self.clean_banner(banner)
        if ehlo is not None:
            zout.transformed['ehlo'] = self.clean_banner(ehlo)
        if starttls is not None:
            zout.transformed['starttls'] = self.clean_banner(starttls)
        
        if len(zout.transformed) == 0:
            raise errors.IgnoreObject("Empty output dict")

        return zout
開發者ID:LubyRuffy,項目名稱:ztag,代碼行數:33,代碼來源:smtp.py

示例5: _transform_object

# 需要導入模塊: from ztag.transform import ZMapTransformOutput [as 別名]
# 或者: from ztag.transform.ZMapTransformOutput import certificates [as 別名]
 def _transform_object(self, obj):
     if 'tls' not in obj['data']:
         raise errors.IgnoreObject("Not a TLS response")
     tls = obj['data']['tls']
     out, certificates = HTTPSTransform.make_tls_obj(tls)
     zout = ZMapTransformOutput()
     zout.transformed = out
     zout.certificates = certificates
     return zout
開發者ID:zmap,項目名稱:ztag,代碼行數:11,代碼來源:https.py

示例6: encode

# 需要導入模塊: from ztag.transform import ZMapTransformOutput [as 別名]
# 或者: from ztag.transform.ZMapTransformOutput import certificates [as 別名]
    def encode(self, zout):
        out = ZMapTransformOutput()

        obj = zout.transformed
        ip = obj['ip_address']
        ts = obj['timestamp']
        domain = obj.get('domain', None)
        if zout.metadata.local_metadata is not None:
            obj['metadata'] = zout.metadata.local_metadata.to_dict()

        m = zout.metadata.global_metadata.to_dict()
        tags = list(zout.metadata.tags)

        data = {x: obj[x] for x in obj if x not in self.DROP_KEYS}

        m = {k: simple_strip(v) for k, v in m.iteritems()}

        metadata = self.Metadatum.from_dict(m)
        atom = self.ProtocolAtom(tags=tags, metadata=metadata, data=data)
        record = self.Record(ip, self.port, self.protocol.value, self.subprotocol.value,
                        protocol_atom=atom, domain=domain,
                        timestamp=ts, scan_id=self.scan_id)
        out.transformed = record.protobuf

        out.certificates = []
        for cert_dict in zout.certificates:
            ar = self.zsearch_definitions.anonstore_pb2.AnonymousRecord()
            c = ar.certificate
            c.parsed = json.dumps(cert_dict["parsed"], sort_keys=True)
            c.raw = base64.b64decode(cert_dict["raw"])
            c.sha1fp = cert_dict["parsed"]["fingerprint_sha1"].decode("hex")
            c.sha256fp = cert_dict["parsed"]["fingerprint_sha256"].decode("hex")
            valid_nss = cert_dict.get("nss_trusted", None)
            if valid_nss is not None:
                c.valid_nss = valid_nss
                c.validation_timestamp = record.timestamp
            parents_sha256 = cert_dict.get("parents", None)
            if parents_sha256 is not None:
                c.parents.extend([
                    sha_value.decode("hex") for sha_value in parents_sha256
                ])
            ar.sha256fp = c.sha256fp
            ar.scan_id = self.scan_id
            out.certificates.append(ar)
        return out
開發者ID:LubyRuffy,項目名稱:ztag,代碼行數:47,代碼來源:protobuf.py


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