1 |
// Media Folder |
2 |
// |
3 |
// Douglas Thrift |
4 |
// |
5 |
// $Id$ |
6 |
|
7 |
#include "MediaFolder.hpp" |
8 |
|
9 |
#include <menes-dbi/resultset.hpp> |
10 |
|
11 |
MediaFolder::MediaFolder(_H<dbi::Connection>& connection, const api::Path& path) : connection(connection), path(path) |
12 |
{ |
13 |
// XXX: implement |
14 |
} |
15 |
|
16 |
MediaFolder::MediaFolder(_H<dbi::Connection>& connection, const api::Path& path, const api::Path& root) : connection(connection), path(path), root(root) |
17 |
{ |
18 |
_H<dbi::ResultSet> path_(connection->Parse(_B("SELECT path FROM folders WHERE path = ? AND root = ?"))->Execute(path.GetPath(), root.GetPath())); |
19 |
|
20 |
if (!path_->MoveNext()) |
21 |
{ |
22 |
connection->Parse(_B("DELETE FROM folders WHERE path = ?"))->Execute(path.GetPath()); |
23 |
|
24 |
if (path.GetPath() != root.GetPath()) |
25 |
connection->Parse(_B("INSERT INTO folders (path, folder, root) VALUES (?, ?, ?)"))->Execute(path.GetPath(), path.GetParent().GetPath(), root.GetPath()); |
26 |
else |
27 |
connection->Parse(_B("INSERT INTO folders (path, folder, root) VALUES (?, NULL, ?)"))->Execute(path.GetPath(), root.GetPath()); |
28 |
} |
29 |
} |
30 |
|
31 |
_L<MediaFile> MediaFolder::GetFiles() const |
32 |
{ |
33 |
_H<dbi::ResultSet> paths(connection->Parse(_B("SELECT path FROM files WHERE live = TRUE AND folder = ?"))->Execute(path.GetPath())); |
34 |
_L<MediaFile> files; |
35 |
|
36 |
while (paths->MoveNext()) |
37 |
files.InsertLast(MediaFile(connection, paths->GetString(_B("path")))); |
38 |
|
39 |
return files; |
40 |
} |
41 |
|
42 |
_L<MediaFolder> MediaFolder::GetFolders() const |
43 |
{ |
44 |
_H<dbi::ResultSet> paths(connection->Parse(_B("SELECT path FROM folders WHERE live = TRUE AND folder = ?"))->Execute(path.GetPath())); |
45 |
_L<MediaFolder> folders; |
46 |
|
47 |
while (paths->MoveNext()) |
48 |
folders.InsertLast(MediaFolder(connection, paths->GetString(_B("path")))); |
49 |
|
50 |
return folders; |
51 |
} |