11 |
|
#include "MediaFolder.hpp" |
12 |
|
#include "Share.hpp" |
13 |
|
|
14 |
< |
MediaFolder::MediaFolder(const _R<dbi::Connection>& connection, const api::Path& path) : connection(connection), path(path) |
14 |
> |
MediaFolder::MediaFolder(const _R<Connector>& connector, const api::Path& path) : connector(connector), path(path) |
15 |
|
{ |
16 |
+ |
_R<dbi::Connection> connection(connector->Connect()); |
17 |
|
_R<dbi::ResultSet> root_(connection->Parse(_B("SELECT root FROM folders WHERE path = ?"))->Execute(path.GetPath())); |
18 |
|
|
19 |
|
if (root_->MoveNext()) |
20 |
|
root = root_->GetString(_B("root")); |
21 |
+ |
|
22 |
+ |
connector->Release(connection); |
23 |
|
} |
24 |
|
|
25 |
< |
MediaFolder::MediaFolder(const _R<dbi::Connection>& connection, const api::Path& path, const api::Path& root) : connection(connection), path(path), root(root) |
25 |
> |
MediaFolder::MediaFolder(const _R<Connector>& connector, const api::Path& path, const api::Path& root) : connector(connector), path(path), root(root) |
26 |
|
{ |
27 |
+ |
_R<dbi::Connection> connection(connector->Connect()); |
28 |
|
_R<dbi::ResultSet> path_(connection->Parse(_B("SELECT path FROM folders WHERE path = ?"))->Execute(path.GetPath())); |
29 |
|
|
30 |
|
if (path_->MoveNext()) |
37 |
|
connection->Parse(_B("INSERT INTO folders (path, folder, root) VALUES (?, ?, ?)"))->Execute(path.GetPath(), path.GetParent().GetPath(), root.GetPath()); |
38 |
|
else |
39 |
|
connection->Parse(_B("INSERT INTO folders (path, folder, root) VALUES (?, NULL, ?)"))->Execute(path.GetPath(), root.GetPath()); |
40 |
+ |
|
41 |
+ |
connector->Release(connection); |
42 |
|
} |
43 |
|
|
44 |
|
cse::String MediaFolder::GetName() const |
56 |
|
return path.GetName(); |
57 |
|
} |
58 |
|
|
59 |
< |
_L<MediaFile> MediaFolder::GetFiles() const |
59 |
> |
_L<MediaFile> MediaFolder::GetFiles(unsigned page) const |
60 |
|
{ |
61 |
< |
_R<dbi::ResultSet> paths(connection->Parse(_B("SELECT path FROM files WHERE live = TRUE AND folder = ? ORDER BY path"))->Execute(path.GetPath())); |
61 |
> |
_R<dbi::Connection> connection(connector->Connect()); |
62 |
> |
_R<dbi::ResultSet> paths(connection->Parse(_B("SELECT path FROM files WHERE live = TRUE AND folder = ? ORDER BY path LIMIT 50 OFFSET ?"))->Execute(path.GetPath(), page * 50)); |
63 |
|
_L<MediaFile> files; |
64 |
|
|
65 |
|
while (paths->MoveNext()) |
66 |
< |
files.InsertLast(MediaFile(connection, paths->GetString(_B("path")))); |
66 |
> |
files.InsertLast(MediaFile(connector, paths->GetString(_B("path")))); |
67 |
> |
|
68 |
> |
connector->Release(connection); |
69 |
|
|
70 |
|
return files; |
71 |
|
} |
72 |
|
|
73 |
< |
_L<MediaFolder> MediaFolder::GetFolders() const |
73 |
> |
_L<MediaFolder> MediaFolder::GetFolders(unsigned page) const |
74 |
|
{ |
75 |
< |
_R<dbi::ResultSet> paths(connection->Parse(_B("SELECT path FROM folders WHERE folder = ? ORDER BY path"))->Execute(path.GetPath())); |
75 |
> |
_R<dbi::Connection> connection(connector->Connect()); |
76 |
> |
_R<dbi::ResultSet> paths(connection->Parse(_B("SELECT path FROM folders WHERE folder = ? ORDER BY path LIMIT 50 OFFSET ?"))->Execute(path.GetPath(), page * 50)); |
77 |
|
_L<MediaFolder> folders; |
78 |
|
|
79 |
|
while (paths->MoveNext()) |
80 |
< |
folders.InsertLast(MediaFolder(connection, paths->GetString(_B("path")))); |
80 |
> |
folders.InsertLast(MediaFolder(connector, paths->GetString(_B("path")))); |
81 |
> |
|
82 |
> |
connector->Release(connection); |
83 |
|
|
84 |
|
return folders; |
85 |
|
} |