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,43 @@
1
+ module Intrigue
2
+ module Ident
3
+ module Check
4
+ class Openssl < Intrigue::Ident::Check::Base
5
+
6
+ def generate_checks(url)
7
+ [
8
+ {
9
+ :type => "fingerprint",
10
+ :category => "application",
11
+ :tags => ["Library"],
12
+ :vendor =>"OpenSSL",
13
+ :product =>"OpenSSL",
14
+ :match_details =>"server header",
15
+ :version => nil,
16
+ :match_type => :content_headers,
17
+ :match_content => /^.*OpenSSL\/.*$/i,
18
+ :dynamic_version => lambda { |x|
19
+ # check for backported OS type
20
+ backported = false
21
+ backported = true if _first_header_match(x,/^server:.*\(CentOS\).*$/)
22
+ backported = true if _first_header_match(x,/^server:.*\(Red Hat\).*$/)
23
+ backported = true if _first_header_match(x,/^server:.*\(Red Hat Enterprise Linux\).*$/)
24
+
25
+ # grab the version
26
+ version = _first_header_capture(x,/^.*OpenSSL\/([\w\d\.\-]*)\s.*$/i)
27
+
28
+ # return a version string that indicates we can't do inference
29
+ return "#{version} (Backported)" if backported
30
+
31
+ # otherwise just return the version
32
+ version
33
+ },
34
+ :paths => ["#{url}"],
35
+ :inference => true
36
+ }
37
+ ]
38
+ end
39
+
40
+ end
41
+ end
42
+ end
43
+ end
@@ -0,0 +1,46 @@
1
+ module Intrigue
2
+ module Ident
3
+ module Check
4
+ class OpenTextWebSolutionsCMS < Intrigue::Ident::Check::Base
5
+
6
+ def generate_checks(url)
7
+ [
8
+ {
9
+ :type => "fingerprint",
10
+ :category => "application",
11
+ :tags => ["CMS"],
12
+ :vendor => "OpenText",
13
+ :product => "Open Text Web Solutions",
14
+ :references => ["https://www.opentext.com/products-and-solutions/products/customer-experience-management/web-content-management/web-site-management"],
15
+ :version => nil,
16
+ :match_type => :content_body,
17
+ :match_content => /published by open text web solutions (.*.\d)/i,
18
+ :dynamic_version => lambda { |x| _first_body_capture(x, /published by open text web solutions (.*.\d)/i)},
19
+ :match_details => "header match",
20
+ :hide => false,
21
+ :paths => ["#{url}"],
22
+ :inference => true
23
+ },
24
+ {
25
+ :type => "fingerprint",
26
+ :category => "application",
27
+ :tags => ["COTS"],
28
+ :vendor => "OpenText",
29
+ :product => "OpenText FirstClass",
30
+ :references => ["https://www.opentext.com/products-and-solutions/products/specialty-technologies/firstclass"],
31
+ :version => nil,
32
+ :match_type => :content_headers,
33
+ :match_content => /^Server:\ OpenText\ FC\ (Sync\ Services|WebServer\ ((\d{1,3}\.){1,9}\d{1,3})\ .{2,30})$/i,
34
+ :dynamic_version => lambda { |x|
35
+ _first_header_capture(x,/^Server:\ OpenText\ FC\ (Sync\ Services|WebServer\ ((\d{1,3}\.){1,9}\d{1,3})\ .{2,30})$/i) },
36
+ :hide => false,
37
+ :paths => ["#{url}"],
38
+ :inference => true
39
+ }
40
+ ]
41
+ end
42
+
43
+ end
44
+ end
45
+ end
46
+ end
@@ -0,0 +1,27 @@
1
+ module Intrigue
2
+ module Ident
3
+ module Check
4
+ class Openvpn < Intrigue::Ident::Check::Base
5
+
6
+ def generate_checks(url)
7
+ [
8
+ {
9
+ :type => "fingerprint",
10
+ :category => "application",
11
+ :tags => ["Library"],
12
+ :vendor =>"OpenVPN",
13
+ :product =>"Access Server",
14
+ :match_details =>"server header",
15
+ :version => nil,
16
+ :match_type => :content_headers,
17
+ :match_content => /^server: OpenVPN-AS$/i,
18
+ :paths => ["#{url}"],
19
+ :inference => false
20
+ }
21
+ ]
22
+ end
23
+
24
+ end
25
+ end
26
+ end
27
+ end
@@ -0,0 +1,43 @@
1
+
2
+ module Intrigue
3
+ module Ident
4
+ module Check
5
+ class Opscode < Intrigue::Ident::Check::Base
6
+
7
+ def generate_checks(url)
8
+ [
9
+ {
10
+ :type => "fingerprint",
11
+ :category => "application",
12
+ :tags => ["COTS","Development"],
13
+ :vendor => "Opscode",
14
+ :product =>"Chef",
15
+ :match_details =>"Chef Server",
16
+ :version => nil,
17
+ :match_type => :content_body,
18
+ :match_content => /<title>Chef Server<\/title>/,
19
+ :dynamic_version => lambda{|x|
20
+ _first_body_capture(x,/Version\ (.*)\ &mdash;/) },
21
+ :paths => ["#{url}"],
22
+ :inference => true
23
+ },
24
+ {
25
+ :type => "fingerprint",
26
+ :category => "application",
27
+ :tags => ["COTS","Development"],
28
+ :vendor => "Opscode",
29
+ :product =>"Chef",
30
+ :match_details =>"Chef Server",
31
+ :version => nil,
32
+ :match_type => :content_cookies,
33
+ :match_content => /chef-manage/i,
34
+ :paths => ["#{url}"],
35
+ :inference => false
36
+ }
37
+ ]
38
+ end
39
+
40
+ end
41
+ end
42
+ end
43
+ end
@@ -0,0 +1,335 @@
1
+ module Intrigue
2
+ module Ident
3
+ module Check
4
+ class Oracle < Intrigue::Ident::Check::Base
5
+
6
+ def generate_checks(url)
7
+ [
8
+ {
9
+ :type => "fingerprint",
10
+ :category => "application",
11
+ :tags => ["Application Server"],
12
+ :vendor => "Oracle",
13
+ :product =>"Access Management",
14
+ :match_details =>"cookie",
15
+ :references => ["https://docs.oracle.com/cd/E52734_01/oam/AIAAG/GUID-5FD1A6DD-5EE7-4D22-9336-915C62B46C8F.htm#AIAAG297"],
16
+ :version => nil,
17
+ :match_type => :content_cookies,
18
+ :match_content => /ObSSOCookie=/,
19
+ :paths => ["#{url}"],
20
+ :hide => false,
21
+ :inference => false
22
+ },
23
+ {
24
+ :type => "fingerprint",
25
+ :category => "application",
26
+ :tags => ["Application Server"],
27
+ :vendor => "Oracle",
28
+ :product =>"Application Server",
29
+ :match_details =>"server header",
30
+ :references => [],
31
+ :version => nil,
32
+ :match_type => :content_headers,
33
+ :match_content => /Oracle-Application-Server/,
34
+ :hide => false,
35
+ :dynamic_version => lambda { |x|
36
+ _first_header_capture(x,/Oracle-Application-Server-[0-9]+[a-z]?\/(.*?)\ /) },
37
+ :paths => ["#{url}"],
38
+ :inference => true
39
+ },
40
+ {
41
+ :type => "fingerprint",
42
+ :category => "application",
43
+ :tags => ["Application Server"],
44
+ :vendor => "Oracle",
45
+ :product =>"Fusion Middleware",
46
+ :match_details =>"Web Cache Server - server header",
47
+ :references => [],
48
+ :version => nil,
49
+ :match_type => :content_headers,
50
+ :match_content => /Oracle-Web-Cache/,
51
+ :hide => false,
52
+ :dynamic_version => lambda { |x|
53
+ _first_header_capture(x,/Oracle-Web-Cache-[0-9]+[a-z]?\/(.*?)\ /) },
54
+ :paths => ["#{url}"]
55
+ }, {
56
+ :type => "fingerprint",
57
+ :category => "application",
58
+ :tags => ["Application Server"],
59
+ :vendor => "Oracle",
60
+ :product =>"Fusion Middleware",
61
+ :match_details =>"page title & docs link... should give us a version",
62
+ :version => nil,
63
+ :dynamic_version => lambda { |x|
64
+ doc_version = _first_body_capture(x,/download.oracle.com\/docs\/cd\/(.*?)\/index.htm/)
65
+ case doc_version
66
+ when "E15217_01"
67
+ fmw_version = "10.1.4.3"
68
+ when "E15051_01"
69
+ fmw_version = "11.1.1.0"
70
+ when "E12839_01"
71
+ fmw_version = "11.1.1.1"
72
+ when "E15523_01"
73
+ fmw_version = "11.1.1.2"
74
+ when "E14571_01"
75
+ fmw_version = "11.1.1.3"
76
+ when "E17904_01"
77
+ fmw_version = "11.1.1.4"
78
+ when "E21764_01"
79
+ fmw_version = "11.1.1.5"
80
+ else
81
+ fmw_version = nil
82
+ end
83
+ fmw_version
84
+ },
85
+ :match_type => :content_body,
86
+ :references => [
87
+ "https://en.wikipedia.org/wiki/Oracle_Fusion_Middleware",
88
+ "https://docs.oracle.com/cd/E21764_01/index.htm"
89
+ ],
90
+ :match_content => /<title>Welcome to Oracle Fusion Middleware/,
91
+ :hide => false,
92
+ :paths => ["#{url}"],
93
+ :inference => true
94
+ },
95
+ {
96
+ :type => "fingerprint",
97
+ :category => "application",
98
+ :tags => ["Application Server"],
99
+ :vendor => "Oracle",
100
+ :product =>"Glassfish Server",
101
+ :match_details =>"Oracle / Sun GlassFish Enterprise Server",
102
+ :references => [],
103
+ :version => nil,
104
+ :match_type => :content_headers,
105
+ :match_content => /Sun GlassFish Enterprise Server/,
106
+ :hide => false,
107
+ :dynamic_version => lambda { |x|
108
+ _first_header_capture(x,/Sun GlassFish Enterprise Server\sv([\d\.]+)/)
109
+ },
110
+ :paths => ["#{url}"],
111
+ :inference => true
112
+ },
113
+ {
114
+ :type => "fingerprint",
115
+ :category => "application",
116
+ :tags => ["Application Server"],
117
+ :vendor => "Oracle",
118
+ :product =>"Glassfish Server",
119
+ :match_details =>"Oracle / Sun GlassFish Enterprise Server",
120
+ :references => [],
121
+ :version => nil,
122
+ :match_type => :content_headers,
123
+ :match_content => /GlassFish Server Open Source Edition/,
124
+ :hide => false,
125
+ :dynamic_version => lambda { |x|
126
+ _first_header_capture(x,/GlassFish Server Open Source Edition\s+([\d\.]+)$/) },
127
+ :paths => ["#{url}"],
128
+ :inference => true
129
+ },
130
+ {
131
+ :type => "fingerprint",
132
+ :category => "application",
133
+ :tags => ["Web Server"],
134
+ :vendor => "Oracle",
135
+ :product =>"HTTP Server",
136
+ :match_details =>"server header",
137
+ :references => [],
138
+ :version => nil,
139
+ :match_type => :content_headers,
140
+ :match_content => /Oracle-HTTP-Server/,
141
+ :hide => false,
142
+ :dynamic_version => lambda { |x|
143
+ _first_header_capture(x,/Oracle-HTTP-Server\/(.*?)\ /)
144
+ },
145
+ :paths => ["#{url}"],
146
+ :inference => true
147
+ },
148
+ {
149
+ :type => "fingerprint",
150
+ :category => "application",
151
+ :tags => ["Web Server","Embedded"],
152
+ :vendor => "Oracle",
153
+ :product =>"GoAhead Web Server",
154
+ :match_details =>"server header",
155
+ :references => [],
156
+ :version => nil,
157
+ :match_type => :content_headers,
158
+ :match_content => /server: GoAhead-Webs/,
159
+ :hide => false,
160
+ :paths => ["#{url}"],
161
+ :inference => true
162
+ },
163
+ {
164
+ :type => "fingerprint",
165
+ :category => "application",
166
+ :tags => ["Web Server"],
167
+ :vendor => "Oracle",
168
+ :product =>"iPlanet Web Server",
169
+ :match_details =>"server header",
170
+ :references => [],
171
+ :version => nil,
172
+ :match_type => :content_headers,
173
+ :match_content => /server:\ Oracle-iPlanet-Web-Server/,
174
+ :hide => false,
175
+ :dynamic_version => lambda { |x|
176
+ _first_header_capture(x,/Oracle-iPlanet-Web-Server\/(.*)/)
177
+ },
178
+ :paths => ["#{url}"],
179
+ :inference => true
180
+ },
181
+ {
182
+ :type => "fingerprint",
183
+ :category => "application",
184
+ :tags => ["Web Framework"],
185
+ :vendor => "Oracle",
186
+ :product =>"Java",
187
+ :match_details =>"JSESSIONID cookie",
188
+ :references => [
189
+ "https://javarevisited.blogspot.com/2012/08/what-is-jsessionid-in-j2ee-web.html"],
190
+ :version => nil,
191
+ :match_type => :content_cookies,
192
+ :match_content => /JSESSIONID=/,
193
+ :hide => false,
194
+ :paths => ["#{url}"],
195
+ :inference => false
196
+ },
197
+ { ### SPECIFIC TO SAP
198
+ :type => "fingerprint",
199
+ :category => "application",
200
+ :tags => ["Web Framework"],
201
+ :vendor =>"Oracle",
202
+ :product =>"Java",
203
+ :match_details =>"server header",
204
+ :references => [],
205
+ :match_type => :content_headers,
206
+ :match_content => /server: SAP NetWeaver Application Server [\d\.]+ \/ AS Java [\d\.]+/i,
207
+ :dynamic_version => lambda { |x| _first_header_capture(x, /AP NetWeaver Application Server [\d\.]+ \/ AS Java ([\d\.]+)/i) },
208
+ :paths => ["#{url}"],
209
+ :inference => true
210
+ },
211
+ { # TODO - this will tell us J2EE versions, see references!!!
212
+ :type => "fingerprint",
213
+ :category => "application",
214
+ :tags => ["Web Framework"],
215
+ :vendor => "Oracle",
216
+ :product =>"Java Servlet Container",
217
+ :match_details =>"x-header",
218
+ :references => [
219
+ "http://www.ntu.edu.sg/home/ehchua/programming/java/javaservlets.html"],
220
+ :version => nil,
221
+ :dynamic_version => lambda { |x|
222
+ _first_header_capture(x,/^x-powered-by: Servlet\/(.*)JSP.*$/) },
223
+ :match_type => :content_headers,
224
+ :match_content => /x-powered-by: Servlet/,
225
+ :hide => false,
226
+ :paths => ["#{url}"],
227
+ :inference => true
228
+ },
229
+
230
+ { # TODO - this will tell us J2EE versions, see references!!!
231
+ :type => "fingerprint",
232
+ :category => "application",
233
+ :tags => ["Web Framework"],
234
+ :vendor => "Oracle",
235
+ :product =>"Java Server Container",
236
+ :match_details =>"x-header",
237
+ :references => ["http://www.ntu.edu.sg/home/ehchua/programming/java/javaservlets.html"],
238
+ :version => nil,
239
+ :dynamic_version => lambda { |x| _first_header_capture(x,/^x-powered-by: Servlet\/.*JSP\/(.*)$/) },
240
+ :match_type => :content_headers,
241
+ :match_content => /x-powered-by: Servlet\/.*JSP.*/,
242
+ :hide => false,
243
+ :paths => ["#{url}"],
244
+ },
245
+ {
246
+ :type => "fingerprint",
247
+ :category => "application",
248
+ :tags => ["Web Framework"],
249
+ :vendor => "Oracle",
250
+ :product =>"Mojarra",
251
+ :match_details =>"Viewstate inclusion of javaserver faces",
252
+ :references => [
253
+ "http://www.oracle.com/technetwork/java/javaee/javaserverfaces-139869.html",
254
+ "http://www.oracle.com/technetwork/topics/index-090910.html",
255
+ "https://www.owasp.org/index.php/Java_Server_Faces",
256
+ "https://www.alphabot.com/security/blog/2017/java/Misconfigured-JSF-ViewStates-can-lead-to-severe-RCE-vulnerabilities.html"
257
+ ],
258
+ :version => nil,
259
+ :match_type => :content_body,
260
+ :match_content => /javax.faces.ViewState/,
261
+ :hide => false,
262
+ :paths => ["#{url}"],
263
+ :inference => false
264
+ },
265
+ {
266
+ :type => "fingerprint",
267
+ :category => "application",
268
+ :tags => ["Web Server"],
269
+ :vendor => "Oracle",
270
+ :product =>"iPlanet Web Server",
271
+ :match_details =>"server header",
272
+ :references => [],
273
+ :version => nil,
274
+ :match_type => :content_headers,
275
+ :match_content => /server: Sun-ONE-Web-Server.*/i,
276
+ :dynamic_version => lambda { |x|
277
+ _first_header_capture(x,/Server: Sun-ONE-Web-Server\/([\d\.]*).*/i) },
278
+ :hide => false,
279
+ :paths => ["#{url}"],
280
+ :inference => true
281
+ },
282
+ {
283
+ :type => "fingerprint",
284
+ :category => "application",
285
+ :tags => ["Application Server"],
286
+ :vendor => "Oracle",
287
+ :product =>"Weblogic Server",
288
+ :match_details =>"weblogic fault / fail",
289
+ :references => ["https://coderanch.com/t/603067/application-servers/Calling-weblogic-webservice-error"],
290
+ :version => nil,
291
+ :match_type => :content_body,
292
+ :match_content => /<faultcode>env:WebServiceFault/,
293
+ :hide => false,
294
+ :paths => ["#{url}"],
295
+ :inference => false
296
+ },
297
+ {
298
+ :type => "fingerprint",
299
+ :category => "application",
300
+ :tags => ["Application Server"],
301
+ :vendor => "Oracle",
302
+ :product =>"Weblogic Server",
303
+ :match_details =>"generator tag",
304
+ :version => nil,
305
+ :match_type => :content_generator,
306
+ :match_content => /^WebLogic Server$/,
307
+ :hide => false,
308
+ :paths => ["#{url}"],
309
+ :inference => false
310
+ },
311
+ {
312
+ :type => "fingerprint",
313
+ :category => "application",
314
+ :tags => ["Application Server"],
315
+ :vendor => "Oracle",
316
+ :product =>"Weblogic Server",
317
+ :match_details =>"weblogic header",
318
+ :references => [
319
+ "https://support.oracle.com/knowledge/Middleware/2100514_1.html",
320
+ "https://www.qualogy.com/techblog/oracle/how-to-harden-weblogic-and-fusion-middleware-against-worm-attacks"
321
+ ],
322
+ :version => nil,
323
+ :match_type => :content_headers,
324
+ :match_content => /^x-oracle-dms-ecid:/,
325
+ :hide => false,
326
+ :paths => ["#{url}"],
327
+ :inference => true
328
+ }
329
+ ]
330
+ end
331
+
332
+ end
333
+ end
334
+ end
335
+ end