|
|
After constructing the main screen, the next stage includes checking for authorization, collecting data, and entering the main procedure for event/callback driven processing. ``Template main procedure: Main'' shows the Main procedure used in the SCOadmin template.
Template main procedure: Main
proc Main {} { global appvals# Where are we? set appvals(localhost) [SaHostGetLocalName] set appvals(managedhost) $appvals(localhost)
# Collect command line options ParseCommandLine
# Initialize UI, build main form, present initial view
# Sample who module needs to tweak a few things first if {$appvals(who)} { WhoInit }
UiStart
# Main UI is now presented and Locked # Time-consuming startup operations can now take place with # optional status messages # # Examples: # + check user authorizations # + collect data to populate main form widgets # + populate main form widgets with live data
UiStatusBarSet [IntlLocalizeMsg APP_MSG_INIT]
# Authorizations
set authorized 1
# Sample when using who module if {$appvals(who)} { set authorized [WhoAuthorized $appvals(managedhost)] }
# Canonical error dialog and exit if not authorized if {!$authorized} { UiDisplayNoAuths $appvals(title) $appvals(managedhost) UiMainLoop return }
# Refresh main form data UiRefreshCB
# Set initial focus (list or menu bar) UiSetAppFocus
# Set sensitivity of all main screen ui selection devices UiSensitizeFunctions
# Setup complete # Wait for user events
UiStatusBarClear UiMainLoop }
If you want to prevent most users from running your manager without authorization, you should associate your manager with an existing authorization, or create a new one as described in asroot(ADM).
Authorizations can be checked using auths(C) command with the -q option. A standard message can be displayed for insufficient authorization using SaDisplayNoAuths(TCL_ADM). SaDisplayNotRoot(TCL_ADM) is used to generate a similar message when the user must be root to run the manager.
See also: