Freeswitch中mod_commonds

 

mod_commands


Table of Contents (click to expand)

  • 0. About
  • 1. Usage 
    • 1.1 CLI
    • 1.2 API/Event Interfaces
    • 1.3 Scripting Interfaces
    • 1.4 From the Dialplan
  • 2. Format of returned data
  • 3. Core Commands 
    • 3.1 acl  
      • 3.1.1 Syntax
      • 3.1.2 Examples
    • 3.2 alias 
      • 3.2.1 Syntax
      • 3.2.2 Examples
    • 3.3 bgapi  
      • 3.3.1 Syntax
      • 3.3.2 Examples
  • cond
  • domain_exists
  • eval
  • expand
  • fsctl 
    • api_expansion
    • calibrate_clock
    • debug_level 
    • debug_sql
    • default_dtmf_duration
    • flush_db_handles
    • hupall
    • last_sps
    • loglevel
    • max_sessions
    • max_dtmf_duration
    • min_dtmf_duration
    • min_idle_cpu
    • pause
    • pause_check
    • ready_check
    • reclaim_mem
    • recover
    • resume
    • save_history
    • send_sighup
    • shutdown
    • shutdown_check
    • sps
    • sync_clock
    • sync_clock_when_idle
    • verbose_events
  • global_getvar
  • global_setvar
  • group
  • group_call
  • help
  • host_lookup
  • hupall
  • in_group
  • is_lan_addr
  • json
  • load
  • md5
  • module_exists
  • msleep
  • nat_map
  • regex
  • reload
  • reloadacl
  • reloadxml
  • show 
    • Tips For Showing Calls and Channels
  • shutdown
  • status
  • strftime_tz
  • unload
  • version
  • xml_locate
  • xml_wrap

·  Call Management Commands 

  • break
  • create_uuid
  • originate 
    • Arguments
    • Variables
    • Examples
  • pause
  • uuid_answer
  • uuid_audio
  • uuid_break
  • uuid_bridge
  • uuid_broadcast
  • uuid_buglist
  • uuid_chat
  • uuid_debug_media 
    • Read Format
    • Write Format
  • uuid_deflect
  • uuid_displace
  • uuid_display
  • uuid_dual_transfer
  • uuid_dump
  • uuid_early_ok
  • uuid_exists
  • uuid_flush_dtmf
  • uuid_fileman
  • uuid_getvar
  • uuid_hold
  • uuid_kill
  • uuid_limit
  • uuid_media
  • uuid_media_reneg
  • uuid_park
  • uuid_pre_answer
  • uuid_preprocess
  • uuid_recv_dtmf
  • uuid_send_dtmf
  • uuid_send_info
  • uuid_session_heartbeat
  • uuid_setvar
  • uuid_setvar_multi
  • uuid_simplify
  • uuid_transfer
  • uuid_phone_event

·  Record/Playback Commands 

  • uuid_record

·  Limit Commands 

  • limit_reset
  • limit_status
  • limit_usage
  • uuid_limit_release
  • limit_interval_reset

·  Miscellaneous Commands 

  • bg_system
  • echo
  • file_exists
  • find_user_xml
  • list_users
  • sched_api
  • sched_broadcast
  • sched_del
  • sched_hangup
  • sched_transfer
  • stun
  • system
  • time_test
  • timer_test
  • tone_detect
  • unsched_api
  • url_decode
  • url_encode
  • user_data
  • user_exists

·  See Also 


0. About

mod_commands processes the FreeSWITCH API commands.

FreeSWITCH API 

The public FreeSWITCH API  consists of all the commands that can be issued to FreeSWITCH via

  • its console, fs_cli,
  • the event socket interface, and
  • scripting interfaces.

The set of available commands is dependent on which modules are loaded. The authoritative set of commands for your installation is the union of the sets of commands registered by each module.

To see a list of available API commands simply type help or show api at the CLI.

1. Usage

1.1 CLI

See below.

1.2 API/Event Interfaces

  • mod_event_socket
  • mod_erlang_event
  • mod_xml_rpc

1.3 Scripting Interfaces

  • mod_perl
  • mod_v8
  • mod_python
  • mod_lua

1.4 From the Dialplan 

An API command can be called from the dialplan. Example:

Invoke API Command From Dialplan 

 <extension name="Make API call from Dialplan">

   <condition field="destination_number" expression="^(999)$">

     <!-- next line calls hupall, so be careful! -->

     <action application="set" data="api_result=${hupall(normal_clearing)}"/>

   </condition>

 </extension>

Other examples:

Other Dialplan API Command Examples 

 <action application="set" data="api_result=${status()}"/>

 <action application="set" data="api_result=${version()}"/>

 <action application="set" data="api_result=${strftime()}"/>

 <action application="set" data="api_result=${expr(1+1)}"/>

API commands with multiple arguments usually have the arguments separated by a space:

Multiple Arguments 

<action application="set" data="api_result=${sched_api(+5 none avmd ${uuid} start)}"/>

Dialplan Usage

If you are calling an API command from the dialplan make absolutely certain that there isn't already a dialplan application that gives you the functionality you are looking for. See mod_dptools for a list of dialplan applications, they are quite extensive.

2. Format of returned data

Results of some status and listing commands are presented in comma delimited lists by default.

Data returned from some modules may also contain commas, making it difficult to automate result processing. They may be able to be retrieved as

  • XML by appending the string as xml 
  • JSON by appending the string as json 
  • the default format but changing the default comma delimiter by appending as delim <custom_delimiter>

to the end of the command string.

3. Core Commands

Extraction script

Mitch Capper wrote a Perl script to extract commands from mod_commands's source code, mod_commands.c , but should work for most other files as well.

Extraction Perl Script  Expand source 

#!/usr/bin/perl

use strict;

open (fl,"src/mod/applications/mod_commands/mod_commands.c");

my $cont;

{

local $/ = undef;

$cont = <fl>;

}

close fl;

my %DEFINES;

my $reg_define = qr/[A-Za-z0-9_]+/;

my $reg_function = qr/[A-Za-z0-9_]+/;

