Difference between revisions of "Ns register filter"

From AOLserver Wiki
Jump to navigation Jump to search
Line 8: Line 8:
 
'''SYNOPSIS'''
 
'''SYNOPSIS'''
  
'''ns_register_filter''' ''when method url procname ?arg arg ...?''
+
'''ns_register_filter''' ''?-first? when method URLpatttern procname ?arg arg ...?''
  
'''ns_register_trace''' method url procname ?arg arg ...?''
+
'''ns_register_trace''' ''method URLpatttern procname ?arg arg ...?''
  
  
 
'''DESCRIPTION'''
 
'''DESCRIPTION'''
  
: Registers a Tcl filter script for the specified method/URL combination on a virtual server. The script can be called at one or more of three given times: pre-authorization, post-authorization before page data has been returned to the user, and after the connection has been processed and closed.
+
: Registers a Tcl filter script for the specified method/URL combination on a virtual server. The script can be called at one of several times as indicated by the ''when'' argument:
 +
* '''prequeue'''
 +
* '''preauth''' - pre-authorization
 +
* '''postauth'''- post-authorization before page data has been returned to the user
 +
* '''trace''' - after the connection has been processed and closed.
  
: This function will be called at the specified stage of a connection, if the method/URL combination for the filter matches the method/URL combination for the connection using glob style matching.
+
: Also upcoming in AOLserver 4.6 are:
 +
* '''read'''
 +
* '''write'''
  
