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


Python validators.ipv4方法代碼示例

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


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

示例1: _create_payload

# 需要導入模塊: import validators [as 別名]
# 或者: from validators import ipv4 [as 別名]
def _create_payload(self, name: str, zone: str, address: str, address_type: str) -> dict:
        payload = {
            "name": name,
            "zone": zone
        }
        if address_type == "fqdn":
            payload["domain"] = address
            payload["dns_ttl"] = 0
        elif address_type == "cidr":
            payload["network"] = self._generate_subnet_netmask(address)
        else:
            payload["host"] = {
                "ip": address
            }

        object_type = address_type
        if address_type == "cidr":
            object_type = "ipv4"

        return {
            "address_objects": [{
                object_type: payload
            }]
        } 
開發者ID:rapid7,項目名稱:insightconnect-plugins,代碼行數:26,代碼來源:action.py

示例2: filter_ip_list

# 需要導入模塊: import validators [as 別名]
# 或者: from validators import ipv4 [as 別名]
def filter_ip_list(ip_list):
    """Filter out identical addresses in an IP address list.

    Params:
    - ip_list: (type: string list) IP address list.

    Returns:
    - return_list: (type: string list) filtered IP address list.
    """
    LOGGING.info('Filtering IP list...')
    LOGGING.info('Before: {0}'.format(len(ip_list)))

    unique_list = list(set(ip_list))
    return_list = []

    for ip_addr in unique_list:
        if validators.ipv4(ip_addr):
            return_list.append(ip_addr)

    LOGGING.info('After: {0}'.format(len(return_list)))
    LOGGING.info('Filtering complete!')

    return return_list 
開發者ID:phage-nz,項目名稱:ph0neutria,代碼行數:25,代碼來源:filter_utils.py

示例3: resolve_country

# 需要導入模塊: import validators [as 別名]
# 或者: from validators import ipv4 [as 別名]
def resolve_country(host_name):
    """Resolve an IP address or domain to it's hosting country.

    Params:
    - host_name: (type: string) FQDN or IP address.

    Returns:
    - result: (type: string) two-letter country code.
    """
    isCidr = re.match(r'\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}/\d{1,2}', host_name)

    if isCidr:
        host_name = str(random.choice(netaddr.IPNetwork(host_name)))

    if validators.ipv4(host_name):
        return geo_lookup(host_name)

    ip_addr = resolve_dns(host_name)

    if ip_addr:
        return geo_lookup(ip_addr)

    return 'ZZ' 
開發者ID:phage-nz,項目名稱:ph0neutria,代碼行數:25,代碼來源:geo_utils.py

示例4: resolve_asn

# 需要導入模塊: import validators [as 別名]
# 或者: from validators import ipv4 [as 別名]
def resolve_asn(ip_addr):
    """Resolve the ASN of an IP address or FQDN.

    Params:
    - ip_addr: (type: string) FQDN or IP address.

    Returns:
    - result: (type: string) ASN number and organisation.
    """
    isCidr = re.match(r'\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}/\d{1,2}', ip_addr)

    if isCidr:
        ip_addr = str(random.choice(netaddr.IPNetwork(ip_addr)))

    if validators.ipv4(ip_addr):
        return asn_lookup(ip_addr)

    host_addr = resolve_dns(ip_addr)

    if host_addr:
        return asn_lookup(host_addr)

    return 'AS0000 Unknown' 
開發者ID:phage-nz,項目名稱:ph0neutria,代碼行數:25,代碼來源:geo_utils.py

示例5: resolve_dns

# 需要導入模塊: import validators [as 別名]
# 或者: from validators import ipv4 [as 別名]
def resolve_dns(host_name):
    """Perform a DNS lookup of a FQDN.

    Params:
    - host_name: (type: string) FQDN to perform lookup of.

    Returns:
    - result: (type: string) resulting IP address.
    """
    if validators.ipv4(host_name):
        return host_name

    ip_addr = forward_dns_lookup(host_name)

    if ip_addr is not None:
        return ip_addr

    return False 
開發者ID:phage-nz,項目名稱:ph0neutria,代碼行數:20,代碼來源:dns_utils.py

示例6: process_iocs

# 需要導入模塊: import validators [as 別名]
# 或者: from validators import ipv4 [as 別名]
def process_iocs(results):
    """Return data formatted for Splunk from CyberCrime Tracker."""
    if results != None:
        provided_iocs = [y for x in results for y in x.values()]
    else:
        provided_iocs = sys.argv[1:]

    session      = commons.create_session()
    splunk_table = []

    for provided_ioc in set(provided_iocs):
        provided_ioc = commons.deobfuscate_string(provided_ioc)

        if validators.domain(provided_ioc) or validators.ipv4(provided_ioc):
            cct_dicts = query_cct(provided_ioc, session)
        else:
            splunk_table.append({"invalid": provided_ioc})
            continue

        for cct_dict in cct_dicts:
            splunk_table.append(cct_dict)

    session.close()
    return splunk_table 