my $reg_string_or_define = qr/(?:(?:$reg_define)|(?:"[^"]*"))/;

#load defines

while ($cont =~ /

^\s* \#define \s+ ($reg_define) \s+ \"([^"]*)\"

/mgx){

warn "$1 is #defined multiple times" if ($DEFINES{$1});

$DEFINES{$1} = $2;

}

sub resolve_str_or_define($){

my ($str) = @_;

if ($str =~ s/^"// && $str =~ s/"$//){ #if starts and ends with a quote strip them off and return the str

return $str;

}

warn "Unable to resolve define: $str" if (! $DEFINES{$str});

return $DEFINES{$str};

}

#parse commands

while ($cont =~ /

SWITCH_ADD_API \s* \( ([^,]+) #interface $1

,\s* ($reg_string_or_define) # command $2

,\s* ($reg_string_or_define) # command description $3

,\s* ($reg_function) # function $4

,\s* ($reg_string_or_define) # usage $5

\s*\);

/sgx){

my ($interface,$command,$descr,$function,$usage) = ($1,$2,$3,$4,$5);

$command = resolve_str_or_define($command);

$descr = resolve_str_or_define($descr);

$usage = resolve_str_or_define($usage);

warn "Found a not command interface of: $interface for command: $command" if ($interface ne "commands_api_interface");

print "$command -- $descr -- $usage\n";

}

3.1 acl 

Match an IP address against an access control list (ACL).

3.1.1 Syntax

Syntax 

acl <ip_address> <acl_name>

3.1.2 Examples

Examples 

acl 1.2.3.4 test

3.2 alias

Provide an alternative name (i.e., an alias) to commonly used commands on the CLI to save on some keystrokes.

Subcommand

Description

add

Create an alias.

stickyadd

Create an alias that persists across restarts.

del

Delete alias.

3.2.1 Syntax

Syntax 

alias add <alias> <command(s)>

alias stickyadd <alias> <command(s)>

alias del [<alias>|*]

3.2.2 Examples

Examples 

freeswitch> alias add reloadall reloadacl reloadxml

+OK

freeswitch> alias add unreg sofia profile internal flush_inbound_reg

+OK

freeswitch> alias stickyadd reloadall reloadacl reloadxml

+OK

freeswitch> alias del reloadall

+OK

3.3 bgapi 

Execute an API command in a thread.

3.3.1 Syntax

Syntax 

bgapi <command>[ <command_args>]

3.3.2 Examples

Command

Description

Syntax

Examples

acl

Match an IP address against an access control list (ACL).

acl <ip_address> <acl_name>

acl 1.2.3.4 test

alias

Provide an alternative name (i.e., an alias) to commonly used commands on the CLI to save on some keystrokes.

Subcommand

Description

add

Create an alias.

stickyadd

Create an alias that persists across restarts.

del

Delete alias.

alias add <alias> <command(s)>

alias stickyadd <alias> <command(s)>

alias del [<alias>|*]

freeswitch> alias add reloadall reloadacl reloadxml
+OK

freeswitch> alias add unreg sofia profile internal flush_inbound_reg
+OK

freeswitch> alias stickyadd reloadall reloadacl reloadxml
+OK

freeswitch> alias del reloadall
+OK

bgapi

Execute an API command in a thread.

bgapi <command>[ <command_args>]

complete

Complete.

TODO That description is not very helpful.

complete add <word>|del [<word>|*]

complete

Complete.

Usage: complete add <word>|del [<word>|*]

cond

Evaluate a conditional expression.

Usage: cond <expr> ? <true val> : <false val>

Operators supported by <expr> are:

  • == (equal to)
  • != (not equal to)
  • >  (greater than)
  • >= (greater than or equal to)
  • <  (less than)
  • <= (less than or equal to)

How are values compared?

  • two strings are compared as strings
  • two numbers are compared as numbers
  • a string and a number are compared as strlen(string) and numbers

For example, foo == 3 evaluates to true, and foo == three to false.

Examples (click to expand)

Example:

Return true if first value is greater than the second 

cond 5 > 3 ? true : false

true

Example in dialplan:

<action application="set" data="voicemail_authorized=${cond(${sip_authorized} == true ? true : false)}"/>

Slightly more complex example:

<action application="set" data="voicemail_authorized=${cond(${sip_acl_authed_by} == domains ? false : ${cond(${sip_authorized} == true ? true : false)})}"/>

Note about syntax

The whitespace around the question mark and colon are required since FS-5945. Before that, they were optional. If the spaces are missing, the cond function will return -ERR.

domain_exists

Check if a FreeSWITCH domain exists.

Usage: domain_exists <domain>

eval

Eval (noop). Evaluates a string, expands variables. Those variables that are set only during a call session require the uuid of the desired session or else return "-ERR no reply".

Usage: eval [uuid:<uuid> ]<expression>

Examples:

eval ${domain}

10.15.0.94

eval Hello, World!

Hello, World!

eval uuid:e72aff5c-6838-49a8-98fb-84c90ad840d9 ${channel-state}

CS_EXECUTE

expand

Execute an API command with variable expansion.

Usage: expand [uuid:<uuid> ]<cmd> <args>

Example:

expand originate sofia/internal/1001%${domain} 9999

In this example the value of ${domain} is expanded. If the domain were, for example, "192.168.1.1" then this command would be executed:

originate sofia/internal/1001%192.168.1.1 9999

fsctl

Send control messages to FreeSWITCH.

USAGE: fsctl

   [

   api_expansion [on|off] |

   calibrate_clock |

   debug_level [level] |

   debug_sql |

   default_dtmf_duration [n] |

   flush_db_handles |

   hupall |

   last_sps |

   loglevel [level] |

   max_dtmf_duration [n] |

   max_sessions [n] |

   min_dtmf_duration [n] |

   min_idle_cpu [d] |

   pause [inbound|outbound] |

   pause_check [inbound|outbound] |

   ready_check |

   reclaim_mem |

   recover |

   resume [inbound|outbound] |

   save_history |

   send_sighup |

   shutdown [cancel|elegant|asap|now|restart] |

   shutdown_check |

   sps |

   sps_peak_reset |

   sql [start] |

   sync_clock |

   sync_clock_when_idle |

   threaded_system_exec |

   verbose_events [on|off]

   ]

fsctl arguments 

api_expansion

Usage: fsctl api_expansion [on|off]

Toggles API expansion. With it off, no API functions can be expanded inside channel variables like ${show channels} This is a specific security mode that is not often used.

calibrate_clock

Usage: fsctl calibrate_clock

Runs an algorithm to compute how long it actually must sleep in order to sleep for a true 1ms.  It's only useful in older kernels that don't have timerfd.  In those older kernels FS auto detects that it needs to do perform that computation. This command just repeats the calibration.

debug_level 

Usage: fsctl debug_level [level]

Set the amount of debug information that will be posted to the log. 1 is less verbose while 9 is more verbose. Additional debug messages will be posted at the ALERT loglevel.

0 - fatal errors, panic

1 - critical errors, minimal progress at subsystem level

2 - non-critical errors

3 - warnings, progress messages

5 - signaling protocol actions (incoming packets, ...)

7 - media protocol actions (incoming packets, ...)

9 - entering/exiting functions, very verbatim progress

debug_sql

Usage: fsctl debug_sql

Toggle core SQL debugging messages on or off each time this command is invoked. Use with caution on busy systems. In order to see all messages issue the "logelevel debug" command on the fs_cli interface.

default_dtmf_duration

Usage: fsctl default_dtmf_duration [int]

int = number of clock ticks

Example:

fsctl default_dtmf_duration 2000

This example sets the default_dtmf_duration switch parameter to 250ms. The number is specified in clock ticks (CT) where duration (milliseconds) = CT / 8 or CT = duration * 8

The default_dtmf_duration specifies the DTMF duration to use on originated DTMF events or on events that are received without a duration specified. This value is bounded on the lower end by min_dtmf_duration and on the upper end by max_dtmf_duration. So max_dtmf_duration >= default_dtmf_duration >= min_dtmf_duration . This value can be set persistently in switch.conf.xml

To check the current value:

fsctl default_dtmf_duration 0

FS recognizes a duration of 0 as a status check. Instead of setting the value to 0, it simply returns the current value.

flush_db_handles

Usage: fsctl flush_db_handles

Flushes cached database handles from the core db handlers. FreeSWITCH reuses db handles whenever possible, but a heavily loaded FS system can accumulate a large number of db handles during peak periods while FS continues to allocate new db handles to service new requests in a FIFO manner. "fsctl flush_db_handles" closes db connections that are no longer needed to avoid exceeding connections to the database server.

hupall

Usage: fsctl hupall <clearing_type> dialed_ext <extension>

Disconnect existing calls to a destination and post a clearing cause.

For example, to kill an active call with normal clearing and the destination being extension 1000:

fsctl hupall normal_clearing dialed_ext 1000

last_sps

Usage: fsctl last_sps

Query the actual sessions-per-second.

fsctl last_sps

+OK last sessions per second: 723987253

(Your mileage might vary.)

loglevel

Usage: fsctl loglevel [level]

Filter much detail the log messages will contain when displayed on the fs_cli interface. See mod_console for legal values of "level" and further discussion.

The available loglevels can be specified by number or name:

0 - CONSOLE

1 - ALERT

2 - CRIT

3 - ERR

4 - WARNING

5 - NOTICE

6 - INFO

7 - DEBUG

max_sessions

Usage: fsctl max_sessions [int]

Set how many simultaneous call sessions FS will allow. This value can be ascertained by load testing, but is affected by processor speed and quantity, network and disk bandwidth, choice of codecs, and other factors. See switch.conf.xml for the persistent setting max-sessions.

max_dtmf_duration

Usage: fsctl max_dtmf_duration [int]

Default = 192000 clock ticks

Example:

fsctl max_dtmf_duration 80000

This example sets the max_dtmf_duration switch parameter to 10,000ms (10 seconds). The integer is specified in clock ticks (CT) where CT / 8 = ms. The max_dtmf_duration caps the playout of a DTMF event at the specified duration. Events exceeding this duration will be truncated to this duration. You cannot configure a duration that exceeds this setting. This setting can be lowered, but cannot exceed 192000 (the default). This setting cannot be set lower than min_dtmf_duration. This setting can be set persistently in switch.conf.xml as max-dtmf-duration.

To query the current value:

fsctl max_dtmf_duration 0

FreeSWITCH recognizes a duration of 0 as a status check. Instead of setting the value to 0, it simply returns the current value.

min_dtmf_duration

Usage: fsctl min_dtmf_duration [int]

Default = 400 clock ticks

Example:

fsctl min_dtmf_duration 800

This example sets the min_dtmf_duration switch parameter to 100ms. The integer is specified in clock ticks (CT) where CT / 8 = ms. The min_dtmf_duration specifies the minimum DTMF duration to use on outgoing events. Events shorter than this will be increased in duration to match min_dtmf_duration. You cannot configure a DTMF duration on a profile that is less than this setting. You may increase this value, but cannot set it lower than 400 (the default). This value cannot exceed max_dtmf_duration. This setting can be set persistently in switch.conf.xml as min-dtmf-duration.

It is worth noting that many devices squelch in-band DTMF when sending RFC 2833. Devices that squelch in-band DTMF have a certain reaction time and clamping time which can sometimes reach as high as 40ms, though most can do it in less than 20ms. As the shortness of your DTMF event duration approaches this clamping threshold, the risk of your DTMF being ignored as a squelched event increases. If your call is always IP-IP the entire route, this is likely not a concern. However, when your call is sent to the PSTN, the RFC 2833 DTMF events must be encoded in the audio stream. This means that other devices down the line (possibly a PBX or IVR that you are calling) might not hear DTMF tones that are long enough to decode and so will ignore them entirely. For this reason, it is recommended that you do not send DTMF events shorter than 80ms.

TODO RFC 2833 is obsoleted by RFC 4733.

Checking the current value:

fsctl min_dtmf_duration 0

FreeSWITCH recognizes a duration of 0 as a status check. Instead of setting the value to 0, it simply returns the current value.

min_idle_cpu

Usage: fsctl min_idle_cpu [int]

Allocates the minimum percentage of CPU idle time available to other processes to prevent FreeSWITCH from consuming all available CPU cycles.

Example:

fsctl min_idle_cpu 10

This allocates a minimum of 10% CPU idle time which is not available for processing by FS. Once FS reaches 90% CPU consumption it will respond with cause code 503 to additional SIP requests until its own usage drops below 90%, while reserving that last 10% for other processes on the machine.

 

pause

Usage: fsctl pause [inbound|outbound]

Pauses the ability to receive inbound or originate outbound calls, or both directions if the keyword is omitted. Executing fsctl pause inbound will also prevent registration requests from being processed. Executing fsctl pause outbound will result in the Critical log message "The system cannot create any outbound sessions at this time" in the FS log.

Use resume with the corresponding argument to restore normal operation.

pause_check

Usage: fsctl pause_check [inbound|outbound]

Returns true if the specified mode is active.

Examples:

fsctl pause_check inbound

true

indicates that inbound calls and registrations are paused. Use fsctl resume inbound to restore normal operation.

fsctl pause_check

true

indicates that both inbound and outbound sessions are paused. Use fsctl resume to restore normal operation.

ready_check

Usage: fsctl ready_check

Returns true if the system is in the ready state, as opposed to awaiting an elegant shutdown or other not-ready state.

reclaim_mem

Usage: fsctl reclaim_mem

recover

Usage: fsctl recover

Sends an endpoint–specific recover command to each channel detected as recoverable. This replaces “sofia recover” and makes it possible to have multiple endpoints besides SIP implement recovery.

resume

Usage: fsctl resume [inbound|outbound]

Resumes normal operation after pausing inbound, outbound, or both directions of call processing by FreeSWITCH.

Example:

fsctl resume inbound

+OK

Resumes processing of inbound calls and registrations. Note that this command always returns +OK, but the same keyword must be used that corresponds to the one used in the pause command in order to take effect.

save_history

Usage: fsctl save_history

Write out the command history in anticipation of executing a configuration that might crash FS. This is useful when debugging a new module or script to allow other developers to see what commands were executed before the crash.

send_sighup

Usage: fsctl send_sighup

Does the same thing that killing the FS process with -HUP would do without having to use the UNIX kill command. Useful in environments like Windows where there is no kill command or in cron or other scripts by using fs_cli -x "fsctl send_sighup" where the FS user process might not have privileges to use the UNIX kill command.

shutdown

Usage: fsctl shutdown [asap|asap restart|cancel|elegant|now|restart|restart asap|restart elegant]

  • cancel - discontinue a previous shutdown request.
  • elegant - wait for all traffic to stop, while allowing new traffic.
  • asap - wait for all traffic to stop, but deny new traffic.
  • now - shutdown FreeSWITCH immediately.
  • restart - restart FreeSWITCH immediately following the shutdown.

When giving "elegant", "asap" or "now" it's also possible to add the restart command:

shutdown_check

Usage: fsctl shutdown_check

Returns true if FS is shutting down, or shutting down and restarting.

sps

Usage: fsctl sps [int]

This changes the sessions-per-second limit from the value initially set in switch.conf

sync_clock

Usage: fsctl sync_clock

FreeSWITCH will not trust the system time. It gets one sample of system time when it first starts and uses the monotonic clock after that moment. You can sync it back to the current value of the system's real-time clock with fsctl sync_clock

Note: fsctl sync_clock immediately takes effect, which can affect the times on your CDRs. You can end up underbilling/overbilling, or even calls hungup before they originated. e.g. if FS clock is off by 1 month, then your CDRs will show calls that lasted for 1 month!

See fsctl sync_clock_when_idle which is much safer.

sync_clock_when_idle

Usage: fsctl sync_clock_when_idle

Synchronize the FreeSWITCH clock to the host machine's real-time clock, but wait until there are 0 channels in use. That way it doesn't affect any CDRs.

verbose_events

Usage: fsctl verbose_events [on|off]

Enables verbose events. Verbose events have every channel variable in every event for a particular channel. Non-verbose events have only the pre-selected channel variables in the event headers.

See switch.conf.xml for the persistent setting of verbose-channel-events.

global_getvar

Gets the value of a global variable. If the parameter is not provided then it gets all the global variables.

Usage: global_getvar [<varname>]

global_setvar

Sets the value of a global variable.

Usage: global_setvar <varname>=<value>

Example:

global_setvar outbound_caller_id=2024561000

group

TODO

group_call

Returns the bridge string defined in a call group.

Usage: group_call group@domain[+F|+A|+E]

+F will return the group members in a serial fashion separated by | (the pipe character)

+A (default) will return them in a parallel fashion separated by , (comma)

+E will return them in a enterprise fashion separated by :_: (colon underscore colon).

There is no space between the domain and the optional flag. See Groups in the XML User Directory for more information.

Please note: If you need to have outgoing user variables set in leg B, make sure you don't have dial-string and group-dial-string in your domain or dialed group variables list; instead set dial-string or group-dial-string in the default group of the user. This way group_call will return user/101 and user/ would set all your user variables to the leg B channel.

The B leg receives a new variable, dialed_group, containing the full group name.

help

Show help for all the API commands.

Usage: help

host_lookup

Performs a DNS lookup on a host name.

Usage: host_lookup <hostname>

hupall

Disconnect existing channels.

Usage: hupall <cause> [<variable> <value>]

All channels with <variable> set to <value> will be disconnected with <cause> code.

Example:

originate {foo=bar}sofia/internal/someone1@server.com,sofia/internal/someone2@server.com &park

hupall normal_clearing foo bar

To hang up all calls on the switch indiscriminately:

hupall system_shutdown

in_group

Determine if a user is a member of a group.

Usage: in_group <user>[@<domain>] <group_name>

is_lan_addr

See if an IP is a LAN address.

Usage: is_lan_addr <ip>

json

JSON API

Usage: json {"command" : "...", "data" : "..."}

Example 

> json {"command" : "status", "data" : ""}

{"command":"status","data":"","status":"success","response":{"systemStatus":"ready","uptime":{"years":0,"days":20,"hours":20,"minutes":37,"seconds":4,"milliseconds":254,"microseconds":44},"version":"1.6.9 -16-d574870 64bit","sessions":{"count":{"total":132,"active":0,"peak":2,"peak5Min":0,"limit":1000},"rate":{"current":0,"max":30,"peak":2,"peak5Min":0}},"idleCPU":{"used":0,"allowed":99.733333},"stackSizeKB":{"current":240,"max":8192}}}

load

Load external module

Usage: load <mod_name>

Example:

load mod_v8

md5

Return MD5 hash for the given input data

Usage: md5 hash-key

Example:

md5 freeswitch-is-awesome

765715d4f914bf8590d1142b6f64342e

module_exists

Check if module is loaded.

Usage: module_exists <module>

Example:

module_exists mod_event_socket

true

msleep

Sleep for x number of milliseconds

Usage: msleep <number of milliseconds to sleep>

nat_map

Manage Network Address Translation mapping.

Usage: nat_map [status|reinit|republish] | [add|del] <port> [tcp|udp] [sticky] | [mapping] <enable|disable>

  • status - Gives the NAT type, the external IP, and the currently mapped ports.
  • reinit - Completely re-initializes the NAT engine. Use this if you have changed routes or have changed your home router from NAT mode to UPnP mode.
  • republish - Causes FreeSWITCH to republish the NAT maps. This should not be necessary in normal operation.
  • mapping - Controls whether port mapping requests will be sent to the NAT (the command line option of -nonatmap can set it to disable on startup). This gives the ability of still using NAT for getting the public IP without opening the ports in the NAT.

Note: sticky makes the mapping stay across FreeSWITCH restarts. It gives you a permanent mapping.

Warning: If you have multiple network interfaces with unique IP addresses defined in sip profiles using the same port, nat_map *will* get confused when it tries to map the same ports for multiple profiles. Set up a static mapping between the public address and port and the private address and port in the sip_profiles to avoid this problem.

regex

Evaluate a regex (regular expression).

Usage: regex <data>|<pattern>[|<subst string>][|(n|b)]

       regex m:/<data>/<pattern>[/<subst string>][/(n|b)]

       regex m:~<data>~<pattern>[~<subst string>][~(n|b)]

This command behaves differently depending upon whether or not a substitution string and optional flag is supplied:

  • If a subst is not supplied, regex returns either "true" if the pattern finds a match or "false" if not.
  • If a subst is supplied, regex returns the subst value on a true condition.
  • If a subst is supplied, on a false (no pattern match) condition regex returns:
    • the source string with no flag;
    • with the n flag regex returns null which forces the response "-ERR no reply" from regex;
    • with the b flag regex returns "false"

The regex delimiter defaults to the | (pipe) character. The delimiter may be changed to ~ (tilde) or / (forward slash) by prefixing the regex with m:

Examples:

regex test1234|\d                  <== Returns "true"

regex m:/test1234/\d               <== Returns "true"

regex m:~test1234~\d               <== Returns "true"

regex test|\d                      <== Returns "false"

regex test1234|(\d+)|$1            <== Returns "1234"

regex sip:foo@bar.baz|^sip:(.*)|$1 <== Returns "foo@bar.baz"

regex testingonetwo|(\d+)|$1       <== Returns "testingonetwo" (no match)

regex m:~30~/^(10|20|40)$/~$1      <== Returns "30" (no match)

regex m:~30~/^(10|20|40)$/~$1~n    <== Returns "-ERR no reply" (no match)

regex m:~30~/^(10|20|40)$/~$1~b    <== Returns "false" (no match)

Logic in revision 14727 if the source string matches the result then the condition was false however there was a match and it is 1001.

regex 1001|/(^\d{4}$)/|$1

  • See also Regular_Expression

reload

Reload a module.

Usage: reload <mod_name>

reloadacl

Reload Access Control Lists after modifying them in autoload_configs/acl.conf.xml and as defined in extensions in the user directory conf/directory/*.xml

Usage: reloadacl [reloadxml]

reloadxml

Reload conf/freeswitch.xml settings after modifying configuration files.

Usage: reloadxml

show

Display various reports, VERY useful for troubleshooting and confirming proper configuration of FreeSWITCH. Arguments can not be abbreviated, they must be specified fully.

Usage: show [

   aliases |

   api |

   application |

   bridged_calls |

   calls [count] |

   channels [count|like <match string>] |

   chat |

   codec |

   complete |

   detailed_bridged_calls |

   detailed_calls |

   dialplan |

   endpoint |

   file |

   interface_types |

   interfaces |

   limits

   management |

   modules |

   nat_map |

   registrations |

   say |

   tasks |

   timer |

   ] [as xml|as delim <delimiter>]

XML formatted:

show foo as xml

JSON formatted:

show foo as json

Example 

fs_cli -x "show channels as json" | jq

Example output 

{

  "row_count": 1,

  "rows": [

    {

      "uuid": "aa47bc9c-ab5e-11ea-85f1-311ce82e049e",

      "direction": "inbound",

      "created": "2020-06-10 17:09:26",

      "created_epoch": "1591823366",

      "name": "sofia/internal/1019@192.0.2.10",

      "state": "CS_EXECUTE",

      "cid_name": "1019",

      "cid_num": "1019",

      "ip_addr": "192.0.2.50",

      "dest": "55",

      "application": "echo",

      "application_data": "",

      "dialplan": "XML",

      "context": "default",

      "read_codec": "PCMU",

      "read_rate": "8000",

      "read_bit_rate": "64000",

      "write_codec": "PCMU",

      "write_rate": "8000",

      "write_bit_rate": "64000",

      "secure": "",

      "hostname": "hostname.local",

      "presence_id": "1019@192.0.2.10",

      "presence_data": "",

      "accountcode": "1019",

      "callstate": "ACTIVE",

      "callee_name": "",

      "callee_num": "",

      "callee_direction": "",

      "call_uuid": "",

      "sent_callee_name": "",

      "sent_callee_num": "",

      "initial_cid_name": "1019",

      "initial_cid_num": "1019",

      "initial_ip_addr": "192.0.2.50",

      "initial_dest": "55",

      "initial_dialplan": "XML",

      "initial_context": "default"

    }

  ]

}

Change delimiter:

show foo as delim |

  • aliases – list defined command aliases
  • api – list API commands exposed by loadable modules
  • application – list applications exposed by loadable modules, notably mod_dptools
  • bridged_calls – deprecated, use "show calls"
  • calls [count] – list details of currently active calls; the keyword "count" eliminates the details and only prints the total count of calls
  • channels [count|like <match string>] – list current channels; see Channels vs Calls 
    • count – show only the count of active channels, no details
    • like <match string> – filter results to include only channels that contain <match string> in uuid, channel name, cid_number, cid_name, presence data fields.
  • chat – list chat interfaces
  • codec – list codecs that are currently loaded in FreeSWITCH
  • complete – list command argument completion tables
  • detailed_bridged_calls – same as "show detailed_calls"
  • detailed_calls – like "show calls" but with more fields
  • dialplan – list dialplan interfaces
  • endpoint – list endpoint interfaces currently available to FS
  • file – list supported file format interfaces
  • interface_types – list all interface types with a summary count of each type of interface available
  • interfaces – enumerate all available interfaces by type, showing the module which exposes each interface
  • limits – list database limit interfaces
  • management – list management interfaces
  • module – enumerate modules and the path to each
  • nat_map – list Network Address Translation map
  • registrations – enumerate user extension registrations
  • say – enumerate available TTS (text-to-speech) interface modules with language supported
  • tasks – list FS tasks
  • timer – list timer modules

Tips For Showing Calls and Channels

The best way to get an understanding of all of the show calls/channels is to use them and observe the results. To display more fields:

  • show detailed_calls
  • show bridged_calls
  • show detailed_bridged_calls

These three take the expand on information shown by "show calls". Note that "show detailed_calls" replaces "show distinct_channels". It provides similar, but more detailed, information. Also note that there is no "show detailed_channels" command, however using "show detailed_calls" will yield the same net result: FreeSWITCH lists detailed information about one-legged calls and bridged calls by using "show detailed_calls", which can be quite useful while configuring and troubleshooting FS.

Filtering Results

To filter only channels matching a specific uuid or related to a specific call, set the presence_data channel variable in the bridge or originate application to a unique string. Then you can use:

show channels like foo

to list only those channels of interest. The like directive filters on these fields:

  • uuid
  • channel name
  • caller id name
  • caller id number
  • presence_data

NOTE: presence_data must be set during bridge or originate and not after the channel is established.

shutdown

Stop the FreeSWITCH program.

Usage: shutdown

This works from the local console (FreeSWITCH running in the foreground) as well as fs_cli. To shutdown FS from an API call you should use "fsctl shutdown" which offers a number of options.

Shutdown from the console or fs_cli ignores arguments and exits immediately!

status

Show current FS status. Very helpful information to provide when asking questions on the mailing list or irc channel.

Usage: status

freeswitch@internal> status

UP 17 years, 20 days, 10 hours, 10 minutes, 31 seconds, 571 milliseconds, 721 microseconds

FreeSWITCH (Version 1.5.8b git 87751f9 2013-12-13 18:13:56Z 32bit) is ready  <!-- FS version -->

53987253 session(s) since startup                                            <!-- cumulative total number of channels created since FS started -->

127 session(s) - peak 127, last 5min 253                                     <!-- current number of active channels -->

55 session(s) per Sec out of max 60, peak 55, last 5min 253                  <!-- current channels per second created, max cps set in switch.conf.xml -->

1000 session(s) max                                                          <!-- set in switch.conf.xml -->

min idle cpu 0.00/97.71                                                      <!-- minimum reserved idle CPU time before refusing new calls, set in switch.conf.xml -->

strftime_tz

Displays formatted time, converted to a specific timezone. See /usr/share/zoneinfo/zone.tab for the standard list of Linux timezones.

Usage: strftime_tz <timezone> [format_string]

Example:

strftime_tz US/Eastern %Y-%m-%d %T

unload

Unload external module.

Usage: unload <mod_name>

version

Show version of the switch

Usage: version [short]

Examples:

freeswitch@internal> version

FreeSWITCH Version 1.5.8b+git~20131213T181356Z~87751f9eaf~32bit (git 87751f9 2013-12-13 18:13:56Z 32bit)

freeswitch@internal> version short

1.5.8b

xml_locate

Write active xml tree or specified branch to stdout.

Usage: xml_locate [root | <section> | <section> <tag> <tag_attr_name> <tag_attr_val>]

xml_locate root will return all XML being used by FreeSWITCH

xml_locate <section>: Will return the XML corresponding to the specified <section>

xml_locate directory

xml_locate configuration

xml_locate dialplan

xml_locate phrases

Example:

xml_locate directory domain name example.com

xml_locate configuration configuration name ivr.conf

xml_wrap

Wrap another API command in XML.

Usage: xml_wrap <command> <args>

Call Management Commands

break

Deprecated. See uuid_break.

create_uuid

Creates a new UUID and returns it as a string.

Usage: create_uuid

originate

Originate a new call.

Usage 

originate <call_url> <exten>|&<application_name>(<app_args>) [<dialplan>] [<context>] [<cid_name>] [<cid_num>] [<timeout_sec>]

FreeSWITCH will originate a call to <call_url> as Leg A. If that leg supervises within 60 seconds FS will continue by searching for an extension definition in the specified dialplan for <exten> or else execute the application that follows the & along with its arguments.

Originate Arguments 

Arguments

  • <call_url> URL you are calling. For more info on sofia SIP URL syntax see: FreeSwitch Endpoint Sofia
  • Destination, one of:
    • <exten> Destination number to search in dialplan; note that registered extensions will fail this way, use &bridge(user/xxxx) instead
    • &<application_name>(<app_args>)
      • "&" indicates what follows is an application name, not an exten
      • (<app_args>) is optional (not all applications require parameters, e.g. park)
      • The most commonly used application names include:
        park, bridge, javascript/lua/perl, playback (remove mod_native_file).
      • Note: Use single quotes to pass arguments with spaces, e.g. '&lua(test.lua arg1 arg2)'
      • Note: There is no space between & and the application name
  • <dialplan> Defaults to 'XML' if not specified.
  • <context> Defaults to 'default' if not specified.
  • <cid_name> CallerID name to send to Leg A.
  • <cid_num> CallerID number to send to Leg A.
  • <timeout_sec> Timeout in seconds; default = 60 seconds.

Originate Variables 

Variables

These variables can be prepended to the dial string inside curly braces and separated by commas. Example:

originate {sip_auto_answer=true,return_ring_ready=false}user/1001 9198

Variables within braces must be separated by a comma.

  • group_confirm_key
  • group_confirm_file
  • forked_dial
  • fail_on_single_reject
  • ignore_early_media - must be defined on Leg B in bridge or originate command to stop remote ringback from being heard by Leg A
  • return_ring_ready
  • originate_retries
  • originate_retry_sleep_ms
  • origination_caller_id_name
  • origination_caller_id_number
  • originate_timeout
  • sip_auto_answer

Description of originate's related variables 

Originate Examples 

Examples

You can call a locally registered sip endpoint 300 and park the call like so Note that the "example" profile used here must be the one to which 300 is registered. Also note the use of % instead of @ to indicate that it is a registered extension.

   originate sofia/example/300%pbx.internal &park()

Or you could instead connect a remote sip endpoint to extension 8600

   originate sofia/example/300@foo.com 8600

Or you could instead connect a remote SIP endpoint to another remote extension

   originate sofia/example/300@foo.com &bridge(sofia/example/400@bar.com)

Or you could even run a Javascript application test.js

   originate sofia/example/1000@somewhere.com &javascript(test.js)

To run a javascript with arguments you must surround it in single quotes.

   originate sofia/example/1000@somewhere.com '&javascript(test.js myArg1 myArg2)'

Setting channel variables to the dial string

   originate {ignore_early_media=true}sofia/mydomain.com/18005551212@1.2.3.4 15555551212

Setting SIP header variables to send to another FS box during originate

originate {sip_h_X-varA=111,sip_h_X-varB=222}sofia/mydomain.com/18005551212@1.2.3.4 15555551212

Note: you can set any channel variable, even custom ones. Use single quotes to enclose values with spaces, commas, etc.

   originate {my_own_var=my_value}sofia/mydomain.com/that.ext@1.2.3.4 15555551212

   originate {my_own_var='my value'}sofia/mydomain.com/that.ext@1.2.3.4 15555551212

If you need to fake the ringback to the originated endpoint try this:

   originate {ringback=\'%(2000,4000,440.0,480.0)\'}sofia/example/300@foo.com &bridge(sofia/example/400@bar.com)

To specify a parameter to the Leg A call and the Leg B bridge application:

originate {'origination_caller_id_number=2024561000'}sofia/gateway/whitehouse.gov/2125551212 &bridge(['effective_caller_id_number=7036971379']sofia/gateway/pentagon.gov/3035554499)

If you need to make originate return immediately when the channel is in "Ring-Ready" state try this:

   originate {return_ring_ready=true}sofia/gateway/someprovider/919246461929 &socket('127.0.0.1:8082 async full')

More info on return_ring_ready 

You can even set music on hold for the ringback if you want:

   originate {ringback=\'/path/to/music.wav\'}sofia/gateway/name/number &bridge(sofia/gateway/siptoshore/12425553741)

You can originate a call in the background (asynchronously) and playback a message with a 60 second timeout.

   bgapi originate {ignore_early_media=true,originate_timeout=60}sofia/gateway/name/number &playback(message)

You can specify the UUID of an originated call by doing the following:

  • Use create_uuid to generate a UUID to use.
  • This will allow you to kill an originated call before it is answered by using uuid_kill.
  • If you specify origination_uuid, it will remain the UUID for the answered call leg for the whole session.

    originate {origination_uuid=...}user/100@domain.name.com

TODO Event List#1.21CHANNEL_UUIDevent also mention the origination_uuid in conjunction with the bridge command, but couldn't find it documented there.

Here's an example of originating a call to the echo conference (an external sip URL) and bridging it to a local user's phone:

   originate sofia/internal/9996@conference.freeswitch.org &bridge(user/105@default)

Here's an example of originating a call to an extension in a different context than 'default' (required for the FreePBX which uses context_1, context_2, etc.):

   originate sofia/internal/2001@foo.com 3001 xml context_3

You can also originate to multiple extensions as follows:

   originate user/1001,user/1002,user/1003 &park()

To put an outbound call into a conference at early media, either of these will work (they are effectively the same thing)

   originate sofia/example/300@foo.com &conference(conf_uuid-TEST_CON)

   originate sofia/example/300@foo.com conference:conf_uuid-TEST_CON inline

   

See mod_dptools: Inline Dialplan for more detail on 'inline' Dialplans

An example of using loopback and inline on the A-leg can be found in this mailing list post 

originate的语法:

originate <call_url> <exten>|&<application_name>(<app_args>)

[<dialplan>] [<context>] [<cid_name>] [<cid_num>] [<timeout_sec>]

首先,它的第一个参数call_url是呼叫字符串。第二个参数可以是一个exten(这个一会再讲),或者&加上 一个AppApp的参数要放到括号里,如:

originate user/1000 &echo

originate user/1000 &playback(/tmp/sound.wav)

originate user/1000 &record(/tmp/recording.wav)

这是最简单的形式,首先,originate会产生一个Channel,它会呼叫user/1000这个用户。请注意,这是一个 单腿的通话,因此只有一个Channel。但一个Channel有两端,一端是1000这个用户,另一端是FreeSWITCH(我们 上面已经说过,实现上是1000在跟FreeSWITCH的某个App通话,如这里的echoplaybackrecord)。 user/1000接电话后(严格说是收到它的earlymedia后),FreeSWITCH即开始在该Channel上执行&后面的 App。但这种形式只能执行一个App,如果要执行多个,就需要将电话转入Dialplan,可以使用下面的形式:

originate user/1000 9196

originate user/1000 9196 XML default

上面两个命令的效果是一样的。它们的作用是,在user/1000接听电话后,电话的另一端(也就是

FreeSWITCH)需要对电话进行路由,在这里它要将电话路由到9196这个Extension上,第一条命令由于没有指定是

哪个Dialplan,因此它会在默认的XML Dialplan中查找,同时XML Dialplan需要一个Context,它默认就是

default。它的效果跟直接用软电话拨打9196这个分机一样(不同的是呼叫方向的问题,这种情况相当于回拨)。

当然,除此之外,它还可以加一些可选的参数,用于指定来电显示(Caller ID)的名字(cid_name)和号码

cid_number),以及呼叫超时的秒数,如:

originate user/1000 9196 XML default 'Seven Du' 9196 30

当然,我们这里学了inline Dialplan,所以你也可以用下面这种形式:

originate user/1000 echo inline

请注意,在XML Dialplan中,9196是一个分机号,而inline Dialplan中的echo是一个App,当然你也可以顺

序执行多个App。如下列第一条originate命令分别执行answer(应答)、playback(播放语音)、record(录

音),第二条则分别执行playbackbridge

originate user/1000 answer,playback:/tmp/pleace_leave_a_message.wav,record:/tmp/recording.wav

inline

originate user/1000 playback:/tmp/beep.wav,bridge:user/1001 inline

有时候,App的参数中可能会有逗号,因而会与默认的App间的逗号分隔符相冲突,以下的m语法形式将默认的

逗号改为^分隔(相当于转义:

originate user/1000

'm:^:playback/tmp/beep.wav^bridge:

{ignore_early_media=true,originate_caller_id_number=1000}user/1001'

inline

其中,“m:^表示将App间的分隔符临时改为了“^,所以后面的bridge中的参数中的逗号就不会误认为是

App间的分隔符了。

当然你也可以把inlineDialplan用在任何需要Dialplan的地方,如(以下两行实为一行):

uuid_transfer 2bde6598-0f1a-48fe-80bc-a457a31b0055

'set:test_var=test_value,info,palyback:/tmp/beep.wav,record:/tmp/recording.wav'

上述命令会将一个Channel转入一个inline Dialplan,它首先执行set以设置一个test_var的通道变量,然后

执行info在日志中打印当前Channel的详细情况,接下来播放一个声音文件(如beep应该是的一声),然后

开始录音。

pause

Pause <uuid> playback of recorded media that was started with uuid_broadcast.

Usage 

pause <uuid> <on|off>

Turning pause "on" activates the pause function, i.e. it pauses the playback of recorded media. Turning pause "off" deactivates the pause function and resumes playback of recorded media at the same point where it was paused.

Note: always returns -ERR no reply when successful; returns -ERR No such channel! when uuid is invalid.

uuid_answer

Answer a channel

Usage 

uuid_answer <uuid>

See Also

  • mod_dptools: answer

uuid_audio

Adjust the audio levels on a channel or mute (read/write) via a media bug.

Usage 

uuid_audio <uuid> [start [read|write] [[mute|level] <level>]|stop]

<level> is in the range from -4 to 4, 0 being the default value.

Level is required for both mute|level params:

freeswitch@internal> uuid_audio 0d7c3b93-a5ae-4964-9e4d-902bba50bd19 start write mute <level>

freeswitch@internal> uuid_audio 0d7c3b93-a5ae-4964-9e4d-902bba50bd19 start write level <level>

(This command behaves funky. Requires further testing to vet all arguments. - JB)

See Also

  • mod_dptools: set audio level

uuid_break

Break out of media being sent to a channel. For example, if an audio file is being played to a channel, issuing uuid_break will discontinue the media and the call will move on in the dialplan, script, or whatever is controlling the call.

Usage: uuid_break <uuid> [all]

If the all flag is used then all audio files/prompts/etc. that are queued up to be played to the channel will be stopped and removed from the queue, otherwise only the currently playing media will be stopped.

uuid_bridge

Bridge two call legs together.

Usage 

uuid_bridge <uuid> <other_uuid>

uuid_bridge needs at least any one leg to be in the answered state. If, for example, one channel is parked and another channel is actively conversing on a call, executing uuid_bridge on these 2 channels will drop the existing call and bridge together the specified channels.

mod_dptools: bridge VS uuid_bridge

https://lists.freeswitch.org/pipermail/freeswitch-users/2014-September/108166.html

uuid_broadcast

Execute an arbitrary dialplan application, typically playing a media file, on a specific uuid. If a filename is specified then it is played into the channel(s). To execute an application use "app::args" syntax.

Usage 

uuid_broadcast <uuid> <path> [aleg|bleg|both]

Execute an application on a chosen leg(s) with optional hangup afterwards:

Usage 

uuid_broadcast <uuid> app[![hangup_cause]]::args [aleg|bleg|both]

Here are some examples:

Examples 

uuid_broadcast 336889f2-1868-11de-81a9-3f4acc8e505e sorry.wav both

uuid_broadcast 336889f2-1868-11de-81a9-3f4acc8e505e say::en\snumber\spronounced\s12345 aleg

uuid_broadcast 336889f2-1868-11de-81a9-3f4acc8e505e say!::en\snumber\spronounced\s12345 aleg

uuid_broadcast 336889f2-1868-11de-81a9-3f4acc8e505e say!user_busy::en\snumber\spronounced\s12345 aleg

uuid_broadcast 336889f2-1868-11de-81a9-3f4acc8e505e playback!user_busy::sorry.wav aleg

uuid_buglist

List the media bugs on channel. Output is formatted as XML.

Usage 

uuid_buglist <uuid>

Example 

uuid_buglist c2746178-ab61-11ea-86b8-311ce82e049e

Example output 

<media-bugs>

 <media-bug>

  <function>session_record</function>

  <target>rtmp://domain.local/stream:teststream</target>

  <thread-locked>0</thread-locked>

 </media-bug>

</media-bugs>

uuid_chat

Send a chat message.

Usage 

uuid_chat <uuid> <text>

If the endpoint associated with the session <uuid> has a receive_event handler, this message gets sent to that session and is interpreted as an instant message.

uuid_debug_media

Debug media, either audio or video.

Usage 

uuid_debug_media <uuid> <read|write|both|vread|vwrite|vboth> <on|off>

Use "read" or "write" for the audio direction to debug, or "both" for both directions. And prefix with v for video media.

uuid_debug_media emits a HUGE amount of data. If you invoke this command from fs_cli, be prepared.

Example output 

R sofia/internal/1003@192.168.65.3 b= 172 192.168.65.3:17668 192.168.65.114:16072 192.168.65.114:16072 pt=0 ts=2981605109 m=0

W sofia/internal/1003@192.168.65.3 b= 172 192.168.65.3:17668 192.168.65.114:16072 192.168.65.114:16072 pt=0 ts=12212960 m=0

R sofia/internal/1003@192.168.65.3 b= 172 192.168.65.3:17668 192.168.65.114:16072 192.168.65.114:16072 pt=0 ts=2981605269 m=0

W sofia/internal/1003@192.168.65.3 b= 172 192.168.65.3:17668 192.168.65.114:16072 192.168.65.114:16072 pt=0 ts=12213120 m=0

Read Format

"R %s b=%4ld %s:%u %s:%u %s:%u pt=%d ts=%u m=%d\n"

where the values are:

  • switch_channel_get_name(switch_core_session_get_channel(session)),
  • (long) bytes,
  • my_host, switch_sockaddr_get_port(rtp_session->local_addr),
  • old_host, rtp_session->remote_port,
  • tx_host, switch_sockaddr_get_port(rtp_session->from_addr),
  • rtp_session->recv_msg.header.pt,
  • ntohl(rtp_session->recv_msg.header.ts),
  • rtp_session->recv_msg.header.m

Write Format

"W %s b=%4ld %s:%u %s:%u %s:%u pt=%d ts=%u m=%d\n"

where the values are:

  • switch_channel_get_name(switch_core_session_get_channel(session)),
  • (long) bytes,
  • my_host, switch_sockaddr_get_port(rtp_session->local_addr),
  • old_host, rtp_session->remote_port,
  • tx_host, switch_sockaddr_get_port(rtp_session->from_addr),
  • send_msg->header.pt,
  • ntohl(send_msg->header.ts),
  • send_msg->header.m);

uuid_deflect

Deflect an answered SIP call off of FreeSWITCH by sending the REFER method

Usage: uuid_deflect <uuid> <sip URL>

uuid_deflect waits for the final response from the far end to be reported. It returns the sip fragment from that response as the text in the FreeSWITCH response to uuid_deflect. If the far end reports the REFER was successful, then FreeSWITCH will issue a bye on the channel. (*)

(*) Starting with FreeSWITCH 1.10.7, a variable named sip_refer_continue_after_reply is introduced, if True, will let the current call continues as is, after sending the REFER message. This is useful when testing rfc4579 REFER method to request a Focus to Add a New Resource to a Conference

Example 

uuid_deflect 0c9520c4-58e7-40c4-b7e3-819d72a98614 sip:info@example.net

Response:

  Content-Type: api/response

  Content-Length: 30

  +OK:SIP/2.0 486 Busy Here

uuid_displace

Displace the audio for the target <uuid> with the specified audio <file>.

Usage: uuid_displace <uuid> [start|stop] <file> [<limit>] [mux]

Arguments:

  • uuid = Unique ID of this call (see 'show channels')
  • start|stop = Start or stop this action
  • file = path to an audio source (.wav file, shoutcast stream, etc...)
  • limit = limit number of seconds before terminating the displacement
  • mux = multiplex; mix the original audio together with 'file', i.e. both parties can still converse while the file is playing (if the level is not too loud)

To specify the 5th argument 'mux' you must specify a limit; if no time limit is desired on playback, then specify 0.

Examples 

cli> uuid_displace 1a152be6-2359-11dc-8f1e-4d36f239dfb5 start /sounds/test.wav 60

cli> uuid_displace 1a152be6-2359-11dc-8f1e-4d36f239dfb5 stop /sounds/test.wav

uuid_display

Updates the display on a phone if the phone supports this. This works on some SIP phones right now including Polycom and Snom.

Usage: <uuid> name|number

Note the pipe character separating the Caller ID name and Caller ID number.

This command makes the phone re-negotiate the codec. The SIP -> RTP Packet Size should be 0.020 seconds. If it is set to 0.030 on the Cisco SPA series phones it causes a DTMF lag. When DTMF keys are pressed on the phone they are can be seen on the fs_cli 4-6 seconds late.

Example:

freeswitch@sidious> uuid_display f4053af7-a3b9-4c78-93e1-74e529658573 Fred Jones|1001

+OK Success

uuid_dual_transfer

Transfer each leg of a call to different destinations.

Usage: <uuid> <A-dest-exten>[/<A-dialplan>][/<A-context>] <B-dest-exten>[/<B-dialplan>][/<B-context>]

uuid_dump

Dumps all variable values for a session.

Usage: uuid_dump <uuid> [format]

Format options: txt (default, may be omitted), XML, JSON, plain

uuid_early_ok

Stops the process of ignoring early media, i.e. if ignore_early_media=true, this stops ignoring early media coming from Leg B and responds normally.

Usage: uuid_early_ok <uuid>

uuid_exists

Checks whether a given UUID exists.

Usage: uuid_exists <uuid>

Returns true or false.

uuid_flush_dtmf

Flush queued DTMF digits

Usage: uuid_flush_dtmf <uuid>

uuid_fileman

Manage the audio being played into a channel from a sound file

Usage: uuid_fileman <uuid> <cmd:val>

Commands are:

  • speed:<+[step]>|<-[step]>
  • volume:<+[step]>|<-[step]>
  • pause (toggle)
  • stop
  • truncate
  • restart
  • seek:<+[milliseconds]>|<-[milliseconds]> (1000ms = 1 second, 10000ms = 10 seconds.)

Example to seek forward 30 seconds:

uuid_fileman 0171ded1-2c31-445a-bb19-c74c659b7d08 seek:+3000

(Or use the current channel via ${uuid}, e.g. in a bind_digit_action)

The 'pause' argument is a toggle: the first time it is invoked it will pause playback, the second time it will resume playback.

uuid_getvar

Get a variable from a channel.

Usage: uuid_getvar <uuid> <varname>

uuid_hold

Place a channel on hold.

Usage:

uuid_hold <uuid>           place a call on hold

uuid_hold off <uuid>       switch off on hold

uuid_hold toggle <uuid>    toggles call-state based on current call-state

uuid_kill

Reset a specific <uuid> channel.

Usage: uuid_kill <uuid> [cause]

If no cause code is specified, NORMAL_CLEARING will be used.

uuid_limit

Apply or change limit(s) on a specified uuid.

Usage: uuid_limit <uuid> <backend> <realm> <resource> [<max>[/interval]] [number [dialplan [context]]]

See also mod_dptools: limit

uuid_media

Reinvite FreeSWITCH out of the media path:

Usage: uuid_media [off] <uuid>

Reinvite FreeSWITCH back in:

Usage: uuid_media <uuid>

uuid_media_reneg

Tell a channel to send a re-invite with optional list of new codecs to be renegotiated.

Usage: uuid_media_reneg <uuid> <=><codec string>

Example: Adding =PCMU makes the offered codec string absolute.

uuid_park

Park call

Usage: uuid_park <uuid>

The specified channel will be parked and the other leg of the call will be disconnected.

uuid_pre_answer

Pre–answer a channel.

Usage: uuid_preanswer <uuid>

See Also: Misc._Dialplan_Tools_pre_answer

uuid_preprocess

Pre-process Channel

Usage: uuid_preprocess <uuid>

uuid_recv_dtmf

Usage: uuid_recv_dtmf <uuid> <dtmf_data>

uuid_send_dtmf

Send DTMF digits to <uuid>

Usage: uuid_send_dtmf <uuid> <dtmf digits>[@<tone_duration>]

Use the character w for a .5 second delay and the character W for a 1 second delay.

Default tone duration is 2000ms .

uuid_send_info

Send info to the endpoint

Usage: uuid_send_info <uuid>

uuid_session_heartbeat

Usage: uuid_session_heartbeat <uuid> [sched] [0|<seconds>]

uuid_setvar

Set a variable on a channel. If value is omitted, the variable is unset.

Usage: uuid_setvar <uuid> <varname> [value]

Dialplan equivalent

<action application="set" data="<varname>=<value>"/>

<!-- For example: -->

<action application="set" data="playback_terminators=none"/>

Example 

uuid_setvar c2746178-ab61-11ea-86b8-311ce82e049e record_sample_rate 8000


uuid_setvar_multi

Set multiple vars on a channel.

Usage: uuid_setvar_multi <uuid> <varname>=<value>[;<varname>=<value>[;...]]

uuid_simplify

This command directs FreeSWITCH to remove itself from the SIP signaling path if it can safely do so.

Usage: uuid_simplify <uuid>

Execute this API command to instruct FreeSWITCH™ to inspect the Leg A and Leg B network addresses. If they are both hosted by the same switch as a result of a transfer or forwarding loop across a number of FreeSWITCH™ systems the one executing this command will remove itself from the SIP and media path and restore the endpoints to their local FreeSWITCH™ to shorten the network path. This is particularly useful in large distributed FreeSWITCH™ installations.

For example, suppose a call arrives at a FreeSWITCH™ box in Los Angeles, is answered, then forwarded to a FreeSWITCH™ box in London, answered there and then forwarded back to Los Angeles. The London switch could execute uuid_simplify to tell its local switch to examine both legs of the call to determine that they could be hosted by the Los Angeles switch since both legs are local to it. Alternatively, setting sip_auto_simplify to true either globally in vars.xml or as part of a dailplan extension would tell FS to perform this check for each call when both legs supervise. 

uuid_transfer

TODO What is the difference between uuid_transfer in mod_commands and mod_dptools: transfer?

Transfers an existing call to a specific extension within a <dialplan> and <context>. Dialplan may be "xml" or "directory".

Usage 

uuid_transfer <uuid> [-bleg|-both] <dest-exten> [<dialplan>] [<context>]

The optional first argument will allow you to transfer both parties (-both) or only the party to whom <uuid> is talking.(-bleg). Beware that -bleg actually means "the other leg", so when it is executed on the actual B leg uuid it will transfer the actual A leg that originated the call and disconnect the actual B leg.

NOTE: if the call has been bridged, and you want to transfer either side of the call, then you will need to use <action application="set" data="hangup_after_bridge=false"/> (or the API equivalent). If it's not set, transfer doesn't really work as you'd expect, and leaves calls in limbo.

And more examples see Inline Dialplan

uuid_phone_event

Send hold indication upstream:

Usage 

uuid_phone_event <uuid> hold|talk

uuid_phone_event 6f6bbc12-2a30-4dce-9297-f714943dacfc talk

Record/Playback Commands

uuid_record

Record the audio associated with the channel with the given UUID into a file. The start command causes FreeSWITCH to start mixing all call legs together and saves the result as a file in the format that the file's extension dictates. The stop command (if available) will stop the recording and close the file.

This API command is possibly broken and the "(if available)" remark may be an allusion to that: uuid_record seems to completely hijack control, no FreeSWITCH events are generated (neither on fs_cli nor to an event socket app), and the only way to stop it is by hanging up (as it doesn't seem to honour the playback_terminators variable).

Use mod_dptools:record or mod_dptools:record_session instead.

If media setup hasn't yet happened, the file will contain silent audio until media is available. Audio will be recorded for calls that are parked. The recording will continue through the bridged call. If the call is set to return to park after the bridge, the bug will remain on the call, but no audio is recorded until the call is bridged again.

TODO What if media doesn't flow through FreeSWITCH? Will it re-INVITE first? Or do we just not get the audio in that case?

See channel variables related to recording at mod_dptools:record. Another module worth looking at is mod_dptools: record_session.

Syntax 

uuid_record <uuid> [start|stop|mask|unmask] <path> [<limit>]

Parameter

Description

uuid

UUID of the channel.

start

Start recording the audio.

stop

Stop recording.

all may be used for <path> to stop all recordings for the channel with the given UUID.

uuid_record <uuid> stop all

mask

Mask with silence part of the recording beginning when the mask argument is executed by this command.

See http://jira.freeswitch.org/browse/FS-5269

unmask

Stop the masking and continue recording live audio normally.

See Issues · signalwire/freeswitch · GitHub

path

Record to file specified by given path. 

If only filename is given the it will be saved to channel variable sound_prefix, or base_dir

 when sound_prefix not set.

limit

(optional) The maximum duration of the recording in seconds.

Limit Commands

More information is available at Limit commands

limit_reset

Reset a limit backend.

limit_status

Retrieve status from a limit backend.

limit_usage

Retrieve usage for a given resource.

uuid_limit_release

Manually decrease a resource usage by one.

limit_interval_reset

Reset the interval counter to zero prior to the start of the next interval.

Miscellaneous Commands

bg_system

Execute a system command in the background.

Usage: bg_system <command>

echo

Echo input back to the console

Usage: echo <text to echo>

Example:

echo This text will appear

This text will appear

file_exists

Tests whether filename exists.

file_exists filename

Examples:

freeswitch> file_exists /tmp/real_file

true

freeswitch> file_exists /tmp/missing_file

false

Example dialplan usage:

file_exists example 

<extension name="play-news-announcements">

  <condition expression="${file_exists(${sounds_dir}/news.wav)}" expression="true"/>

    <action application="playback" data="${sounds_dir}/news.wav"/>

    <anti-action application="playback" data="${soufnds_dir}/no-news-is-good-news.wav"/>

  </condition>

</extension>

file_exists tests whether FreeSWITCH can see the file, but the file may still be unreadable because of restrictive permissions.

Example start/stop record to rtmp 

uuid_record c2746178-ab61-11ea-86b8-311ce82e049e start rtmp://domain.com/stream:teststream

uuid_record c2746178-ab61-11ea-86b8-311ce82e049e stop rtmp://domain.com/stream:teststream

find_user_xml

Checks to see if a user exists. Matches user tags found in the directory, similar to user_exists, but returns an XML representation of the user as defined in the directory (like the one shown in user_exists).

Usage: find_user_xml <key> <user> <domain>

<key> references a key specified in a directory's user tag

<user> represents the value of the key

<domain> is the domain to which the user is assigned.

list_users

Lists Users configured in Directory

Usage:

list_users [group <group>] [domain <domain>] [user <user>] [context <context>]

Examples:

freeswitch@localhost> list_users group default

userid|context|domain|group|contact|callgroup|effective_caller_id_name|effective_caller_id_number

2000|default|192.168.20.73|default|sofia/internal/sip:2000@192.168.20.219:5060|techsupport|B#-Test 2000|2000

2001|default|192.168.20.73|default|sofia/internal/sip:2001@192.168.20.150:63412;rinstance=8e2c8b86809acf2a|techsupport|Test 2001|2001

2002|default|192.168.20.73|default|error/user_not_registered|techsupport|Test 2002|2002

2003|default|192.168.20.73|default|sofia/internal/sip:2003@192.168.20.149:5060|techsupport|Test 2003|2003

2004|default|192.168.20.73|default|error/user_not_registered|techsupport|Test 2004|2004

+OK

Search filters can be combined:

freeswitch@localhost> list_users group default user 2004

userid|context|domain|group|contact|callgroup|effective_caller_id_name|effective_caller_id_number

2004|default|192.168.20.73|default|error/user_not_registered|techsupport|Test 2004|2004

+OK

sched_api

Schedule an API call in the future.

Usage 

sched_api [+@]<time> <group_name> <command_string>[&]

<time> is the UNIX timestamp at which the command should be executed. If it is prefixed by +, <time> specifies the number of seconds to wait before executing the command. If prefixed by @, it will execute the command periodically every <time> seconds; for the first instance it will be executed after <time> seconds.

<group_name> will be the value of "Task-Group" in generated events. "none" is the proper value for no group. If set to UUID of channel (example: ${uuid}), task will automatically be unscheduled when channel hangs up.

<command_string> is the command to execute at the scheduled time.

A scheduled task or group of tasks can be revoked with sched_del or unsched_api.

You could append the "&" symbol to the end of the line to executed this command in its own thread.

Examples 

sched_api +1800 none originate sofia/internal/1000%${sip_profile} &echo()

sched_api @600 check_sched log Periodic task is running...

sched_api +10 ${uuid} chat verto|fs@mydomain.com|1000@mydomain.com|Hello World

sched_broadcast

Play a <path> file to a specific <uuid> call in the future.

Usage 

sched_broadcast [[+]<time>|@time] <uuid> <path> [aleg|bleg|both]

Schedule execution of an application on a chosen leg(s) with optional hangup:

sched_broadcast [+]<time> <uuid> app[![hangup_cause]]::args [aleg|bleg|both]

<time> is the UNIX timestamp at which the command should be executed. If it is prefixed by +, <time> specifies the number of seconds to wait before executing the command. If prefixed by @, it will execute the command periodically every <time> seconds; for the first instance it will be executed after <time> seconds.

Examples 

sched_broadcast +60 336889f2-1868-11de-81a9-3f4acc8e505e commercial.wav both

sched_broadcast +60 336889f2-1868-11de-81a9-3f4acc8e505e say::en\snumber\spronounced\s12345 aleg

sched_del

Removes a prior scheduled group or task ID

Usage 

sched_del <group_name|task_id>

The one argument can either be a group of prior scheduled tasks or the returned task-id from sched_api.

sched_transfer, sched_hangup and sched_broadcast commands add new tasks with group names equal to the channel UUID. Thus, sched_del with the channel UUID as the argument will remove all previously scheduled hangups, transfers and broadcasts for this channel.

Examples 

sched_del my_group

sched_del 2

sched_hangup

Schedule a running call to hangup.

Usage 

sched_hangup [+]<time> <uuid> [<cause>]

sched_hangup +0 is the same as uuid_kill

sched_transfer

Schedule a transfer for a running call.

Usage 

sched_transfer [+]<time> <uuid> <target extension> [<dialplan>] [<context>]

sched_transfer "+600 uuid 900699 XML doosan_inbound_target "

stun

Executes a STUN lookup.

Usage:

stun <stunserver>[:port]

Example:

stun stun.freeswitch.org

system

Execute a system command.

Usage:

system <command>

The <command> is passed to the system shell, where it may be expanded or interpreted in ways you don't expect. This can lead to security bugs if you're not careful. For example, the following command is dangerous:

<action application="system" data="log_caller_name ${caller_id_name}" />

If a malicious remote caller somehow sets his caller ID name to "; rm -rf /" you would unintentionally be executing this shell command:

log_caller_name; rm -rf /

This would be a Bad Thing.

time_test

Runs a test to see how bad timer jitter is. It runs the test <count> times if specified, otherwise it uses the default count of 10, and tries to sleep for mss microseconds. It returns the actual timer duration along with an average.

Usage:

time_test <mss> [count]

Example:

time_test 100 5

test 1 sleep 100 99

test 2 sleep 100 97

test 3 sleep 100 96

test 4 sleep 100 97

test 5 sleep 100 102

avg 98

timer_test

Runs a test to see how bad timer jitter is. Unlike time_test, this uses the actual FreeSWITCH timer infrastructure to do the timer test and exercises the timers used for call processing.

Usage:

timer_test <10|20|40|60|120> [<1..200>] [<timer_name>]

The first argument is the timer interval.

The second is the number of test iterations.

The third is the timer name; "show timers" will give you a list.

Example:

timer_test 20 3

Avg: 16.408ms Total Time: 49.269ms

2010-01-29 12:01:15.504280 [CONSOLE] mod_commands.c:310 Timer Test: 1 sleep 20 9254

2010-01-29 12:01:15.524351 [CONSOLE] mod_commands.c:310 Timer Test: 2 sleep 20 20042

2010-01-29 12:01:15.544336 [CONSOLE] mod_commands.c:310 Timer Test: 3 sleep 20 19928

tone_detect

Start Tone Detection on a channel.

Usage:

tone_detect <uuid> <key> <tone_spec> [<flags> <timeout> <app> <args>] <hits>

<uuid> is required when this is executed as an api call; as a dialplan app the uuid is implicit as part of the channel variables

<key> is an arbitrary name that identifies this tone_detect instance; required

<tone_spec> frequencies to detect; required

<flags> 'r' or 'w' to specify which direction to monitor

<timeout> duration during which to detect tones;

0 = detect forever

+time = number of milliseconds after tone_detect is executed

time = absolute time to stop in seconds since The Epoch (1 January, 1970)

<app> FS application to execute when tone_detect is triggered; if app is omitted, only an event will be returned

<args> arguments to application enclosed in single quotes

<hits> the number of times tone_detect should be triggered before executing the specified app

Once tone_detect returns a result, it will not trigger again until reset. Reset tone_detect by calling tone_detect <key> with no additional arguments to reactivate the previously specified tone_detect declaration.

See also http://wiki.freeswitch.org/wiki/Misc._Dialplan_Tools_tone_detect

unsched_api

Unschedule a previously scheduled API command.

Usage 

unsched_api <task_id>

url_decode

Usage:

url_decode <string>

url_encode

Url encode a string.

Usage:

url_encode <string>

user_data

Retrieves user information (parameters or variables) as defined in the FreeSWITCH user directory.

Usage:

user_data <user>@<domain> <attr|var|param> <name>

<user> is the user's id

<domain> is the user's domain

<attr|var|param> specifies whether the requested data is contained in the "variables" or "parameters" section of the user's record

<name> is the name (key) of the variable to retrieve

Examples:

user_data 1000@192.168.1.101 param password

will return a result of 1234, and

user_data 1000@192.168.1.101 var accountcode

will return a result of 1000 from the example user shown in user_exists, and

user_data 1000@192.168.1.101 attr id

will return the user's actual alphanumeric ID (i.e. "john") when number-alias="1000" was set as an attribute for that user.

user_exists

Checks to see if a user exists. Matches user tags found in the directory and returns either true/false:

Usage:

user_exists <key> <user> <domain>

<key> references a key specified in a directory's user tag

<user> represents the value of the key

<domain> is the domain to which the user belongs

Example:

user_exists id 1000 192.168.1.101

will return true where there exists in the directory a user with a key called id whose value equals 1000:

User Directory Entry 

    <user id="1000" randomvar="45">

        <params>

          <param name="password" value="1234"/>

          <param name="vm-password" value="1000"/>

        </params>

        <variables>

          <variable name="accountcode" value="1000"/>

          <variable name="user_context" value="default"/>

          <variable name="effective_caller_id_name" value="Extension 1000"/>

          <variable name="effective_caller_id_number" value="1000"/>

        </variables>

    </user>

In the above example, we also could have tested for randomvar:

user_exists randomvar 45 192.168.1.101

And we would have received the same true result, but:

user_exists accountcode 1000 192.168.1.101

or

user_exists vm-password 1000 192.168.1.101

Would have returned false.

See Also

  • Channel Variables

在FreeSwitch终端输入help后显示的所有终端命令(默认):

acl,<ip> <list_name>,Compare anip to an acl list,mod_commands

alias,[add|stickyadd] <alias><command> | del [<alias>|*],Alias,mod_commands

banner,,Return the system banner,mod_commands

bg_system,<command>,Execute a systemcommand in the background,mod_commands

bgapi,<command>[ <arg>],Executean api command in a thread,mod_commands

break,<uuid>[all],uuid_break,mod_commands

cdr_csv,parameters,cdr_csvcontrols,mod_cdr_csv

chat,<proto>|<from>|<to>|<message>|[<content-type>],chat,mod_dptools

coalesce,[^^<delim>]<value1>,<value2>,...,Returnfirst nonempty parameter,mod_commands

complete,add <word>|del[<word>|*],Complete,mod_commands

cond,<expr> ? <true val> :<false val>,Evaluate a conditional,mod_commands

conference,,Conference modulecommands,mod_conference

console,loglevel [level]|colorize[on|toggle|off],Console,mod_console

console_complete,<line>,,mod_commands

console_complete_xml,<line>,,mod_commands

create_uuid,<uuid> <other_uuid>,Createa uuid,mod_commands

db,[insert|delete|select|exists|count|list]/<realm>/<key>/<value>,dbget/set,mod_db

db_cache,status,Manage dbcache,mod_commands

domain_exists,<domain>,Check if adomain exists,mod_commands

echo,<data>,Echo,mod_commands

enum,,ENUM,mod_enum

enum_auto,,ENUM,mod_enum

escape,<data>,Escape astring,mod_commands

eval,[uuid:<uuid>]<expression>,eval (noop),mod_commands

event_sink,<webdata>,event_sink,mod_event_socket

expand,[uuid:<uuid> ]<cmd><args>,Execute an api with variable expansion,mod_commands

expr,<expr>,Eval anexpression,mod_expr

fifo,list|list_verbose|count|debug|status|has_outbound|importance[<fifo name>]|reparse [del_all],Return data about a fifo,mod_fifo

fifo_add_outbound,<node> <url>[<priority>],Add outbound members to a fifo,mod_fifo

fifo_check_bridge,<uuid>|<outbound_id>,checkif uuid is in a bridge,mod_fifo

fifo_member,[add <fifo_name><originate_string> [<simo_count>] [<timeout>] [<lag>][<expires>] [<taking_calls>] | del <fifo_name><originate_string>],Add members to a fifo,mod_fifo

file_exists,<file>,Check if a fileexists on server,mod_commands

find_user_xml,<key> <user><domain>,Find a user,mod_commands

fsctl,[recover|send_sighup|hupall|pause [inbound|outbound]|resume[inbound|outbound]|shutdown[cancel|elegant|asap|now|restart]|sps|sps_peak_reset|sync_clock|sync_clock_when_idle|reclaim_mem|max_sessions|min_dtmf_duration[num]|max_dtmf_duration [num]|default_dtmf_duration [num]|min_idle_cpu|loglevel[level]|debug_level [level]],FS control mes sages,mod_commands

getcputime,[reset],Gets CPU time inmilliseconds (user,kernel),mod_commands

getenv,<name>,getenv,mod_commands

gethost,,gethostbyname,mod_commands

global_getvar,<var>,Get globalvar,mod_commands

global_setvar,<var>=<value>[=<value2>],Set global var,mod_commands

group,[insert|delete|call]:<groupname>:<url>,group [insert|delete|call],mod_db

group_call,<group>[@<domain>],Generatea dial string to call a group,mod_commands

hash,[insert|delete|select]/<realm>/<key>/<value>,hashget/set,mod_hash

hash_dump,all|limit|db [<realm>],dumphash/limit_hash data (used for synchronization),mod_hash

hash_remote,list|kill [name]|rescan,hashremote,mod_hash

help,,Show help for all the apicommands,mod_commands

host_lookup,<hostname>,Lookuphost,mod_commands

hostname,,Return the systemhostname,mod_commands

httapi,[debug_on|debug_off],HT-TAPIHypertext Telephony API,mod_httapi

hupall,<cause> [<var><value>],hupall,mod_commands

in_group,<user>[@<domain>]<group_name>,Determine if a user is in a group,mod_commands

interface_ip,[auto|ipv4|ipv6]<ifname>,Return the primary IP of an interface,mod_commands

is_lan_addr,<ip>,See if an ip is alan addr,mod_commands

json,JSON,JSON API,mod_commands

limit_hash_usage,<realm><id>,Deprecated: gets the usage count of a limited resource,mod_commands

limit_interval_reset,<backend><realm> <resource>,Reset the interval counter for a limitedresource,mod_commands

limit_reset,<backend>,Reset thecounters of a limit backend,mod_commands

limit_status,<backend>,Get the statusof a limit backend,mod_commands

limit_usage,<backend> <realm><id>,Get the usage count of a limited resource,mod_commands

list_users,[group <group>] [domain<domain>] [user <user>] [context <context>],List Usersconfigured in Directory,mod_commands

load,<mod_name>,LoadModule,mod_commands

local_stream,<show|start|reload|stop|hup><local_stream_name>,manage local streams,mod_local_stream

log,<level><message>,Log,mod_commands

lua,<script>,run a script as an apifunction,mod_lua

luarun,<script>,run a script,mod_lua

md5,<data>,Return md5hash,mod_commands

module_exists,<module>,Check ifmodule exists,mod_commands

msleep,<milliseconds>,Sleep Nmilliseconds,mod_commands

nat_map,[status|republish|reinit] |[add|del] <port> [tcp|udp] [static],Manage NAT,mod_commands

opus_debug,<on|off>,Set OPUSDebug,mod_opus

originate,<call url><exten>|&<application_name>(<app_args>)[<dialplan>] [<context>] [<cid_name>] [<cid_num>][<timeout_sec>],Originate a call,mod_commands

page,(var1=val1,var2=val2)<var1=val1,var2=val2><chan1>[:_:<chanN>],Senda file as a page,mod_dptools

pause,<uuid> <on|off>,Pausemedia on a channel,mod_commands

presence,[in|out] <user> <rpid><message>,presence,mod_dptools

quote_shell_arg,<data>,Quote/escape a string for use on shell command line,mod_commands

reg_url,<user>@<realm>,, mod_commands

regex,<data>|<pattern>[|<subststring>][n|b],Evaluate a regex,mod_commands

reload,[-f] <mod_name>,Reloadmodule,mod_commands

reloadacl,,Reload XML,mod_commands

reloadxml,,Reload XML,mod_commands

replace,<data>|<string1>|<string2>,Replacea string,mod_commands

say_string,<module_name>[.<ext>]<lang>[.<ext>] <say_type> <say_method>[<say_gender>] <text>,,mod_commands

sched_api,[+@]<time><group_name> <command_string>[&],Schedule an apicommand,mod_commands

sched_broadcast,[[+]<time>|@time]<uuid> <path> [aleg|bleg|both],Schedule a broadcast event to arunning call,mod_commands

sched_del,<task_id>|<group_id>,Deletea scheduled task,mod_commands

sched_hangup,[+]<time> <uuid>[<cause>],Schedule a running call to hangup,mod_commands

sched_transfer,[+]<time> <uuid><extension> [<dialplan>] [<context>],Schedule a transfer fora running call,mod_commands

show,codec|endpoint|application|api|dialplan|file|timer|calls[count]|channels [count|like <matchstring>]|calls|detailed_calls|bridged_calls|detailed_bridged_calls|aliases|complete|chat|management|modules|nat_map|say|interfaces|interface_types|tasks|limits|status,Showvarious reports,mod_commands

shutdown,,Shutdown,mod_commands

sofia,<cmd> <args>,SofiaControls,mod_sofia

sofia_contact,[profile/]<user>@<domain>,SofiaContacts,mod_sofia

sofia_count_reg,[profile/]<user>@<domain>,CountSofia registration,mod_sofia

sofia_dig,<url>,SIP DIG,mod_sofia

sofia_gateway_data,<gateway_name>[ivar|ovar|var] <name>,Get data from a sofia gateway,mod_sofia

sofia_presence_data,[list|status|rpid|user_agent][profile/]<user>@domain,Sofia Presence Data,mod_sofia

sofia_username_of,[profile/]<user>@<domain>,SofiaUsername Lookup,mod_sofia

spandsp_start_tone_detect,<uuid><name>,Start background tone detection with cadence,mod_spandsp

spandsp_stop_tone_detect,<uuid>,Stopbackground tone detection with cadence,mod_spandsp

sql_escape,<string>,Escape a stringto prevent sql injection,mod_commands

start_tdd_detect,<uuid>,Startbackground tdd detection,mod_spandsp

status,,Show current status,mod_commands

stop_tdd_detect,<uuid>,Stopbackground tdd detection,mod_spandsp

strepoch,<string>,Convert a datestring into epoch time,mod_dptools

strftime,<format_string>,strftime,mod_dptools

strftime_tz,<timezone_name>[<epoch>|][format string],Display formatted time of timezone,mod_commands

strmicroepoch,<string>,Convert a datestring into micoepoch time,mod_dptools

stun,<stun_server>[:port] [<source_ip>[:<source_port]],ExecuteSTUN lookup,mod_commands

switchname,,Return the switchname,mod_commands

system,<command>,Execute a systemcommand,mod_commands

time_test,<mss> [count],Show timejitter,mod_commands

timer_test,<10|20|40|60|120>[<1..200>] [<timer_name>],Exercise FS timer,mod_commands

tone_detect,<uuid> <key><tone_spec> [<flags> <timeout> <app> <args><hits>],Start tone detection on a channel,mod_commands

unload,[-f] <mod_name>,Unloadmodule,mod_commands

unsched_api,<task_id>,Unschedule anapi command,mod_commands

uptime,[us|ms|s|m|h|d|microseconds|milliseconds|seconds|minutes|hours|days],Showuptime,mod_commands

url_decode,<string>,Url decode astring,mod_commands

url_encode,<string>,Url encode astring,mod_commands

user_data,<user>@<domain>[var|param|attr] <name>,Find user data,mod_commands

user_exists,<key> <user><domain>,Find a user,mod_commands

uuid_answer,<uuid>,answer,mod_commands

uuid_audio, <uuid> [start [read|write][mute|level <level>]|stop],uuid_audio,mod_commands

uuid_break, <uuid> [all],Break out of media sent to channel, mod_commands

uuid_bridge,, Bridge call legs, mod_commands

uuid_broadcast,<uuid> <path>[aleg|bleg|holdb|both],Execute dialplan application,mod_commands

uuid_buglist,<uuid>,List media bugson a session,mod_commands

uuid_chat,<uuid> <text>,Send achat message,mod_commands

uuid_codec_debug,<uuid> audio|video<level>,Send codec a debug message,mod_commands

uuid_codec_param,<uuid> audio|videoread|write <param> <val>,Send codec a param,mod_commands

uuid_debug_media,<uuid><read|write|both|vread|vwrite|vboth|all> <on|off>,Debugmedia,mod_commands

uuid_deflect,<uuid> <uri>,Senda deflect,mod_commands

uuid_displace,<uuid> [start|stop]<path> [<limit>] [mux],Displace audio,mod_commands

uuid_display,<uuid><display>,Update phone display,mod_commands

uuid_drop_dtmf,<uuid> [on | off ] [mask_digits <digits> | mask_file <file>],Drop all DTMF or replaceit with a mask,mod_commands

uuid_dual_transfer,<uuid><A-dest-exten>[/<A-dialplan>][/<A-context>]<B-dest-exten>[/<B-dialplan>][/<B-context>],Transfer asession and its partner,mod_commands

uuid_dump,<uuid> [format],Dumpsession vars,mod_commands

uuid_early_ok,<uuid>,stop ignoringearly media,mod_commands

uuid_exists,<uuid>,Check if a uuidexists,mod_commands

uuid_fileman,<uuid><cmd>:<val>,Manage session audio,mod_commands

uuid_flush_dtmf,<uuid>,Flush dtmf ona given uuid,mod_commands

uuid_getvar,<uuid> <var>,Get avariable from a channel,mod_commands

uuid_hold,[off|toggle] <uuid>[<display>],Place call on hold,mod_commands

uuid_jitterbuffer,<uuid>[0|<min_msec>[:<max_msec>]],uuid_jitterbuffer,mod_commands

uuid_kill,<uuid> [cause],Killchannel,mod_commands

uuid_limit,<uuid> <backend><realm> <resource> [<max>[/interval]] [number [dialplan[context]]],Increase limit resource,mod_commands

uuid_limit_release,<uuid><backend> [realm] [resource],Release limit resource,mod_commands

uuid_limit_release,<uuid> <backend>[realm] [resource],Release limit resource,mod_commands

uuid_loglevel,<uuid><level>,Set loglevel on session,mod_commands

uuid_media,[off] <uuid>,Reinvite FSin or out of media path,mod_commands

uuid_media_3p,[off] <uuid>,ReinviteFS in or out of media path using 3pcc,mod_commands

uuid_media_reneg,<uuid>[<codec_string>],Media negotiation,mod_commands

uuid_outgoing_answer,<uuid>,Answeroutgoing channel,mod_commands

uuid_park,<uuid>,Parkchannel,mod_commands

uuid_pause,<uuid><on|off>,Pause media on a channel,mod_commands

uuid_phone_event,<uuid>,Send an event to the phone, mod_commands

uuid_pre_answer,<uuid>,pre_answer,mod_commands

uuid_preprocess,<>,Pre-processChannel,mod_commands

uuid_record,<uuid>[start|stop|mask|unmask] <path> [<limit>],Record sessionaudio,mod_commands

uuid_recovery_refresh,<uuid><uri>,Send a recovery_refresh,mod_commands

uuid_recv_dtmf,<uuid><dtmf_data>,Receive dtmf digits,mod_commands

uuid_redirect,<uuid> <uri>,Senda redirect,mod_commands

uuid_ring_ready,<uuid>[queued],Sending ringing to a channel,mod_commands

uuid_send_dtmf,<uuid><dtmf_data>,Send dtmf digits,mod_commands

uuid_send_info,<uuid>[<mime_type> <mime_subtype>] <message>,Send info to theendpoint,mod_commands

uuid_send_message,<uuid><message>,Send MESSAGE to the endpoint,mod_commands

uuid_send_tdd,<uuid><text>,send tdd data to a uuid,mod_spandsp

uuid_session_heartbeat,<uuid> [sched][0|<seconds>],uuid_session_heartbeat,mod_commands

uuid_set_media_stats,<uuid>,Set mediastats,mod_commands

uuid_setvar,<uuid> <var> [value],Seta variable,mod_commands

uuid_setvar_multi,<uuid><var>=<value>;<var>=<value>...,Set multiplevariables,mod_commands

uuid_simplify,<uuid>,Try to cut outof a call path / attended xfer,mod_commands

uuid_transfer,<uuid> [-bleg|-both]<dest-exten> [<dialplan>] [<context>],Transfer asession,mod_commands

uuid_video_bitrate,<uuid><bitrate>,Send video bitrate req.,mod_commands

uuid_video_refresh,<uuid>,Send videorefresh.,mod_commands

uuid_zombie_exec,<uuid>,Setzombie_exec flag on the specified uuid,mod_commands

valet_info,[<lot name>],Valet ParkingInfo,mod_valet_parking

version,[short],Version,mod_commands

vm_boxcount,[profile/]<user>@<domain>[|[new|saved|new-urgent|saved-urgent|all]],vm_boxcount,mod_voicemail

vm_delete,<id>@<domain>[/profile][<uuid>],vm_delete,mod_voicemail

vm_fsdb_auth_login,<profile><domain> <user> <password>,vm_fsdb_auth_login,mod_voicemail

vm_fsdb_msg_count,<format><profile> <domain> <user><folder>,vm_fsdb_msg_count,mod_voicemail

vm_fsdb_msg_delete,<profile><domain> <user> <uuid>,vm_fsdb_msg_delete,mod_voicemail

vm_fsdb_msg_email,<profile><domain> <user> <uuid><email>,vm_fsdb_msg_email,mod_voicemail

vm_fsdb_msg_forward,<profile><domain> <user> <uuid> <dst_domain> <dst_user> [prepend_file_location],vm_fsdb_msg_forward,mod_voicemail

vm_fsdb_msg_get,<format><profile> <domain> <user><uuid>,vm_fsdb_msg_get,mod_voicemail

vm_fsdb_msg_list,<format><profile> <domain> <user> <folder> <filter>[msg-order = ASC | DESC],vm_fsdb_msg_list,mod_voicemail

vm_fsdb_msg_purge,<profile><domain> <user>,vm_fsdb_msg_purge,mod_voicemail

vm_fsdb_msg_save,<profile><domain> <user> <uuid>,vm_fsdb_msg_save,mod_voicemail

vm_fsdb_msg_undelete,<profile><domain> <user> <uuid>,vm_fsdb_msg_undelete,mod_voicemail

vm_fsdb_pref_greeting_get,<format><profile> <domain> <user>[slot],vm_fsdb_pref_greeting_get,mod_voicemail

vm_fsdb_pref_greeting_set,<profile><domain> <user> <slot>[file-path],vm_fsdb_pref_greeting_set,mod_voicemail

vm_fsdb_pref_password_set,<profile><domain> <user><password>,vm_fsdb_pref_password_set,mod_voicemail

vm_fsdb_pref_recname_set,<profile><domain> <user><file-path>,vm_fsdb_pref_recname_set,mod_voicemail

vm_inject,[group=<group>[@domain]|domain=<domain>|<box>[@<domain>]]<sound_file> [<cid_num>] [<cid_name>],vm_inject,mod_voicemail

vm_list,<id>@<domain>[/profile][xml],vm_list,mod_voicemail

vm_prefs,[profile/]<user>@<domain>[|[name_path|greeting_path|password]],vm_prefs,mod_voicemail

vm_read,<id>@<domain>[/profile]<read|unread> [<uuid>],vm_read,mod_voicemail

voicemail,rss [<host> <port><uri> <user> <domain>] | [load|unload|reload] <profile>[reloadxml],voicemail,mod_voicemail

voicemail_inject,[group=<group>[@domain]|domain=<domain>|<box>[@<domain>]]<sound_file> [<cid_num>] [<cid_name>],voicemail_inject,mod_voicemail

xml_flush_cache,<id> <key><val>,Clear xml cache,mod_commands

xml_locate,[root | <section><tag> <tag_attr_name> <tag_attr_val>],Find somexml,mod_commands

xml_wrap,<command> <args>,Wrapanother api command in xml,mod_commands

[                 ...]  [                 acl]  [               alias]  [              banner]

[               bgapi]  [           bg_system]  [               break]  [    callcenter_break]

[   callcenter_config]  [             cdr_csv]  [                chat]  [            coalesce]

[            complete]  [                cond]  [          conference]  [             console]

[    console_complete]  [console_complete_xml]  [         create_uuid]  [                curl]

[       curl_sendfile]  [                  db]  [            db_cache]  [         domain_data]

[       domain_exists]  [                echo]  [                enum]  [           enum_auto]

[              escape]  [                eval]  [event_channel_broadcast]       [          event_sink]

[              expand]  [                expr]  [                fifo]  [   fifo_add_outbound]

[   fifo_check_bridge]  [         fifo_member]  [         file_exists]  [       find_user_xml]

[               fsctl]  [          getcputime]  [              getenv]  [             gethost]

[       global_getvar]  [       global_setvar]  [               group]  [          group_call]

[                hash]  [           hash_dump]  [         hash_remote]  [                help]

[         host_lookup]  [            hostname]  [              httapi]  [              hupall]

[            in_group]  [        interface_ip]  [         is_lan_addr]  [                json]

[    limit_hash_usage]  [limit_interval_reset]  [         limit_reset]  [        limit_status]

[         limit_usage]  [          list_users]  [                load]  [        local_stream]

[                 log]  [                 lua]  [              luarun]  [                 md5]

[       module_exists]  [              msleep]  [                msrp]  [             nat_map]

[          nibblebill]  [          opus_debug]  [           originate]  [                page]

[               pause]  [            presence]  [     quote_shell_arg]  [               regex]

[             reg_url]  [              reload]  [           reloadacl]  [           reloadxml]

[             replace]  [          say_string]  [           sched_api]  [     sched_broadcast]

[           sched_del]  [        sched_hangup]  [      sched_transfer]  [                show]

[            shutdown]  [               sofia]  [       sofia_contact]  [     sofia_count_reg]

[           sofia_dig]  [  sofia_gateway_data]  [ sofia_presence_data]  [   sofia_username_of]

[spandsp_start_tone_detect]     [spandsp_stop_tone_detect]      [          sql_escape]  [    start_tdd_detect]

[              status]  [     stop_tdd_detect]  [            strepoch]  [            strftime]

[         strftime_tz]  [       strmicroepoch]  [                stun]  [          switchname]

[              system]  [          timer_test]  [           time_test]  [             tolower]

[         tone_detect]  [             toupper]  [              unload]  [         unsched_api]

[              uptime]  [          url_decode]  [          url_encode]  [           user_data]

[         user_exists]  [         uuid_answer]  [          uuid_audio]  [          uuid_break]

[         uuid_bridge]  [      uuid_broadcast]  [        uuid_buglist]  [   uuid_capture_text]

[           uuid_chat]  [    uuid_codec_debug]  [    uuid_codec_param]  [    uuid_debug_media]

[        uuid_deflect]  [       uuid_displace]  [        uuid_display]  [      uuid_drop_dtmf]

[  uuid_dual_transfer]  [           uuid_dump]  [       uuid_early_ok]  [         uuid_exists]

[        uuid_fileman]  [     uuid_flush_dtmf]  [         uuid_getvar]  [           uuid_hold]

[   uuid_jitterbuffer]  [           uuid_kill]  [          uuid_limit]  [  uuid_limit_release]

[       uuid_loglevel]  [          uuid_media]  [       uuid_media_3p]  [    uuid_media_reneg]

[      uuid_msrp_send]  [uuid_outgoing_answer]  [           uuid_park]  [          uuid_pause]

[    uuid_phone_event]  [     uuid_pre_answer]  [     uuid_preprocess]  [         uuid_record]

[uuid_recovery_refresh] [      uuid_recv_dtmf]  [       uuid_redirect]  [     uuid_ring_ready]

[      uuid_send_dtmf]  [      uuid_send_info]  [   uuid_send_message]  [       uuid_send_tdd]

[      uuid_send_text]  [uuid_session_heartbeat]        [uuid_set_media_stats]  [         uuid_setvar]

[   uuid_setvar_multi]  [       uuid_simplify]  [       uuid_transfer]  [uuid_video_bandwidth]

[  uuid_video_bitrate]  [  uuid_video_refresh]  [      uuid_write_png]  [    uuid_xfer_zombie]

[    uuid_zombie_exec]  [          valet_info]  [             version]  [               verto]

[       verto_contact]  [         vm_boxcount]  [           vm_delete]  [  vm_fsdb_auth_login]

[   vm_fsdb_msg_count]  [  vm_fsdb_msg_delete]  [   vm_fsdb_msg_email]  [ vm_fsdb_msg_forward]

[     vm_fsdb_msg_get]  [    vm_fsdb_msg_list]  [   vm_fsdb_msg_purge]  [    vm_fsdb_msg_save]

[vm_fsdb_msg_undelete]  [vm_fsdb_pref_greeting_get]     [vm_fsdb_pref_greeting_set]     [vm_fsdb_pref_password_set]

[vm_fsdb_pref_recname_set]      [           vm_inject]  [             vm_list]  [            vm_prefs]

[             vm_read]  [           voicemail]  [    voicemail_inject]  [                 vpx]

[     xml_flush_cache]  [          xml_locate]  [            xml_wrap]  [        uuid_warning]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/155727.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

VBA技术资料MF83:将Word文档批量另存为PDF文件

我给VBA的定义&#xff1a;VBA是个人小型自动化处理的有效工具。利用好了&#xff0c;可以大大提高自己的工作效率&#xff0c;而且可以提高数据的准确度。我的教程一共九套&#xff0c;分为初级、中级、高级三大部分。是对VBA的系统讲解&#xff0c;从简单的入门&#xff0c;到…

初始MySQL(六)(自增长,索引,事务,隔离级别)

目录 自增长 索引 索引的原理: mysql索引的类型 添加/删除索引/查看索引 添加索引 删除索引 查看索引(没有生成或者问问什么时候存在) 小结 MySQL事务 关于事务的一些概念 mysql数据库控制台事务的几个重要操作 MySQL事务细节讨论 MySQL事务隔离级别 介绍 数据库…

ElasticSearch 安装(单机版本)

文章目录 ElasticSearch 安装&#xff08;单机版本&#xff09;环境配置下载安装包调整系统参数安装启动并验证 ElasticSearch 安装&#xff08;单机版本&#xff09; 此文档演示 ElasticSearch 的单机版本在 CentOS 7 环境下的安装方式以及相关的配置。 环境配置 Linux 主机一…

Android 14 Beta 1

Android 14的第一个 Beta 版&#xff0c;围绕隐私、安全、性能、开发人员生产力和用户定制等核心主题构建&#xff0c;同时继续改进平板电脑、可折叠设备等大屏幕设备的体验。我们一直在完善 Android 14 的功能和稳定性方面取得稳步进展&#xff0c;现在是时候向开发者和早期采…

C++基础(3)——类与对象

1.构造函数&#xff1a; 1.1 构造函数的引入&#xff1a; 在关于数据结构这一部分的文章中&#xff0c;创建了一个新的数据结构后&#xff0c;通常需要编写一个初始化函数来对这个数据结构进行一次初始化。在C的类中&#xff0c;如果存在函数&#xff0c;同样也需要对函数进行…

传递函数的推导和理解

传递函数的推导和理解 假设有一个线性系统&#xff0c;在一般情况下&#xff0c;它的激励 x ( t ) x(t) x(t)与响应 y ( t ) y(t) y(t)所满足的的关系&#xff0c;可用下列微分方程来表示&#xff1a; a n y ( n ) a n − 1 y ( n − 1 ) a n − 2 y ( n − 2 ) ⋯ a 1 y…

【重点文章】服务升级惨痛教训

文章目录 事故解析:避免方法涉及知识 以前怎么接触过大表&#xff0c;所以alter操作我都是一次性执行好几条的&#xff0c;这几条一下子干过去了   结果就是一直在转圈执行&#xff0c;因为alter产生的是表级排它锁&#xff0c;所以有关这几个表的查询更新操作全部处于阻塞…

CTF-栈溢出-基本ROP-【ret2shellcode】

文章目录 ret2shellcodeHTBCyberSanta 2021 sleigh思路exp ret2shellcode 控制程序去执行我们自己填充的代码。 条件&#xff1a; 我们填充的代码的位置具有可执行权限 HTBCyberSanta 2021 sleigh 检查保护 Has RWX segments提示有可读可写可执行的段 main函数 banner函数…

教师资格证的照片是什么底色?一键替换证件照背景色

现在在报考教师资格证时&#xff0c;我们提交个人资料信息都是在网络上进行的&#xff0c;最关键的一步就是要提交证件照&#xff0c;很多小伙伴还都不太情书教师资格证证件照要求&#xff0c;比如规定的证件照背景色是什么颜色&#xff0c;今天就围绕着这个问题给大家详细说明…

赶快来!程序员接单必须知道的六大注意事项!!!

花花世界迷人眼&#xff0c;增加实力多搞钱&#xff01;对于咱程序员来说&#xff0c;搞钱的最好办法就是网上接单了&#xff0c;相信也有不少小伙伴已经在尝试了吧&#xff01;但是如何正确的搞钱呢&#xff1f;其中的注意事项你真的了解吗&#xff1f; 本期就和小编一起来看…

使用nacos配置中心管理配置文件时,springcloud程序启动报错,无法找到对应的配置文件(加载到了错误的配置文件)

这里写目录标题 一、场景二、关键依赖三、报错信息四、排查1、bootstrap.yml配置2、查看Nacos配置中心3、重启后程序依旧报错&#xff0c;查看启动日志&#xff0c;发现Nacos加载到了错误的配置文件4、Debug查看源码&#xff0c;企图弄清楚使用错误应用名的原因5、找不到使用依…

DDR3 的相关设计规范(个人总结)

文章目录 阻抗控制布局布线电源处理时序要求 DDR3 的相关设计规范(个人总结) 阻抗控制 DDR3 要严格控制阻抗&#xff0c;单线 50ohm&#xff0c;差分 100ohm&#xff0c;差分一般为时钟、DQS。在走线过程中&#xff0c;尽量减小阻抗跳变的因素&#xff0c;比如:换层(无法避免…

CSS特效012:边框线条环绕流动效果

CSS常用示例100专栏目录 本专栏记录的是经常使用的CSS示例与技巧&#xff0c;主要包含CSS布局&#xff0c;CSS特效&#xff0c;CSS花边信息三部分内容。其中CSS布局主要是列出一些常用的CSS布局信息点&#xff0c;CSS特效主要是一些动画示例&#xff0c;CSS花边是描述了一些CSS…

C++二分查找算法:规划兼职工作

题目 你打算利用空闲时间来做兼职工作赚些零花钱。 这里有 n 份兼职工作&#xff0c;每份工作预计从 startTime[i] 开始到 endTime[i] 结束&#xff0c;报酬为 profit[i]。 给你一份兼职工作表&#xff0c;包含开始时间 startTime&#xff0c;结束时间 endTime 和预计报酬 pro…

Vue3 生命周期

如下是Vue3的生命周期函数图&#xff1a; 一、Vue2生命周期和Vue3声明周期的区别 1. Vue2 中&#xff0c;只要创建Vue实例对象而不需要挂载就可以实现beforeCreate 和 created 生命周期函数。 Vue3中必须要将Vue实例对象挂载完成&#xff0c;所有的准备工作做完&#xff0c;…

V10 桌面版、服务器版系统加固

V10 桌面版、服务器版系统加固 一、 文档说明 本文档中涉及的加固方法主要包括&#xff1a;密码策略配置、防火墙规 则配置、禁用高风险服务等。 二、 V10 桌面版系统加固 2.1 密码策略配置 密码策略包括密码老化控制策略和密码复杂度策略。密码老化 控制策略需要配置/etc…

Git客户端(TortoiseGit)使用

参考文章&#xff1a; https://www.cnblogs.com/xuwenjin/p/8573603.html 【精选】使用TortoiseGit工具进行开发&#xff08;连接远程仓库进行克隆、拉取、获取、提交、推送、新建/切换/合并分支、解决冲突&#xff09;_tortoisegit连接远程仓库-CSDN博客 tortoise git 拉取…

二进制的形式在内存中绘制一个对象实例

一、引用类型实例的内存布局 从内存布局的角度来看&#xff0c;一个引用类型的实例由如下图所示的三部分组成&#xff1a;ObjHeader TypeHandle Fields。前置的ObjHeader用来缓存哈希值和同步状态&#xff0c;TypeHandle部分存储类型对应方法表&#xff08;Method Table&…

2023.11.17 -hivesql调优,数据压缩,数据存储

目录 1.hive命令和参数配置 2.hive数据压缩 3.hive数据存储 0.原文件大小 18.1MB 1.textfile行存储格式, 压缩后size:18MB 2.行存储格式:squencefile ,压缩后大小8.89MB​ 3. 列存储格式 orc - ZILIB ,压缩后大小2.78MB 4.列存储格式 orc-snappy ,压缩后大小3.75MB 5…

设计模式-中介者模式-笔记

Medicator中介者模式 动机&#xff08;Motivation&#xff09; 在软件构建过程中&#xff0c;经常会出现多个对象相互关联交际的情况&#xff0c;对象之间常常会维持一种复杂的引用关系&#xff0c;如果遇到一些需求的更改&#xff0c;这种直接的引用关系将面临不断的变化。 …