Support solid backgrounds in searchBackground.

GitOrigin-RevId: 48e242b53ca1d4c4b2fcf5d8858de2f74f28d1e1
This commit is contained in:
levlam 2019-05-10 16:06:53 +03:00
parent 652d2a9570
commit c3d126cbf6
2 changed files with 43 additions and 19 deletions

View File

@ -267,6 +267,24 @@ BackgroundId BackgroundManager::search_background(const string &name, Promise<Un
return it->second; return it->second;
} }
if (name.empty()) {
promise.set_error(Status::Error(400, "Background name must be non-empty"));
return BackgroundId();
}
if (name.size() <= 6) {
for (auto c : name) {
if (!is_hex_digit(c)) {
promise.set_error(Status::Error(400, "WALLPAPER_INVALID"));
return BackgroundId();
}
}
int32 color = static_cast<int32>(hex_to_integer<uint32>(name));
auto background_id = add_solid_background(color);
promise.set_value(Unit());
return background_id;
}
reload_background_from_server(BackgroundId(), telegram_api::make_object<telegram_api::inputWallPaperSlug>(name), reload_background_from_server(BackgroundId(), telegram_api::make_object<telegram_api::inputWallPaperSlug>(name),
std::move(promise)); std::move(promise));
return BackgroundId(); return BackgroundId();
@ -289,6 +307,24 @@ Result<FileId> BackgroundManager::prepare_input_file(const tl_object_ptr<td_api:
return std::move(file_id); return std::move(file_id);
} }
BackgroundId BackgroundManager::add_solid_background(int32 color) {
CHECK(0 <= color && color < 0x1000000);
BackgroundId background_id(static_cast<int64>(color) + 1);
auto *background = add_background(background_id);
if (background->id != background_id) {
background->id = background_id;
background->access_hash = 0;
background->is_creator = true;
background->is_default = false;
background->is_dark = (color & 0x808080) == 0;
background->type = BackgroundType(color);
background->name = background->type.get_color_hex_string();
background->file_id = FileId();
background->file_source_id = FileSourceId();
}
return background_id;
}
BackgroundId BackgroundManager::set_background(const td_api::InputBackground *input_background, BackgroundId BackgroundManager::set_background(const td_api::InputBackground *input_background,
const td_api::BackgroundType *background_type, Promise<Unit> &&promise) { const td_api::BackgroundType *background_type, Promise<Unit> &&promise) {
auto r_type = get_background_type(background_type); auto r_type = get_background_type(background_type);
@ -299,26 +335,12 @@ BackgroundId BackgroundManager::set_background(const td_api::InputBackground *in
auto type = r_type.move_as_ok(); auto type = r_type.move_as_ok();
if (type.type == BackgroundType::Type::Solid) { if (type.type == BackgroundType::Type::Solid) {
auto color = type.color; auto background_id = add_solid_background(type.color);
CHECK(0 <= color && color < 0x1000000); if (set_background_id_ != background_id) {
BackgroundId id(static_cast<int64>(color)); set_background_id(background_id, type);
if (set_background_id_ != id) {
auto *background = add_background(id);
background->id = id;
background->access_hash = 0;
background->is_creator = true;
background->is_default = false;
background->is_dark = (color & 0x808080) == 0;
background->type = type;
background->name = type.get_color_hex_string();
background->file_id = FileId();
background->file_source_id = FileSourceId();
set_background_id(id, type);
} }
promise.set_value(Unit()); promise.set_value(Unit());
return id; return background_id;
} }
if (input_background == nullptr) { if (input_background == nullptr) {
@ -505,7 +527,7 @@ BackgroundId BackgroundManager::on_get_background(BackgroundId expected_backgrou
if (expected_background_id.is_valid() && id != expected_background_id) { if (expected_background_id.is_valid() && id != expected_background_id) {
LOG(ERROR) << "Expected " << expected_background_id << ", but receive " << to_string(wallpaper); LOG(ERROR) << "Expected " << expected_background_id << ", but receive " << to_string(wallpaper);
} }
if (wallpaper->slug_.size() <= 6) { if (wallpaper->slug_.size() <= 6 || (0 < wallpaper->id_ && wallpaper->id_ <= 0x1000000)) {
LOG(ERROR) << "Receive " << to_string(wallpaper); LOG(ERROR) << "Receive " << to_string(wallpaper);
return BackgroundId(); return BackgroundId();
} }

View File

@ -79,6 +79,8 @@ class BackgroundManager : public Actor {
telegram_api::object_ptr<telegram_api::InputWallPaper> &&input_wallpaper, telegram_api::object_ptr<telegram_api::InputWallPaper> &&input_wallpaper,
Promise<Unit> &&promise) const; Promise<Unit> &&promise) const;
BackgroundId add_solid_background(int32 color);
Background *add_background(BackgroundId background_id); Background *add_background(BackgroundId background_id);
Background *get_background_ref(BackgroundId background_id); Background *get_background_ref(BackgroundId background_id);