109 lines
3.6 KiB
Plaintext
Executable File
109 lines
3.6 KiB
Plaintext
Executable File
comment_file_types=(md html)
|
|
|
|
fn conf_enable_comments {
|
|
if(~ $1 -n) {
|
|
allow_new_user_comments=yes
|
|
shift
|
|
}
|
|
if not if(~ $1 -a) {
|
|
bridge_anon_comments=yes
|
|
}
|
|
enable_comments=yes
|
|
groups_allowed_comments=$*
|
|
conf_enable_app bridge
|
|
}
|
|
|
|
fn bridge_init {
|
|
if(~ $#enable_comments 1 && ! ~ `{ls $local_path.$comment_file_types >[2]/dev/null|wc -l} 0) {
|
|
|
|
comments_dir=$sitedir$req_path'_werc/comments'
|
|
if(~ $REQUEST_METHOD GET && test -d $comments_dir)
|
|
ll_add handlers_body_foot template apps/bridge/comments_list.tpl
|
|
|
|
if(check_user $groups_allowed_comments || {~ $#logged_user 0 && ~ 1 $#allow_new_user_comments $#bridge_anon_comments}) {
|
|
|
|
if(~ $#post_arg_bridge_post 1) {
|
|
ll_add handlers_body_foot template apps/bridge/foot.tpl
|
|
|
|
if(mk_new_comment $comments_dir)
|
|
post_redirect $base_url^$req_path
|
|
if not
|
|
saved_comment_text=$post_arg_comment_text
|
|
}
|
|
if not if(~ $REQUEST_METHOD GET)
|
|
ll_add handlers_body_foot template apps/bridge/foot.tpl
|
|
}
|
|
if not if(~ $REQUEST_METHOD GET)
|
|
ll_add handlers_body_foot echo '<hr><p>To post a comment you need to <a href="/_users/login">login</a> first.</p>'
|
|
}
|
|
}
|
|
|
|
fn validate_new_user {
|
|
usr=$1; pass=$2; pass2=$3
|
|
_status=()
|
|
|
|
if(~ $"usr '' || ! echo $usr |sed 1q|grep -s '^'$allowed_user_chars'+$')
|
|
_status='Requested user name is invalid, must match: '^$allowed_user_chars^'+'
|
|
if not if(test -d etc/users/$usr)
|
|
_status='Sorry, user name '''^$usr^''' already taken, please pick a different one.'
|
|
|
|
if(~ $"pass '' || ! ~ $"pass $"pass2)
|
|
_status=($_status 'Provided passwords don''t match.')
|
|
|
|
status=$_status
|
|
}
|
|
|
|
|
|
fn mk_new_comment {
|
|
_status=()
|
|
dir=$1
|
|
if(~ $"post_arg_comment_text '')
|
|
_status='Provide a comment!'
|
|
if not if(~ $#logged_user 0) {
|
|
if(! ~ $#allow_new_user_comments 0) {
|
|
if(validate_new_user $"post_arg_comment_user $post_arg_comment_passwd $post_arg_comment_passwd2) {
|
|
u=$post_arg_comment_user':'$post_arg_comment_passwd
|
|
dir=$comments_dir^'_pending'
|
|
# XXX: This doesn't work because we then do a redirect.
|
|
# NN: Now it works, but the notify_notes has to be not-empty.
|
|
# Kind of a hack, because I'm not really that familiar with rc.
|
|
notify_notes='Saved commend.'
|
|
_status='Saved comment and registration info, they will be enabled when approved by an admin.'
|
|
}
|
|
if not
|
|
_status=$status
|
|
}
|
|
if not if(! ~ $#bridge_anon_comments 0) {
|
|
if(~ $"post_arg_ima_robot 'not')
|
|
u='Anonymous' # Anonymous
|
|
if not
|
|
_status='You are a robot!'
|
|
}
|
|
if not
|
|
_status='You need to log in to comment.'
|
|
}
|
|
if not if(check_user $groups_allowed_comments)
|
|
u=$logged_user
|
|
if not
|
|
_status='You are not a member of a group allowed to comment.'
|
|
|
|
# if(~ $#_status 0) {
|
|
if (~ $#notify_notes 1){
|
|
umask 002
|
|
|
|
dir=$dir'/'`{date -n} # FIXME Obvious race
|
|
mkdir -m 775 -p $dir &&
|
|
echo $u > $dir/user &&
|
|
echo $current_date_time > $dir/posted &&
|
|
echo $post_arg_comment_text > $dir/body
|
|
_s=$status
|
|
if(! ~ $"_s '') {
|
|
dprint 'ERROR XXX: Could not create comment: ' $_s
|
|
_status='Could not post comment due internal error, sorry.'
|
|
}
|
|
}
|
|
notify_errors=$_status
|
|
status=$_status
|
|
}
|
|
|