本文整理匯總了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
示例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
示例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
示例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
示例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
示例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