added: issues ticket system

added functions: ticket, createticket, editticket
         (there is no 'rm' function working for tickets yet)
changed: mount parser and mount points
         now we have more parameters (arguments in parameters)
some refactoring in functions 'emacs' and 'mkdir'



git-svn-id: svn://ttmath.org/publicrep/cmslu/trunk@554 e52654a7-88a9-db11-a3e9-0013d4bc506e
This commit is contained in:
2010-01-25 04:52:17 +00:00
parent 356e93914b
commit 89daf6489d
48 changed files with 2856 additions and 874 deletions

View File

@@ -17,55 +17,49 @@
void Content::PostFunMkdir(bool add_to_dir_table, int mask)
bool Content::FunMkdirCheckAccess()
{
if( !request.CanUseMkdir(*request.dir_table.back()) )
if( request.is_item || !request.CanUseMkdir(*request.dir_table.back()) )
{
request.status = Error::permission_denied;
return;
return false;
}
Item item;
request.session->done = Done::added_dir;
// try
// {
item.type = Item::dir;
request.PostVar("subject", item.subject);
request.PostVar("url", item.url);
item.parent_id = request.dir_table.back()->id;
SetUser(item);
item.group_id = -1;
item.privileges = mask;
item.default_item = -1;
return true;
}
void Content::Mkdir(Item & item, bool add_to_dir_table)
{
request.session->done_status = db.AddItem(item);
// dates (creation and modification) is set by the Item() constructor
PrepareUrl(item);
request.session->done_status = db.AddItem(item);
/* }
catch(const Error & e)
{
request.session->done_status = e;
}
*/
if( request.session->done_status == Error::ok )
{
Item * pdir = data.dirs.AddDir(item);
if( add_to_dir_table )
request.dir_table.push_back(pdir);
request.session->item = item;
request.session->done_timer = 2;
}
}
void Content::PostFunMkdir(bool add_to_dir_table, int privileges)
{
if( !FunMkdirCheckAccess() )
return;
ReadItem(request.item, Item::dir);
request.item.privileges = privileges;
request.session->done = Done::added_dir;
Mkdir(request.item, add_to_dir_table);
if( request.session->done_status == Error::ok )
{
request.notify_code |= CMSLU_NOTIFY_DIR_ADD;
RedirectTo(item);
RedirectTo(request.item);
}
else
{
@@ -78,13 +72,7 @@ void Content::PostFunMkdir(bool add_to_dir_table, int mask)
void Content::FunMkdir()
{
// !! what about an item? (is_item)
if( !request.CanUseMkdir(*request.dir_table.back()) )
{
request.status = Error::permission_denied;
return;
}
FunMkdirCheckAccess();
}