Sha256: 0ef51083422d3f44d0d2b632ecd15499a6f75cb7a06e5e362ddeeff1a6ad9759
Contents?: true
Size: 1.82 KB
Versions: 6
Compression:
Stored size: 1.82 KB
Contents
# frozen_string_literal: true ## # This file is part of WhatWeb and may be subject to # redistribution and commercial restrictions. Please see the WhatWeb # web site for more information on licensing and terms of use. # http://www.morningstarsecurity.com/research/whatweb ## # Version 0.2 # 2016-04-19 # Andrew Horton # Move HTTP server match from passive function to matches[] ## WhatWeb::Plugin.define "Carel-Data-Server" do @author = "Brendan Coles <bcoles@gmail.com>" # 2011-03-07 @version = "0.2" @description = "Pl@ntVisor is a communication data server distributed by CAREL Italy. It is now obsolete and replaced by Pl@ntVisorPRO" # ShodanHQ results as at 2011-03-07 # # 265 for Document follows CarelDataServer # 265 for CarelDataServer # Matches # @matches = [ # Default JavaScript HTML { text: '<script type="text/javascript" language="JavaScript" src="/MPwebCoreFn.js"></script>' }, # Default logo HTML { text: '<img style="position:absolute;left:0;top:0;" src=plv_primoLW.jpg zwidth="100%" zheight="100%">' }, # Default background image { url: "/plv_primoLW.jpg", md5: "df1e885e87f6ab393a90b908b6ce5dc4" }, # Version Detection # HTTP Server header { version: /^CarelDataServer\/([\d\.]{1,10})/, search: "headers[server]" }, ] # Passive # def passive(target) m = [] # Server: CarelDataServer if /^CarelDataServer\/[\d\.]{1,10}/.match?(target.headers["server"]) # Account Detection # LoginName select tag accounts = target.body.scan(/<select name='LoginName'>(.*)<\/select>/m).flatten if target.body =~ /<select name='LoginName'>(.*)<\/select>/m m << { account: accounts.to_s.scan(/<option value="([^"]+)"[^>]*>[^<]+<\/option>/).flatten } if accounts.to_s =~ /<option value="([^"]+)"[^>]*>[^<]+<\/option>/ end # Return passive matches m end end
Version data entries
6 entries across 6 versions & 1 rubygems