1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
|
##
# 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 Andrew Horton - added matches[] for devices without a Server: header, removed out of date examples
Plugin.define "Grandstream-Phone" do
author "Brendan Coles <bcoles@gmail.com>" # 2011-03-14
version "0.2"
description "Grandstream Networks is the leading manufacturer of IP voice/video telephony and video surveillance solutions. - Homepage: http://www.grandstream.com/"
# ShodanHQ results as at 2011-03-14 #
# 25,344 for Grandstream
# Examples #
examples %w|
216.54.149.49
84.28.128.218
62.165.255.156
78.32.89.204
109.73.41.210
|
matches [
{:text=>'<title>Grandstream Device Configuration</title>'},
{:text=>'All Rights Reserved Grandstream Networks, Inc.', :url=>"/"}
]
# Passive #
def passive
m=[]
# HTTP Server Header
if @headers["server"] =~ /^Grandstream/
# Model Detection
m << { :model=>@headers["server"].scan(/^Grandstream ([^\s]+) [\d\.]+$/) } if @headers["server"] =~ /^Grandstream ([^\s]+) [\d\.]+$/
# Version Detection
m << { :version=>@headers["server"].scan(/^Grandstream [^\s]+ ([\d\.]+)$/) } if @headers["server"] =~ /^Grandstream [^\s]+ ([\d\.]+)$/
m << { :version=>@headers["server"].scan(/^Grandstream\/([\d\.]+)$/) } if @headers["server"] =~ /^Grandstream\/([\d\.]+)$/
end
# Return passive matches
m
end
end
|