Skip to content

SVCrack Usage

Pinaki edited this page Mar 20, 2021 · 5 revisions

How to use svcrack

SVCrack is another tool of the sipvicious toolset which allows you to crack the password for a specific username/extension on a PBX.

svcrack Usage

examples:
sipvicious_svcrack -u100 -d dictionary.txt udp://10.0.0.1:5080
sipvicious_svcrack -u100 -r1-9999 -z4 10.0.0.1


Options:
  --version             show program's version number and exit
  -h, --help            show this help message and exit
  -v, --verbose         Increase verbosity
  -q, --quiet           Quiet mode
  -p PORT, --port=PORT  Destination port or port ranges of the SIP device - eg
                        -p5060,5061,8000-8100
  -P PORT, --localport=PORT
                        Source port for our packets
  -x IP, --externalip=IP
                        IP Address to use as the external ip. Specify this if
                        you have multiple interfaces or if you are behind NAT
  -b BINDINGIP, --bindingip=BINDINGIP
                        By default we bind to all interfaces. This option
                        overrides that and binds to the specified ip address
  -t SELECTTIME, --timeout=SELECTTIME
                        This option allows you to throttle the speed at which
                        packets are sent. Change this if you're losing
                        packets. For example try 0.5.
  -R, --reportback      Send the author an exception traceback. Currently
                        sends the command line parameters and the traceback
  -A, --autogetip       Automatically get the current IP address. This is
                        useful when you are not getting any responses back due
                        to SIPVicious not resolving your local IP.
  -s NAME, --save=NAME  save the session. Has the benefit of allowing you to
                        resume a previous scan and allows you to export scans
  --resume=NAME         resume a previous scan
  -c, --enablecompact   enable compact mode. Makes packets smaller but
                        possibly less compatible
  -u USERNAME, --username=USERNAME
                        username to try crack
  -d DICTIONARY, --dictionary=DICTIONARY
                        specify a dictionary file with passwords or - for stdin
  -r RANGE, --range=RANGE
                        specify a range of numbers. example:
                        100-200,300-310,400
  -e EXTENSION, --extension=EXTENSION
                        Extension to crack. Only specify this when the
                        extension is different from the username.
  -z PADDING, --zeropadding=PADDING
                        the number of zeros used to padd the password.
                        the options "-r 1-9999 -z 4" would give 0001 0002 0003
                        ... 9999
  -n, --reusenonce      Reuse nonce. Some SIP devices don't mind you reusing
                        the nonce (making them vulnerable to replay attacks).
                        Speeds up the cracking.
  -T TEMPLATE, --template=TEMPLATE
                        A format string which allows us to specify a template
                        for the extensions                       example
                        svwar.py -e 1-999 --template="123%#04i999" would scan
                        between 1230001999 to 1230999999"
  --maximumtime=MAXIMUMTIME
                        Maximum time in seconds to keep sending requests
                        without receiving a response back
  -D, --enabledefaults  Scan for default / typical passwords such as
                        1000,2000,3000 ... 1100, etc. This option is off by
                        default.                       Use --enabledefaults to
                        enable this functionality
  --domain=DOMAIN       force a specific domain name for the SIP message, eg.
                        -d example.org
  --requesturi=REQUESTURI
                        force the first line URI to a specific value; e.g.
                        sip:999@example.org
  -6                    scan an IPv6 address
  -m METHOD, --method=METHOD

Target

svcrack requires the user to pass a target as well as an username to crack. The target can be specified in form of a full URL format, i.e. udp://<host>:<port>. By default it will use guess passwords as numbers but additional options are available which can further help you.

Example:

./svcrack 10.0.0.1 -u 100
./svcrack udp://10.0.0.1:5080 -u 100

To specify a hostname instead of the IP:

./svcrack siphost.com -u 100

To use a IPv6 address as a target, specify the -6 switch:

./svcrack -6 fe80::6ca6:57ff:fecf:a43f -u 100

Options

Save

