/pyigdc

A command line UPnP IGD Client/Lib in python

Primary LanguagePythonBSD 2-Clause "Simplified" LicenseBSD-2-Clause

pyigdc

This is a UPnP IGD command line client/lib in python. Support following services:

  • WANIPConnection v1
  • WANIPv6FirewallControl v1
  • Vendor specific action could be supported via "custom" action

Target for developer and protocol testing.

Installation

Require python 2.7 (python3 is not supported)

Should be able to run on both Windows and *nix

Usage as a Command Line Client

python igdc.py -h
usage: igdc.py [-h] [-d] [-pp] -s SOURCE [-u URL]
               {add,del,getextip,getgpm,getspm,getnrss,getwdd,setwdd,getidt,setidt,getadt,setadt,getsi,rt,ft,rc,getct,setct,custom,getfwstatus,addph,getopht,updateph,delph,getphpkts,chkph}
               ...

UPnP IGD Client by Hu Jun; Implements WANIPConnection and
WANIPv6FirewallControl Services

positional arguments:
  {add,del,getextip,getgpm,getspm,getnrss,getwdd,setwdd,getidt,setidt,getadt,setadt,getsi,rt,ft,rc,getct,setct,custom,getfwstatus,addph,getopht,updateph,delph,getphpkts,chkph}
    add                 add port mapping
    del                 del port mapping
    getextip            get external IP
    getgpm              get generic pm entry
    getspm              get specific port mapping
    getnrss             get NAT and RSIP status
    getwdd              get warn disconnect delay
    setwdd              set warn disconnect delay
    getidt              get idle disconnect time
    setidt              set idle disconnect time
    getadt              get auto disconnect time
    setadt              set auto disconnect time
    getsi               get status info
    rt                  request termination
    ft                  force termination
    rc                  request connection
    getct               get connection type info
    setct               set connection type
    custom              use custom action
    getfwstatus         get IPv6 FW status
    addph               add IPv6 FW Pinhole
    getopht             get IPv6 FW OutboundPinholeTimeout
    updateph            update IPv6 FW pinhole
    delph               delete IPv6 FW pinhole
    getphpkts           get number of packets go through specified IPv6FW
                        pinhole
    chkph               check if the specified pinhole is working

optional arguments:
  -h, --help            show this help message and exit
  -d, --DEBUG           enable DEBUG output
  -pp, --pretty_print   enable xml pretty output for debug and custom action
  -s SOURCE, --source SOURCE
                        source address of requests
  -u URL, --url URL     control URL

add -h after each action to see help for the specific action:

python igdc.py add -h
usage: igdc.py add [-h] [-r REMOTE] [-d DESC] [-e {1,0}] [-du DURATION]
                   intIP intPort extPort {UDP,TCP}

positional arguments:
  intIP                 Internal IP
  intPort               Internal Port
  extPort               External Port
  {UDP,TCP}             Protocol

optional arguments:
  -h, --help            show this help message and exit
  -r REMOTE, --remote REMOTE
                        remote host
  -d DESC, --desc DESC  Description of port mapping
  -e {1,0}, --enabled {1,0}
                        enable or disable port mapping
  -du DURATION, --duration DURATION
                        Duration of the mapping

all getxxx action's output is in json format

Use Custom Action

python igdc.py custom -h
usage: igdc.py custom [-h] [-svc {WANIPConnection,WANIPv6FirewallControl}]
                      [-iargs INPUT_ARGS]
                      method_name

positional arguments:
  method_name           name of custom action

optional arguments:
  -h, --help            show this help message and exit
  -svc {WANIPConnection,WANIPv6FirewallControl}
                        IGD service, default is WANIPConnection
  -iargs INPUT_ARGS, --input_args INPUT_ARGS
                        input args, the format is same as python dict,e.g.
                        '{"NewPortMappingIndex": [0, "ui4"]}'

method_name is the name of the action defined in the IGD service description XML.

-iargs specify a list of input arguments to the action,the format is same as python dict:

  • key is the argument name
  • value is a two element list, 1st one is the value of arguement, 2nd one is the UPnP data type defined in the service description XML

The ouput of this action is the responed XML from the server.

An example to use custom action achieve action:GetGenericPortMappingEntry

python igdc.py -pp -s 40.0.0.100 custom GetGenericPortMappingEntry -iargs '{"NewPortMappingIndex": [0, "ui4"]}'
<?xml version="1.0" ?>
<s:Envelope s:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
	<s:Body>
		<u:GetGenericPortMappingEntryResponse xmlns:u="urn:schemas-upnp-org:service:WANIPConnection:1">
			<NewRemoteHost/>
			<NewExternalPort>2100</NewExternalPort>
			<NewProtocol>TCP</NewProtocol>
			<NewInternalPort>2100</NewInternalPort>
			<NewInternalClient>40.0.0.100</NewInternalClient>
			<NewEnabled>1</NewEnabled>
			<NewPortMappingDescription/>
			<NewLeaseDuration>0</NewLeaseDuration>
		</u:GetGenericPortMappingEntryResponse>
	</s:Body>
</s:Envelope>

Usage as a Library

from igdc import IGDClient

see comments in igdc.py for detail usage

License

MIT