: The URLpattern can contain standard string match glob matching characters (not regex). For example, these are valid URL patterns:
+
: The registered script will be called at the specified stage of a connection, if the method/URL combination for the filter matches the method/URL combination for the connection using glob style (i.e. as in string match) matching. For example, these are valid ''URLpatterns'':
  
 
     /employees/*.tcl
 
     /employees/*.tcl
 
 
     /accounts/*/out
 
     /accounts/*/out
  
: Valid values for the "when" argument are: '''prequeue''', '''preauth''', '''postauth''', and '''trace''' (and upcoming in AOLserver 4.6 also '''read''' and '''write''').
 
 
: Using pre-authorization, the procedure will be called (assuming that the method/URL combination matches) just before authorization. If the procedure returns with a code of:
 
: Using pre-authorization, the procedure will be called (assuming that the method/URL combination matches) just before authorization. If the procedure returns with a code of:
  
; '''TCL_OK'''
+
* '''TCL_OK'''
 
: (using: return "filter_ok"): The server will continue to the next pre-authorization filter for this connection, or, if there are no more pre-authorization filters, it will continue on with authorization.
 
: (using: return "filter_ok"): The server will continue to the next pre-authorization filter for this connection, or, if there are no more pre-authorization filters, it will continue on with authorization.
; '''TCL_BREAK'''
+
* '''TCL_BREAK'''
 
: (using: return "filter_break"): The server will not process any more pre-authorization filters for this connection, and it will continue on with authorization.
 
: (using: return "filter_break"): The server will not process any more pre-authorization filters for this connection, and it will continue on with authorization.
; '''TCL_RETURN'''
+
* '''TCL_RETURN'''
 
: (using: return "filter_return"): The server will close the connection and will not run any more pre-authorization filters. It will not authorize the request, and it will not run the function registered for this METHOD/URL. It WILL run any trace functions registered for this METHOD/URL, usually including logging. It is assumed that the filter has sent a proper response (e.g., using ns_return) to the client before returning TCL_RETURN.
 
: (using: return "filter_return"): The server will close the connection and will not run any more pre-authorization filters. It will not authorize the request, and it will not run the function registered for this METHOD/URL. It WILL run any trace functions registered for this METHOD/URL, usually including logging. It is assumed that the filter has sent a proper response (e.g., using ns_return) to the client before returning TCL_RETURN.
; Using post-authorization, the procedure will be called (assuming that the method/URL combination matches) just after successful authorization. If the procedure returns:
+
 
; '''TCL_OK'''
+
: Using post-authorization, the procedure will be called (assuming that the method/URL combination matches) just after successful authorization. If the procedure returns:
 +
* '''TCL_OK'''
 
: (using: return "filter_ok"): The server will continue to the next post-authorization filter for this connection, or, if there are no more post-authorization filters, it will run the function registered to handle this request.
 
: (using: return "filter_ok"): The server will continue to the next post-authorization filter for this connection, or, if there are no more post-authorization filters, it will run the function registered to handle this request.
; '''TCL_BREAK'''
+
* '''TCL_BREAK'''
 
: (using: return "filter_break"): The server will not process any more post-authorization filters for this connection, and it will run the function registered to handle this request.
 
: (using: return "filter_break"): The server will not process any more post-authorization filters for this connection, and it will run the function registered to handle this request.
; '''TCL_RETURN'''
+
* '''TCL_RETURN'''
 
: (using: return "filter_return"): The server will close the connection and will not run any more post-authorization filters and it will not run the function registered for this METHOD/URL. It WILL run any trace functions registered for this METHOD/URL, usually including logging. It is assumed that the filter has returned a proper response (e.g., using ns_return) to the client before returning TCL_RETURN.
 
: (using: return "filter_return"): The server will close the connection and will not run any more post-authorization filters and it will not run the function registered for this METHOD/URL. It WILL run any trace functions registered for this METHOD/URL, usually including logging. It is assumed that the filter has returned a proper response (e.g., using ns_return) to the client before returning TCL_RETURN.
; Using trace, the procedure will be called (assuming that the method/URL combination match) after the connection has been totally processed and closed. If the procedure returns:
+
 
; '''TCL_OK'''
+
: Using trace, the procedure will be called (assuming that the method/URL combination match) after the connection has been totally AND successfully processed (i.e. not a Server Error) and closed. If the procedure returns:
 +
* '''TCL_OK'''
 
: (using: return "filter_ok"): The server will continue to the next trace filter.
 
: (using: return "filter_ok"): The server will continue to the next trace filter.
; '''TCL_BREAK'''
+
* '''TCL_BREAK'''
 
: (using: return "filter_break"): The rest of the trace filters are ignored.
 
: (using: return "filter_break"): The rest of the trace filters are ignored.
; '''TCL_RETURN'''
+
* '''TCL_RETURN'''
 
: (using: return "filter_break"): The rest of the trace filters are ignored.
 
: (using: return "filter_break"): The rest of the trace filters are ignored.
  
 
'''Syntax for the registered procedure:'''
 
'''Syntax for the registered procedure:'''
  
The conn (connection) argument is optional for procedures registered by ns_register_filter if the procedure has 1 or 2 arguments (including why but not including conn). The following examples show the variations that can be used in this case:
+
The ''conn'' (connection id) argument is optional for procedures registered by ns_register_filter if the procedure has 1 or 2 arguments (including why but not including ''conn''). The following examples show the variations that can be used in this case:
  
 
     '''ns_register_filter''' ''trace'' GET /noargs filter_noargs
 
     '''ns_register_filter''' ''trace'' GET /noargs filter_noargs
Line 72: Line 78:
 
     } ;# filter_noargs
 
     } ;# filter_noargs
  
: The conn (connection) argument is required for procedures registered by ns_register_filter if the procedure has 3 or more arguments (including why but not including conn). The conn argument is automatically filled with the connection information. The first argument following conn will always take the value supplied by ns_register_filter, if there is one, or an empty value. The why argument at the end is automatically filled with the type of filter requested. All other arguments must supply a default value. The following examples show the variations that can be used in this case:
+
: The ''conn'' (connection) argument is required for procedures registered by '''ns_register_filter''' if the procedure has 3 or more arguments (including why but not including ''conn''). The ''conn'' argument is automatically filled with the connection id. The first argument following ''conn'' will always take the value supplied by '''ns_register_filter''', if there is one, or an empty value. The why argument at the end is automatically filled with the type of filter requested (the ''when'' it was registered for). All other arguments must supply a default value. The following examples show the variations that can be used in this case:
  
     <code> '''ns_register_filter''' ''postauth'' GET /threeargs threeargs aaa
+
     <code>
 +
    '''ns_register_filter''' ''postauth'' GET /threeargs threeargs aaa
 
     '''ns_register_filter''' ''postauth'' GET /fourargs fourargs aaa bbb ccc
 
     '''ns_register_filter''' ''postauth'' GET /fourargs fourargs aaa bbb ccc
 
     </code>
 
     </code>
Line 90: Line 97:
 
==='''ns_register_trace:'''===
 
==='''ns_register_trace:'''===
  
; Register a Tcl trace script to a method and matching URL.
+
: This command is very similar to '''ns_register_filter trace'''. Known internally as ''void_traces'', procedures registered by this command fire after the procedures registered by '''ns_register_filter trace''' and differ in that their return value is ignored.
: (Note: This function is obsolete. Use '''ns_register_filter''' instead.)
 
  
: '''ns_register_trace''' registers a Tcl script as a trace for the specified method/URL combination. After the server handles the request for the specified method on an URL that matches the ''URLpattern'', it calls the trace script with the connection id and any arguments (args) specified. The ''URLpattern'' can contain standard string-matching characters. For example, these are valid URLpatterns:
 
  
    /employees/*.tcl /accounts/*/out
