FileManager: add #mtime#<mtime># prefix to generate conversion
GitOrigin-RevId: 4253d68e4f7878d871f53e0bbcf77633258cc946
This commit is contained in:
parent
bc88b8e951
commit
f788c1e917
@ -20,6 +20,7 @@
|
|||||||
#include "td/utils/common.h"
|
#include "td/utils/common.h"
|
||||||
#include "td/utils/logging.h"
|
#include "td/utils/logging.h"
|
||||||
#include "td/utils/misc.h"
|
#include "td/utils/misc.h"
|
||||||
|
#include "td/utils/Parser.h"
|
||||||
#include "td/utils/port/path.h"
|
#include "td/utils/port/path.h"
|
||||||
#include "td/utils/Slice.h"
|
#include "td/utils/Slice.h"
|
||||||
|
|
||||||
@ -342,9 +343,39 @@ FileGenerateManager::Query::~Query() = default;
|
|||||||
FileGenerateManager::Query::Query(Query &&other) = default;
|
FileGenerateManager::Query::Query(Query &&other) = default;
|
||||||
FileGenerateManager::Query &FileGenerateManager::Query::operator=(Query &&other) = default;
|
FileGenerateManager::Query &FileGenerateManager::Query::operator=(Query &&other) = default;
|
||||||
|
|
||||||
void FileGenerateManager::generate_file(uint64 query_id, const FullGenerateFileLocation &generate_location,
|
Status check_mtime(std::string &conversion, CSlice original_path) {
|
||||||
|
if (original_path.empty()) {
|
||||||
|
return Status::OK();
|
||||||
|
}
|
||||||
|
Parser parser(conversion);
|
||||||
|
if (!parser.skip_start_with("#mtime#")) {
|
||||||
|
return td::Status::OK();
|
||||||
|
}
|
||||||
|
auto mtime_str = parser.read_till('#');
|
||||||
|
parser.skip('#');
|
||||||
|
auto r_mtime = to_integer_safe<uint64>(mtime_str);
|
||||||
|
if (parser.status().is_error() || r_mtime.is_error()) {
|
||||||
|
return td::Status::OK();
|
||||||
|
}
|
||||||
|
auto expected_mtime = r_mtime.move_as_ok();
|
||||||
|
conversion = parser.read_all().str();
|
||||||
|
auto r_stat = stat(original_path);
|
||||||
|
uint64 actual_mtime = r_stat.is_ok() ? r_stat.ok().mtime_nsec_ : 0;
|
||||||
|
if (expected_mtime == actual_mtime) {
|
||||||
|
return td::Status::OK();
|
||||||
|
}
|
||||||
|
return td::Status::Error(PSLICE() << "mtime changed " << tag("file", original_path)
|
||||||
|
<< tag("expected mtime", expected_mtime) << tag("actual mtime", actual_mtime));
|
||||||
|
}
|
||||||
|
|
||||||
|
void FileGenerateManager::generate_file(uint64 query_id, FullGenerateFileLocation generate_location,
|
||||||
const LocalFileLocation &local_location, string name,
|
const LocalFileLocation &local_location, string name,
|
||||||
unique_ptr<FileGenerateCallback> callback) {
|
unique_ptr<FileGenerateCallback> callback) {
|
||||||
|
auto mtime_status = check_mtime(generate_location.conversion_, generate_location.original_path_);
|
||||||
|
if (mtime_status.is_error()) {
|
||||||
|
return callback->on_error(std::move(mtime_status));
|
||||||
|
}
|
||||||
|
|
||||||
CHECK(query_id != 0);
|
CHECK(query_id != 0);
|
||||||
auto it_flag = query_id_to_query_.insert(std::make_pair(query_id, Query{}));
|
auto it_flag = query_id_to_query_.insert(std::make_pair(query_id, Query{}));
|
||||||
CHECK(it_flag.second) << "Query id must be unique";
|
CHECK(it_flag.second) << "Query id must be unique";
|
||||||
|
@ -35,7 +35,7 @@ class FileGenerateManager : public Actor {
|
|||||||
explicit FileGenerateManager(ActorShared<> parent) : parent_(std::move(parent)) {
|
explicit FileGenerateManager(ActorShared<> parent) : parent_(std::move(parent)) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void generate_file(uint64 query_id, const FullGenerateFileLocation &generate_location,
|
void generate_file(uint64 query_id, FullGenerateFileLocation generate_location,
|
||||||
const LocalFileLocation &local_location, string name, unique_ptr<FileGenerateCallback> callback);
|
const LocalFileLocation &local_location, string name, unique_ptr<FileGenerateCallback> callback);
|
||||||
void cancel(uint64 query_id);
|
void cancel(uint64 query_id);
|
||||||
|
|
||||||
|
@ -697,6 +697,15 @@ FileId FileManager::register_url(string url, FileType file_type, FileLocationSou
|
|||||||
Result<FileId> FileManager::register_generate(FileType file_type, FileLocationSource file_location_source,
|
Result<FileId> FileManager::register_generate(FileType file_type, FileLocationSource file_location_source,
|
||||||
string original_path, string conversion, DialogId owner_dialog_id,
|
string original_path, string conversion, DialogId owner_dialog_id,
|
||||||
int64 expected_size) {
|
int64 expected_size) {
|
||||||
|
// add #mtime# into conversion
|
||||||
|
if (!original_path.empty() && !begins_with(conversion, "#mtime#") && !begins_with(conversion, "#file_id#") &&
|
||||||
|
!begins_with(conversion, "#map#")) {
|
||||||
|
auto r_stat = stat(original_path);
|
||||||
|
uint64 mtime = r_stat.is_ok() ? r_stat.ok().mtime_nsec_ : 0;
|
||||||
|
auto new_conversion = PSTRING() << "#mtime#" << mtime << "#" << conversion;
|
||||||
|
conversion = std::move(new_conversion);
|
||||||
|
}
|
||||||
|
|
||||||
FileData data;
|
FileData data;
|
||||||
data.generate_ =
|
data.generate_ =
|
||||||
td::make_unique<FullGenerateFileLocation>(file_type, std::move(original_path), std::move(conversion));
|
td::make_unique<FullGenerateFileLocation>(file_type, std::move(original_path), std::move(conversion));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user