/usr/share/tcltk/xotcl1.6.8-actiweb/PlaceAccessControl.xotcl is in xotcl 1.6.8-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 | package provide xotcl::actiweb::placeAccessControl 1.0
package require -exact xotcl::comm::httpd 1.1
package require -exact xotcl::actiweb::httpPlace 1.0
package require XOTcl 1
#
# Simple Object Pwd Protection with BasicAccessControl
#
#Usage example:
#ConferenceOrgPlace confPlace -port $placeport -root [pwd] \
# -mixin PlaceAccessControl
#
#confPlace protect conference.html [confData set password]
#
#confPlace setPasswd conference.html xxx
namespace eval ::xotcl::actiweb::placeAccessControl {
namespace import ::xotcl::*
Class ObjectAccessControl -superclass BasicAccessControl
ObjectAccessControl instproc protectedResource {fn method varAuthMethod varRealm} {
# check whether access to $fn via $method is protected
upvar [self callinglevel] $varAuthMethod authMethod $varRealm realm
my instvar root
# we check only the current directory, not the parent directories
set call [url decodeItem $fn]
regsub "^$root" $call "" call
set call [string trimleft $call /]
set call [string trimleft $call :]
regexp {^([^ ]*)} $call _ call
set call "$root/$call"
foreach i [list $call $call:$method] {
#puts stderr "check <$i>"
if {[my exists protected($i)]} {
set realm [my set protected($i)]
set authMethod Basic
return 1
}
}
return 0
}
Class PlaceAccessControl
PlaceAccessControl instproc init args {
next
[self]::httpd mixin add ObjectAccessControl
[self]::httpd initWorkerMixins
}
PlaceAccessControl instproc protect {objName id pwd} {
set objName [string trimleft $objName :]
[self]::httpd protectDir $objName $objName {}
if {$pwd ne ""} {
my setPassword $objName $id $pwd
}
}
PlaceAccessControl instproc credentialsNotOk {credentials authMethod realm} {
#my instvar passwd
#parray passwd
next
}
PlaceAccessControl instproc setPassword {realm id pwd} {
set httpd [self]::httpd
if {[$httpd exists passwd($realm:$id)]} {
$httpd unset passwd($realm:$id)
$httpd set passwd($realm:$id) $pwd
} else {
$httpd addRealmEntry $realm "$id $pwd"
}
#$httpd set passwd($realm:admin) nimda
}
PlaceAccessControl instproc removeID {realm id} {
set httpd [self]::httpd
if {[$httpd exists passwd($realm:$id)]} {
$httpd unset passwd($realm:$id)
}
}
namespace export ObjectAccessControl PlaceAccessControl
}
namespace import ::xotcl::actiweb::placeAccessControl::*
|