-s allows one to save a session with all the details of the scan. You must specify a session name which has not been used previously to save a session.

Example

./svcrack -s session1 10.0.0.1 -u 100

This also serves the purpose of being compatible with the input and resume options.

Resume

Resumes a previously incomplete session. To list sessions make use of "svreport.py list". When a session is saved, svcrack will periodically save the current state and also save the state upon exit.

Example

./svcrack --resume session1 -u 100

Destination port

By default, most SIP devices listen on the udp port 5060. However some SIP phones might listen on a high port. Make use of svmap to scan for ports which speak SIP on a target address. You can then pass the non-standard port to svcrack by specifying "-p" option.

Example

./svcrack -p5061 10.0.0.1 -u 100

Timeout or Select time

This option allows you to specify the timeout for the select() function. If the network is slow, then it is recommended that you set this to something higher than the default. The default is 0.005. Try with 0.01 first, and start increasing.

Example

./svcrack -t 0.1 10.0.0.1 -u 100

Compact mode

SIP supports compact mode, where some headers can be written in short form. By default this is disabled because some devices might not support it.

Example

./svcrack -c 10.0.0.1 -u 100

Method

By default, war uses the REGISTER method. However some devices might not reveal existing extensions through this method. You may specify a different method to scan with, such as OPTIONS and INVITE. Note that INVITE can be noisy and generate a "ring" at the other end. For a list of method consult with the relevant RFCs or the wikipedia page.

Example

./svcrack -m INVITE 10.0.0.1 -u 100

Verbose

The verbose gives you more info. If you need to view all debug information, then specify -vvv instead of -v.

Example

./svcrack -vv 10.0.0.1 -u 100

Quiet

Quiet mode does not print anything except for critical errors. Be sure to save to a session if you want to still view the results later on. Example

./svcrack -q 10.0.0.1 -u 100

Report Back

This option allows the end user to send a bug report to the author.

Example

./svcrack -R 10.0.0.1 -s test -u 100

Force scan

svcrack does a sanity check before it starts scanning, to make sure that a PBX server is really listening at the target. This option overrides the sanity check.

Example

./svcrack --force 10.0.0.1 -u 100

Extension range mode

By default svcrack will try to guess numeric ranges between 100 and 999. You can specify the ranges by making use of the following format: start-end,start2-end2,start3-end3,...

Example

./svcrack -e 1-99,1000-9999,150-200 1.0.0.1 -u 100

Zero padding

When making use of the extension range mode, possible extension numbers can be padded with a given number of zeros. For example, with options -z4, when trying extension number 1 the extension would be 0001.

Example

./svcrack -z4 -e1-9999 10.0.0.1 -u 100

Dictionary guessing mode

Dictionary refers to a text file with a list of possible passwords. You can specify - to direct svwar to take input via stdin. This allows for alphanumeric PBX extensions.

Example

./svcrack -d dictionary.txt 10.0.0.1 -u 100

The following is an example of the contents of a dictionary file:

123456
12345
123456789
password
iloveyou<3
princess
1234567
12345678
abc123

For input via STDIN:

echo '1001' | ./svcrack -d - 10.0.0.1 -u 100

Please refer to the SecLists repository for freely available dictionary files, or maskprocessor for generating combinations for possible extension names for STDIN.

Nonce Reuse

Nonce reuse refers to the replay attack technique which could be used to speed up the cracking process:

./svcrack -u 100 -n 10.0.0.1

Enable Defaults

This option allows scanning for default passwords/weak passwords. Can be activated using the -D or the --enabledefaults switch.

./svcrack -u 100 -D 10.0.0.1

Maximum Time

This option decides on what is the max. time to keep sending requests before a response is received.

./svcrack --maximumtime 2 -u 100 10.0.0.1

Further examples

Scan from 00000 to 99999 using padding, and save the session to 'session1':

./svcrack -s session1 -e0-99999 -z5 10.0.0.1 -u 100

SIPVicious Wiki

Clone this wiki locally