+
'''NOTES'''
  
: Note '''ns_register_trace''' is similar to '''ns_register_proc''' except that the pattern-matching for the URL is performed differently. With '''ns_register_proc''', the specified URL is used to match that URL and any URL below it in the hierarchy. Wildcards such as "*" are meaningful only for the final part of the URL, such as /scripts/*.tcl. With '''ns_register_trace''', the ''URLpattern'' is used to match URLs as a string with standard string-matching characters. '''ns_register_proc''' results in a single match, whereas multiple ns_register_trace’s can be matched and will be called.
+
: Note '''ns_register_filter''' (and _trace) is similar to '''[[ns_register_proc]]''' except that the pattern-matching for the URL is performed differently. With '''ns_register_proc''', the specified URL is used to match that URL and any URL below it in the hierarchy. Wildcards such as "*" are meaningful only for the final part of the URL, such as /scripts/*.tcl. With '''ns_register_filter''', the ''URLpattern'' is used to match URLs as a string with standard string-matching characters. '''ns_register_proc''' always results in a single match to just one procedure, whereas multiple procedures registered with '''ns_register_filter''' can be matched and will be called in the order they were registered.  In AOLserver 4.5.2, you can use the optional ''-first'' switch to specify that the procedure should go to the top of registered filters for a particular pattern and therefore to be called first.
  
  
'''NOTES'''
+
: To be more precise the allowed matching characters in ''URLpattern'' are determined by [http://www.tcl.tk/man/tcl8.0/TclLib/StrMatch.htm Tcl_StrMatch] which in turn is determined by [http://www.tcl.tk/man/tcl8.0/TclCmd/string.htm#M10 TCL string match].
 
 
: To be more precise the allowed matching characters are determined by [http://www.tcl.tk/man/tcl8.0/TclLib/StrMatch.htm Tcl_StrMatch] which in turn is determined by [http://www.tcl.tk/man/tcl8.0/TclCmd/string.htm#M10 TCL string match].
 
  
 
----
 
----
  
 
[[Category:Core Tcl API]]
 
[[Category:Core Tcl API]]

Revision as of 04:29, 20 June 2010

Man page: http://aolserver.com/man/4.0/tcl/ns_filter.html


NAME

ns_register_filter, ns_register_trace - Register a filter or trace callback


SYNOPSIS

ns_register_filter ?-first? when method URLpatttern procname ?arg arg ...?

ns_register_trace method URLpatttern procname ?arg arg ...?


DESCRIPTION

Registers a Tcl filter script for the specified method/URL combination on a virtual server. The script can be called at one of several times as indicated by the when argument:
  • prequeue
  • preauth - pre-authorization
  • postauth- post-authorization before page data has been returned to the user
  • trace - after the connection has been processed and closed.
Also upcoming in AOLserver 4.6 are:
  • read
  • write
The registered script will be called at the specified stage of a connection, if the method/URL combination for the filter matches the method/URL combination for the connection using glob style (i.e. as in string match) matching. For example, these are valid URLpatterns:
   /employees/*.tcl
   /accounts/*/out
Using pre-authorization, the procedure will be called (assuming that the method/URL combination matches) just before authorization. If the procedure returns with a code of:
  • TCL_OK
(using: return "filter_ok"): The server will continue to the next pre-authorization filter for this connection, or, if there are no more pre-authorization filters, it will continue on with authorization.
  • TCL_BREAK
(using: return "filter_break"): The server will not process any more pre-authorization filters for this connection, and it will continue on with authorization.
  • TCL_RETURN
