added: function: mkdir

git-svn-id: svn://ttmath.org/publicrep/cmslu/trunk@471 e52654a7-88a9-db11-a3e9-0013d4bc506e
This commit is contained in:
2008-12-31 13:36:46 +00:00
parent 3e328932fc
commit 114b5724f8
18 changed files with 77 additions and 22 deletions

View File

@@ -36,12 +36,5 @@ void Data::SetHttpHost()
if( strncmp(base_url.c_str(), "https://", 8) == 0 )
base_url_http_host = base_url.substr(8);
else
base_url_http_host.clear();
if( base_url_http_host.empty() )
return;
// removing the last slash (if it is present)
if( base_url_http_host[ base_url_http_host.size() - 1 ] == '/' )
base_url_http_host.erase( base_url_http_host.end() - 1 );
base_url_http_host.clear(); // if empty the RequestController::BaseUrlRedirect() returns false and no redirecting will be done
}

View File

@@ -401,13 +401,14 @@ Error Db::AddItemIntoItem(Item & item)
{
AssertConnection();
std::ostringstream query;
query << "insert into core.item (user_id, group_id, privileges, type, parent_id, content_id, url) values (";
query << "insert into core.item (user_id, group_id, privileges, type, parent_id, content_id, default_item, url) values (";
query << '\'' << item.user_id << "', ";
query << '\'' << item.group_id << "', ";
query << '\'' << item.privileges << "', ";
query << '\'' << static_cast<int>(item.type) << "', ";
query << '\'' << item.parent_id << "', ";
query << '\'' << item.content_id << "', ";
query << '\'' << item.default_item << "', ";
url_without_id = AddItemCreateUrlSubject(item);
@@ -473,8 +474,13 @@ return result;
Error Db::AddItem(Item & item)
{
Error result = AddItemIntoContent(item);
Error result = Error::ok;
if( item.type == Item::file )
result = AddItemIntoContent(item);
else
item.content_id = -1;
if( result == Error::ok )
result = AddItemIntoItem(item);

View File

@@ -72,7 +72,7 @@ bool rebuild_indexes = false;
}
table.push_back(item);
log << log2 << "DirCont: added item, id: " << item.id << ", parent_id: " << item.parent_id << logend;
log << log2 << "DirCont: added dir, url: " << item.url << ", id: " << item.id << ", parent_id: " << item.parent_id << logend;
if( rebuild_indexes )
@@ -113,7 +113,7 @@ void DirContainer::AddIndexes(Iterator item)
table_id.insert( std::make_pair(item->id, item) );
table_parent.insert( std::make_pair(item->parent_id, item) );
log << log2 << "DirCont: added indexes to item, id: " << item->id << ", parent_id: " << item->parent_id << logend;
log << log2 << "DirCont: added indexes to dir, id: " << item->id << ", parent_id: " << item->parent_id << logend;
}

View File

@@ -335,3 +335,11 @@ Item * Dirs::GetDir(long id)
return &(*i);
}
void Dirs::AddDir(const Item & item)
{
dir_table.PushBack(item);
}

View File

@@ -81,7 +81,7 @@ public:
Item * GetDir(const std::string & path);
Item * GetDir(long id);
void AddDir(const Item & item);
};

View File

@@ -24,6 +24,7 @@ public:
edited_item,
deleted_item,
privileged_item,
added_dir,
loggedout
};

View File

@@ -29,6 +29,7 @@ public:
cat,
node,
emacs,
mkdir,
privileges,
rm,
login,

View File

@@ -51,6 +51,10 @@ void Functions::ReadFunctions()
f.item.url = "edytuj";
table.insert( std::make_pair(f.item.url, f) );
f.code = Function::mkdir;
f.item.url = "mkdir";
table.insert( std::make_pair(f.item.url, f) );
f.code = Function::privileges;
f.item.url = "uprawnienia";
table.insert( std::make_pair(f.item.url, f) );

View File

@@ -52,6 +52,7 @@ long default_item;
// used by the database
// !! moze da sie w ogole z tego zrezygnowac?
long content_id;

View File

@@ -113,15 +113,16 @@ return true;
bool RequestController::BaseUrlRedirect()
{
if( request.env_request_uri[0] == 0 )
if( data.base_url_http_host.empty() )
return false;
if( data.base_url_http_host == request.env_http_host )
return false;
request.result = Request::redirect;
request.str = data.base_url + (request.env_request_uri + 1); // +1 means skipping the first slash from env_request_uri
request.str = data.base_url + request.env_request_uri;
log << log3 << "RC: BaseUrlRedirect from: " << request.env_http_host << logend;
return true;
}

View File

@@ -95,7 +95,7 @@ int attempts = 100;
request.session = const_cast<Session*>( &(*res.first) );
request.SetCookie(data.http_session_id_name.c_str(), request.session->id);
log << log1 << "created a new session: " << s.id << logend;
log << log2 << "SM: created a new session: " << s.id << logend;
return;
}
@@ -104,7 +104,7 @@ int attempts = 100;
// there is a problem with generating a new session id
// we do not set a session cookie
CreateTemporarySession();
log << log1 << "cannot create a session id (temporary used: with id 0)" << logend;
log << log1 << "SM: cannot create a session id (temporary used: with id 0)" << logend;
}
@@ -127,7 +127,7 @@ void SessionManager::SetSession()
{
// that session is in the table
request.session = const_cast<Session*>( &(*s) );
log << log1 << "session: " << s->id << logend;
log << log1 << "SM: session: " << s->id << logend;
}
else
{