winix/templates/item.cpp

582 lines
10 KiB
C++
Executable File

/*
* This file is a part of Winix
* and is not publicly distributed
*
* Copyright (c) 2008-2010, Tomasz Sowa
* All rights reserved.
*
*/
#include "templates.h"
#include "misc.h"
#include "core/request.h"
#include "core/misc.h"
#include "core/bbcodeparser.h"
#include "core/textstream.h"
namespace TemplatesFunctions
{
static BBCODEParser bbcode_parser;
void item_is(Info & i)
{
i.res = request->is_item;
}
void item_id(Info & i)
{
i.out << request->item.id;
}
void item_subject(Info & i)
{
i.out << request->item.subject;
}
void item_subject_noescape(Info & i)
{
i.out << request->item.subject;
}
void item_content(Info & i)
{
i.out << request->item.content;
}
void item_content_noescape(Info & i)
{
i.out << request->item.content;
}
void item_content_type_is(Item & item, Info & i)
{
i.res = false;
if( item.content_type == Item::ct_text && i.par == L"text" )
i.res = true;
else
if( item.content_type == Item::ct_formatted_text && i.par == L"formatted text" )
i.res = true;
else
if( item.content_type == Item::ct_html && i.par == L"html" )
i.res = true;
else
if( item.content_type == Item::ct_bbcode && i.par == L"bbcode" )
i.res = true;
else
if( item.content_type == Item::ct_raw && i.par == L"raw" )
i.res = true;
}
void item_content_type_is(Info & i)
{
item_content_type_is(request->item, i);
}
void item_print_content(HtmlTextStream & out, const std::wstring & content, Item::ContentType content_type)
{
if( content_type == Item::ct_text )
{
out << content;
}
else
if( content_type == Item::ct_formatted_text )
{
HtmlEscapeFormTxt(out, content);
}
else
if( content_type == Item::ct_html || content_type == Item::ct_raw )
{
out << R(content);
}
else
if( content_type == Item::ct_bbcode )
{
static std::wstring out_temp;
out_temp.clear();
out_temp.reserve(content.size()*2);
bbcode_parser.Filter(content.c_str(), out_temp);
out << R(out_temp);
}
}
void item_content_is_empty(Info & i)
{
i.res = request->item.content.empty();
}
void item_print_content(Info & i)
{
item_print_content(i.out, request->item.content, request->item.content_type);
}
void item_privileges(Info & i)
{
i.out << Toa(request->item.privileges, 8);
}
void item_dir(Info & i)
{
dir(i);
}
void item_url(Info & i)
{
i.out << request->item.url;
}
void item_url_is(Info & i)
{
if( !request->is_item )
return; // default false
i.res = (request->item.url == i.par);
}
void item_link(Info & i)
{
i.out << config->base_url;
item_dir(i);
item_url(i);
}
void item_filetype_is_none(Info & i)
{
i.res = request->item.file_type == WINIX_ITEM_FILETYPE_NONE;
}
void item_filetype_is_image(Info & i)
{
i.res = request->item.file_type == WINIX_ITEM_FILETYPE_IMAGE;
}
void item_has_thumb(Info & i)
{
i.res = request->item.has_thumb;
}
void item_can_read(Info & i)
{
i.res = system->HasReadAccess(request->item);
}
void item_can_write(Info & i)
{
i.res = system->HasWriteAccess(request->item);
}
void item_can_remove(Info & i)
{
// !! tutaj trzeba bedzie cos innego zrobic
// zwlaszcza jak dojdzie sticky bit
i.res = system->HasWriteAccess(*request->dir_tab.back());
}
void item_user(Info & i)
{
User * puser = system->users.GetUser(request->item.user_id);
print_user_name(i, puser, request->item.guest_name);
}
void item_modification_user(Info & i)
{
User * puser = system->users.GetUser(request->item.modification_user_id);
print_user_name(i, puser, request->item.guest_name);
}
void item_users_different(Info & i)
{
i.res = (request->item.user_id != request->item.modification_user_id);
}
void item_date_creation(Info & i)
{
tm rtm = system->LocalTime(request->item.date_creation);
i.out << DateToStr(rtm.tm_year + 1900, rtm.tm_mon + 1, rtm.tm_mday, rtm.tm_hour, rtm.tm_min, rtm.tm_sec);
}
void item_date_modification(Info & i)
{
tm rtm = system->LocalTime(request->item.date_modification);
i.out << DateToStr(rtm.tm_year + 1900, rtm.tm_mon + 1, rtm.tm_mday, rtm.tm_hour, rtm.tm_min, rtm.tm_sec);
}
void item_date_creation_nice(Info & i)
{
print_date_nice(i, request->item.date_creation);
}
void item_date_modification_nice(Info & i)
{
print_date_nice(i, request->item.date_modification);
}
void item_dates_equal(Info & i)
{
tm * ptm1 = &request->item.date_creation;
tm * ptm2 = &request->item.date_modification;
i.res = ptm1->tm_year == ptm2->tm_year &&
ptm1->tm_mon == ptm2->tm_mon &&
ptm1->tm_mday == ptm2->tm_mday &&
ptm1->tm_hour == ptm2->tm_hour &&
ptm1->tm_min == ptm2->tm_min &&
ptm1->tm_sec == ptm2->tm_sec;
}
void item_run(Info & i)
{
if( !request->is_item )
{
i.out << "<!-- there is no an item to run -->";
return;
}
if( !system->HasReadExecAccess(request->item) )
{
i.out << "<!-- run: permission denied -->";
return;
}
Ezc::Pattern * p = pattern_cacher.GetPattern(request->item);
HtmlTextStream item_run_content; // !! zrobic static z tego i tu dac tylko clearowanie
EzcGen gen;
//gen.Generate(item_run_content, *p, ezc_functions);
gen.Generate(item_run_content, *p);
item_print_content(i.out, item_run_content.Str(), request->item.content_type);
}
void item_guest_name(Info & i)
{
i.out << request->item.guest_name;
}
void item_html_template(Info & i)
{
i.out << request->item.html_template;
}
void item_has_html_template(Info & i)
{
i.res = !request->item.html_template.empty();
}
static size_t item_index;
void item_tab(Info & i)
{
item_index = i.iter;
i.res = item_index < request->item_tab.size();
}
void item_tab_id(Info & i)
{
if( item_index < request->item_tab.size() )
i.out << request->item_tab[item_index].id;
}
void item_tab_subject(Info & i)
{
if( item_index < request->item_tab.size() )
i.out << request->item_tab[item_index].subject;
}
void item_tab_subject_noescape(Info & i)
{
if( item_index < request->item_tab.size() )
i.out << request->item_tab[item_index].subject;
}
void item_tab_content(Info & i)
{
if( item_index < request->item_tab.size() )
i.out << request->item_tab[item_index].content;
}
void item_tab_content_noescape(Info & i)
{
if( item_index < request->item_tab.size() )
i.out << request->item_tab[item_index].content;
}
void item_tab_print_content(Info & i)
{
if( item_index >= request->item_tab.size() )
return;
std::wstring & content = request->item_tab[item_index].content;
Item::ContentType type = request->item_tab[item_index].content_type;
item_print_content(i.out, content, type);
}
void item_tab_privileges(Info & i)
{
if( item_index < request->item_tab.size() )
i.out << "0" << Toa(request->item_tab[item_index].privileges, 8);
}
void item_tab_dir(Info & i)
{
if( item_index < request->item_tab.size() )
{
std::wstring path;
if( system->dirs.MakePath(request->item_tab[item_index].parent_id, path) )
i.out << path;
else
i.out << "/the path does not exist/"; // !! do konfiga
}
}
void item_tab_url(Info & i)
{
if( item_index < request->item_tab.size() )
i.out << request->item_tab[item_index].url;
}
void item_tab_link(Info & i)
{
if( item_index < request->item_tab.size() )
{
i.out << config->base_url;
item_tab_dir(i);
item_tab_url(i);
}
}
void item_tab_can_read(Info & i)
{
if( item_index < request->item_tab.size() )
{
if( system->HasReadAccess(request->item_tab[item_index]) )
i.res = true;
}
}
void item_tab_can_write(Info & i)
{
if( item_index < request->item_tab.size() )
{
if( system->HasWriteAccess(request->item_tab[item_index]) )
i.res = true;
}
}
void item_tab_user(Info & i)
{
if( item_index < request->item_tab.size() )
{
User * puser = system->users.GetUser(request->item_tab[item_index].user_id);
print_user_name(i, puser, request->item_tab[item_index].guest_name);
}
}
void item_tab_modification_user(Info & i)
{
if( item_index < request->item_tab.size() )
{
User * puser = system->users.GetUser(request->item_tab[item_index].modification_user_id);
print_user_name(i, puser, request->item_tab[item_index].guest_name);
}
}
void item_tab_users_different(Info & i)
{
if( item_index < request->item_tab.size() )
{
i.res = (request->item_tab[item_index].user_id != request->item_tab[item_index].modification_user_id);
}
}
void item_tab_group(Info & i)
{
if( item_index < request->item_tab.size() )
{
long group_id = request->item_tab[item_index].group_id;
Group * pgroup = system->groups.GetGroup(group_id);
if( pgroup )
i.out << pgroup->name;
else
i.out << group_id;
}
}
void item_tab_date_creation(Info & i)
{
if( item_index < request->item_tab.size() )
{
tm rtm = system->LocalTime(request->item_tab[item_index].date_creation);
i.out << DateToStr(rtm.tm_year + 1900, rtm.tm_mon + 1, rtm.tm_mday, rtm.tm_hour, rtm.tm_min, rtm.tm_sec);
}
}
void item_tab_date_modification(Info & i)
{
if( item_index < request->item_tab.size() )
{
tm rtm = system->LocalTime(request->item_tab[item_index].date_modification);
i.out << DateToStr(rtm.tm_year + 1900, rtm.tm_mon + 1, rtm.tm_mday, rtm.tm_hour, rtm.tm_min, rtm.tm_sec);
}
}
void item_tab_date_creation_nice(Info & i)
{
if( item_index < request->item_tab.size() )
{
print_date_nice(i, request->item_tab[item_index].date_creation);
}
}
void item_tab_date_modification_nice(Info & i)
{
if( item_index < request->item_tab.size() )
{
print_date_nice(i, request->item_tab[item_index].date_modification);
}
}
void item_tab_dates_equal(Info & i)
{
if( item_index < request->item_tab.size() )
{
tm * ptm1 = &request->item_tab[item_index].date_creation;
tm * ptm2 = &request->item_tab[item_index].date_modification;
i.res = ptm1->tm_year == ptm2->tm_year &&
ptm1->tm_mon == ptm2->tm_mon &&
ptm1->tm_mday == ptm2->tm_mday &&
ptm1->tm_hour == ptm2->tm_hour &&
ptm1->tm_min == ptm2->tm_min &&
ptm1->tm_sec == ptm2->tm_sec;
}
}
void item_tab_run(Info & i)
{
if( item_index < request->item_tab.size() )
{
if( !system->HasReadExecAccess(request->item) )
{
i.out << "<!-- run: permission denied -->";
return;
}
Ezc::Pattern * p = pattern_cacher.GetPattern(request->item_tab[item_index]);
HtmlTextStream item_run_content; // !! zrobic static z tego i tu dac tylko clearowanie
EzcGen gen;
//gen.Generate(item_run_content, *p, ezc_functions);
gen.Generate(item_run_content, *p);
item_print_content(i.out, item_run_content.Str(), request->item_tab[item_index].content_type);
}
}
void item_tab_can_use_emacs(Info & i)
{
if( item_index < request->item_tab.size() )
{
// !!
//i.res = request->CanUseEmacs(request->item_tab[item_index], true);
}
}
} // namespace TemplatesFunctions