| Documentation | Documentation.Script-Flags-3-0 HistoryShow minor edits - Show changes to output June 26, 2020, at 11:49 AM 
        by  -  Changed line 112 from:    xlog("-------branch=$T_branch_idx, branch flags=$bF\n"); to:    xlog("-------branch=$T_branch_idx, branch flags=$bf\n"); April 25, 2020, at 08:04 PM 
        by  - Comment added Added lines 140-148: >><< [[#comment2]](:nl:)>>messagehead<< !!!!![[~Satish]] — [-25 April 2020, 20:04-] >>messageitem<< I think there's a typo. There/These "There flags will show up in all routes where messages related to initial branch request are processed." should be "These flags will show up in all routes where messages related to initial branch request are processed." May 30, 2019, at 10:41 AM 
        by  - Comment added Added lines 131-140: [[#comment1]](:nl:)>>messagehead<< !!!!![[~Virendra]] — [-30 May 2019, 10:41-] >>messageitem<< in onreply route yo will see the branch flags corresponding to the branch the reply belongs to; English issue only : in onreply route "you" will see the branch flags corresponding to the branch the reply belongs to; >><< December 07, 2018, at 06:23 PM 
        by  -  Changed lines 20-21 from: * '''script flags'''  are no-message-related flags - they are only script persistent and you can strictly use them for scripting. Once you exit a top level route, they will be lost. These flags are useful and they offer an option to de-congest the message flags - many flags have no need to be saved as they just reflect some scripting status. to: Deleted lines 47-53: !!!! Script flags * setsflag/setscriptflag(FLAG) * resetsflag/resetscriptflag(FLAG) * issflagset/isscriptflagset(FLAG) Deleted lines 60-64: !!!! Script flags $sf - ReadOnly; outputs a list of flags Deleted lines 76-81: !!!! Script flags There flags are available only in script and are reset after each top level route execution (routes internally triggered by OpenSIPS). They will be persistent per main route, onreply_route, branch_route, failure_route. Note they will be inherit in routes called from other routes. July 21, 2015, at 11:51 AM 
        by  -  Changed lines 45-49 from: * setbflag(flag_idx) * resetbflag(flag_idx) * isbflagset(flag_idx) to: * setbflag(FLAG) * resetbflag(FLAG) * isbflagset(FLAG) Changed lines 52-54 from: * setsflag/setscriptflag(flag_idx) * resetsflag/resetscriptflag(flag_idx) * issflagset/isscriptflagset(flag_idx) to: * setsflag/setscriptflag(FLAG) * resetsflag/resetscriptflag(FLAG) * issflagset/isscriptflagset(FLAG) July 21, 2015, at 11:51 AM 
        by  -  Changed line 25 from: Starting from OpenSIPS 1.9, flags may receive alphanumerical values. However, this does not affect performance, since they are converted into bit indexes upon startup. When it comes to DB persistency (only a few modules do this - e.g. usrloc), flags are generally stored in their string form, in order to preserve their semantics, and not the bit index they received during a given OpenSIPS run. to: Starting from OpenSIPS 1.9, '''flags may receive alphanumerical values'''. However, this does not affect performance, since they are converted into bit indexes upon startup. When it comes to DB persistency (only a few modules do this - e.g. usrloc), flags are generally stored in their string form, in order to preserve their semantics, and not the bit index they received during a given OpenSIPS run. July 21, 2015, at 11:50 AM 
        by  -  Changed lines 25-26 from: Starting from OpenSIPS 1.9, flags may receive alphanumerical values. to: Starting from OpenSIPS 1.9, flags may receive alphanumerical values. However, this does not affect performance, since they are converted into bit indexes upon startup. When it comes to DB persistency (only a few modules do this - e.g. usrloc), flags are generally stored in their string form, in order to preserve their semantics, and not the bit index they received during a given OpenSIPS run. Changed lines 29-32 from: * setflag(flag_idx) * resetflag(flag_idx) * isflagset(flag_idx) to: * setflag(FLAG) * resetflag(FLAG) * isflagset(FLAG) Changed lines 37-39 from: * setbflag/setbranchflag(branch_idx,flag_idx) * resetbflag/resetbranchflag(branch_idx,flag_idx) * isbflagset/isbranchflagset(branch_idx,flag_idx) to: * setbflag/setbranchflag(branch_idx, FLAG) * resetbflag/resetbranchflag(branch_idx, FLAG) * isbflagset/isbranchflagset(branch_idx, FLAG) May 06, 2014, at 05:41 PM 
        by  -  Changed lines 112-113 from:       setbflag(NAT_BFLAG); # set branch flag 3 for the branch 0 to:       setbflag(NAT_BFLAG); # set branch flag "NAT_BFLAG" for the branch 0 Changed line 116 from:       # the branch flags (including 3) will be saved into location to:       # the branch flags (including "NAT_BFLAG") will be saved into location March 20, 2014, at 08:34 PM 
        by  -  Added lines 1-151: !!!!!Documentation -> [[Documentation.Manuals|Manuals]] -> [[Documentation.Manual-3-0|Manual 3.0]] -> Script Flags (:title Script Flags - 3.0:) ---- (:allVersions Script-Flags 3.0:) \\ || %color=#185662%[+'''Script Flags v3.0 '''+]%% || ||[[Script-CoreVar-3-0|Prev]] || [[Script-Tran-3-0|Next]]|| ---- (:toc-float Table of Content:) !!! Types of flags * '''message flags''' (or transaction flags) these flags are transaction persistent. They are visible in all routes and cases where the transaction context is visible * '''branch flags''' are saved also in transaction, but per branch; also they will be saved in usrloc (per contact). A new set of functions were added for manipulating these flags from script. So, there flags will be registration persistent and branch persistent. * '''script flags''' are no-message-related flags - they are only script persistent and you can strictly use them for scripting. Once you exit a top level route, they will be lost. These flags are useful and they offer an option to de-congest the message flags - many flags have no need to be saved as they just reflect some scripting status. ---- !!! Corresponding Functions Starting from OpenSIPS 1.9, flags may receive alphanumerical values. !!!! Message/transaction flags * setflag(flag_idx) * resetflag(flag_idx) * isflagset(flag_idx) ''Examples: setflag(accounting), resetflag(DO_NAT) or setflag(19)'' !!!! Branch flags * setbflag/setbranchflag(branch_idx,flag_idx) * resetbflag/resetbranchflag(branch_idx,flag_idx) * isbflagset/isbranchflagset(branch_idx,flag_idx) \\ or, the shorter format, working on the default (branch 0) flags: * setbflag(flag_idx) * resetbflag(flag_idx) * isbflagset(flag_idx) !!!! Script flags * setsflag/setscriptflag(flag_idx) * resetsflag/resetscriptflag(flag_idx) * issflagset/isscriptflagset(flag_idx) ---- !!! Flags and Pseudo Variables !!!! Message/transaction flags $mf - ReadOnly; outputs a list of flags !!!! Branch flags $bf - ReadOnly; returns a list of flags !!!! Script flags $sf - ReadOnly; outputs a list of flags ---- !!! Flags and routes !!!! Message/transaction flags These flags will show up in all routes where messages related to the initial request are processed. So, they will be visible and changeable in onbranch, failure and onreply routes; the flags will be visible in all branch routes; if you change a flag in a branch route, the next branch routes will inherit the change. !!!! Branch flags There flags will show up in all routes where messages related to initial branch request are processed. So, in branch route you will see different sets of flags (as they are different branches); in onreply route yo will see the branch flags corresponding to the branch the reply belongs to; in failure route, the branch flags corresponding to the branch the winning reply belongs to will be visible. In request route, you can have multiple branches (as a result of a lookup(), enum query, append_branch(), etc) - the default branch is 0 (corresponding to the RURI); In reply routes there will be only one branch , the 0 one. In branch route the default branch is the current process branch (having index 0); In failure route, initially there is only one branch (index 0), corresponding the failed branch. !!!! Script flags There flags are available only in script and are reset after each top level route execution (routes internally triggered by OpenSIPS). They will be persistent per main route, onreply_route, branch_route, failure_route. Note they will be inherit in routes called from other routes. ---- !!! Example !!!! Nat flag handling [@ .......... # 3 - the nat flag modparam("usrloc", "nat_bflag", "NAT_BFLAG") .......... route { .......... if (nat detected) setbflag(NAT_BFLAG); # set branch flag 3 for the branch 0 .......... if (is_method("REGISTER")) { # the branch flags (including 3) will be saved into location save("location"); exit; } else { # lookup will load the branch flag from location if (!lookup("location")) { sl_send_reply("404","Not Found"); exit; } t_on_branch("1") t_relay(); } } branch_route[1] { xlog("-------branch=$T_branch_idx, branch flags=$bF\n"); if (isbflagset(NAT_BFLAG)) { #current branch is marked as natted ......... } } @] if no parallel forking is done, you can get rid of the branch route and add instead of t_on_branch(): [@ ........ if (isbflagset(NAT_BFLAG)) { #current branch is marked as natted ......... } ......... @] ---- (:commentboxchrono:) | 
 
  