prol2tp(1)                      ProL2TP Manual                      prol2tp(1)



NAME
       prol2tp - management utility for prol2tpd

SYNOPSIS
       prol2tp [-h] [-d] [command]

       prol2tp  create  tunnel  name <tunnel_name> profile <profile_name> peer
       <peer ip> [ wait ]
       prol2tp create session  name  <session_name>  in  tunnel  <id>  profile
       <profile_name> [ wait ]
       prol2tp destroy tunnel <id> [ wait ]
       prol2tp destroy session <id> in tunnel <id> [ wait ]
       prol2tp recreate tunnel <id>
       prol2tp recreate session <id> in tunnel <id>
       prol2tp show system [ stats ]
       prol2tp show license
       prol2tp show tunnels
       prol2tp show tunnel <id> [ stats ]
       prol2tp show sessions
       prol2tp show session <id> in tunnel <id> [ stats ]
       prol2tp debug system <level>
       prol2tp debug tunnel <id> <level>
       prol2tp debug session <id> in tunnel <id> <level>
       prol2tp update license <filename>
       prol2tp reload config
       prol2tp register license [ name <name> ]
       prol2tp unregister license
       prol2tp checkin license

DESCRIPTION
       prol2tp  is  a  command-line management utility for interactive control
       and query of the prol2tpd L2TP daemon.  It communicates with the daemon
       using an IPC socket.

       The prol2tp utility offers a range of commands, documented below, which
       control its runtime behaviour.

       prol2tp is a part of  the  ProL2TP  suite  of  programs.   For  general
       information on the features of the ProL2TP suite refer to prol2tp(7).

OPTIONS
       -h, --help
              Displays brief usage information

       -d, --debug
              Enables debug logging of IPC messages.