(using: return "filter_return"): The server will close the connection and will not run any more pre-authorization filters. It will not authorize the request, and it will not run the function registered for this METHOD/URL. It WILL run any trace functions registered for this METHOD/URL, usually including logging. It is assumed that the filter has sent a proper response (e.g., using ns_return) to the client before returning TCL_RETURN.
Using post-authorization, the procedure will be called (assuming that the method/URL combination matches) just after successful authorization. If the procedure returns:
  • TCL_OK
(using: return "filter_ok"): The server will continue to the next post-authorization filter for this connection, or, if there are no more post-authorization filters, it will run the function registered to handle this request.
  • TCL_BREAK
(using: return "filter_break"): The server will not process any more post-authorization filters for this connection, and it will run the function registered to handle this request.
  • TCL_RETURN
(using: return "filter_return"): The server will close the connection and will not run any more post-authorization filters and it will not run the function registered for this METHOD/URL. It WILL run any trace functions registered for this METHOD/URL, usually including logging. It is assumed that the filter has returned a proper response (e.g., using ns_return) to the client before returning TCL_RETURN.
Using trace, the procedure will be called (assuming that the method/URL combination match) after the connection has been totally AND successfully processed (i.e. not a Server Error) and closed. If the procedure returns:
  • TCL_OK
(using: return "filter_ok"): The server will continue to the next trace filter.
  • TCL_BREAK
(using: return "filter_break"): The rest of the trace filters are ignored.
  • TCL_RETURN
(using: return "filter_break"): The rest of the trace filters are ignored.

Syntax for the registered procedure:

The conn (connection id) argument is optional for procedures registered by ns_register_filter if the procedure has 1 or 2 arguments (including why but not including conn). The following examples show the variations that can be used in this case:

   ns_register_filter trace GET /noargs filter_noargs
   ns_register_filter trace GET /context filter_context fnord
   ns_register_filter trace GET /conncontext filter_conncontext
   proc filter_noargs { why } {
   ns_log Notice "filter noargs"
   return filter_ok
   } ;# filter_noargs
   proc filter_context { arg why } {
   ns_log Notice "filter context. Arg: $arg"
   return filter_ok
   } ;# filter_noargs
   proc filter_conncontext { conn arg why } {
   ns_log Notice "filter conn context"
   return filter_ok
   } ;# filter_noargs
The conn (connection) argument is required for procedures registered by ns_register_filter if the procedure has 3 or more arguments (including why but not including conn). The conn argument is automatically filled with the connection id. The first argument following conn will always take the value supplied by ns_register_filter, if there is one, or an empty value. The why argument at the end is automatically filled with the type of filter requested (the when it was registered for). All other arguments must supply a default value. The following examples show the variations that can be used in this case:
   
   ns_register_filter postauth GET /threeargs threeargs aaa
   ns_register_filter postauth GET /fourargs fourargs aaa bbb ccc
   
   proc threeargs { conn context { greeble bork } why } {
   ...
   } ;
   proc fourargs { conn context { greeble bork } {hoover quark} why } {
   ...
   } ;
When a GET of /threeargs is requested, the conn and why arguments will be filled automatically, the context argument will be assigned "aaa" and the greeble argument will be assigned the default value "bork". When a GET of /fourargs is requested, the conn and why arguments will be filled automatically, the context argument will be assigned "aaa", the greeble argument will be assigned "bbb", and the hoover argument will be assigned the default value "quark".

ns_register_trace:

This command is very similar to ns_register_filter trace. Known internally as void_traces, procedures registered by this command fire after the procedures registered by ns_register_filter trace and differ in that their return value is ignored.


NOTES

Note ns_register_filter (and _trace) is similar to ns_register_proc except that the pattern-matching for the URL is performed differently. With ns_register_proc, the specified URL is used to match that URL and any URL below it in the hierarchy. Wildcards such as "*" are meaningful only for the final part of the URL, such as /scripts/*.tcl. With ns_register_filter, the URLpattern is used to match URLs as a string with standard string-matching characters. ns_register_proc always results in a single match to just one procedure, whereas multiple procedures registered with ns_register_filter can be matched and will be called in the order they were registered. In AOLserver 4.5.2, you can use the optional -first switch to specify that the procedure should go to the top of registered filters for a particular pattern and therefore to be called first.


To be more precise the allowed matching characters in URLpattern are determined by Tcl_StrMatch which in turn is determined by TCL string match.