Title: | Query 'Team Cymru' 'IP' Address, Autonomous System Number ('ASN'), Border Gateway Protocol ('BGP'), Bogon and 'Malware' Hash Data Services |
---|---|
Description: | A toolkit for querying 'Team Cymru' <http://team-cymru.org> 'IP' address, Autonomous System Number ('ASN'), Border Gateway Protocol ('BGP'), Bogon and 'Malware' Hash Data Services. |
Authors: | Bob Rudis [aut, cre] |
Maintainer: | Bob Rudis <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.5.0 |
Built: | 2025-01-05 04:48:07 UTC |
Source: | https://github.com/hrbrmstr/cymruservices |
Retrieves BGP Origin ASN info for a list of IPv4 addresses
bulk_origin(ips, timeout = getOption("timeout"))
bulk_origin(ips, timeout = getOption("timeout"))
ips |
vector of IPv4 address (character - dotted-decimal) |
timeout |
numeric: the timeout (in seconds) to be used for this connection. Beware that some OSes may treat very large values as zero: however the POSIX standard requires values up to 31 days to be supported. |
data frame of BGP Origin ASN lookup results
as
- AS #
ip
- IPv4 (passed in)
bgp_refix
- BGP CIDR
cc
- Country code
registry
- Registry it falls under
allocated
- date it was allocated
as_ame
- AS name
If a socket connection cannot be made (i.e. a network problem on your
end or a service/network problem on their end), all columns will be
NA
.
The Team Cymru's service is NOT a GeoIP service! Do not use this function for that as your results will not be accurate. Data is updated every 4 hours. Also, A direct connection to TCP Port 43 (WHOIS) is required for most of these API functions to work properly.
http://www.team-cymru.org/IP-ASN-mapping.html
## Not run: bulk_origin(c("68.22.187.5", "207.229.165.18", "198.6.1.65")) ## End(Not run)
## Not run: bulk_origin(c("68.22.187.5", "207.229.165.18", "198.6.1.65")) ## End(Not run)
Retrieves BGP Origin ASN info for a list of ASN ids
bulk_origin_asn(asns, timeout = getOption("timeout"))
bulk_origin_asn(asns, timeout = getOption("timeout"))
asns |
character vector of ASN ids (character) |
timeout |
numeric: the timeout (in seconds) to be used for this connection. Beware that some OSes may treat very large values as zero: however the POSIX standard requires values up to 31 days to be supported. |
data frame of BGP Origin ASN lookup results
as
- AS #
cc
- Country code
registry
- registry it falls under
allocated
- when it was allocated
as_name
- name associated with the allocation
If a socket connection cannot be made (i.e. a network problem on your
end or a service/network problem on their end), all columns will be
NA
.
The Team Cymru's service is NOT a GeoIP service! Do not use this function for that as your results will not be accurate. Data is updated every 4 hours. Also, A direct connection to TCP Port 43 (WHOIS) is required for most of these API functions to work properly.
http://www.team-cymru.org/IP-ASN-mapping.html
## Not run: bulk_origin_asn(c(22822, 1273, 2381, 2603, 2914, 3257, 3356, 11164, 174, 286, 1299, 2914, 3257, 3356, 3549, 22822)) ## End(Not run)
## Not run: bulk_origin_asn(c(22822, 1273, 2381, 2603, 2914, 3257, 3356, 11164, 174, 286, 1299, 2914, 3257, 3356, 3549, 22822)) ## End(Not run)
Retrieves BGP Peer ASN info for a list of IPv4 addresses
bulk_peer(ips, timeout = getOption("timeout"))
bulk_peer(ips, timeout = getOption("timeout"))
ips |
vector of IPv4 address (character - dotted-decimal) |
timeout |
numeric: the timeout (in seconds) to be used for this connection. Beware that some OSes may treat very large values as zero: however the POSIX standard requires values up to 31 days to be supported. |
data frame of BGP Peer ASN lookup results
peer_as
- peer AS #
ip
- IPv4 (passsed in)
bgp_prefix
- BGP CIDR block
cc
- Country code
registry
- Registry it falls under
allocated
- date allocated
peer_as_name
- peer name
If a socket connection cannot be made (i.e. a network problem on your
end or a service/network problem on their end), all columns will be
NA
.
The Team Cymru's service is NOT a GeoIP service! Do not use this function for that as your results will not be accurate. Data is updated every 4 hours. Also, A direct connection to TCP Port 43 (WHOIS) is required for most of these API functions to work properly.
http://www.team-cymru.org/IP-ASN-mapping.html
## Not run: bulk_peer(c("68.22.187.5", "207.229.165.18", "198.6.1.65")) ## End(Not run)
## Not run: bulk_peer(c("68.22.187.5", "207.229.165.18", "198.6.1.65")) ## End(Not run)
Check to see if Team Cymru WHOIS servers are up
cymru_active(timeout = 1, count = 3L, verbose = TRUE)
cymru_active(timeout = 1, count = 3L, verbose = TRUE)
timeout |
how long to wait for a response (seconds). Default is one second. |
count |
number of pings to issue. Default is three pings. |
verbose |
be verbose in output? Default |
cymru_active()
cymru_active()
cymruservices is an R package that provides interfaces to various Team Cymru Services including The Bogon Refrerence, The IP to ASN Mapping Project and The Malware Hash Registry
A direct connection to TCP Port 43 (WHOIS) is required for most of these API functions to work properly.
Bob Rudis ([email protected])
Within a given R session, it will be highly unlikely that API responses
to calls to Team Cymru services will change if the parameters have
not varied (i.e. you use the same vector of IP addresses again). To
respect the resources that have beeen freely provided, all the API
functions cache their results.
It may be advantageous or necessary to invalidate one or more of these
caches. This function allows for the invalidation of one or more (or all)
caches.
flush(..., quiet = TRUE)
flush(..., quiet = TRUE)
... |
strings naming cached results to flush. Can be any of
" |
quiet |
if |
Invalid cache names will be ignored. If quiet
is FALSE
and flush
was called from an interactive session invalid
cache names will be noted.
Also, you will still need to
force
the reloading of bogon lists if you are within the 4
hour window even if you invalided the memoised cache.
## Not run: flush("peer", "origin") flush() ## End(Not run)
## Not run: flush("peer", "origin") flush() ## End(Not run)
The traditional bogon prefixes (IPV4), plus prefixes that have been allocated to RIRs but not yet assigned by those RIRs to ISPs, end-users, etc. Updated every four hours.
ipv4_bogons(force = FALSE, cached_bogons = NA)
ipv4_bogons(force = FALSE, cached_bogons = NA)
force |
force a refresh even if the time-frame (4-hours) is not up |
cached_bogons |
if you pass in the previous result of a call to |
Bogons are defined as Martians (private and reserved addresses defined by RFC 1918, RFC 5735, and RFC 6598) and netblocks that have not been allocated to a regional internet registry (RIR) by the Internet Assigned Numbers Authority.
Fullbogons are a larger set which also includes IP space that has been allocated to an RIR, but not assigned by that RIR to an actual ISP or other end-user. IANA maintains a convenient IPv4 summary page listing allocated and reserved netblocks, and each RIR maintains a list of all prefixes that they have assigned to end-users. Our bogon reference pages include additional links and resources to assist those who wish to properly filter bogon prefixes within their networks.
http://www.team-cymru.org/bogon-reference-http.html
## Not run: v4_bogons <- ipv4_bogons() v4_bogons <- ipv4_bogons(cached_bogons=v4_bogons) ## End(Not run)
## Not run: v4_bogons <- ipv4_bogons() v4_bogons <- ipv4_bogons(cached_bogons=v4_bogons) ## End(Not run)
IPv6 "fullbogons", all IPv6 prefixes that have not been allocated to RIRs and that have not been assigned by RIRs to ISPs, end-users, etc. Updated every four hours.
ipv6_bogons(force = FALSE, cached_bogons = NA)
ipv6_bogons(force = FALSE, cached_bogons = NA)
force |
force a refresh even if the time-frame (4-hours) is not up |
cached_bogons |
if you pass in the previous result of a call to |
Bogons are defined as Martians (private and reserved addresses defined by RFC 1918, RFC 5735, and RFC 6598) and netblocks that have not been allocated to a regional internet registry (RIR) by the Internet Assigned Numbers Authority.
Fullbogons are a larger set which also includes IP space that has been allocated to an RIR, but not assigned by that RIR to an actual ISP or other end-user. IANA maintains a convenient IPv4 summary page listing allocated and reserved netblocks, and each RIR maintains a list of all prefixes that they have assigned to end-users. Our bogon reference pages include additional links and resources to assist those who wish to properly filter bogon prefixes within their networks.
http://www.team-cymru.org/bogon-reference-http.html
## Not run: v6_bogons <- ipv6_bogons() v6_bogons <- ipv6_bogons(cached_bogons=v6_bogons) ## End(Not run)
## Not run: v6_bogons <- ipv6_bogons() v6_bogons <- ipv6_bogons(cached_bogons=v6_bogons) ## End(Not run)
The Malware Hash Registry (MHR) project is a look-up service similar to the Team Cymru IP address to ASN mapping project. This project differs however, in that you can query the service for a computed MD5 or SHA-1 hash of a file and, if it is malware and the service knows about it, it returns the last time it's seen it along with an approximate anti-virus detection percentage.
malware_hash(hashes, timeout = getOption("timeout"))
malware_hash(hashes, timeout = getOption("timeout"))
hashes |
vector of IPv4 address (character - dotted-decimal) |
timeout |
numeric: the timeout (in seconds) to be used for this connection. Beware that some OSes may treat very large values as zero: however the POSIX standard requires values up to 31 days to be supported. |
data frame of BGP Origin ASN lookup results
sha1_md5
- hash queried for
last_known_timestamp
- last known GMT timestamp associated with that hash
detection_pct
- detection percentage across a mix of AV packages
If a socket connection cannot be made (i.e. a network problem on your
end or a service/network problem on their end), all columns will be
NA
.
Attempting to enumerate the malware registry via the public service interface is not only impractical, it is also strictly prohibited. Contact Team Cymru if the public interface is insufficient for your needs and we may be able to come up with alternative arrangement. Also, A direct connection to TCP Port 43 (WHOIS) is required for most of these API functions to work properly.
http://www.team-cymru.org/IP-ASN-mapping.html
## Not run: malware_hash(c("1250ac278944a0737707cf40a0fbecd4b5a17c9d", "7697561ccbbdd1661c25c86762117613", "cbed16069043a0bf3c92fff9a99cccdc", "e6dc4f4d5061299bc5e76f5cd8d16610", "e1112134b6dcc8bed54e0e34d8ac272795e73d74")) ## End(Not run)
## Not run: malware_hash(c("1250ac278944a0737707cf40a0fbecd4b5a17c9d", "7697561ccbbdd1661c25c86762117613", "cbed16069043a0bf3c92fff9a99cccdc", "e6dc4f4d5061299bc5e76f5cd8d16610", "e1112134b6dcc8bed54e0e34d8ac272795e73d74")) ## End(Not run)