COMMANDS
       prol2tp offers the following commands:

       * create: create tunnel and session instances

       * destroy: destroy tunnel and session instances

       * recreate: tear down and recreate tunnel and session instances

       * show: query daemon state

       * debug: control daemon log levels

       * miscellaneous: reload config, update license, register and unregister
         license

   IDENTIFYING TUNNEL AND SESSION INSTANCES
       Tunnel and session instances can be identified in a number of different
       ways, which are controlled by keywords in the prol2tp command.

       * Identification by administrative name.

         This  method  applies  to  locally-created instances, which must have
         administrative names assigned to them on creation.

         Keyword: name, e.g. tunnel name tunnel_42.

       * Identification by L2TP ID (tunnel ID, or session ID).

         This method applies to any  tunnel  or  session  instance,  including
         those  created  by network request which will not have administrative
         names assigned them.

         Keyword: id, e.g. tunnel id 279127.

   CREATE COMMANDS
       create tunnel name <tunnel_name> profile <profile_name> peer <peer  ip>
       [ wait ]
              Create a new tunnel instance.

              * tunnel_name  is  the administrative name to be assigned to the
                new instance.  Administrative names must be unique,  so  there
                must be no existing tunnel of this name.

              * profile_name  is  the name of the tunnel configuration profile
                to use for the new instance.   This  must  be  a  pre-existing
                profile in the prol2tpd configuration file.

              * peer ip is the IP address of the peer for the tunnel.

              * wait  is an optional keyword: if specified, prol2tp will block
                on the tunnel either being created in the network, or  failing
                due  to  e.g. transport  timeout  or  the peer being down.  By
                default prol2tp returns as soon as prol2tpd has  responded  to
                the  tunnel create request, while the tunnel setup is still in
                progress.

       create   session   name   <session_name>   in   tunnel   <id>   profile
       <profile_name> [ wait ]
              Create a new session instance.

              * session_name  is the administrative name to be assigned to the
                new instance.  Session administrative  names  must  be  unique
                within the parent tunnel.

              * id  identifies  the parent tunnel of the new session instance,
                using either the L2TP tunnel ID, or the administrative name.

              * profile_name refers to the session  configuration  profile  to
                use  for the new instance.  The must be a pre-existing profile
                in the prol2tpd configuration file.

              * wait is an optional keyword: if specified, prol2tp will  block
                on the session either being created in the network, or failing
                due to e.g. transport timeout or  the  peer  being  down.   By
                default  prol2tp  returns as soon as prol2tpd has responded to
                the session create request, while the session setup  is  still
                in progress.

       The create commands can be useful to create L2TP instances dynamically,
       perhaps on a system event, where having the  instance  defined  in  the
       config file prol2tpd.conf isn't convenient.

   DESTROY COMMANDS
       destroy tunnel <id> [ wait ]
              Destroy an existing tunnel instance.

              * id  identifies  the  tunnel  to destroy, using either the L2TP
                tunnel ID, or the administrative name.

              * wait is an optional keyword: if specified, prol2tp will  block
                on  the  tunnel  being torn down and removed from the network.
                By default prol2tp returns as soon as prol2tpd  has  responded
                to the tunnel destroy request.

       destroy session <session id> in tunnel <tunnel id> [ wait ]
              Destroy an existing session instance.

              * session id identifies the session to destroy, using either the
                L2TP session ID, or the administrative name.

              * tunnel id identifies the session's parent tunnel, using either
                the L2TP tunnel ID, or the administrative name.

              * wait  is an optional keyword: if specified, prol2tp will block
                on the session being torn down and removed from  the  network.
                By  default  prol2tp returns as soon as prol2tpd has responded
                to the session destroy request.

       Destroy commands can only  destroy  instances  created  by  the  create
       command.  It is not possible to destroy instances defined in the config
       file prol2tpd.conf.

   RECREATE COMMANDS
       recreate tunnel <tunnel id>
              Tear down and recreate an existing tunnel instance.

              * tunnel id identifies the tunnel to recreate, using either  the
                L2TP tunnel ID, or the administrative name.

       recreate session <session id> in tunnel <tunnel id>
              Tear down and recreate an existing session instance.

              * session  id  identifies  the session to recreate, using either
                the L2TP session ID, or the administrative name.

              * tunnel id identifies the session's parent tunnel, using either
                the L2TP tunnel ID, or the administrative name.

       The  recreate command offers a convenient way to recreate misconfigured
       tunnels and sessions.  It only  applies  to  locally-created  instances
       (i.e. those  from  the  config file or created by IPC request): this is
       because prol2tpd has no way to recreate an instance created by a peer.

   SHOW COMMANDS
       show system [ stats ]
              Display information about  the  system.   The  optional  keyword
              stats displays system statistics.

       show license
              Display   information   about   the  currently  loaded  license,
              including enabled  features  and  tunnel/session  limits.   When
              using  a  Cloud license, this command displays information about
              the license server state.

       show tunnels
              Display a list of tunnel instances with a brief one-line summary
              of tunnel status.

       show tunnel <id> [ stats ]
              Display detailed information about a single tunnel instance.  If
              the optional keyword  stats  is  included  the  output  includes
              control and data plane statistics.

       show sessions
              Display  a  list  of  session  instances  with  a brief one-line
              summary of session status.

       show session <id> in tunnel <id> [ stats ]
              Display detailed information about a  single  session  instance.
              If  the  optional  keyword stats is included the output includes
              data plane statistics.

   DEBUG COMMANDS
       debug system <level>
              Modify log level for prol2tpd core.  This  controls  the  daemon
              logging  level,  and  will  be inherited by tunnels and sessions
              created from that point forward, so long  as  the  configuration
              file doesn't call out a log level.

              Valid  levels  are:  crit,  emerg, error, warning, notice, info,
              debug; corresponding to syslog(3) logging levels.

       debug tunnel <id> <level>
              Modify log level for a specific tunnel instance.  This  controls
              the tunnel's logging level.

              Valid  levels  are:  crit,  emerg, error, warning, notice, info,
              debug; corresponding to syslog(3) logging levels.

       debug session <id> in tunnel <id> <level>
              Modify log level for a specific session instance.  This controls
              the session's logging level.

              Valid  levels  are:  crit,  emerg, error, warning, notice, info,
              debug; corresponding to syslog(3) logging levels.

   MISCELLANEOUS COMMANDS
       update license <filename>
              Update the prol2tpd license file.  This is intended for in-field
              license  upgrades,  allowing  the  running  daemon to be updated
              without taking down the existing tunnel and  session  instances.
              Upon  successful  completion  the  license  will  be  written to
              persistent storage under the default license file path such that
              prol2tpd will load the new license when it next starts up.

       register license [ name <name> ]
              Register  a Cloud license with the ProL2TP license server, which
              is necessary prior  to  running  prol2tpd.   The  optional  name
              parameter  overrides  the  default  name  (hostname)  which  the
              license server stores  to  allow  management  of  Cloud  license
              instances.

       unregister license
              Unregister  a Cloud license by contacting the server to indicate
              that this instance is being decommissioned.

       checkin license
              When using a Cloud license with limit sharing  enabled,  request
              prol2tpd  checks  in  with  the  ProL2TP  license  server.  This
              command may be helpful for debugging connectivity issues between
              prol2tpd  and the ProL2TP license server.  This command may also
              trigger a recalculation of the sharing  of  tunnel  and  session
              limits  between  the  prol2tpd  instances registered against the
              Cloud  license,  which  may  be  helpful  for  managing   client
              migration from one prol2tpd instance to another.

       reload config
              Reread  the  prol2tpd configuration file.  Equivalent of sending
              prol2tpd a SIGHUP signal.

AUTHORS
       Katalix Systems, Ltd.



ProL2TP 2.6.3                     August 2024                       prol2tp(1)