2019-10-30 13:21:03 +00:00
|
|
|
#!@PERL_EXECUTABLE@ -w
|
2018-01-31 21:57:17 +00:00
|
|
|
use strict;
|
|
|
|
#
|
|
|
|
# ==========================================================================
|
|
|
|
#
|
|
|
|
# ZoneMinder ONVIF Control Protocol Module
|
|
|
|
# Copyright (C) 2014 Jan M. Hochstein
|
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or
|
|
|
|
# modify it under the terms of the GNU General Public License
|
|
|
|
# as published by the Free Software Foundation; either version 2
|
|
|
|
# of the License, or (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program; if not, write to the Free Software
|
|
|
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
#
|
|
|
|
# ==========================================================================
|
|
|
|
#
|
|
|
|
# This module contains the implementation of the ONVIF capability prober
|
|
|
|
#
|
|
|
|
|
|
|
|
use Getopt::Std;
|
|
|
|
|
|
|
|
require ONVIF::Client;
|
|
|
|
|
|
|
|
|
|
|
|
# ========================================================================
|
|
|
|
# options processing
|
|
|
|
|
|
|
|
$Getopt::Std::STANDARD_HELP_VERSION = 1;
|
|
|
|
|
|
|
|
our ($opt_v);
|
|
|
|
|
2019-10-30 13:21:03 +00:00
|
|
|
my $OPTIONS = 'v';
|
2018-01-31 21:57:17 +00:00
|
|
|
|
2019-10-30 13:21:03 +00:00
|
|
|
sub HELP_MESSAGE {
|
2018-01-31 21:57:17 +00:00
|
|
|
my ($fh, $pkg, $ver, $opts) = @_;
|
2020-05-18 21:57:40 +00:00
|
|
|
print $fh "Usage: " . __FILE__ . " [-v] probe <soap versions> <network interface>\n";
|
2018-01-31 21:57:17 +00:00
|
|
|
print $fh " " . __FILE__ . " [-v] <command> <device URI> <soap version> <user> <password>\n";
|
|
|
|
print $fh <<EOF
|
|
|
|
Commands are:
|
|
|
|
probe - scan for devices on the local network and list them
|
|
|
|
profiles - print the device's supported stream configurations
|
|
|
|
metadata - print some of the device's configuration settings
|
|
|
|
move - move the device (only ptz cameras)
|
|
|
|
Common parameters:
|
|
|
|
-v - increase verbosity
|
|
|
|
Device access parameters (for all commands but 'probe'):
|
|
|
|
device URL - the ONVIF Device service URL
|
2020-05-18 21:57:40 +00:00
|
|
|
soap versions - SOAP versions (1.1 or 1.2 or 1.1,1.2)
|
2018-01-31 21:57:17 +00:00
|
|
|
user - username of a user with access to the device
|
|
|
|
password - password for the user
|
|
|
|
EOF
|
|
|
|
}
|
|
|
|
|
|
|
|
# ========================================================================
|
|
|
|
# MAIN
|
|
|
|
|
|
|
|
if ( !getopts($OPTIONS) ) {
|
|
|
|
HELP_MESSAGE(\*STDOUT);
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
my $action = shift;
|
|
|
|
|
2020-05-18 21:57:40 +00:00
|
|
|
if ( !defined $action ) {
|
2018-01-31 21:57:17 +00:00
|
|
|
HELP_MESSAGE(\*STDOUT);
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
@EXTRA_PERL_LIB@
|
|
|
|
require ZoneMinder::ONVIF;
|
|
|
|
if ( defined $opt_v ) {
|
|
|
|
$ZoneMinder::ONVIF::verbose = 1;
|
2019-10-30 13:21:03 +00:00
|
|
|
} else {
|
|
|
|
$ZoneMinder::ONVIF::verbose = 0;
|
2018-01-31 21:57:17 +00:00
|
|
|
}
|
|
|
|
|
2019-10-30 13:21:03 +00:00
|
|
|
if ( $action eq 'probe' ) {
|
2018-01-31 21:57:17 +00:00
|
|
|
my $soap_version = shift;
|
2020-02-19 19:28:23 +00:00
|
|
|
my $net_interface = shift;
|
|
|
|
ZoneMinder::ONVIF::discover($soap_version, $net_interface);
|
2018-01-31 21:57:17 +00:00
|
|
|
} else {
|
|
|
|
# all other actions need URI and credentials
|
|
|
|
my $url_svc_device = shift @ARGV;
|
|
|
|
my $soap_version = shift @ARGV;
|
|
|
|
my $username = @ARGV ? shift @ARGV : '';
|
|
|
|
my $password = @ARGV ? shift @ARGV: '';
|
|
|
|
|
|
|
|
my $client = ONVIF::Client->new( {
|
2020-05-12 19:49:42 +00:00
|
|
|
verbose => $ZoneMinder::ONVIF::verbose,
|
2019-10-30 13:21:03 +00:00
|
|
|
url_svc_device => $url_svc_device,
|
|
|
|
soap_version => $soap_version } );
|
2018-01-31 21:57:17 +00:00
|
|
|
|
|
|
|
$client->set_credentials($username, $password, 1);
|
|
|
|
|
|
|
|
$client->create_services();
|
|
|
|
|
2019-10-30 13:21:03 +00:00
|
|
|
if ( $action eq 'profiles' ) {
|
2020-05-12 14:49:47 +00:00
|
|
|
my @profiles = ZoneMinder::ONVIF::profiles($client);
|
|
|
|
foreach my $profile ( @profiles ) {
|
2020-05-12 19:49:42 +00:00
|
|
|
my ( $token, $name, $encoding, $width, $height, $frame_rate_limit, $stream_type, $uri ) = @{$profile};
|
2020-05-12 14:49:47 +00:00
|
|
|
print join(', ', $token,
|
|
|
|
$name,
|
|
|
|
$encoding,
|
|
|
|
$width,
|
|
|
|
$height,
|
|
|
|
$frame_rate_limit,
|
2020-05-12 19:49:42 +00:00
|
|
|
$stream_type,
|
2020-05-12 14:49:47 +00:00
|
|
|
$uri,
|
|
|
|
) . "\n";
|
|
|
|
|
|
|
|
} # end foreach profile
|
2020-05-12 19:49:42 +00:00
|
|
|
} elsif ( $action eq 'move' ) {
|
2018-01-31 21:57:17 +00:00
|
|
|
my $dir = shift;
|
|
|
|
ZoneMinder::ONVIF::move($client, $dir);
|
2019-10-30 13:21:03 +00:00
|
|
|
} elsif ( $action eq 'metadata' ) {
|
2018-01-31 21:57:17 +00:00
|
|
|
ZoneMinder::ONVIF::metadata($client);
|
|
|
|
} else {
|
2020-05-12 19:49:42 +00:00
|
|
|
my $media = $client->get_endpoint('media');
|
|
|
|
if ( ! $media ) {
|
|
|
|
print "No media endpoint for client.\n";
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
my $result = $media->$action( { } ,, );
|
|
|
|
if ( $result ) {
|
|
|
|
use XML::LibXML;
|
|
|
|
my $dom = XML::LibXML->load_xml(string=>$result);
|
|
|
|
print "Received message:\n" . $dom->toString(1) . "\n";
|
|
|
|
} else {
|
|
|
|
print("Error: Unknown command \"$action\"");
|
|
|
|
exit(1);
|
|
|
|
}
|
2018-01-31 21:57:17 +00:00
|
|
|
}
|
2020-05-12 19:49:42 +00:00
|
|
|
} # end if probe or other
|
2018-01-31 21:57:17 +00:00
|
|
|
|
|
|
|
1;
|
|
|
|
__END__
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
|
|
|
zmonvif-probe.pl - ZoneMinder ONVIF probing tool
|
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
zmonfig-probe.pl [-v] probe <soap version>
|
|
|
|
[-v] <command> <device URI> <soap version> <user> <password>\n";
|
|
|
|
|
|
|
|
Commands are:
|
|
|
|
probe - scan for devices on the local network and list them
|
|
|
|
profiles - print the device's supported stream configurations
|
|
|
|
metadata - print some of the device's configuration settings
|
|
|
|
move - move the device (only ptz cameras)
|
2020-05-12 19:49:42 +00:00
|
|
|
other - Any command supported by the ONVIF Media element.
|
|
|
|
|
2018-01-31 21:57:17 +00:00
|
|
|
Common parameters:
|
|
|
|
-v - increase verbosity
|
|
|
|
Device access parameters (for all commands but 'probe'):
|
|
|
|
device URL - the ONVIF Device service URL
|
|
|
|
soap version - SOAP version (1.1 or 1.2)
|
|
|
|
user - username of a user with access to the device
|
|
|
|
password - password for the user
|
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
|
|
|
|
=head1 OPTIONS
|
|
|
|
|
|
|
|
-c, --continuous - Run continuously
|
|
|
|
-f, --force - Run even if pid file exists
|
|
|
|
-i, --interactive - Ask before applying any changes
|
|
|
|
-m, --monitor_id - Only consider the given monitor
|
|
|
|
-r, --report - Just report don't actually do anything
|
|
|
|
-s, --storage_id - Specify a storage area to audit instead of all
|
|
|
|
-v, --version - Print the installed version of ZoneMinder
|
|
|
|
|
|
|
|
=cut
|