Provided by: libnet-upnp-perl_1.4.2-1_all bug

NAME

       Net::UPnP::AV::MediaServer - Perl extension for UPnP.

SYNOPSIS

           use Net::UPnP::ControlPoint;
           use Net::UPnP::AV::MediaServer;

           my $obj = Net::UPnP::ControlPoint->new();

           @dev_list = $obj->search(st =>'upnp:rootdevice', mx => 3);

           $devNum= 0;
           foreach $dev (@dev_list) {
               $device_type = $dev->getdevicetype();
               if  ($device_type ne 'urn:schemas-upnp-org:device:MediaServer:1') {
                   next;
               }
               print "[$devNum] : " . $dev->getfriendlyname() . "\n";
               unless ($dev->getservicebyname('urn:schemas-upnp-org:service:ContentDirectory:1')) {
                   next;
               }
               $mediaServer = Net::UPnP::AV::MediaServer->new();
               $mediaServer->setdevice($dev);
               @content_list = $mediaServer->getcontentlist(ObjectID => 0);
               foreach $content (@content_list) {
                   print_content($mediaServer, $content, 1);
               }
               $devNum++;
           }

           sub print_content {
               my ($mediaServer, $content, $indent) = @_;
               my $id = $content->getid();
               my $title = $content->gettitle();
               for ($n=0; $n<$indent; $n++) {
                   print "\t";
               }
               print "$id = $title";
               if ($content->isitem()) {
                   print " (" . $content->geturl();
                   if (length($content->getdate())) {
                       print " - " . $content->getdate();
                   }
                   print " - " . $content->getcontenttype() . ")";
               }
               print "\n";
               unless ($content->iscontainer()) {
                   return;
               }
               @child_content_list = $mediaServer->getcontentlist(ObjectID => $id );
               if (@child_content_list <= 0) {
                   return;
               }
               $indent++;
               foreach my $child_content (@child_content_list) {
                   print_content($mediaServer, $child_content, $indent);
               }
           }

DESCRIPTION

       The package is a extention UPnP/AV media server.

METHODS

       new - create new Net::UPnP::AV::MediaServer.
               $mservier = Net::UPnP::AV::MediaServer();

           Creates a new object. Read `perldoc perlboot` if you don't understand that.

           The new object is not associated with any UPnP devices. Please use setdevice() to set
           the device.

       setdevice - set a UPnP devices
               $mservier->setdevice($dev);

           Set a device to the object.

       browse - browse the content directory.
               @action_response = $mservier->browse(
                                                   ObjectID => $objid, # 0
                                                   BrowseFlag => $browseFlag, # 'BrowseDirectChildren'
                                                   Filter => $filter, # "*'
                                                   StartingIndex => $startIndex, # 0
                                                   RequestedCount => $reqCount, # 0
                                                   SortCriteria => $sortCrit # ''
                                                   );

           Browse the content directory and return the action response,
           Net::UPnP::ActionResponse.

       getcontentlist - get the content list.
               @content_list = $mservier->getcontentlist(
                                                   ObjectID => $objid, # 0
                                                   Filter => $filter, # "*'
                                                   StartingIndex => $startIndex, # 0
                                                   RequestedCount => $reqCount, # 0
                                                   SortCriteria => $sortCrit # ''
                                                   );

           Browse the content directory and return the content list. Please see
           Net::UPnP::AV::Content, Net::UPnP::AV::Item and Net::UPnP::AV::Container.

SEE ALSO

       Net::UPnP::AV::Content

       Net::UPnP::AV::Item

       Net::UPnP::AV::Container

AUTHOR

       Satoshi Konno skonno@cybergarage.org

       CyberGarage http://www.cybergarage.org

COPYRIGHT AND LICENSE

       Copyright (C) 2005 by Satoshi Konno

       It may be used, redistributed, and/or modified under the terms of BSD License.