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.
Files changed (484) hide show
  1. checksums.yaml +4 -4
  2. data/.circleci/config.yml +21 -0
  3. data/.gitignore +3 -0
  4. data/.ruby-version +1 -0
  5. data/Dockerfile +39 -0
  6. data/Gemfile +10 -3
  7. data/Gemfile.lock +35 -20
  8. data/LICENSE.md +12 -0
  9. data/README.md +79 -0
  10. data/checks/ftp/base.rb +15 -0
  11. data/checks/ftp/filezilla.rb +28 -0
  12. data/checks/ftp/microsoft.rb +27 -0
  13. data/checks/ftp/proftp.rb +28 -0
  14. data/checks/ftp/pureftpd.rb +27 -0
  15. data/checks/ftp/vsftp.rb +28 -0
  16. data/checks/http/123reg.rb +31 -0
  17. data/checks/http/acme.rb +28 -0
  18. data/checks/http/acquia.rb +28 -0
  19. data/checks/http/adeptia.rb +30 -0
  20. data/checks/http/adobe.rb +168 -0
  21. data/checks/http/advantshop.rb +33 -0
  22. data/checks/http/afrihost.rb +29 -0
  23. data/checks/http/aftermarketpl.rb +46 -0
  24. data/checks/http/agility.rb +34 -0
  25. data/checks/http/akamai.rb +88 -0
  26. data/checks/http/alkacon.rb +30 -0
  27. data/checks/http/allegro.rb +28 -0
  28. data/checks/http/almuba.rb +30 -0
  29. data/checks/http/amazon.rb +263 -0
  30. data/checks/http/amirocms.rb +30 -0
  31. data/checks/http/anelectron.rb +29 -0
  32. data/checks/http/anquanbao.rb +32 -0
  33. data/checks/http/aol.rb +29 -0
  34. data/checks/http/apache.rb +358 -0
  35. data/checks/http/appdynamics.rb +43 -0
  36. data/checks/http/arris.rb +30 -0
  37. data/checks/http/artifactory.rb +30 -0
  38. data/checks/http/aruba.rb +27 -0
  39. data/checks/http/atlassian.rb +152 -0
  40. data/checks/http/auth0.rb +44 -0
  41. data/checks/http/automattic.rb +292 -0
  42. data/checks/http/axinom.rb +30 -0
  43. data/checks/http/axios.rb +29 -0
  44. data/checks/http/axis.rb +27 -0
  45. data/checks/http/axway.rb +33 -0
  46. data/checks/http/backdrop.rb +30 -0
  47. data/checks/http/banu.rb +30 -0
  48. data/checks/http/barracuda.rb +99 -0
  49. data/checks/http/base.rb +139 -0
  50. data/checks/http/beehive.rb +30 -0
  51. data/checks/http/bigcartel.rb +33 -0
  52. data/checks/http/bigcommerce.rb +33 -0
  53. data/checks/http/binarysec.rb +47 -0
  54. data/checks/http/bitly.rb +40 -0
  55. data/checks/http/blackboard.rb +44 -0
  56. data/checks/http/blueimp.rb +27 -0
  57. data/checks/http/bomgar.rb +27 -0
  58. data/checks/http/bootstrap.rb +27 -0
  59. data/checks/http/bower.rb +28 -0
  60. data/checks/http/broadcom.rb +29 -0
  61. data/checks/http/brocade.rb +39 -0
  62. data/checks/http/browsermedia.rb +29 -0
  63. data/checks/http/bsm.rb +29 -0
  64. data/checks/http/bynder.rb +31 -0
  65. data/checks/http/calibre.rb +33 -0
  66. data/checks/http/centos.rb +28 -0
  67. data/checks/http/cerberus.rb +28 -0
  68. data/checks/http/charity_engine.rb +27 -0
  69. data/checks/http/checkpoint.rb +56 -0
  70. data/checks/http/cherokee.rb +29 -0
  71. data/checks/http/cisco.rb +134 -0
  72. data/checks/http/citrix.rb +137 -0
  73. data/checks/http/cloud_city.rb +30 -0
  74. data/checks/http/cloudflare.rb +219 -0
  75. data/checks/http/cmsimple.rb +30 -0
  76. data/checks/http/codeigniter.rb +26 -0
  77. data/checks/http/communigate.rb +32 -0
  78. data/checks/http/concrete5.rb +30 -0
  79. data/checks/http/contenido.rb +33 -0
  80. data/checks/http/content/analytics.rb +40 -0
  81. data/checks/http/content/authentication.rb +111 -0
  82. data/checks/http/content/content.rb +92 -0
  83. data/checks/http/content/security_headers.rb +70 -0
  84. data/checks/http/cpanel.rb +56 -0
  85. data/checks/http/cradlepoint.rb +30 -0
  86. data/checks/http/craft.rb +42 -0
  87. data/checks/http/crazydomains.rb +31 -0
  88. data/checks/http/crowdstrike.rb +27 -0
  89. data/checks/http/dan.rb +30 -0
  90. data/checks/http/danneo.rb +30 -0
  91. data/checks/http/day.rb +31 -0
  92. data/checks/http/debian.rb +27 -0
  93. data/checks/http/dell.rb +43 -0
  94. data/checks/http/dev_php.rb +30 -0
  95. data/checks/http/discourse.rb +30 -0
  96. data/checks/http/discuz!.rb +30 -0
  97. data/checks/http/distil.rb +27 -0
  98. data/checks/http/django.rb +27 -0
  99. data/checks/http/dmanager.rb +29 -0
  100. data/checks/http/dns_made_easy.rb +29 -0
  101. data/checks/http/docuwiki.rb +27 -0
  102. data/checks/http/docverify.rb +29 -0
  103. data/checks/http/domain_parking_ru.rb +31 -0
  104. data/checks/http/domainname_shop.rb +30 -0
  105. data/checks/http/dosarrest.rb +29 -0
  106. data/checks/http/dreamhost.rb +31 -0
  107. data/checks/http/drupal.rb +91 -0
  108. data/checks/http/duo.rb +45 -0
  109. data/checks/http/dyn.rb +41 -0
  110. data/checks/http/dynamicweb.rb +29 -0
  111. data/checks/http/dynatrace.rb +40 -0
  112. data/checks/http/easyname.rb +44 -0
  113. data/checks/http/eclipse.rb +64 -0
  114. data/checks/http/enservio.rb +29 -0
  115. data/checks/http/envoy.rb +26 -0
  116. data/checks/http/epiccom.rb +31 -0
  117. data/checks/http/ergon.rb +31 -0
  118. data/checks/http/expressjs.rb +27 -0
  119. data/checks/http/ezproxy.rb +28 -0
  120. data/checks/http/f5.rb +122 -0
  121. data/checks/http/facebook.rb +27 -0
  122. data/checks/http/fastly.rb +67 -0
  123. data/checks/http/first_domains.rb +31 -0
  124. data/checks/http/flywheel.rb +30 -0
  125. data/checks/http/forgerock.rb +43 -0
  126. data/checks/http/fortinet.rb +29 -0
  127. data/checks/http/fresh_service.rb +30 -0
  128. data/checks/http/frontify.rb +29 -0
  129. data/checks/http/generic.rb +272 -0
  130. data/checks/http/github.rb +40 -0
  131. data/checks/http/gitlab.rb +30 -0
  132. data/checks/http/glimpse.rb +32 -0
  133. data/checks/http/globalscape.rb +27 -0
  134. data/checks/http/goahead.rb +31 -0
  135. data/checks/http/godaddy.rb +31 -0
  136. data/checks/http/google.rb +164 -0
  137. data/checks/http/google_cloud.rb +27 -0
  138. data/checks/http/grafana.rb +27 -0
  139. data/checks/http/gunicorn.rb +30 -0
  140. data/checks/http/haskell.rb +31 -0
  141. data/checks/http/heroku.rb +77 -0
  142. data/checks/http/hikvision.rb +29 -0
  143. data/checks/http/hp.rb +27 -0
  144. data/checks/http/hubspot.rb +104 -0
  145. data/checks/http/ibm.rb +182 -0
  146. data/checks/http/icewarp.rb +29 -0
  147. data/checks/http/impresspages.rb +30 -0
  148. data/checks/http/imunify360.rb +28 -0
  149. data/checks/http/incapsula.rb +54 -0
  150. data/checks/http/ingram_micro.rb +28 -0
  151. data/checks/http/innovative_interfaces_inc.rb +27 -0
  152. data/checks/http/inside_sales.rb +27 -0
  153. data/checks/http/instra.rb +61 -0
  154. data/checks/http/intercom.rb +27 -0
  155. data/checks/http/ivanti.rb +28 -0
  156. data/checks/http/jamf.rb +31 -0
  157. data/checks/http/jekyll.rb +31 -0
  158. data/checks/http/jenkins.rb +59 -0
  159. data/checks/http/jetbrains.rb +27 -0
  160. data/checks/http/jetty.rb +27 -0
  161. data/checks/http/jforum.rb +27 -0
  162. data/checks/http/jitbit.rb +30 -0
  163. data/checks/http/jive.rb +27 -0
  164. data/checks/http/joomla.rb +43 -0
  165. data/checks/http/jquery.rb +58 -0
  166. data/checks/http/jupyter.rb +28 -0
  167. data/checks/http/kentico.rb +27 -0
  168. data/checks/http/kerio.rb +34 -0
  169. data/checks/http/kibana.rb +56 -0
  170. data/checks/http/kong.rb +32 -0
  171. data/checks/http/kubernetes.rb +66 -0
  172. data/checks/http/laravel.rb +27 -0
  173. data/checks/http/lastpass.rb +27 -0
  174. data/checks/http/lcn.rb +27 -0
  175. data/checks/http/leadpages.rb +29 -0
  176. data/checks/http/lighttpd.rb +31 -0
  177. data/checks/http/limelight_networks.rb +43 -0
  178. data/checks/http/limesuvey.rb +27 -0
  179. data/checks/http/link1.rb +31 -0
  180. data/checks/http/linksys.rb +38 -0
  181. data/checks/http/litespeed.rb +29 -0
  182. data/checks/http/lithium.rb +43 -0
  183. data/checks/http/lotus.rb +55 -0
  184. data/checks/http/magento.rb +96 -0
  185. data/checks/http/magnolia.rb +27 -0
  186. data/checks/http/mailchimp.rb +27 -0
  187. data/checks/http/manage_engine.rb +27 -0
  188. data/checks/http/markmonitor.rb +27 -0
  189. data/checks/http/mbf_bioscience.rb +29 -0
  190. data/checks/http/mcafee.rb +27 -0
  191. data/checks/http/media_temple.rb +27 -0
  192. data/checks/http/mediawiki.rb +54 -0
  193. data/checks/http/mhcsoftwareinc.rb +29 -0
  194. data/checks/http/microsoft.rb +1325 -0
  195. data/checks/http/mikrotik.rb +44 -0
  196. data/checks/http/modwsgi.rb +30 -0
  197. data/checks/http/mojolicious.rb +32 -0
  198. data/checks/http/moodle.rb +28 -0
  199. data/checks/http/mura.rb +30 -0
  200. data/checks/http/nagios.rb +27 -0
  201. data/checks/http/namesilo.rb +31 -0
  202. data/checks/http/nationbuilder.rb +30 -0
  203. data/checks/http/nec.rb +32 -0
  204. data/checks/http/netlify.rb +40 -0
  205. data/checks/http/netobjects_inc.rb +30 -0
  206. data/checks/http/netscape.rb +29 -0
  207. data/checks/http/neustar.rb +29 -0
  208. data/checks/http/new_relic.rb +27 -0
  209. data/checks/http/nexicom.rb +44 -0
  210. data/checks/http/nginx.rb +82 -0
  211. data/checks/http/nisource.rb +29 -0
  212. data/checks/http/nodejs.rb +79 -0
  213. data/checks/http/okta.rb +53 -0
  214. data/checks/http/ookla.rb +28 -0
  215. data/checks/http/openbsd.rb +30 -0
  216. data/checks/http/openresty.rb +41 -0
  217. data/checks/http/openscholar.rb +27 -0
  218. data/checks/http/opensolution.rb +46 -0
  219. data/checks/http/openssl.rb +43 -0
  220. data/checks/http/opentext.rb +46 -0
  221. data/checks/http/openvpn.rb +27 -0
  222. data/checks/http/opscode.rb +43 -0
  223. data/checks/http/oracle.rb +335 -0
  224. data/checks/http/orion_technology.rb +30 -0
  225. data/checks/http/ovh.rb +46 -0
  226. data/checks/http/palo_alto.rb +27 -0
  227. data/checks/http/pantheon.rb +54 -0
  228. data/checks/http/papercut.rb +29 -0
  229. data/checks/http/parallels.rb +44 -0
  230. data/checks/http/pardot.rb +44 -0
  231. data/checks/http/parkingcrew.rb +47 -0
  232. data/checks/http/pbworks.rb +27 -0
  233. data/checks/http/perfectsense.rb +28 -0
  234. data/checks/http/perl.rb +62 -0
  235. data/checks/http/pfsense.rb +27 -0
  236. data/checks/http/php.rb +72 -0
  237. data/checks/http/phpmyadmin.rb +40 -0
  238. data/checks/http/phpwind.rb +30 -0
  239. data/checks/http/phusion.rb +59 -0
  240. data/checks/http/ping_identity.rb +28 -0
  241. data/checks/http/pivotal_software.rb +97 -0
  242. data/checks/http/pjax.rb +40 -0
  243. data/checks/http/plesk.rb +58 -0
  244. data/checks/http/porkbun.rb +31 -0
  245. data/checks/http/progress.rb +30 -0
  246. data/checks/http/proofpoint.rb +30 -0
  247. data/checks/http/pulsesecure.rb +91 -0
  248. data/checks/http/python.rb +30 -0
  249. data/checks/http/qnap.rb +43 -0
  250. data/checks/http/qualys.rb +69 -0
  251. data/checks/http/rapid7.rb +27 -0
  252. data/checks/http/rbs.rb +30 -0
  253. data/checks/http/readmeio.rb +28 -0
  254. data/checks/http/red_hat.rb +95 -0
  255. data/checks/http/redmine.rb +38 -0
  256. data/checks/http/restlet.rb +30 -0
  257. data/checks/http/ritecms.rb +30 -0
  258. data/checks/http/roadiz.rb +30 -0
  259. data/checks/http/rock.rb +30 -0
  260. data/checks/http/rollbar.rb +27 -0
  261. data/checks/http/roundcube.rb +42 -0
  262. data/checks/http/ruby.rb +92 -0
  263. data/checks/http/ruckus_wireless.rb +26 -0
  264. data/checks/http/sailpoint.rb +30 -0
  265. data/checks/http/salesforce.rb +28 -0
  266. data/checks/http/sap.rb +149 -0
  267. data/checks/http/seamless_cms.rb +30 -0
  268. data/checks/http/securi.rb +54 -0
  269. data/checks/http/sedo.rb +63 -0
  270. data/checks/http/segment.rb +27 -0
  271. data/checks/http/sencha.rb +31 -0
  272. data/checks/http/sentry.rb +27 -0
  273. data/checks/http/serendipity.rb +30 -0
  274. data/checks/http/shopfactory.rb +30 -0
  275. data/checks/http/sip.rb +29 -0
  276. data/checks/http/sitecore.rb +39 -0
  277. data/checks/http/smartling.rb +27 -0
  278. data/checks/http/smf.rb +30 -0
  279. data/checks/http/snews.rb +30 -0
  280. data/checks/http/software_ag.rb +47 -0
  281. data/checks/http/soha.rb +66 -0
  282. data/checks/http/solarwinds.rb +41 -0
  283. data/checks/http/sonatype.rb +43 -0
  284. data/checks/http/sonicwall.rb +63 -0
  285. data/checks/http/sophos.rb +40 -0
  286. data/checks/http/southriver.rb +43 -0
  287. data/checks/http/splash.rb +29 -0
  288. data/checks/http/splunk.rb +27 -0
  289. data/checks/http/springfox.rb +43 -0
  290. data/checks/http/squarespace.rb +41 -0
  291. data/checks/http/stackpath.rb +29 -0
  292. data/checks/http/stibo_systems.rb +35 -0
  293. data/checks/http/subrion.rb +29 -0
  294. data/checks/http/symantec.rb +27 -0
  295. data/checks/http/synacor.rb +26 -0
  296. data/checks/http/tableau_software.rb +42 -0
  297. data/checks/http/telerik.rb +46 -0
  298. data/checks/http/tengine.rb +29 -0
  299. data/checks/http/tibco.rb +57 -0
  300. data/checks/http/townnews.rb +33 -0
  301. data/checks/http/tridium.rb +28 -0
  302. data/checks/http/twiki.rb +27 -0
  303. data/checks/http/typo3.rb +27 -0
  304. data/checks/http/uberflip.rb +28 -0
  305. data/checks/http/ucoz.rb +31 -0
  306. data/checks/http/umbraco.rb +29 -0
  307. data/checks/http/unbounce.rb +28 -0
  308. data/checks/http/united_domains.rb +27 -0
  309. data/checks/http/vanilla_forums.rb +27 -0
  310. data/checks/http/varnish.rb +79 -0
  311. data/checks/http/vbulletin.rb +66 -0
  312. data/checks/http/verizon.rb +27 -0
  313. data/checks/http/vmware.rb +53 -0
  314. data/checks/http/vue_js.rb +27 -0
  315. data/checks/http/webflow.rb +44 -0
  316. data/checks/http/webgui.rb +30 -0
  317. data/checks/http/webmin.rb +44 -0
  318. data/checks/http/webpagetest_project.rb +30 -0
  319. data/checks/http/wftpserver.rb +28 -0
  320. data/checks/http/wildfly.rb +29 -0
  321. data/checks/http/wix.rb +28 -0
  322. data/checks/http/woltlab_gmbh.rb +30 -0
  323. data/checks/http/wordpress/ithemes.rb +50 -0
  324. data/checks/http/wordpress/john_godley.rb +29 -0
  325. data/checks/http/wordpress/pixelcraft.rb +31 -0
  326. data/checks/http/wordpress/rocklobster.rb +29 -0
  327. data/checks/http/wordpress/team_heateor.rb +31 -0
  328. data/checks/http/wordpress/w3_total_cache.rb +30 -0
  329. data/checks/http/wordpress/wp_fastest_cache.rb +30 -0
  330. data/checks/http/wordpress/wp_super_cache.rb +46 -0
  331. data/checks/http/wordpress/wpbakery.rb +30 -0
  332. data/checks/http/world4you.rb +46 -0
  333. data/checks/http/wp_engine.rb +57 -0
  334. data/checks/http/xcms.rb +30 -0
  335. data/checks/http/xelion.rb +27 -0
  336. data/checks/http/xerox.rb +27 -0
  337. data/checks/http/xmb.rb +30 -0
  338. data/checks/http/xtec.rb +30 -0
  339. data/checks/http/yaf.rb +30 -0
  340. data/checks/http/yaws.rb +30 -0
  341. data/checks/http/yoast.rb +31 -0
  342. data/checks/http/zeit.rb +30 -0
  343. data/checks/http/zendesk.rb +41 -0
  344. data/checks/http/zengenti.rb +30 -0
  345. data/checks/http/zoho.rb +69 -0
  346. data/checks/http/zscaler.rb +30 -0
  347. data/checks/smtp/base.rb +16 -0
  348. data/checks/smtp/exim.rb +30 -0
  349. data/checks/snmp/base.rb +15 -0
  350. data/checks/snmp/cisco.rb +59 -0
  351. data/checks/ssh/array_networks.rb +28 -0
  352. data/checks/ssh/base.rb +16 -0
  353. data/checks/ssh/openssh.rb +26 -0
  354. data/checks/telnet/base.rb +16 -0
  355. data/checks/telnet/huawei.rb +26 -0
  356. data/data/logos/acquia.png +0 -0
  357. data/data/logos/amazon_cloudfront.png +0 -0
  358. data/data/logos/apache_coyote.png +0 -0
  359. data/data/logos/apache_tomcat.png +0 -0
  360. data/data/logos/atlassian_bamboo.png +0 -0
  361. data/data/logos/atlassian_bitbucket.png +0 -0
  362. data/data/logos/atlassian_confluence.png +0 -0
  363. data/data/logos/atlassian_crowd.png +0 -0
  364. data/data/logos/atlassian_crucible.png +0 -0
  365. data/data/logos/atlassian_fisheye.png +0 -0
  366. data/data/logos/atlassian_jira.png +0 -0
  367. data/data/logos/atlassian_sourcetree.png +0 -0
  368. data/data/logos/automattic_wordpress.png +0 -0
  369. data/data/logos/calibre.png +0 -0
  370. data/data/logos/cisco_ssl_vpn.png +0 -0
  371. data/data/logos/citrix_netscaler_gateway.png +0 -0
  372. data/data/logos/cloudflare_cdn.png +0 -0
  373. data/data/logos/drupal.png +0 -0
  374. data/data/logos/f5_big-ip.png +0 -0
  375. data/data/logos/f5_big-ip_apm.png +0 -0
  376. data/data/logos/fastly.png +0 -0
  377. data/data/logos/generic.png +0 -0
  378. data/data/logos/gitlab.png +0 -0
  379. data/data/logos/ibm_axway_securetransport.png +0 -0
  380. data/data/logos/lithium.png +0 -0
  381. data/data/logos/microsoft_asp.net.png +0 -0
  382. data/data/logos/microsoft_iis.png +0 -0
  383. data/data/logos/microsoft_outlook_web_access.png +0 -0
  384. data/data/logos/microsoft_sharepoint.png +0 -0
  385. data/data/logos/microtik_routeros.png +0 -0
  386. data/data/logos/mikrotik_routeros.png +0 -0
  387. data/data/logos/newrelic.png +0 -0
  388. data/data/logos/nginx.png +0 -0
  389. data/data/logos/okta.png +0 -0
  390. data/data/logos/oracle_glassfish.png +0 -0
  391. data/data/logos/oracle_java_application_server.png +0 -0
  392. data/data/logos/oracle_java_server_pages.png +0 -0
  393. data/data/logos/oracle_weblogic.png +0 -0
  394. data/data/logos/phpmyadmin.png +0 -0
  395. data/data/logos/tableau.png +0 -0
  396. data/data/logos/vmware_esxi.png +0 -0
  397. data/data/logos/vmware_horizon.png +0 -0
  398. data/data/logos/zendesk.png +0 -0
  399. data/data/logos/zimbra_server.png +0 -0
  400. data/data/microsoft_sharepoint_versions.csv +224 -0
  401. data/intrigue-ident.gemspec +8 -7
  402. data/lib/banner_helpers.rb +36 -0
  403. data/lib/ftp/check_factory.rb +24 -0
  404. data/lib/ftp/content.rb +13 -0
  405. data/lib/ftp/ftp.rb +52 -0
  406. data/lib/ftp/matchers.rb +26 -0
  407. data/lib/http/browser.rb +260 -0
  408. data/lib/http/check_factory.rb +47 -0
  409. data/lib/http/content.rb +45 -0
  410. data/lib/http/http.rb +463 -0
  411. data/lib/http/matchers.rb +132 -0
  412. data/lib/ident.rb +263 -0
  413. data/lib/recog_wrapper.rb +70 -0
  414. data/lib/simple_socket.rb +41 -0
  415. data/lib/smtp/check_factory.rb +24 -0
  416. data/lib/smtp/content.rb +13 -0
  417. data/lib/smtp/matchers.rb +28 -0
  418. data/lib/smtp/smtp.rb +53 -0
  419. data/lib/snmp/check_factory.rb +24 -0
  420. data/lib/snmp/content.rb +13 -0
  421. data/lib/snmp/matchers.rb +25 -0
  422. data/lib/snmp/snmp.rb +55 -0
  423. data/lib/ssh/check_factory.rb +24 -0
  424. data/lib/ssh/content.rb +13 -0
  425. data/lib/ssh/matchers.rb +26 -0
  426. data/lib/ssh/ssh.rb +52 -0
  427. data/lib/telnet/check_factory.rb +24 -0
  428. data/lib/telnet/content.rb +13 -0
  429. data/lib/telnet/matchers.rb +26 -0
  430. data/lib/telnet/telnet.rb +52 -0
  431. data/lib/utils.rb +19 -0
  432. data/lib/version.rb +3 -0
  433. data/lib/vulndb_client.rb +43 -0
  434. data/util/console.rb +9 -0
  435. data/util/docker.sh +2 -0
  436. data/util/ident.rb +375 -0
  437. data/util/list_paths.rb +12 -0
  438. data/util/tags.rb +36 -0
  439. data/utils.rb +19 -0
  440. metadata +487 -55
  441. data/ident.rb +0 -319
  442. data/lib/check_factory.rb +0 -22
  443. data/lib/checks/akamai.rb +0 -22
  444. data/lib/checks/amazon.rb +0 -26
  445. data/lib/checks/aruba.rb +0 -20
  446. data/lib/checks/asp_net.rb +0 -70
  447. data/lib/checks/atlassian.rb +0 -55
  448. data/lib/checks/base.rb +0 -13
  449. data/lib/checks/chef.rb +0 -31
  450. data/lib/checks/cisco.rb +0 -33
  451. data/lib/checks/citrix.rb +0 -24
  452. data/lib/checks/cloudflare.rb +0 -59
  453. data/lib/checks/cloudfront.rb +0 -41
  454. data/lib/checks/cpanel.rb +0 -23
  455. data/lib/checks/django.rb +0 -22
  456. data/lib/checks/drupal.rb +0 -26
  457. data/lib/checks/f5.rb +0 -24
  458. data/lib/checks/fastly.rb +0 -22
  459. data/lib/checks/generic.rb +0 -23
  460. data/lib/checks/gitlab.rb +0 -22
  461. data/lib/checks/google.rb +0 -23
  462. data/lib/checks/grafana.rb +0 -22
  463. data/lib/checks/jenkins.rb +0 -40
  464. data/lib/checks/joomla.rb +0 -23
  465. data/lib/checks/limesuvey.rb +0 -22
  466. data/lib/checks/lithium.rb +0 -30
  467. data/lib/checks/magento.rb +0 -22
  468. data/lib/checks/mcafee.rb +0 -22
  469. data/lib/checks/mediawiki.rb +0 -38
  470. data/lib/checks/microsoft.rb +0 -69
  471. data/lib/checks/nagios.rb +0 -22
  472. data/lib/checks/oracle.rb +0 -38
  473. data/lib/checks/palo_alto.rb +0 -23
  474. data/lib/checks/pardot.rb +0 -22
  475. data/lib/checks/pfsense.rb +0 -25
  476. data/lib/checks/phpmyadmin.rb +0 -22
  477. data/lib/checks/rabbitmq.rb +0 -29
  478. data/lib/checks/spring.rb +0 -31
  479. data/lib/checks/team_city.rb +0 -22
  480. data/lib/checks/telerik.rb +0 -25
  481. data/lib/checks/tomcat.rb +0 -22
  482. data/lib/checks/varnish.rb +0 -27
  483. data/lib/checks/wordpress.rb +0 -120
  484. data/lib/checks/wp_engine.rb +0 -22
