LibCore+LibConfig+ConfigServer: Add Config::{add,remove}_group()

Plumbs synchronous calls for adding and removing group entries to
config files. This is useful for services like SystemServer which
default to group names for executable paths, and for removing all
keys at once.
This commit is contained in:
thankyouverycool 2022-09-23 09:45:05 -04:00 committed by Ali Mohammad Pur
parent 6f394d9ee2
commit c34f2e75e9
Notes: sideshowbarker 2024-07-17 23:02:37 +09:00
10 changed files with 97 additions and 0 deletions

View file

@ -75,6 +75,16 @@ void Client::remove_key(StringView domain, StringView group, StringView key)
remove_key_entry(domain, group, key);
}
void Client::remove_group(StringView domain, StringView group)
{
remove_group_entry(domain, group);
}
void Client::add_group(StringView domain, StringView group)
{
add_group_entry(domain, group);
}
void Client::notify_changed_string_value(String const& domain, String const& group, String const& key, String const& value)
{
Listener::for_each([&](auto& listener) {
@ -103,4 +113,18 @@ void Client::notify_removed_key(String const& domain, String const& group, Strin
});
}
void Client::notify_removed_group(String const& domain, String const& group)
{
Listener::for_each([&](auto& listener) {
listener.config_group_was_removed(domain, group);
});
}
void Client::notify_added_group(String const& domain, String const& group)
{
Listener::for_each([&](auto& listener) {
listener.config_group_was_added(domain, group);
});
}
}

View file

@ -35,6 +35,8 @@ public:
void write_i32(StringView domain, StringView group, StringView key, i32 value);
void write_bool(StringView domain, StringView group, StringView key, bool value);
void remove_key(StringView domain, StringView group, StringView key);
void remove_group(StringView domain, StringView group);
void add_group(StringView domain, StringView group);
static Client& the();
@ -48,6 +50,8 @@ private:
void notify_changed_i32_value(String const& domain, String const& group, String const& key, i32 value) override;
void notify_changed_bool_value(String const& domain, String const& group, String const& key, bool value) override;
void notify_removed_key(String const& domain, String const& group, String const& key) override;
void notify_removed_group(String const& domain, String const& group) override;
void notify_added_group(String const& domain, String const& group) override;
};
inline Vector<String> list_groups(StringView domain)
@ -95,6 +99,16 @@ inline void remove_key(StringView domain, StringView group, StringView key)
Client::the().remove_key(domain, group, key);
}
inline void remove_group(StringView domain, StringView group)
{
Client::the().remove_group(domain, group);
}
inline void add_group(StringView domain, StringView group)
{
Client::the().add_group(domain, group);
}
inline void pledge_domains(Vector<String> const& domains)
{
Client::the().pledge_domains(domains);

View file

@ -45,4 +45,12 @@ void Listener::config_key_was_removed(String const&, String const&, String const
{
}
void Listener::config_group_was_removed(String const&, String const&)
{
}
void Listener::config_group_was_added(String const&, String const&)
{
}
}

View file

@ -20,6 +20,8 @@ public:
virtual void config_i32_did_change(String const& domain, String const& group, String const& key, i32 value);
virtual void config_bool_did_change(String const& domain, String const& group, String const& key, bool value);
virtual void config_key_was_removed(String const& domain, String const& group, String const& key);
virtual void config_group_was_removed(String const& domain, String const& group);
virtual void config_group_was_added(String const& domain, String const& group);
protected:
Listener();

View file

@ -234,6 +234,12 @@ bool ConfigFile::has_group(String const& group) const
return m_groups.contains(group);
}
void ConfigFile::add_group(String const& group)
{
m_groups.ensure(group);
m_dirty = true;
}
void ConfigFile::remove_group(String const& group)
{
m_groups.remove(group);

View file

@ -54,6 +54,7 @@ public:
ErrorOr<void> sync();
void add_group(String const& group);
void remove_group(String const& group);
void remove_entry(String const& group, String const& key);

View file

@ -4,4 +4,6 @@ endpoint ConfigClient
notify_changed_i32_value(String domain, String group, String key, i32 value) =|
notify_changed_bool_value(String domain, String group, String key, bool value) =|
notify_removed_key(String domain, String group, String key) =|
notify_removed_group(String domain, String group) =|
notify_added_group(String domain, String group) =|
}

View file

@ -15,4 +15,6 @@ endpoint ConfigServer
write_i32_value(String domain, String group, String key, i32 value) => ()
write_bool_value(String domain, String group, String key, bool value) => ()
remove_key_entry(String domain, String group, String key) => ()
remove_group_entry(String domain, String group) => ()
add_group_entry(String domain, String group) => ()
}

View file

@ -267,4 +267,40 @@ void ConnectionFromClient::remove_key_entry(String const& domain, String const&
});
}
void ConnectionFromClient::remove_group_entry(String const& domain, String const& group)
{
if (!validate_access(domain, group, {}))
return;
auto& config = ensure_domain_config(domain);
if (!config.has_group(group))
return;
config.remove_group(group);
m_dirty_domains.set(domain);
start_or_restart_sync_timer();
for_each_monitoring_connection(domain, this, [&domain, &group](ConnectionFromClient& connection) {
connection.async_notify_removed_group(domain, group);
});
}
void ConnectionFromClient::add_group_entry(String const& domain, String const& group)
{
if (!validate_access(domain, group, {}))
return;
auto& config = ensure_domain_config(domain);
if (config.has_group(group))
return;
config.add_group(group);
m_dirty_domains.set(domain);
start_or_restart_sync_timer();
for_each_monitoring_connection(domain, this, [&domain, &group](ConnectionFromClient& connection) {
connection.async_notify_added_group(domain, group);
});
}
}

View file

@ -36,6 +36,8 @@ private:
virtual void write_i32_value([[maybe_unused]] String const& domain, [[maybe_unused]] String const& group, [[maybe_unused]] String const& key, [[maybe_unused]] i32 value) override;
virtual void write_bool_value([[maybe_unused]] String const& domain, [[maybe_unused]] String const& group, [[maybe_unused]] String const& key, [[maybe_unused]] bool value) override;
virtual void remove_key_entry([[maybe_unused]] String const& domain, [[maybe_unused]] String const& group, [[maybe_unused]] String const& key) override;
virtual void remove_group_entry([[maybe_unused]] String const& domain, [[maybe_unused]] String const& group) override;
virtual void add_group_entry([[maybe_unused]] String const& domain, [[maybe_unused]] String const& group) override;
bool validate_access(String const& domain, String const& group, String const& key);
void sync_dirty_domains_to_disk();