diff options
Diffstat (limited to 'common/resourcefacade.cpp')
-rw-r--r-- | common/resourcefacade.cpp | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/common/resourcefacade.cpp b/common/resourcefacade.cpp index 1c6b0c8..091970c 100644 --- a/common/resourcefacade.cpp +++ b/common/resourcefacade.cpp | |||
@@ -376,6 +376,21 @@ QPair<KAsync::Job<void>, typename Sink::ResultEmitter<typename ApplicationDomain | |||
376 | return qMakePair(KAsync::null<void>(), runner->emitter()); | 376 | return qMakePair(KAsync::null<void>(), runner->emitter()); |
377 | } | 377 | } |
378 | 378 | ||
379 | KAsync::Job<void> AccountFacade::remove(const Sink::ApplicationDomain::SinkAccount &account) | ||
380 | { | ||
381 | using namespace Sink::ApplicationDomain; | ||
382 | auto job = KAsync::null(); | ||
383 | |||
384 | //Remove all resources | ||
385 | job = job.then(Store::fetch<SinkResource>(Sink::Query{}.filter<SinkResource::Account>(account))) | ||
386 | .each([] (const SinkResource::Ptr &resource) { return Store::remove(*resource); }); | ||
387 | //Remove all identities | ||
388 | job = job.then(Store::fetch<Identity>(Sink::Query{}.filter<Identity::Account>(account))) | ||
389 | .each([] (const Identity::Ptr &identity) { return Store::remove(*identity); }); | ||
390 | |||
391 | return job.then(LocalStorageFacade<Sink::ApplicationDomain::SinkAccount>::remove(account)); | ||
392 | } | ||
393 | |||
379 | IdentityFacade::IdentityFacade() : LocalStorageFacade<Sink::ApplicationDomain::Identity>("identities", "type") | 394 | IdentityFacade::IdentityFacade() : LocalStorageFacade<Sink::ApplicationDomain::Identity>("identities", "type") |
380 | { | 395 | { |
381 | } | 396 | } |