開發者ID:ecstatic-nobel,項目名稱:OSweep,代碼行數:26,代碼來源:cybercrime_tracker.py

示例7: _determine_address_type

# 需要導入模塊: import validators [as 別名]
# 或者: from validators import ipv4 [as 別名]
def _determine_address_type(address: str) -> str:
        if validators.ipv4(address):
            return "ipv4"
        if validators.ipv6(address):
            return "ipv6"
        if validators.domain(address):
            return "fqdn"
        if re.search('/', address):
            return "cidr"
        raise PluginException(cause="Unknown address type provided.",
                              assistance=f"{address} is not one of the following: IPv4, IPv6, CIDR or domain name.") 
開發者ID:rapid7,項目名稱:insightconnect-plugins,代碼行數:13,代碼來源:action.py

示例8: get_data_type

# 需要導入模塊: import validators [as 別名]
# 或者: from validators import ipv4 [as 別名]
def get_data_type(indicator):
        if validators.ipv4(indicator) or validators.ipv6(indicator):
            return "IP"
        elif validators.url(indicator):
            return "URL"
        elif validators.domain(indicator):
            return "DOMAIN"
        elif validators.sha1(indicator):
            return "FILE_SHA1"

        raise PluginException(
            cause="Invalid indicator input provided.",
            assistance="Supported indicators are IP, URL, domain and SHA1 hash."
        ) 
開發者ID:rapid7,項目名稱:insightconnect-plugins,代碼行數:16,代碼來源:action.py

示例9: _get_payload

# 需要導入模塊: import validators [as 別名]
# 或者: from validators import ipv4 [as 別名]
def _get_payload(self, params):
        agent = params.get(Input.AGENT)
        if params.get(Input.QUARANTINE_STATE, True):
            action = "cmd_isolate_agent"
        else:
            action = "cmd_restore_isolated_agent"

        if "cmd_isolate_agent" == action and agent in params.get(Input.WHITELIST, []):
            raise PluginException(cause="Unable to block whitelisted entry.",
                                  assistance=f"Please remove the host from the action's whitelist or quarantine a different host.")


        payload = {
            "act": action,
            "allow_multiple_match": True
        }

        validate_dict = {
            "entity_id": validators.uuid,
            "ip_address": lambda address: (validators.ipv4(address) or validators.ipv6(address)),
            "host_name": self.validate_host_name,
        }

        if validators.mac_address(agent.replace("-", ":")):
            payload["mac_address"] = agent
        else:
            for name, validate_fn in validate_dict.items():
                if validate_fn(agent):
                    payload[name] = agent
                    break

        return payload 
開發者ID:rapid7,項目名稱:insightconnect-plugins,代碼行數:34,代碼來源:action.py

示例10: geo_lookup

# 需要導入模塊: import validators [as 別名]
# 或者: from validators import ipv4 [as 別名]
def geo_lookup(ip_addr):
    """Resolve an IP address to it's hosting country.

    Params:
    - ip_addr: (type: string) IP address.

    Returns:
    - result: (type: string) two-letter country code.
    """
    if validators.ipv4(ip_addr):
        try:
            if ip_addr == '255.255.255.255':
                return 'ZZ'

            with geoip2.database.Reader(BASECONFIG.geolite_db) as reader:
                response = reader.city(ip_addr)

                if response is not None:
                    if response.country.iso_code is not None:
                        return response.country.iso_code

                    if response.continent.code is not None:
                        return response.continent.code

        except Exception as e:
            LOGGING.warning(
                'Failed to perform GeoLookup for address {0}: {1}'.format(
                    ip_addr, str(e)))

    else:
        LOGGING.warning('Invalid IP address: {0}'.format(ip_addr))

    return 'ZZ' 
開發者ID:phage-nz,項目名稱:ph0neutria,代碼行數:35,代碼來源:geo_utils.py

示例11: asn_lookup

# 需要導入模塊: import validators [as 別名]
# 或者: from validators import ipv4 [as 別名]
def asn_lookup(ip_addr):
    """Resolve the ASN of an IP address.

    Params:
    - ip_addr: (type: string) IP address.

    Returns:
    - result: (type: string) ASN number and organisation.
    """
    if validators.ipv4(ip_addr):
        try:
            if ip_addr == '255.255.255.255':
                return 'AS0000 Unknown'

            with geoip2.database.Reader(BASECONFIG.asn_db) as reader:
                response = reader.asn(ip_addr)

                if response is not None:
                    asn_number = response.autonomous_system_number
                    asn_org = response.autonomous_system_organization
                    return 'AS{0} {1}'.format(asn_number, asn_org)

        except Exception as e:
            LOGGING.warning(
                'Failed to perform ASN lookup for address {0}: {1}'.format(
                    ip_addr, str(e)))

    else:
        LOGGING.warning('Invalid IP address: {0}'.format(ip_addr))

    return 'AS0000 Unknown' 
