intrigue-ident 0.2 → 0.9.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.circleci/config.yml +21 -0
- data/.gitignore +3 -0
- data/.ruby-version +1 -0
- data/Dockerfile +39 -0
- data/Gemfile +10 -3
- data/Gemfile.lock +35 -20
- data/LICENSE.md +12 -0
- data/README.md +79 -0
- data/checks/ftp/base.rb +15 -0
- data/checks/ftp/filezilla.rb +28 -0
- data/checks/ftp/microsoft.rb +27 -0
- data/checks/ftp/proftp.rb +28 -0
- data/checks/ftp/pureftpd.rb +27 -0
- data/checks/ftp/vsftp.rb +28 -0
- data/checks/http/123reg.rb +31 -0
- data/checks/http/acme.rb +28 -0
- data/checks/http/acquia.rb +28 -0
- data/checks/http/adeptia.rb +30 -0
- data/checks/http/adobe.rb +168 -0
- data/checks/http/advantshop.rb +33 -0
- data/checks/http/afrihost.rb +29 -0
- data/checks/http/aftermarketpl.rb +46 -0
- data/checks/http/agility.rb +34 -0
- data/checks/http/akamai.rb +88 -0
- data/checks/http/alkacon.rb +30 -0
- data/checks/http/allegro.rb +28 -0
- data/checks/http/almuba.rb +30 -0
- data/checks/http/amazon.rb +263 -0
- data/checks/http/amirocms.rb +30 -0
- data/checks/http/anelectron.rb +29 -0
- data/checks/http/anquanbao.rb +32 -0
- data/checks/http/aol.rb +29 -0
- data/checks/http/apache.rb +358 -0
- data/checks/http/appdynamics.rb +43 -0
- data/checks/http/arris.rb +30 -0
- data/checks/http/artifactory.rb +30 -0
- data/checks/http/aruba.rb +27 -0
- data/checks/http/atlassian.rb +152 -0
- data/checks/http/auth0.rb +44 -0
- data/checks/http/automattic.rb +292 -0
- data/checks/http/axinom.rb +30 -0
- data/checks/http/axios.rb +29 -0
- data/checks/http/axis.rb +27 -0
- data/checks/http/axway.rb +33 -0
- data/checks/http/backdrop.rb +30 -0
- data/checks/http/banu.rb +30 -0
- data/checks/http/barracuda.rb +99 -0
- data/checks/http/base.rb +139 -0
- data/checks/http/beehive.rb +30 -0
- data/checks/http/bigcartel.rb +33 -0
- data/checks/http/bigcommerce.rb +33 -0
- data/checks/http/binarysec.rb +47 -0
- data/checks/http/bitly.rb +40 -0
- data/checks/http/blackboard.rb +44 -0
- data/checks/http/blueimp.rb +27 -0
- data/checks/http/bomgar.rb +27 -0
- data/checks/http/bootstrap.rb +27 -0
- data/checks/http/bower.rb +28 -0
- data/checks/http/broadcom.rb +29 -0
- data/checks/http/brocade.rb +39 -0
- data/checks/http/browsermedia.rb +29 -0
- data/checks/http/bsm.rb +29 -0
- data/checks/http/bynder.rb +31 -0
- data/checks/http/calibre.rb +33 -0
- data/checks/http/centos.rb +28 -0
- data/checks/http/cerberus.rb +28 -0
- data/checks/http/charity_engine.rb +27 -0
- data/checks/http/checkpoint.rb +56 -0
- data/checks/http/cherokee.rb +29 -0
- data/checks/http/cisco.rb +134 -0
- data/checks/http/citrix.rb +137 -0
- data/checks/http/cloud_city.rb +30 -0
- data/checks/http/cloudflare.rb +219 -0
- data/checks/http/cmsimple.rb +30 -0
- data/checks/http/codeigniter.rb +26 -0
- data/checks/http/communigate.rb +32 -0
- data/checks/http/concrete5.rb +30 -0
- data/checks/http/contenido.rb +33 -0
- data/checks/http/content/analytics.rb +40 -0
- data/checks/http/content/authentication.rb +111 -0
- data/checks/http/content/content.rb +92 -0
- data/checks/http/content/security_headers.rb +70 -0
- data/checks/http/cpanel.rb +56 -0
- data/checks/http/cradlepoint.rb +30 -0
- data/checks/http/craft.rb +42 -0
- data/checks/http/crazydomains.rb +31 -0
- data/checks/http/crowdstrike.rb +27 -0
- data/checks/http/dan.rb +30 -0
- data/checks/http/danneo.rb +30 -0
- data/checks/http/day.rb +31 -0
- data/checks/http/debian.rb +27 -0
- data/checks/http/dell.rb +43 -0
- data/checks/http/dev_php.rb +30 -0
- data/checks/http/discourse.rb +30 -0
- data/checks/http/discuz!.rb +30 -0
- data/checks/http/distil.rb +27 -0
- data/checks/http/django.rb +27 -0
- data/checks/http/dmanager.rb +29 -0
- data/checks/http/dns_made_easy.rb +29 -0
- data/checks/http/docuwiki.rb +27 -0
- data/checks/http/docverify.rb +29 -0
- data/checks/http/domain_parking_ru.rb +31 -0
- data/checks/http/domainname_shop.rb +30 -0
- data/checks/http/dosarrest.rb +29 -0
- data/checks/http/dreamhost.rb +31 -0
- data/checks/http/drupal.rb +91 -0
- data/checks/http/duo.rb +45 -0
- data/checks/http/dyn.rb +41 -0
- data/checks/http/dynamicweb.rb +29 -0
- data/checks/http/dynatrace.rb +40 -0
- data/checks/http/easyname.rb +44 -0
- data/checks/http/eclipse.rb +64 -0
- data/checks/http/enservio.rb +29 -0
- data/checks/http/envoy.rb +26 -0
- data/checks/http/epiccom.rb +31 -0
- data/checks/http/ergon.rb +31 -0
- data/checks/http/expressjs.rb +27 -0
- data/checks/http/ezproxy.rb +28 -0
- data/checks/http/f5.rb +122 -0
- data/checks/http/facebook.rb +27 -0
- data/checks/http/fastly.rb +67 -0
- data/checks/http/first_domains.rb +31 -0
- data/checks/http/flywheel.rb +30 -0
- data/checks/http/forgerock.rb +43 -0
- data/checks/http/fortinet.rb +29 -0
- data/checks/http/fresh_service.rb +30 -0
- data/checks/http/frontify.rb +29 -0
- data/checks/http/generic.rb +272 -0
- data/checks/http/github.rb +40 -0
- data/checks/http/gitlab.rb +30 -0
- data/checks/http/glimpse.rb +32 -0
- data/checks/http/globalscape.rb +27 -0
- data/checks/http/goahead.rb +31 -0
- data/checks/http/godaddy.rb +31 -0
- data/checks/http/google.rb +164 -0
- data/checks/http/google_cloud.rb +27 -0
- data/checks/http/grafana.rb +27 -0
- data/checks/http/gunicorn.rb +30 -0
- data/checks/http/haskell.rb +31 -0
- data/checks/http/heroku.rb +77 -0
- data/checks/http/hikvision.rb +29 -0
- data/checks/http/hp.rb +27 -0
- data/checks/http/hubspot.rb +104 -0
- data/checks/http/ibm.rb +182 -0
- data/checks/http/icewarp.rb +29 -0
- data/checks/http/impresspages.rb +30 -0
- data/checks/http/imunify360.rb +28 -0
- data/checks/http/incapsula.rb +54 -0
- data/checks/http/ingram_micro.rb +28 -0
- data/checks/http/innovative_interfaces_inc.rb +27 -0
- data/checks/http/inside_sales.rb +27 -0
- data/checks/http/instra.rb +61 -0
- data/checks/http/intercom.rb +27 -0
- data/checks/http/ivanti.rb +28 -0
- data/checks/http/jamf.rb +31 -0
- data/checks/http/jekyll.rb +31 -0
- data/checks/http/jenkins.rb +59 -0
- data/checks/http/jetbrains.rb +27 -0
- data/checks/http/jetty.rb +27 -0
- data/checks/http/jforum.rb +27 -0
- data/checks/http/jitbit.rb +30 -0
- data/checks/http/jive.rb +27 -0
- data/checks/http/joomla.rb +43 -0
- data/checks/http/jquery.rb +58 -0
- data/checks/http/jupyter.rb +28 -0
- data/checks/http/kentico.rb +27 -0
- data/checks/http/kerio.rb +34 -0
- data/checks/http/kibana.rb +56 -0
- data/checks/http/kong.rb +32 -0
- data/checks/http/kubernetes.rb +66 -0
- data/checks/http/laravel.rb +27 -0
- data/checks/http/lastpass.rb +27 -0
- data/checks/http/lcn.rb +27 -0
- data/checks/http/leadpages.rb +29 -0
- data/checks/http/lighttpd.rb +31 -0
- data/checks/http/limelight_networks.rb +43 -0
- data/checks/http/limesuvey.rb +27 -0
- data/checks/http/link1.rb +31 -0
- data/checks/http/linksys.rb +38 -0
- data/checks/http/litespeed.rb +29 -0
- data/checks/http/lithium.rb +43 -0
- data/checks/http/lotus.rb +55 -0
- data/checks/http/magento.rb +96 -0
- data/checks/http/magnolia.rb +27 -0
- data/checks/http/mailchimp.rb +27 -0
- data/checks/http/manage_engine.rb +27 -0
- data/checks/http/markmonitor.rb +27 -0
- data/checks/http/mbf_bioscience.rb +29 -0
- data/checks/http/mcafee.rb +27 -0
- data/checks/http/media_temple.rb +27 -0
- data/checks/http/mediawiki.rb +54 -0
- data/checks/http/mhcsoftwareinc.rb +29 -0
- data/checks/http/microsoft.rb +1325 -0
- data/checks/http/mikrotik.rb +44 -0
- data/checks/http/modwsgi.rb +30 -0
- data/checks/http/mojolicious.rb +32 -0
- data/checks/http/moodle.rb +28 -0
- data/checks/http/mura.rb +30 -0
- data/checks/http/nagios.rb +27 -0
- data/checks/http/namesilo.rb +31 -0
- data/checks/http/nationbuilder.rb +30 -0
- data/checks/http/nec.rb +32 -0
- data/checks/http/netlify.rb +40 -0
- data/checks/http/netobjects_inc.rb +30 -0
- data/checks/http/netscape.rb +29 -0
- data/checks/http/neustar.rb +29 -0
- data/checks/http/new_relic.rb +27 -0
- data/checks/http/nexicom.rb +44 -0
- data/checks/http/nginx.rb +82 -0
- data/checks/http/nisource.rb +29 -0
- data/checks/http/nodejs.rb +79 -0
- data/checks/http/okta.rb +53 -0
- data/checks/http/ookla.rb +28 -0
- data/checks/http/openbsd.rb +30 -0
- data/checks/http/openresty.rb +41 -0
- data/checks/http/openscholar.rb +27 -0
- data/checks/http/opensolution.rb +46 -0
- data/checks/http/openssl.rb +43 -0
- data/checks/http/opentext.rb +46 -0
- data/checks/http/openvpn.rb +27 -0
- data/checks/http/opscode.rb +43 -0
- data/checks/http/oracle.rb +335 -0
- data/checks/http/orion_technology.rb +30 -0
- data/checks/http/ovh.rb +46 -0
- data/checks/http/palo_alto.rb +27 -0
- data/checks/http/pantheon.rb +54 -0
- data/checks/http/papercut.rb +29 -0
- data/checks/http/parallels.rb +44 -0
- data/checks/http/pardot.rb +44 -0
- data/checks/http/parkingcrew.rb +47 -0
- data/checks/http/pbworks.rb +27 -0
- data/checks/http/perfectsense.rb +28 -0
- data/checks/http/perl.rb +62 -0
- data/checks/http/pfsense.rb +27 -0
- data/checks/http/php.rb +72 -0
- data/checks/http/phpmyadmin.rb +40 -0
- data/checks/http/phpwind.rb +30 -0
- data/checks/http/phusion.rb +59 -0
- data/checks/http/ping_identity.rb +28 -0
- data/checks/http/pivotal_software.rb +97 -0
- data/checks/http/pjax.rb +40 -0
- data/checks/http/plesk.rb +58 -0
- data/checks/http/porkbun.rb +31 -0
- data/checks/http/progress.rb +30 -0
- data/checks/http/proofpoint.rb +30 -0
- data/checks/http/pulsesecure.rb +91 -0
- data/checks/http/python.rb +30 -0
- data/checks/http/qnap.rb +43 -0
- data/checks/http/qualys.rb +69 -0
- data/checks/http/rapid7.rb +27 -0
- data/checks/http/rbs.rb +30 -0
- data/checks/http/readmeio.rb +28 -0
- data/checks/http/red_hat.rb +95 -0
- data/checks/http/redmine.rb +38 -0
- data/checks/http/restlet.rb +30 -0
- data/checks/http/ritecms.rb +30 -0
- data/checks/http/roadiz.rb +30 -0
- data/checks/http/rock.rb +30 -0
- data/checks/http/rollbar.rb +27 -0
- data/checks/http/roundcube.rb +42 -0
- data/checks/http/ruby.rb +92 -0
- data/checks/http/ruckus_wireless.rb +26 -0
- data/checks/http/sailpoint.rb +30 -0
- data/checks/http/salesforce.rb +28 -0
- data/checks/http/sap.rb +149 -0
- data/checks/http/seamless_cms.rb +30 -0
- data/checks/http/securi.rb +54 -0
- data/checks/http/sedo.rb +63 -0
- data/checks/http/segment.rb +27 -0
- data/checks/http/sencha.rb +31 -0
- data/checks/http/sentry.rb +27 -0
- data/checks/http/serendipity.rb +30 -0
- data/checks/http/shopfactory.rb +30 -0
- data/checks/http/sip.rb +29 -0
- data/checks/http/sitecore.rb +39 -0
- data/checks/http/smartling.rb +27 -0
- data/checks/http/smf.rb +30 -0
- data/checks/http/snews.rb +30 -0
- data/checks/http/software_ag.rb +47 -0
- data/checks/http/soha.rb +66 -0
- data/checks/http/solarwinds.rb +41 -0
- data/checks/http/sonatype.rb +43 -0
- data/checks/http/sonicwall.rb +63 -0
- data/checks/http/sophos.rb +40 -0
- data/checks/http/southriver.rb +43 -0
- data/checks/http/splash.rb +29 -0
- data/checks/http/splunk.rb +27 -0
- data/checks/http/springfox.rb +43 -0
- data/checks/http/squarespace.rb +41 -0
- data/checks/http/stackpath.rb +29 -0
- data/checks/http/stibo_systems.rb +35 -0
- data/checks/http/subrion.rb +29 -0
- data/checks/http/symantec.rb +27 -0
- data/checks/http/synacor.rb +26 -0
- data/checks/http/tableau_software.rb +42 -0
- data/checks/http/telerik.rb +46 -0
- data/checks/http/tengine.rb +29 -0
- data/checks/http/tibco.rb +57 -0
- data/checks/http/townnews.rb +33 -0
- data/checks/http/tridium.rb +28 -0
- data/checks/http/twiki.rb +27 -0
- data/checks/http/typo3.rb +27 -0
- data/checks/http/uberflip.rb +28 -0
- data/checks/http/ucoz.rb +31 -0
- data/checks/http/umbraco.rb +29 -0
- data/checks/http/unbounce.rb +28 -0
- data/checks/http/united_domains.rb +27 -0
- data/checks/http/vanilla_forums.rb +27 -0
- data/checks/http/varnish.rb +79 -0
- data/checks/http/vbulletin.rb +66 -0
- data/checks/http/verizon.rb +27 -0
- data/checks/http/vmware.rb +53 -0
- data/checks/http/vue_js.rb +27 -0
- data/checks/http/webflow.rb +44 -0
- data/checks/http/webgui.rb +30 -0
- data/checks/http/webmin.rb +44 -0
- data/checks/http/webpagetest_project.rb +30 -0
- data/checks/http/wftpserver.rb +28 -0
- data/checks/http/wildfly.rb +29 -0
- data/checks/http/wix.rb +28 -0
- data/checks/http/woltlab_gmbh.rb +30 -0
- data/checks/http/wordpress/ithemes.rb +50 -0
- data/checks/http/wordpress/john_godley.rb +29 -0
- data/checks/http/wordpress/pixelcraft.rb +31 -0
- data/checks/http/wordpress/rocklobster.rb +29 -0
- data/checks/http/wordpress/team_heateor.rb +31 -0
- data/checks/http/wordpress/w3_total_cache.rb +30 -0
- data/checks/http/wordpress/wp_fastest_cache.rb +30 -0
- data/checks/http/wordpress/wp_super_cache.rb +46 -0
- data/checks/http/wordpress/wpbakery.rb +30 -0
- data/checks/http/world4you.rb +46 -0
- data/checks/http/wp_engine.rb +57 -0
- data/checks/http/xcms.rb +30 -0
- data/checks/http/xelion.rb +27 -0
- data/checks/http/xerox.rb +27 -0
- data/checks/http/xmb.rb +30 -0
- data/checks/http/xtec.rb +30 -0
- data/checks/http/yaf.rb +30 -0
- data/checks/http/yaws.rb +30 -0
- data/checks/http/yoast.rb +31 -0
- data/checks/http/zeit.rb +30 -0
- data/checks/http/zendesk.rb +41 -0
- data/checks/http/zengenti.rb +30 -0
- data/checks/http/zoho.rb +69 -0
- data/checks/http/zscaler.rb +30 -0
- data/checks/smtp/base.rb +16 -0
- data/checks/smtp/exim.rb +30 -0
- data/checks/snmp/base.rb +15 -0
- data/checks/snmp/cisco.rb +59 -0
- data/checks/ssh/array_networks.rb +28 -0
- data/checks/ssh/base.rb +16 -0
- data/checks/ssh/openssh.rb +26 -0
- data/checks/telnet/base.rb +16 -0
- data/checks/telnet/huawei.rb +26 -0
- data/data/logos/acquia.png +0 -0
- data/data/logos/amazon_cloudfront.png +0 -0
- data/data/logos/apache_coyote.png +0 -0
- data/data/logos/apache_tomcat.png +0 -0
- data/data/logos/atlassian_bamboo.png +0 -0
- data/data/logos/atlassian_bitbucket.png +0 -0
- data/data/logos/atlassian_confluence.png +0 -0
- data/data/logos/atlassian_crowd.png +0 -0
- data/data/logos/atlassian_crucible.png +0 -0
- data/data/logos/atlassian_fisheye.png +0 -0
- data/data/logos/atlassian_jira.png +0 -0
- data/data/logos/atlassian_sourcetree.png +0 -0
- data/data/logos/automattic_wordpress.png +0 -0
- data/data/logos/calibre.png +0 -0
- data/data/logos/cisco_ssl_vpn.png +0 -0
- data/data/logos/citrix_netscaler_gateway.png +0 -0
- data/data/logos/cloudflare_cdn.png +0 -0
- data/data/logos/drupal.png +0 -0
- data/data/logos/f5_big-ip.png +0 -0
- data/data/logos/f5_big-ip_apm.png +0 -0
- data/data/logos/fastly.png +0 -0
- data/data/logos/generic.png +0 -0
- data/data/logos/gitlab.png +0 -0
- data/data/logos/ibm_axway_securetransport.png +0 -0
- data/data/logos/lithium.png +0 -0
- data/data/logos/microsoft_asp.net.png +0 -0
- data/data/logos/microsoft_iis.png +0 -0
- data/data/logos/microsoft_outlook_web_access.png +0 -0
- data/data/logos/microsoft_sharepoint.png +0 -0
- data/data/logos/microtik_routeros.png +0 -0
- data/data/logos/mikrotik_routeros.png +0 -0
- data/data/logos/newrelic.png +0 -0
- data/data/logos/nginx.png +0 -0
- data/data/logos/okta.png +0 -0
- data/data/logos/oracle_glassfish.png +0 -0
- data/data/logos/oracle_java_application_server.png +0 -0
- data/data/logos/oracle_java_server_pages.png +0 -0
- data/data/logos/oracle_weblogic.png +0 -0
- data/data/logos/phpmyadmin.png +0 -0
- data/data/logos/tableau.png +0 -0
- data/data/logos/vmware_esxi.png +0 -0
- data/data/logos/vmware_horizon.png +0 -0
- data/data/logos/zendesk.png +0 -0
- data/data/logos/zimbra_server.png +0 -0
- data/data/microsoft_sharepoint_versions.csv +224 -0
- data/intrigue-ident.gemspec +8 -7
- data/lib/banner_helpers.rb +36 -0
- data/lib/ftp/check_factory.rb +24 -0
- data/lib/ftp/content.rb +13 -0
- data/lib/ftp/ftp.rb +52 -0
- data/lib/ftp/matchers.rb +26 -0
- data/lib/http/browser.rb +260 -0
- data/lib/http/check_factory.rb +47 -0
- data/lib/http/content.rb +45 -0
- data/lib/http/http.rb +463 -0
- data/lib/http/matchers.rb +132 -0
- data/lib/ident.rb +263 -0
- data/lib/recog_wrapper.rb +70 -0
- data/lib/simple_socket.rb +41 -0
- data/lib/smtp/check_factory.rb +24 -0
- data/lib/smtp/content.rb +13 -0
- data/lib/smtp/matchers.rb +28 -0
- data/lib/smtp/smtp.rb +53 -0
- data/lib/snmp/check_factory.rb +24 -0
- data/lib/snmp/content.rb +13 -0
- data/lib/snmp/matchers.rb +25 -0
- data/lib/snmp/snmp.rb +55 -0
- data/lib/ssh/check_factory.rb +24 -0
- data/lib/ssh/content.rb +13 -0
- data/lib/ssh/matchers.rb +26 -0
- data/lib/ssh/ssh.rb +52 -0
- data/lib/telnet/check_factory.rb +24 -0
- data/lib/telnet/content.rb +13 -0
- data/lib/telnet/matchers.rb +26 -0
- data/lib/telnet/telnet.rb +52 -0
- data/lib/utils.rb +19 -0
- data/lib/version.rb +3 -0
- data/lib/vulndb_client.rb +43 -0
- data/util/console.rb +9 -0
- data/util/docker.sh +2 -0
- data/util/ident.rb +375 -0
- data/util/list_paths.rb +12 -0
- data/util/tags.rb +36 -0
- data/utils.rb +19 -0
- metadata +487 -55
- data/ident.rb +0 -319
- data/lib/check_factory.rb +0 -22
- data/lib/checks/akamai.rb +0 -22
- data/lib/checks/amazon.rb +0 -26
- data/lib/checks/aruba.rb +0 -20
- data/lib/checks/asp_net.rb +0 -70
- data/lib/checks/atlassian.rb +0 -55
- data/lib/checks/base.rb +0 -13
- data/lib/checks/chef.rb +0 -31
- data/lib/checks/cisco.rb +0 -33
- data/lib/checks/citrix.rb +0 -24
- data/lib/checks/cloudflare.rb +0 -59
- data/lib/checks/cloudfront.rb +0 -41
- data/lib/checks/cpanel.rb +0 -23
- data/lib/checks/django.rb +0 -22
- data/lib/checks/drupal.rb +0 -26
- data/lib/checks/f5.rb +0 -24
- data/lib/checks/fastly.rb +0 -22
- data/lib/checks/generic.rb +0 -23
- data/lib/checks/gitlab.rb +0 -22
- data/lib/checks/google.rb +0 -23
- data/lib/checks/grafana.rb +0 -22
- data/lib/checks/jenkins.rb +0 -40
- data/lib/checks/joomla.rb +0 -23
- data/lib/checks/limesuvey.rb +0 -22
- data/lib/checks/lithium.rb +0 -30
- data/lib/checks/magento.rb +0 -22
- data/lib/checks/mcafee.rb +0 -22
- data/lib/checks/mediawiki.rb +0 -38
- data/lib/checks/microsoft.rb +0 -69
- data/lib/checks/nagios.rb +0 -22
- data/lib/checks/oracle.rb +0 -38
- data/lib/checks/palo_alto.rb +0 -23
- data/lib/checks/pardot.rb +0 -22
- data/lib/checks/pfsense.rb +0 -25
- data/lib/checks/phpmyadmin.rb +0 -22
- data/lib/checks/rabbitmq.rb +0 -29
- data/lib/checks/spring.rb +0 -31
- data/lib/checks/team_city.rb +0 -22
- data/lib/checks/telerik.rb +0 -25
- data/lib/checks/tomcat.rb +0 -22
- data/lib/checks/varnish.rb +0 -27
- data/lib/checks/wordpress.rb +0 -120
- data/lib/checks/wp_engine.rb +0 -22
@@ -0,0 +1,31 @@
|
|
1
|
+
module Intrigue
|
2
|
+
module Ident
|
3
|
+
module Check
|
4
|
+
class Porkbun < Intrigue::Ident::Check::Base
|
5
|
+
|
6
|
+
def generate_checks(url)
|
7
|
+
[
|
8
|
+
{
|
9
|
+
:type => "fingerprint",
|
10
|
+
:category => "service",
|
11
|
+
:tags => ["Parked"],
|
12
|
+
:vendor => "Porkbun",
|
13
|
+
:product => "Porkbun",
|
14
|
+
:website => "ttps://porkbun.com/h",
|
15
|
+
:references => [],
|
16
|
+
:version => nil,
|
17
|
+
:match_type => :content_body,
|
18
|
+
:match_content => /but the owner has not put up a site yet. Visit again soon to see what amazing website they decide to build./i,
|
19
|
+
:match_details => "unique body string",
|
20
|
+
:hide => false,
|
21
|
+
:paths => ["#{url}"],
|
22
|
+
:inference => false
|
23
|
+
}
|
24
|
+
]
|
25
|
+
end
|
26
|
+
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
@@ -0,0 +1,30 @@
|
|
1
|
+
module Intrigue
|
2
|
+
module Ident
|
3
|
+
module Check
|
4
|
+
class ProgressCMS < Intrigue::Ident::Check::Base
|
5
|
+
|
6
|
+
def generate_checks(url)
|
7
|
+
[
|
8
|
+
{
|
9
|
+
:type => "fingerprint",
|
10
|
+
:category => "application",
|
11
|
+
:tags => ["CMS"],
|
12
|
+
:vendor => "Progress",
|
13
|
+
:product => "Sitefinity",
|
14
|
+
:references => ["https://www.progress.com/sitefinity-cms"],
|
15
|
+
:version => nil,
|
16
|
+
:match_type => :content_body,
|
17
|
+
:match_content => /sitefinity (.\d*.\d*.\d*.\d*)/i,
|
18
|
+
:dynamic_version => lambda { |x| _first_body_capture(x, /sitefinity (.\d*.\d*.\d*.\d*)/i)},
|
19
|
+
:match_details => "header match",
|
20
|
+
:hide => false,
|
21
|
+
:paths => ["#{url}"],
|
22
|
+
:inference => true
|
23
|
+
}
|
24
|
+
]
|
25
|
+
end
|
26
|
+
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
module Intrigue
|
2
|
+
module Ident
|
3
|
+
module Check
|
4
|
+
class Proofpoint < Intrigue::Ident::Check::Base
|
5
|
+
|
6
|
+
def generate_checks(url)
|
7
|
+
[
|
8
|
+
{
|
9
|
+
:type => "fingerprint",
|
10
|
+
:category => "application",
|
11
|
+
:tags => ["COTS", "Security"],
|
12
|
+
:vendor => "Proofpoint",
|
13
|
+
:product => "Protection Server",
|
14
|
+
:references => ["https://www.proofpoint.com/us/resources/data-sheets/protection-server-technical-brief"],
|
15
|
+
:version => nil,
|
16
|
+
:match_type => :content_title,
|
17
|
+
:match_content => /^Proofpoint Protection Server$/i,
|
18
|
+
:match_details => "title",
|
19
|
+
:hide => false,
|
20
|
+
:paths => ["#{url}"],
|
21
|
+
:inference => false
|
22
|
+
}
|
23
|
+
]
|
24
|
+
end
|
25
|
+
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
@@ -0,0 +1,91 @@
|
|
1
|
+
module Intrigue
|
2
|
+
module Ident
|
3
|
+
module Check
|
4
|
+
class PulseSecure < Intrigue::Ident::Check::Base
|
5
|
+
|
6
|
+
def generate_checks(url)
|
7
|
+
[
|
8
|
+
{
|
9
|
+
:type => "fingerprint",
|
10
|
+
:category => "application",
|
11
|
+
:tags => ["Networking", "VPN"],
|
12
|
+
:vendor =>"PulseSecure",
|
13
|
+
:product =>"Pulse Connect Secure",
|
14
|
+
:match_details => "page title",
|
15
|
+
:match_type => :content_title,
|
16
|
+
:references => [],
|
17
|
+
:match_content => /^Junos Pulse Secure Access Service$/,
|
18
|
+
:version => nil,
|
19
|
+
:paths => ["#{url}"],
|
20
|
+
:inference => false
|
21
|
+
},
|
22
|
+
{
|
23
|
+
:type => "fingerprint",
|
24
|
+
:category => "application",
|
25
|
+
:tags => ["Networking", "VPN"],
|
26
|
+
:vendor =>"PulseSecure",
|
27
|
+
:product =>"Pulse Connect Secure",
|
28
|
+
:match_details => "page title",
|
29
|
+
:match_type => :content_title,
|
30
|
+
:references => [],
|
31
|
+
:match_content => /^Pulse Connect Secure$/,
|
32
|
+
:version => nil,
|
33
|
+
:paths => ["#{url}"],
|
34
|
+
:inference => false
|
35
|
+
},
|
36
|
+
{
|
37
|
+
:type => "fingerprint",
|
38
|
+
:category => "application",
|
39
|
+
:tags => ["Networking", "VPN"],
|
40
|
+
:vendor =>"PulseSecure",
|
41
|
+
:product =>"Pulse Connect Secure",
|
42
|
+
:match_details => "unique image link",
|
43
|
+
:references => [
|
44
|
+
"https://kb.pulsesecure.net/articles/Pulse_Secure_Article/KB40250",
|
45
|
+
"https://github.com/carnal0wnage/Metasploit-Code/blob/master/modules/auxiliary/scanner/juniper_scan.rb",
|
46
|
+
"http://carnal0wnage.attackresearch.com/2013/05/funky-juniper-urls.html" #<^ TODO ... task?
|
47
|
+
],
|
48
|
+
:match_type => :content_body,
|
49
|
+
:match_content => /<td background="\/dana-na\/imgs\/footerbg.gif">/,
|
50
|
+
:version => nil,
|
51
|
+
:paths => ["#{url}"],
|
52
|
+
:inference => false
|
53
|
+
},
|
54
|
+
{
|
55
|
+
:type => "fingerprint",
|
56
|
+
:category => "application",
|
57
|
+
:tags => ["Networking", "VPN"],
|
58
|
+
:vendor =>"PulseSecure",
|
59
|
+
:product =>"Pulse Connect Secure",
|
60
|
+
:match_details => "unique css link",
|
61
|
+
:references => [],
|
62
|
+
:match_type => :content_body,
|
63
|
+
:match_content => /src=\"\/dana-na\/css\/ds.js\">/,
|
64
|
+
:version => nil,
|
65
|
+
:paths => ["#{url}"],
|
66
|
+
:inference => false
|
67
|
+
},
|
68
|
+
{
|
69
|
+
:depends => [{:product => "Pulse Connect Secure"}],
|
70
|
+
:type => "fingerprint",
|
71
|
+
:category => "application",
|
72
|
+
:tags => ["Networking", "VPN"],
|
73
|
+
:vendor =>"PulseSecure",
|
74
|
+
:product =>"Pulse Connect Secure",
|
75
|
+
:match_details => "info disclosure in nc_gina_ver.txt",
|
76
|
+
:references => ["https://know.bishopfox.com/blog/breaching-the-trusted-perimeter"],
|
77
|
+
:match_type => :content_body,
|
78
|
+
:match_content => /DSSETUP_BUILD_VERSION/,
|
79
|
+
:version => nil,
|
80
|
+
:dynamic_version => lambda{|x| _first_body_capture(x,/VALUE=\"Pulse Secure Network Connect ([\d\.]+)/i) },
|
81
|
+
:paths => ["#{url}/dana-na/nc/nc_gina_ver.txt"],
|
82
|
+
:require_product => "Junos Pulse Secure Access Service",
|
83
|
+
:inference => true
|
84
|
+
}
|
85
|
+
]
|
86
|
+
end
|
87
|
+
|
88
|
+
end
|
89
|
+
end
|
90
|
+
end
|
91
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
|
2
|
+
module Intrigue
|
3
|
+
module Ident
|
4
|
+
module Check
|
5
|
+
class Python < Intrigue::Ident::Check::Base
|
6
|
+
|
7
|
+
def generate_checks(url)
|
8
|
+
[
|
9
|
+
{
|
10
|
+
:type => "fingerprint",
|
11
|
+
:category => "application",
|
12
|
+
:tags => ["Web Framework"],
|
13
|
+
:vendor => "Python",
|
14
|
+
:product =>"Python",
|
15
|
+
:match_details =>"server header",
|
16
|
+
:version => nil,
|
17
|
+
:match_type => :content_headers,
|
18
|
+
:match_content => /^server:.*Python.*$/,
|
19
|
+
:dynamic_version => lambda{|x|
|
20
|
+
_first_header_capture(x,/^server:.*Python\/([\d\.]*)\s.*$/i) },
|
21
|
+
:paths => ["#{url}"],
|
22
|
+
:inference => true
|
23
|
+
}
|
24
|
+
]
|
25
|
+
end
|
26
|
+
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
data/checks/http/qnap.rb
ADDED
@@ -0,0 +1,43 @@
|
|
1
|
+
module Intrigue
|
2
|
+
module Ident
|
3
|
+
module Check
|
4
|
+
class Qnap < Intrigue::Ident::Check::Base
|
5
|
+
|
6
|
+
def generate_checks(url)
|
7
|
+
[
|
8
|
+
{
|
9
|
+
:type => "fingerprint",
|
10
|
+
:category => "hardware",
|
11
|
+
:tags => ["Embedded", "IoT", "Appliance", "NAS"],
|
12
|
+
:vendor => "QNAP",
|
13
|
+
:product => "QTS",
|
14
|
+
:match_details => "unique string",
|
15
|
+
:version => nil,
|
16
|
+
:match_type => :content_body,
|
17
|
+
:match_content => /Shone added for detecting default system language when no cookie has been set/i,
|
18
|
+
:paths => ["#{url}"],
|
19
|
+
:inference => false
|
20
|
+
},
|
21
|
+
{
|
22
|
+
:type => "fingerprint",
|
23
|
+
:category => "hardware",
|
24
|
+
:tags => ["Embedded", "IoT", "Appliance", "NAS"],
|
25
|
+
:vendor => "QNAP",
|
26
|
+
:product => "QTS",
|
27
|
+
:match_details => "firmware version on handy cgi page",
|
28
|
+
:version => nil,
|
29
|
+
:dynamic_version => lambda { |x|
|
30
|
+
_first_body_capture(x,%r{<version><!\[CDATA\[([\d\.]*)\]\]></version>})
|
31
|
+
},
|
32
|
+
:match_type => :content_body,
|
33
|
+
:match_content => /QDocRoot/,
|
34
|
+
:paths => ["#{url}/cgi-bin/authLogin.cgi"],
|
35
|
+
:require_product => "QTS",
|
36
|
+
:inference => true
|
37
|
+
}
|
38
|
+
]
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
@@ -0,0 +1,69 @@
|
|
1
|
+
|
2
|
+
module Intrigue
|
3
|
+
module Ident
|
4
|
+
module Check
|
5
|
+
class Qualys < Intrigue::Ident::Check::Base
|
6
|
+
|
7
|
+
def generate_checks(url)
|
8
|
+
[
|
9
|
+
{
|
10
|
+
:type => "fingerprint",
|
11
|
+
:category => "service",
|
12
|
+
:tags => ["Security"],
|
13
|
+
:vendor =>"Qualys",
|
14
|
+
:product =>"QualysGuard",
|
15
|
+
:match_details =>"custom server header",
|
16
|
+
:version => nil,
|
17
|
+
:match_type => :content_headers,
|
18
|
+
:match_content => /^server: Qualys$/i,
|
19
|
+
:paths => ["#{url}"],
|
20
|
+
:inference => false
|
21
|
+
},
|
22
|
+
{
|
23
|
+
:type => "fingerprint",
|
24
|
+
:category => "service",
|
25
|
+
:tags => ["Security"],
|
26
|
+
:vendor =>"Qualys",
|
27
|
+
:product =>"QualysGuard",
|
28
|
+
:match_details =>"custom server header",
|
29
|
+
:version => nil,
|
30
|
+
:match_type => :content_headers,
|
31
|
+
:match_content => /^server: qweb\/.*$/i,
|
32
|
+
:dynamic_version => lambda { |x| _first_header_capture(x, /^server: qweb\/(.*)$/i)},
|
33
|
+
:paths => ["#{url}"],
|
34
|
+
:inference => true
|
35
|
+
},
|
36
|
+
{
|
37
|
+
:type => "fingerprint",
|
38
|
+
:category => "service",
|
39
|
+
:tags => ["Security"],
|
40
|
+
:vendor =>"Qualys",
|
41
|
+
:product =>"Qualys Mobility",
|
42
|
+
:match_details =>"custom server header",
|
43
|
+
:version => nil,
|
44
|
+
:match_type => :content_headers,
|
45
|
+
:match_content => /^server: QMProprietary$/i,
|
46
|
+
:paths => ["#{url}"],
|
47
|
+
:inference => false
|
48
|
+
},
|
49
|
+
{
|
50
|
+
:type => "fingerprint",
|
51
|
+
:category => "service",
|
52
|
+
:tags => ["Security"],
|
53
|
+
:vendor =>"Qualys",
|
54
|
+
:product =>"Qualys Mobility",
|
55
|
+
:match_details =>"custom server header",
|
56
|
+
:version => nil,
|
57
|
+
:match_type => :content_cookies,
|
58
|
+
:match_content => /QualysSession=/i,
|
59
|
+
:paths => ["#{url}"],
|
60
|
+
:inference => false
|
61
|
+
}
|
62
|
+
]
|
63
|
+
end
|
64
|
+
|
65
|
+
end
|
66
|
+
end
|
67
|
+
end
|
68
|
+
end
|
69
|
+
|
@@ -0,0 +1,27 @@
|
|
1
|
+
module Intrigue
|
2
|
+
module Ident
|
3
|
+
module Check
|
4
|
+
class Rapid7 < Intrigue::Ident::Check::Base
|
5
|
+
|
6
|
+
def generate_checks(url)
|
7
|
+
[
|
8
|
+
{
|
9
|
+
:type => "fingerprint",
|
10
|
+
:category => "service",
|
11
|
+
:tags => ["SaaS"],
|
12
|
+
:vendor =>"Rapid7",
|
13
|
+
:product =>"Logentries",
|
14
|
+
:match_details =>"server header",
|
15
|
+
:references => [],
|
16
|
+
:match_type => :content_headers,
|
17
|
+
:match_content => /server: th3 c4k3 is 4 l13\.$/i,
|
18
|
+
:paths => ["#{url}"],
|
19
|
+
:inference => false
|
20
|
+
}
|
21
|
+
]
|
22
|
+
end
|
23
|
+
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
data/checks/http/rbs.rb
ADDED
@@ -0,0 +1,30 @@
|
|
1
|
+
module Intrigue
|
2
|
+
module Ident
|
3
|
+
module Check
|
4
|
+
class RbsCMS < Intrigue::Ident::Check::Base
|
5
|
+
|
6
|
+
def generate_checks(url)
|
7
|
+
[
|
8
|
+
{
|
9
|
+
:type => "fingerprint",
|
10
|
+
:category => "application",
|
11
|
+
:tags => ["CMS"],
|
12
|
+
:vendor => "RBS",
|
13
|
+
:product => "RBS Change",
|
14
|
+
:references => ["https://www.rbschange.fr/"],
|
15
|
+
:version => nil,
|
16
|
+
:match_type => :content_body,
|
17
|
+
:match_content => /RBS Change ([\d\.]+)/i,
|
18
|
+
:dynamic_version => lambda { |x| _first_body_capture(x, /RBS Change ([\d\.]+)/i)},
|
19
|
+
:match_details => "header match",
|
20
|
+
:hide => false,
|
21
|
+
:paths => ["#{url}"],
|
22
|
+
:inference => true
|
23
|
+
}
|
24
|
+
]
|
25
|
+
end
|
26
|
+
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
|
2
|
+
module Intrigue
|
3
|
+
module Ident
|
4
|
+
module Check
|
5
|
+
class Readmeio < Intrigue::Ident::Check::Base
|
6
|
+
|
7
|
+
def generate_checks(url)
|
8
|
+
[
|
9
|
+
{
|
10
|
+
:type => "fingerprint",
|
11
|
+
:category => "service",
|
12
|
+
:tags => ["Javascript", "SaaS", "Support"],
|
13
|
+
:vendor =>"Readme.io",
|
14
|
+
:product =>"Readme.io",
|
15
|
+
:match_details =>"js load string",
|
16
|
+
:version => nil,
|
17
|
+
:match_type => :content_body,
|
18
|
+
:match_content => /cdn.readme.io\/js\/bundle-hub2.js/i,
|
19
|
+
:paths => ["#{url}"],
|
20
|
+
:inference => false
|
21
|
+
}
|
22
|
+
]
|
23
|
+
end
|
24
|
+
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
@@ -0,0 +1,95 @@
|
|
1
|
+
module Intrigue
|
2
|
+
module Ident
|
3
|
+
module Check
|
4
|
+
class RedHat < Intrigue::Ident::Check::Base
|
5
|
+
|
6
|
+
def generate_checks(url)
|
7
|
+
[
|
8
|
+
#
|
9
|
+
{ # server: Apache/2.4.6 (Red Hat Enterprise Linux) OpenSSL/1.0.2k-fips PHP/7.2.12
|
10
|
+
:type => "fingerprint",
|
11
|
+
:category => "operating_system",
|
12
|
+
:tags => ["OS"],
|
13
|
+
:vendor =>"Red Hat",
|
14
|
+
:product =>"Enterprise Linux",
|
15
|
+
:match_details =>"nginx test page",
|
16
|
+
:match_type => :content_headers,
|
17
|
+
:match_content => /^Apache.* \(Red Hat Enterprise Linux\).*$/i,
|
18
|
+
:paths => ["#{url}"],
|
19
|
+
:inference => false
|
20
|
+
},
|
21
|
+
{
|
22
|
+
:type => "fingerprint",
|
23
|
+
:category => "operating_system",
|
24
|
+
:tags => ["OS"],
|
25
|
+
:vendor =>"Red Hat",
|
26
|
+
:product =>"Fedora Linux",
|
27
|
+
:match_details =>"nginx test page",
|
28
|
+
:match_type => :content_title,
|
29
|
+
:match_content => /^Test Page for the Nginx HTTP Server on Fedora$/i,
|
30
|
+
:paths => ["#{url}"],
|
31
|
+
:inference => false
|
32
|
+
},
|
33
|
+
{
|
34
|
+
:type => "fingerprint",
|
35
|
+
:category => "application",
|
36
|
+
:tags => ["Development", "Administrative", "Hypervisor"],
|
37
|
+
:vendor =>"Red Hat",
|
38
|
+
:product =>"OpenShift Container Platform",
|
39
|
+
:match_details =>"error message in html",
|
40
|
+
:references => ["https://bugzilla.redhat.com/show_bug.cgi?id=1414657"],
|
41
|
+
:match_type => :content_body,
|
42
|
+
:match_content => /Route and path matches, but all pods are down./i,
|
43
|
+
:paths => ["#{url}"],
|
44
|
+
:inference => false
|
45
|
+
},
|
46
|
+
{
|
47
|
+
:type => "fingerprint",
|
48
|
+
:category => "application",
|
49
|
+
:tags => ["Development", "Administrative", "Hypervisor"],
|
50
|
+
:vendor =>"Red Hat",
|
51
|
+
:product =>"OpenShift Container Platform",
|
52
|
+
:match_details =>"title",
|
53
|
+
:references => [""],
|
54
|
+
:match_type => :content_title,
|
55
|
+
:match_content => /Login - OpenShift Origin/i,
|
56
|
+
:paths => ["#{url}"],
|
57
|
+
:inference => false
|
58
|
+
},
|
59
|
+
{
|
60
|
+
:type => "fingerprint",
|
61
|
+
:category => "application",
|
62
|
+
:tags => ["Application Server"],
|
63
|
+
:vendor => "Red Hat",
|
64
|
+
:product => "JBoss Core Services",
|
65
|
+
:references => ["https://www.redhat.com/en/resources/jboss-core-services-collection-datasheet"],
|
66
|
+
:version => nil,
|
67
|
+
:match_type => :content_headers,
|
68
|
+
:match_content => /^Server:\ JBCS\ httpd$/i,
|
69
|
+
:dynamic_version => lambda { |x|
|
70
|
+
_first_header_capture(x,/^Server:\ JBCS\ httpd$/i) },
|
71
|
+
:hide => false,
|
72
|
+
:paths => ["#{url}"],
|
73
|
+
:inference => false
|
74
|
+
},
|
75
|
+
{
|
76
|
+
:type => "fingerprint",
|
77
|
+
:category => "application",
|
78
|
+
:tags => ["Application Server"],
|
79
|
+
:vendor => "Red Hat",
|
80
|
+
:product => "JBoss Enterprise Application Platform",
|
81
|
+
:references => ["https://bugzilla.redhat.com/show_bug.cgi?id=1049103"],
|
82
|
+
:version => nil,
|
83
|
+
:match_type => :content_headers,
|
84
|
+
:match_content => /X-Powered-By: JSP\/2./i,
|
85
|
+
:hide => false,
|
86
|
+
:paths => ["#{url}"],
|
87
|
+
:inference => false
|
88
|
+
}
|
89
|
+
]
|
90
|
+
end
|
91
|
+
|
92
|
+
end
|
93
|
+
end
|
94
|
+
end
|
95
|
+
end
|