UNIBASE

Tcl – Unibase Tcl support library

Unibase has tclsh linked in to the binaries and Tcl is our preferred scripting language. NB Other languages can be used, this isn’t exclusive.

Tcl script are supported by a Tcl package called “unibase”. To use this package simply add “package require unibase” at the start of a Tcl script.

All procedures are in the ::unibase namespace or a subspace of it.

Here are the top level namespaces (alphabetically):

  • cookie – manage http cookies
  • getflags – process command flags for Tcl scripts
  • http – http helper proceures
  • httpd – httpd helper procedures
  • recaptchav3 – get the recaptcha key for a URL
  • log – log errors or other info to the system logs
  • session – set up and maintain a Unibase session
  • users – get user details for application security

Commands (alphabetically with their namespaces):

  • ::unibase::getflags {COMMAND FLAGS}
    • process command line arguments in a similar format to standard Linux commands.
    • RETURN
      • Processed flags in ::UB_FLAGS
      • Unprocessed arguments in ::UB_FLAGS::_GLOBAL
      • return 1 on success
      • return 0 on error
    • ERROR
      • Print ::UB_FLAGS::_USAGE:
  • ::unibase::cookie {}
    • Manage cookies
  • ::unibase::cookie::unset {COOKIE}
    • Unset COOKIE
  • ::unibase::http
    • http helper functions
  • ::unibase::http::content {}
    • Output an http Content-Type string and cache-control.
  • ::unibase::httpd
    • Helper functions for cgi scripts
  • ::unibase::httpd::argument {FLAG VARIABLE}
    • Add VARIABLE to the flags for a command to be called
  • ::unibase::httpd::cookies {}
    • Put cookies into the environment
  • ::unibase::httpd::header {}
    • Same as ::unibase::http::content
  • ::unibase::httpd::sessionClear {}
    • clear session info in preparation for a new session
  • ::unibase::httpd::ubqs {QUERY_STRING}
    • decode QUERY_STRING
  • ::unibase::recaptchav3::get
    • get the private key for a Unibase web application
  • ::unibase::recaptcahv3::update {URL KEY}
    • update the private key for a Unibase web application
  • ::unibase::log
    • Add something to the system logs
  • ::unibase::log::debug {type msg}
    • add a message with key to system logs
  • ::unibase::log::log {type msg}
    • add a message with key to system logs
  • ::unibase::session::create {USER APPLICATION}
    • create a new user session in the Unibase session directory
  • ::unibase::session::destroy {}
    • Destroy the current session file
  • ::unibase::session::env {}
    • put the current session variables into the environment
  • ::unibase::session::json {}
    • return the current session variables as JSON
  • ::unibase::session::valid {}
    • check if the current session is valid
    • A session is valid if the session file exists and the last time accessed is less than the “IDLE_TIME” variable in the session
  • ::unibase::session::value {VAR} – get value of a session variable
  • ::unibase::session::var {VAR VALUE} – add var VAR to the session with value VALUE
  • ::unibase::users::attribute {USER APPLICATION ATTRIBUTE} – get an attribute from the users table for USER in application APPLICATION
  • ::unibase::users::password {APPLICATION USER PASSWORD} – check a password for a user using APPLICATION
  • ::unibase::users::salt {PASSWORD} – get salt from a password
  • ::unibase::users::update {USER APPLICATION ATTRIBUTE VALUE} – Update the value of an attribute for a user