開發者ID:phage-nz,項目名稱:ph0neutria,代碼行數:33,代碼來源:geo_utils.py

示例12: checkType

# 需要導入模塊: import validators [as 別名]
# 或者: from validators import ipv4 [as 別名]
def checkType(self, argument):
        """
            Identify observable type
        """
        if not argument or len(argument.strip()) == 0:
            return None
        elif argument[0] is '#':
            return None
        elif validators.url(argument):
            return "URL"
        elif validators.md5(argument):
            return "MD5"
        elif validators.sha1(argument):
            return "SHA1"
        elif validators.sha256(argument):
            return "SHA256"
        elif validators.sha512(argument):
            return "SHA512"
        elif validators.ipv4(argument):
            return "IPv4"
        elif validators.ipv6(argument):
            return "IPv6"
        elif validators.domain(argument):
            return "domain"
        else:
            return None 
開發者ID:conix-security,項目名稱:BTG,代碼行數:28,代碼來源:BTG.py

示例13: process_iocs

# 需要導入模塊: import validators [as 別名]
# 或者: from validators import ipv4 [as 別名]
def process_iocs(results):
    """Return data formatted for Splunk from crt.sh."""
    if results != None:
        provided_iocs = [y for x in results for y in x.values()]
    elif sys.argv[1] != "subdomain" and sys.argv[1] != "wildcard":
        if len(sys.argv) > 1:
            provided_iocs = sys.argv[1:]
    elif sys.argv[1] == "subdomain" or sys.argv[1] == "wildcard":
        if len(sys.argv) > 2:
            provided_iocs = sys.argv[2:]

    session      = commons.create_session()
    splunk_table = []

    for provided_ioc in set(provided_iocs):
        provided_ioc = commons.deobfuscate_string(provided_ioc)

        if validators.domain(provided_ioc) or validators.ipv4(provided_ioc):
            crt_dicts = query_crtsh(provided_ioc, session)
        else:
            splunk_table.append({"invalid": provided_ioc})
            continue

        for crt_dict in crt_dicts:
            splunk_table.append(crt_dict)

    session.close()
    return splunk_table 
開發者ID:ecstatic-nobel,項目名稱:OSweep,代碼行數:30,代碼來源:crtsh.py

示例14: process_iocs

# 需要導入模塊: import validators [as 別名]
# 或者: from validators import ipv4 [as 別名]
def process_iocs(results):
    """Return data formatted for Splunk from Malshare."""
    if results != None:
        provided_iocs = [y for x in results for y in x.values()]
    else:
        provided_iocs = sys.argv[1:]

    session = commons.create_session()
    api_key = commons.get_apikey("malshare")
    splunk_table = []

    for provided_ioc in set(provided_iocs):
        provided_ioc = commons.deobfuscate_string(provided_ioc)
        provided_ioc = provided_ioc.lower()

        if validators.ipv4(provided_ioc) or validators.domain(provided_ioc) or \
            re.match("^[a-f\d]{32}$", provided_ioc) or re.match("^[a-f\d]{64}$", provided_ioc):
            pass
        else:
            splunk_table.append({"invalid": provided_ioc})
            continue

        ioc_dicts = query_malshare(provided_ioc, api_key, session)

        for ioc_dict in ioc_dicts:
            splunk_table.append(ioc_dict)

    session.close()
    return splunk_table 
開發者ID:ecstatic-nobel,項目名稱:OSweep,代碼行數:31,代碼來源:malshare.py

示例15: process_iocs

# 需要導入模塊: import validators [as 別名]
# 或者: from validators import ipv4 [as 別名]
def process_iocs(results):
    """Return data formatted for Splunk from ThreatCrowd."""
    if results != None:
        provided_iocs = [y for x in results for y in x.values()]
    else:
        provided_iocs = sys.argv[1:]

    session = commons.create_session()
    splunk_table = []

    for provided_ioc in set(provided_iocs):
        provided_ioc = commons.deobfuscate_string(provided_ioc)
        provided_ioc = provided_ioc.lower()

        if validators.ipv4(provided_ioc):
            ioc_type = "ip"
        elif validators.domain(provided_ioc):
            ioc_type = "domain"
        elif validators.email(provided_ioc):
            ioc_type = "email"
        elif re.match("^[a-f\d]{32}$", provided_ioc) or re.match("^[a-f\d]{64}$", provided_ioc):
            ioc_type = "resource"
        else:
            splunk_table.append({"invalid": provided_ioc})
            continue

        ioc_dicts = query_threatcrowd(provided_ioc, ioc_type, session)

        for ioc_dict in ioc_dicts:
            splunk_table.append(ioc_dict)

        if len(provided_iocs) > 1:
            sleep(10)

    session.close()
    return splunk_table 
開發者ID:ecstatic-nobel,項目名稱:OSweep,代碼行數:38,代碼來源:threatcrowd.py


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