Index: openacs-4/packages/xotcl-core/tcl/01-debug-procs.tcl =================================================================== RCS file: /usr/local/cvsroot/openacs-4/packages/xotcl-core/tcl/01-debug-procs.tcl,v diff -u -r1.2 -r1.3 --- openacs-4/packages/xotcl-core/tcl/01-debug-procs.tcl 14 Dec 2005 15:55:29 -0000 1.2 +++ openacs-4/packages/xotcl-core/tcl/01-debug-procs.tcl 24 Mar 2006 12:54:59 -0000 1.3 @@ -1,4 +1,5 @@ -# tell serializer to export methods, allthough these are methods of ::xotcl::Object +# tell serializer to export methods, allthough these are methods of +# ::xotcl::Object ::Serializer exportMethods { ::xotcl::Object instproc log ::xotcl::Object instproc debug @@ -15,4 +16,28 @@ } ::xotcl::Object instproc debug msg { ns_log debug "[self] [self callingclass]->[self callingproc]: $msg" -} \ No newline at end of file +} + +# ::xotcl::Class instproc import {class pattern} { +# namespace eval [self] [list \ +# namespace import [list import [$class self]]::$pattern; +# my log "--namespace [list import [$class self]]::$pattern" +# ] +# } + +# ::xotcl::Class instproc export args { +# my log "--namespace eval [self] {eval namespace export $args}" +# namespace eval [self] [list eval namespace export $args] +# } + +#ns_log notice "--T [info command ::ttrace::isenabled]" +# tell ttrace to put these to the blueprint +#if {[info command ::ttrace::isenabled] ne "" && [::ttrace::isenabled]} { +# ns_log notice "--T :ttrace::isenabled" +# set blueprint [ns_ictl get] +# ns_ictl save [append blueprint [::Serializer serializeExportedMethods \ +# [::Serializer new -volatile]]] +# unset blueprint +# ns_log notice "--T [ns_ictl get]" +#} + Index: openacs-4/packages/xotcl-core/tcl/chat-procs.tcl =================================================================== RCS file: /usr/local/cvsroot/openacs-4/packages/xotcl-core/tcl/Attic/chat-procs.tcl,v diff -u --- /dev/null 1 Jan 1970 00:00:00 -0000 +++ openacs-4/packages/xotcl-core/tcl/chat-procs.tcl 24 Mar 2006 12:54:59 -0000 1.1 @@ -0,0 +1,192 @@ +ad_library { + generic chat - chat procs + + @creation-date 2006-02-02 + @author Gustaf Neumann + @cvs-id $Id: chat-procs.tcl,v 1.1 2006/03/24 12:54:59 gustafn Exp $ +} + +namespace eval ::xo { + Class Message -parameter {time user_id msg } + Class Chat -superclass ::xo::OrderedComposite \ + -parameter {chat_id user_id session_id + {encoder urlencode} {timewindow 600} {sweepinterval 60} + } + + Chat instproc init {} { + my instvar array + my log "-- " + my set now [clock clicks -milliseconds] + if {![my exists user_id]} {my set user_id [ad_conn user_id]} + if {![my exists session_id]} {my set session_id [ad_conn session_id]} + set cls [my info class] + set array $cls-[my set chat_id] + if {![nsv_exists $cls initialized]} { + my log "-- initialize $cls" + $cls initialize_nsvs + nsv_set $cls initialized \ + [ad_schedule_proc -thread "t" [my sweepinterval] $cls sweep_all_chats] + } + if {![nsv_exists $array-seen newest]} {nsv_set $array-seen newest 0} + } + + Chat instproc add_msg {{-get_new:boolean true} -uid msg} { + my instvar array now + set user_id [expr {[info exists uid] ? $uid : [my set user_id]}] + set msg_id $now.$user_id + nsv_set $array $msg_id [list $now [clock seconds] $user_id $msg] + nsv_set $array-seen newest $now + nsv_set $array-seen last [clock seconds] ;#### PETER? + nsv_set $array-last-activity $user_id $now + if {$get_new} {my get_new} + } + Chat instproc active_user_list {} { + nsv_array get [my set array]-last-activity + } + + Chat instproc nr_active_users {} { + expr { [llength [nsv_array get [my set array]-last-activity]] / 2 } + } + + Chat instproc last_activity {} { + if { ![nsv_exists [my set array]-seen last] } { return "" } + return [clock format [nsv_get [my set array]-seen last] -format "%d.%m.%y %H:%M:%S"] + } + + Chat instproc check_age {key ago} { + my instvar array timewindow + if {$ago > $timewindow} { + nsv_unset $array $key + #my log "--c unsetting $key" + return 0 + } + return 1 + } + Chat instproc get_new {} { + my instvar array now session_id + set last [expr {[nsv_exists $array-seen $session_id] ? [nsv_get $array-seen $session_id] : 0}] + if {[nsv_get $array-seen newest]>$last} { + #my log "--c must check $session_id: [nsv_get $array-seen newest] > $last" + foreach {key value} [nsv_array get $array] { + foreach {timestamp secs user msg} $value break + if {$timestamp > $last} { + my add [Message new -time $secs -user_id $user -msg $msg] + } else { + my check_age $key [expr {($now - $timestamp) / 1000}] + } + } + nsv_set $array-seen $session_id $now + #my log "--c setting session_id $session_id: $now" + } else { + #my log "--c nothing new for $session_id" + } + my render + } + Chat instproc get_all {} { + my instvar array now session_id + foreach {key value} [nsv_array get $array] { + foreach {timestamp secs user msg} $value break + if {[my check_age $key [expr {($now - $timestamp) / 1000}]]} { + my add [Message new -time $secs -user_id $user -msg $msg] + } + } + #my log "--c setting session_id $session_id: $now" + nsv_set $array-seen $session_id $now + my render + } + + Chat instproc sweeper {} { + my instvar array now + my log "-- starting" + foreach {user timestamp} [nsv_array get $array-last-activity] { + ns_log Notice "YY at user $user with $timestamp" + set ago [expr {($now - $timestamp) / 1000}] + ns_log Notice "YY Checking: now=$now, timestamp=$timestamp, ago=$ago" + # was 1200 + if {$ago > 300} { + my add_msg -get_new false -uid $user "auto logout" + nsv_unset $array-last-activity $user + } + } + my log "-- ending" + } + + Chat instproc logout {} { + my instvar array user_id + ns_log Notice "YY User $user_id logging out of chat" + my add_msg -get_new false [_ xotcl-core.has_left_the_room]. + nsv_unset $array-last-activity $user_id + } + + Chat instproc login {} { + my instvar array user_id now + # was the user already active? + if {![nsv_exists $array-last-activity $user_id]} { + my add_msg -get_new false [_ chat.has_entered_the_room] + } + my encoder noencode + #my log "--c setting session_id [my set session_id]: $now" + my get_all + } + + Chat instproc urlencode {string} {ns_urlencode $string} + Chat instproc noencode {string} {set string} + Chat instproc encode {string} {my [my encoder] $string} + Chat instproc render {} { + my orderby time + set result "" + foreach child [my children] { + set msg [$child msg] + set user_id [$child user_id] + set timelong [clock format [$child time]] + set timeshort [clock format [$child time] -format {[%H:%M:%S]}] + if {$user_id > 0} { + acs_user::get -user_id $user_id -array user + set name [expr {$user(screen_name) ne "" ? $user(screen_name) : $user(name)}] + set url "/shared/community-member?user%5fid=$user_id" + set creator "<a target='_parent' href='$url'>$name</a>" + } else { + set creator "Nobody" + } + append result "<p class='line'><span class='timestamp'>$timeshort</span> \ + <span class='user'> [my encode $creator:]\ + </span><span class='message'> [my encode $msg]</span></p>\n" + } + return $result + } + + + ############# + # class procs + ############# + Class ChatProcs + ChatProcs method sweep_all_chats {} { + my log "-- starting" + foreach nsv [nsv_names "[self]-*-seen"] { + if { [regexp "[self]-(\[0-9\]+)-seen" $nsv _ chat_id] } { + my log "--Chat_id $chat_id" + my new -volatile -chat_id $chat_id -user_id 0 -session_id 0 -init -sweeper + } + } + my log "-- ending" + } + + ChatProcs method initialize_nsvs {} { + # read the last_activity information at server start into a nsv array + db_foreach get_rooms { + select room_id, to_char(max(creation_date),'HH24:MI:SS YYYY-MM-DD') as last_activity + from chat_msgs group by room_id} { + nsv_set [self]-$room_id-seen last [clock scan $last_activity] + } + } + + ChatProcs method flush_messages {-chat_id:required} { + set array "[self]-$chat_id" + nsv_unset $array + nsv_unset $array-seen + nsv_unset $array-last-activity + } + + +} + Index: openacs-4/packages/xotcl-core/tcl/thread_mod-procs.tcl =================================================================== RCS file: /usr/local/cvsroot/openacs-4/packages/xotcl-core/tcl/Attic/thread_mod-procs.tcl,v diff -u -r1.5 -r1.6 --- openacs-4/packages/xotcl-core/tcl/thread_mod-procs.tcl 30 Dec 2005 00:04:44 -0000 1.5 +++ openacs-4/packages/xotcl-core/tcl/thread_mod-procs.tcl 24 Mar 2006 12:54:59 -0000 1.6 @@ -101,6 +101,9 @@ -instrecreate 1 \ -parameter {{persistent 0}} +#Class create ::xotcl::THREAD \ +# -parameter {{persistent 0}} + ::xotcl::THREAD instproc check_blueprint {} { if {![[self class] exists __blueprint_checked]} { if {[string first ::xotcl::THREAD [ns_ictl get]] == -1} {