@@ -0,0 +1,30 @@
1
+ module Intrigue
2
+ module Ident
3
+ module Check
4
+ class Artifactory < Intrigue::Ident::Check::Base
5
+
6
+ def generate_checks(url)
7
+ [
8
+ {
9
+ :type => "fingerprint",
10
+ :category => "application",
11
+ :tags => ["COTS", "Development", "Security"],
12
+ :website => "https://jfrog.com/artifactory/",
13
+ :vendor => "Artifactory",
14
+ :product => "Artifactory",
15
+ :version => nil,
16
+ :dynamic_version => lambda { |x|
17
+ _first_header_capture(x,/server: Artifactory\/(.*)$/i) },
18
+ :match_type => :content_headers,
19
+ :match_content => /server: Artifactory/,
20
+ :match_details =>"server header",
21
+ :paths => ["#{url}"],
22
+ :inference => false
23
+ }
24
+ ]
25
+ end
26
+
27
+ end
28
+ end
29
+ end
30
+ end
@@ -0,0 +1,27 @@
1
+ module Intrigue
2
+ module Ident
3
+ module Check
4
+ class Aruba < Intrigue::Ident::Check::Base
5
+
6
+ def generate_checks(url)
7
+ [
8
+ {
9
+ :type => "fingerprint",
10
+ :category => "operating_system",
11
+ :tags => ["Networking", "COTS", "Wireless"],
12
+ :vendor => "Aruba Networks",
13
+ :product => "Aruba OS",
14
+ :version => nil,
15
+ :match_type => :content_body,
16
+ :match_content => /arubalp=/,
17
+ :match_details =>"Matches an aruba link, generic identifier",
18
+ :paths => ["#{url}"],
19
+ :inference => false
20
+ }
21
+ ]
22
+ end
23
+
24
+ end
25
+ end
26
+ end
27
+ end
@@ -0,0 +1,152 @@
1
+ module Intrigue
2
+ module Ident
3
+ module Check
4
+ class Atlassian < Intrigue::Ident::Check::Base
5
+
6
+ def generate_checks(url)
7
+ [
8
+ {
9
+ :type => "fingerprint",
10
+ :category => "application",
11
+ :tags => ["COTS", "Development"],
12
+ :vendor => "Atlassian",
13
+ :product =>"BitBucket",
14
+ :match_details =>"Atlassian BitBucket",
15
+ :version => nil,
16
+ :match_type => :content_body,
17
+ :match_content => /com.atlassian.bitbucket.server/i,
18
+ :paths => ["#{url}"],
19
+ :inference => false
20
+ },
21
+ {
22
+ :type => "fingerprint",
23
+ :category => "application",
24
+ :tags => ["COTS", "Development"],
25
+ :vendor => "Atlassian",
26
+ :product =>"Confluence",
27
+ :match_details =>"Atlassian Confluence",
28
+ :version => nil,
29
+ :match_type => :content_headers,
30
+ :match_content => /X-Confluence-Request-Time/i,
31
+ :paths => ["#{url}"],
32
+ :inference => false
33
+ },
34
+ {
35
+ :type => "fingerprint",
36
+ :category => "application",
37
+ :tags => ["COTS", "Development"],
38
+ :vendor => "Atlassian",
39
+ :product =>"Crucible",
40
+ :match_details =>"Atlassian Crucible",
41
+ :version => nil,
42
+ :match_type => :content_body,
43
+ :match_content => /FishEye and Crucible/,
44
+ :dynamic_version => lambda{ |x|
45
+ _first_body_capture(x, /Log in to FishEye and Crucible (.*)\</)
46
+ },
47
+ :paths => ["#{url}"],
48
+ :inference => true
49
+ },
50
+ {
51
+ :type => "fingerprint",
52
+ :category => "application",
53
+ :tags => ["COTS", "Development"],
54
+ :vendor => "Atlassian",
55
+ :product =>"Hipchat",
56
+ :match_details =>"Atlassian Hipchat",
57
+ :version => nil,
58
+ :match_type => :content_body,
59
+ :match_content => /\$\(document\).trigger\('hipchat.load'\);/,
60
+ :paths => ["#{url}"],
61
+ :inference => false
62
+ },
63
+ {
64
+ :type => "fingerprint",
65
+ :category => "application",
66
+ :tags => ["COTS", "Development"],
67
+ :vendor => "Atlassian",
68
+ :product =>"Jira",
69
+ :match_details =>"Atlassian Jira",
70
+ :version => nil,
71
+ :match_type => :content_body,
72
+ :match_content => /jira.webresources/i,
73
+ :paths => ["#{url}"],
74
+ :inference => false
75
+ },
76
+ {
77
+ :type => "fingerprint",
78
+ :category => "application",
79
+ :tags => ["COTS", "Development"],
80
+ :vendor => "Atlassian",
81
+ :product =>"Jira",
82
+ :match_details =>"Atlassian Jira",
83
+ :version => nil,
84
+ :match_type => :content_cookies,
85
+ :match_content => /atlassian.xsrf.token=/i,
86
+ :dynamic_version => lambda{ |x|
87
+ _first_body_capture(x,/<meta name="ajs-version-number" content="(.*)">/) },
88
+ :paths => ["#{url}"],
89
+ :inference => true
90
+ },
91
+ {
92
+ :type => "fingerprint",
93
+ :category => "service",
94
+ :tags => ["SaaS", "Development", "Proxy"],
95
+ :vendor => "Atlassian",
96
+ :product =>"Proxy",
97
+ :references => ["https://community.atlassian.com/t5/Jira-questions/REST-API-not-returning-any-data-with-API-token/qaq-p/1292806"],
98
+ :match_details =>"proxy server header",
99
+ :version => nil,
100
+ :match_type => :content_headers,
101
+ :match_content => /^server: AtlassianProxy\/[\d\.]+$/i,
102
+ :dynamic_version => lambda{ |x|
103
+ _first_header_capture(x,/^server: AtlassianProxy\/([\d\.]+)$/i) },
104
+ :paths => ["#{url}"],
105
+ :inference => false
106
+ },
107
+ {
108
+ :type => "fingerprint",
109
+ :category => "service",
110
+ :tags => ["SaaS", "Development", "SaaS"],
111
+ :vendor => "Atlassian",
112
+ :product =>"Statuspage",
113
+ :match_details =>"statuspage icon",
114
+ :version => nil,
115
+ :match_type => :content_body,
116
+ :match_content => /logos-statuspage-logo-gradient-neutral.svg/i,
117
+ :paths => ["#{url}"],
118
+ :inference => false
119
+ },
120
+ {
121
+ :type => "fingerprint",
122
+ :category => "service",
123
+ :tags => ["SaaS", "Development", "SaaS"],
124
+ :vendor => "Atlassian",
125
+ :product =>"Statuspage",
126
+ :match_details =>"statuspage header",
127
+ :version => nil,
128
+ :match_type => :content_heades,
129
+ :match_content => /^x-statuspage-skip-logging:.*$/i,
130
+ :paths => ["#{url}"],
131
+ :inference => false
132
+ },
133
+ {
134
+ :type => "fingerprint",
135
+ :category => "service",
136
+ :tags => ["SaaS", "Development", "SaaS"],
137
+ :vendor => "Atlassian",
138
+ :product =>"Statuspage",
139
+ :match_details =>"statuspage header",
140
+ :version => nil,
141
+ :match_type => :content_headers,
142
+ :match_content => /^x-statuspage-version:.*$/i,
143
+ :paths => ["#{url}"],
144
+ :inference => false
145
+ }
146
+ ]
147
+ end
148
+
149
+ end
150
+ end
151
+ end
152
+ end
@@ -0,0 +1,44 @@
1
+ module Intrigue
2
+ module Ident
3
+ module Check
4
+ class Auth0 < Intrigue::Ident::Check::Base
5
+
6
+ def generate_checks(url)
7
+ [
8
+ {
9
+ :type => "fingerprint",
10
+ :category => "service",
11
+ :tags => ["IAM", "SaaS", "Security"],
12
+ :vendor => "Auth0",
13
+ :product => "Auth0",
14
+ :references => [],
15
+ :version => nil,
16
+ :match_type => :content_body,
17
+ :match_content => /window.auth0AnalyticsOptions/i,
18
+ :match_details => "Auth0 analytics",
19
+ :hide => false,
20
+ :paths => ["#{url}"],
21
+ :inference => false
22
+ },
23
+ {
24
+ :type => "fingerprint",
25
+ :category => "service",
26
+ :tags => ["IAM", "SaaS", "Security"],
27
+ :vendor => "Auth0",
28
+ :product => "Auth0",
29
+ :references => [],
30
+ :version => nil,
31
+ :match_type => :content_body,
32
+ :match_content => /\/auth0/i,
33
+ :match_details => "Auth0 link",
34
+ :hide => false,
35
+ :paths => ["#{url}"],
36
+ :inference => false
37
+ }
38
+ ]
39
+ end
40
+
41
+ end
42
+ end
43
+ end
44
+ end
@@ -0,0 +1,292 @@
1
+ module Intrigue
2
+ module Ident
3
+ module Check
4
+ class Automattic < Intrigue::Ident::Check::Base
5
+
6
+ def generate_checks(url)
7
+ [
8
+ {
9
+ :type => "fingerprint",
10
+ :category => "application",
11
+ :tags => ["CMS"],
12
+ :vendor =>"Wordpress",
13
+ :product =>"Wordpress",
14
+ :match_details =>"wordpress test cookie",
15
+ :version => nil,
16
+ :match_type => :content_cookies,
17
+ :match_content => /wordpress_test_cookie=/i,
18
+ :hide => false,
19
+ :paths => ["#{url}"],
20
+ :inference => false
21
+ },
22
+ {
23
+ :type => "fingerprint",
24
+ :category => "application",
25
+ :tags => ["CMS"],
26
+ :vendor =>"Wordpress",
27
+ :product =>"Wordpress",
28
+ :match_details =>"wordpress login page",
29
+ :version => nil,
30
+ :match_type => :content_body,
31
+ :match_content => /class=\"login login-action-login wp-core-ui/i,
32
+ :hide => false,
33
+ :paths => ["#{url}"],
34
+ :inference => false
35
+ },
36
+ {
37
+ :type => "fingerprint",
38
+ :category => "application",
39
+ :tags => ["CMS"],
40
+ :vendor =>"Wordpress",
41
+ :product =>"Wordpress",
42
+ :match_details =>"wordpress generator tag",
43
+ :version => nil,
44
+ :match_type => :content_generator,
45
+ :match_content => /WordPress/i,
46
+ :dynamic_version => lambda { |x| _first_generator_capture(x, /WordPress\ ([\d\.]+)/i)},
47
+ :hide => false,
48
+ :paths => ["#{url}"],
49
+ :inference => true
50
+ },
51
+ {
52
+ :type => "fingerprint",
53
+ :category => "application",
54
+ :tags => ["CMS"],
55
+ :vendor =>"Wordpress",
56
+ :product =>"Wordpress",
57
+ :match_details =>"wp-embed link",
58
+ :version => nil,
59
+ :match_type => :content_body,
60
+ :match_content => /wp-includes\/js\/wp-embed.min.js\?ver=([\d\.]+)\'/i,
61
+ :dynamic_version => lambda { |x| _first_body_capture(x, /wp-includes\/js\/wp-embed.min.js\?ver=([\d\.]+)\'/i)},
62
+ :hide => false,
63
+ :paths => ["#{url}"],
64
+ :inference => true
65
+ },
66
+ {
67
+ :type => "fingerprint",
68
+ :category => "application",
69
+ :tags => ["CMS"],
70
+ :vendor =>"Wordpress",
71
+ :product =>"Wordpress",
72
+ :match_details =>"version string",
73
+ :version => nil,
74
+ :references => ["https://github.com/caffeinewriter/wp-fingerprinter/blob/master/wp-fingerprint.py"],
75
+ :match_type => :content_cookies,
76
+ :match_content => /Version ([\d\.]+)/i,
77
+ :dynamic_version => lambda { |x| _first_generator_capture(x, /Version ([\d\.]+)/i) },
78
+ :hide => false,
79
+ :require_product => "Wordpress",
80
+ :paths => ["#{url}"],
81
+ :inference => true
82
+ },
83
+ {
84
+ :type => "fingerprint",
85
+ :category => "application",
86
+ :tags => ["CMS"],
87
+ :vendor =>"Wordpress",
88
+ :product =>"Wordpress",
89
+ :match_details =>"common link",
90
+ :version => nil,
91
+ :match_type => :content_body,
92
+ :match_content => /src=\'\/wp-includes\/js\/jquery\/jquery-new\.js\'\>/,
93
+ :paths => ["#{url}"],
94
+ :inference => false
95
+ },
96
+ {
97
+ :type => "fingerprint",
98
+ :category => "application",
99
+ :tags => ["CMS"],
100
+ :vendor =>"Wordpress",
101
+ :product =>"Wordpress",
102
+ :match_details =>"common link",
103
+ :version => nil,
104
+ :match_type => :content_body,
105
+ :match_content => /<link rel='https:\/\/api.w.org\/'/,
106
+ :paths => ["#{url}"],
107
+ :inference => false
108
+ },
109
+ {
110
+ :type => "fingerprint",
111
+ :category => "application",
112
+ :tags => ["CMS", "SaaS"],
113
+ :vendor =>"Wordpress",
114
+ :product =>"Wordpress",
115
+ :match_details =>"unique header for hosted service",
116
+ :version => nil,
117
+ :match_type => :content_headers,
118
+ :match_content => /x-hacker: If you're reading this, you should visit automattic.com/,
119
+ :paths => ["#{url}"],
120
+ :inference => false
121
+ },
122
+ {
123
+ :type => "fingerprint",
124
+ :category => "application",
125
+ :tags => ["CMS"],
126
+ :vendor => "Wordpress",
127
+ :product =>"Wordpress",
128
+ :match_details =>"Wordpress WP-JSON endpoint",
129
+ :version => nil,
130
+ :match_type => :content_body,
131
+ :match_content => /gmt_offset/,
132
+ :paths => ["#{url}/wp-json"],
133
+ :require_product => "Wordpress",
134
+ :inference => false
135
+ },
136
+ {
137
+ :type => "fingerprint",
138
+ :category => "application",
139
+ :tags => ["CMS"],
140
+ :vendor => "Wordpress",
141
+ :product =>"Wordpress",
142
+ :match_details =>"Wordpress TinyMCE Editor",
143
+ :references => ["https://dcid.me/texts/fingerprinting-web-apps.html"],
144
+ :version => "2.0",
145
+ :match_type => :checksum_body,
146
+ :match_content => "a306a72ce0f250e5f67132dc6bcb2ccb",
147
+ :paths => ["#{url}/wp-includes/js/tinymce/tiny_mce.js"],
148
+ :require_product => "Wordpress",
149
+ :inference => true
150
+ },
151
+ {
152
+ :type => "fingerprint",
153
+ :category => "application",
154
+ :tags => ["CMS"],
155
+ :vendor => "Wordpress",
156
+ :product =>"Wordpress",
157
+ :match_details =>"Wordpress TinyMCE Editor",
158
+ :references => ["https://dcid.me/texts/fingerprinting-web-apps.html"],
159
+ :version => "2.1",
160
+ :match_type => :checksum_body,
161
+ :match_content => "4f04728cb4631a553c4266c14b9846aa",
162
+ :paths => ["#{url}/wp-includes/js/tinymce/tiny_mce.js"],
163
+ :require_product => "Wordpress",
164
+ :inference => true
165
+ },
166
+ {
167
+ :type => "fingerprint",
168
+ :category => "application",
169
+ :tags => ["CMS"],
170
+ :vendor => "Wordpress",
171
+ :product =>"Wordpress",
172
+ :match_details =>"Wordpress TinyMCE Editor",
173
+ :references => ["https://dcid.me/texts/fingerprinting-web-apps.html"],
174
+ :version => "2.2",
175
+ :match_type => :checksum_body,
176
+ :match_content => "25e1e78d5b0c221e98e14c6e8c62084f",
177
+ :paths => ["#{url}/wp-includes/js/tinymce/tiny_mce.js"],
178
+ :require_product => "Wordpress",
179
+ :inference => true
180
+ },
181
+ {
182
+ :type => "fingerprint",
183
+ :category => "application",
184
+ :tags => ["CMS"],
185
+ :vendor => "Wordpress",
186
+ :product =>"Wordpress",
187
+ :match_details =>"Wordpress TinyMCE Editor",
188
+ :references => ["https://dcid.me/texts/fingerprinting-web-apps.html"],
189
+ :version => "2.3",
190
+ :match_type => :checksum_body,
191
+ :match_content => "83c83d0f0a71bd57c320d93e59991c53",
192
+ :paths => ["#{url}/wp-includes/js/tinymce/tiny_mce.js"],
193
+ :require_product => "Wordpress",
194
+ :inference => true
195
+ },
196
+ {
197
+ :type => "fingerprint",
198
+ :category => "application",
199
+ :tags => ["CMS"],
200
+ :vendor => "Wordpress",
201
+ :product =>"Wordpress",
202
+ :match_details =>"Wordpress TinyMCE Editor",
203
+ :references => ["https://dcid.me/texts/fingerprinting-web-apps.html"],
204
+ :version => "2.5",
205
+ :match_type => :checksum_body,
206
+ :match_content => "7293453cf0ff5a9a4cfe8cebd5b5a71a",
207
+ :paths => ["#{url}/wp-includes/js/tinymce/tiny_mce.js"],
208
+ :require_product => "Wordpress",
209
+ :inference => true
210
+ },
211
+ {
212
+ :type => "fingerprint",
213
+ :category => "application",
214
+ :tags => ["CMS"],
215
+ :vendor => "Wordpress",
216
+ :product =>"Wordpress",
217
+ :match_details =>"Wordpress TinyMCE Editor",
218
+ :references => ["https://dcid.me/texts/fingerprinting-web-apps.html"],
219
+ :version => "2.6",
220
+ :match_type => :checksum_body,
221
+ :match_content => "61740709537bd19fb6e03b7e11eb8812",
222
+ :paths => ["#{url}/wp-includes/js/tinymce/tiny_mce.js"],
223
+ :require_product => "Wordpress",
224
+ :inference => true
225
+ },
226
+ {
227
+ :type => "fingerprint",
228
+ :category => "application",
229
+ :tags => ["CMS"],
230
+ :vendor => "Wordpress",
231
+ :product =>"Wordpress",
232
+ :match_details =>"Wordpress TinyMCE Editor",
233
+ :references => ["https://dcid.me/texts/fingerprinting-web-apps.html"],
234
+ :version => "2.7",
235
+ :match_type => :checksum_body,
236
+ :match_content => "e6bbc53a727f3af003af272fd229b0b2",
237
+ :paths => ["#{url}/wp-includes/js/tinymce/tiny_mce.js"],
238
+ :require_product => "Wordpress",
239
+ :inference => true
240
+ },
241
+ {
242
+ :type => "fingerprint",
243
+ :category => "application",
244
+ :tags => ["CMS"],
245
+ :vendor => "Wordpress",
246
+ :product =>"Wordpress",
247
+ :match_details =>"Wordpress TinyMCE Editor",
248
+ :references => ["https://dcid.me/texts/fingerprinting-web-apps.html"],
249
+ :version => "2.7.1",
250
+ :match_type => :checksum_body,
251
+ :match_content => "e6bbc53a727f3af003af272fd229b0b2",
252
+ :paths => ["#{url}/wp-includes/js/tinymce/tiny_mce.js"],
253
+ :require_product => "Wordpress",
254
+ :inference => true
255
+ },
256
+ {
257
+ :type => "fingerprint",
258
+ :category => "application",
259
+ :tags => ["CMS"],
260
+ :vendor => "Wordpress",
261
+ :product =>"Wordpress",
262
+ :match_details =>"Wordpress TinyMCE Editor",
263
+ :references => ["https://dcid.me/texts/fingerprinting-web-apps.html"],
264
+ :version => "2.9.1",
265
+ :match_type => :checksum_body,
266
+ :match_content => "128e75ed19d49a94a771586bf83265ec",
267
+ :paths => ["#{url}/wp-includes/js/tinymce/tiny_mce.js"],
268
+ :require_product => "Wordpress",
269
+ :inference => true
270
+ }
271
+ ]
272
+ end
273
+
274
+ =begin
275
+ all_checks = [{
276
+ :url => "#{url}",
277
+ :checklist => [
278
+ {
279
+ :product =>"Yoast Wordpress SEO Plugin", # won't be used if we have
280
+ :match_details =>"Yoast Wordpress SEO Plugin",
281
+ :match_type => "content",
282
+ :match_content => /<!-- \/ Yoast WordPress SEO plugin. -->/,
283
+ :test_site => "https://ip-50-62-231-56.ip.secureserver.net",
284
+ :dynamic_name => lambda{|x| x.scan(/the Yoast WordPress SEO plugin v.* - h/)[0].gsub("the ","").gsub(" - h","") }
285
+ }
286
+ ]},
287
+ =end
288
+
289
+ end
290
+ end
291
+ end
292
+ end