Project

censu

0.0
Repository is archived
No release in over 3 years
Low commit activity in last 3 years
Ruby API client for the Censys Internet search engine.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.16
~> 0.8
~> 2.5
~> 12.3
~> 3.8
~> 4.0
~> 3.4
~> 0.9
 Project Readme

Censu

Build Status Maintainability Coverage Status

Description

Ruby API client to the Censys internet search engine.

Examples

Initialize the API:

require 'censys'
api = Censys::API.new(uid, secret)

Initialize the API by using $CENSYS_ID and $CENSYS_SECRET environment variables:

api = Censys::API.new

Search:

# Search for IPv4 addresses:
response = api.ipv4.search(query: 'dropbox.com')

# Search for Websites:
response = api.websites.search(query: 'dropbox.com')

# Search for Certificates:
response = api.certificates.search(query: 'dropbox.com')

Enumerate through search results:

response.each_page do |page|
    puts ">>> Page ##{page.metadata.page} / #{page.metadata.pages} ..."
    page.each do |result|
        puts result
    end
end

View:

# View for IPv4 addresses:
view = api.ipv4["8.8.8.8"]

# View for Websites:
view = api.websites["google.com"]

# View for Certificates:
view = api.certificates["821a712a29d8e25915f66a9771519746c5aa73a45321fd4ca7ef644e1cadda59"]

Report:

# Generate aggregate reports:
response = api.websites.report(
    query: '80.http.get.headers.server: Apache',
    field: 'location.country_code',
    buckets: 100
)

response.each do |country,count|
    puts "#{country}: #{count}"
end

Combine Search and View API.

api = Censys::API.new
response = api.websites.search(query: "hoge")
response.each_page do |page|
  page.each do |result|
    view = api.websites[result.domain]
    p view.domain                 # => e.g. "nrc.nl"
    p view.autonomous_system.name # => e.g. "NL-INTERMAX"
    p view.location.country       # => e.g. "Netherlands"
    p view.protocols              # => e.g. ["80/http", "0/lookup", "25/smtp", "443/https_www", "443/https", "80/http_www"]
  end
end

Requirements

  • Ruby 2.4 / 2.5

Install

% gem install censu

License

MIT License.

Note: This gem is forked from trailofbits/censys-ruby.