aboutsummaryrefslogtreecommitdiff
path: root/load/load.cxx
diff options
context:
space:
mode:
authorKaren Arutyunov <karen@codesynthesis.com>2018-10-28 01:01:53 +0300
committerKaren Arutyunov <karen@codesynthesis.com>2018-10-30 16:20:21 +0300
commit873987793b05fc0d6e9908f5030b2bca145c4e6d (patch)
tree6641e447d892e5b364ae7471e7a0a71581c85e91 /load/load.cxx
parent018603c5529117b993066f4f3a0f45f48f92e801 (diff)
Add tenant object
Diffstat (limited to 'load/load.cxx')
-rw-r--r--load/load.cxx28
1 files changed, 18 insertions, 10 deletions
diff --git a/load/load.cxx b/load/load.cxx
index 24a3bf3..3036daf 100644
--- a/load/load.cxx
+++ b/load/load.cxx
@@ -1101,9 +1101,9 @@ try
// By default the tenant is empty and assumes a single-tenant mode. Let's
// require the specified tenant to be non-empty.
//
- const string& tenant (ops.tenant ());
+ const string& tnt (ops.tenant ());
- if (ops.tenant_specified () && tenant.empty ())
+ if (ops.tenant_specified () && tnt.empty ())
{
cerr << "error: empty tenant" << endl
<< help_info << endl;
@@ -1140,7 +1140,7 @@ try
//
internal_repositories irs (load_repositories (path (argv[1])));
- if (ops.force () || changed (tenant, irs, db))
+ if (ops.force () || changed (tnt, irs, db))
{
// Rebuild repositories persistent state from scratch.
//
@@ -1150,22 +1150,30 @@ try
// multiple tenants). Otherwise, cleanup the specified and the empty
// tenants only.
//
- if (tenant.empty ()) // Single-tenant mode.
+ if (tnt.empty ()) // Single-tenant mode.
{
db.erase_query<package> ();
db.erase_query<repository> ();
+ db.erase_query<tenant> ();
}
else // Multi-tenant mode.
{
- cstrings ts ({tenant.c_str (), ""});
+ cstrings ts ({tnt.c_str (), ""});
db.erase_query<package> (
query<package>::id.tenant.in_range (ts.begin (), ts.end ()));
db.erase_query<repository> (
query<repository>::id.tenant.in_range (ts.begin (), ts.end ()));
+
+ db.erase_query<tenant> (
+ query<tenant>::id.in_range (ts.begin (), ts.end ()));
}
+ // Persist the tenant.
+ //
+ db.persist (tenant (tnt));
+
// On the first pass over the internal repositories we load their
// certificate information and packages.
//
@@ -1181,7 +1189,7 @@ try
ir.fingerprint);
shared_ptr<repository> r (
- make_shared<repository> (tenant,
+ make_shared<repository> (tnt,
ir.location,
move (ir.display_name),
move (ir.cache_location),
@@ -1198,8 +1206,8 @@ try
for (const auto& ir: irs)
{
shared_ptr<repository> r (
- db.load<repository> (repository_id (tenant,
- ir.location.canonical_name ())));
+ db.load<repository> (
+ repository_id (tnt, ir.location.canonical_name ())));
load_repositories (r, db, ops.shallow ());
}
@@ -1213,7 +1221,7 @@ try
for (auto& p:
db.query<package> (
- query::id.tenant == tenant &&
+ query::id.tenant == tnt &&
query::internal_repository.canonical_name.is_not_null ()))
resolve_dependencies (p, db);
@@ -1222,7 +1230,7 @@ try
package_ids chain;
for (const auto& p:
db.query<package> (
- query::id.tenant == tenant &&
+ query::id.tenant == tnt &&
query::internal_repository.canonical_name.is_not_null ()))
detect_dependency_cycle (p.id, chain, db);
}