Class TenantManagement

java.lang.Object
com.apple.foundationdb.TenantManagement

public class TenantManagement extends Object
The FoundationDB API includes function to manage the set of tenants in a cluster.
  • Method Details

    • createTenant

      public static void createTenant(Transaction tr, byte[] tenantName)
      Creates a new tenant in the cluster. If the tenant already exists, this operation will complete successfully without changing anything. The transaction must be committed for the creation to take effect or to observe any errors.
      Parameters:
      tr - The transaction used to create the tenant.
      tenantName - The name of the tenant. Can be any byte string that does not begin a 0xFF byte.
    • createTenant

      public static void createTenant(Transaction tr, Tuple tenantName)
      Creates a new tenant in the cluster. If the tenant already exists, this operation will complete successfully without changing anything. The transaction must be committed for the creation to take effect or to observe any errors.

      This is a convenience method that generates the tenant name by packing a Tuple.
      Parameters:
      tr - The transaction used to create the tenant.
      tenantName - The name of the tenant, as a Tuple.
    • createTenant

      public static CompletableFuture<Void> createTenant(Database db, byte[] tenantName)
      Creates a new tenant in the cluster using a transaction created on the specified Database. This operation will first check whether the tenant exists, and if it does it will set the CompletableFuture to a tenant_already_exists error. Otherwise, it will attempt to create the tenant in a retry loop. If the tenant is created concurrently by another transaction, this function may still return successfully.
      Parameters:
      db - The database used to create a transaction for creating the tenant.
      tenantName - The name of the tenant. Can be any byte string that does not begin a 0xFF byte.
      Returns:
      a CompletableFuture that when set without error will indicate that the tenant has been created.
    • createTenant

      public static CompletableFuture<Void> createTenant(Database db, Tuple tenantName)
      Creates a new tenant in the cluster using a transaction created on the specified Database. This operation will first check whether the tenant exists, and if it does it will set the CompletableFuture to a tenant_already_exists error. Otherwise, it will attempt to create the tenant in a retry loop. If the tenant is created concurrently by another transaction, this function may still return successfully.

      This is a convenience method that generates the tenant name by packing a Tuple.
      Parameters:
      db - The database used to create a transaction for creating the tenant.
      tenantName - The name of the tenant, as a Tuple.
      Returns:
      a CompletableFuture that when set without error will indicate that the tenant has been created.
    • deleteTenant

      public static void deleteTenant(Transaction tr, byte[] tenantName)
      Deletes a tenant from the cluster. If the tenant does not exists, this operation will complete successfully without changing anything. The transaction must be committed for the deletion to take effect or to observe any errors.

      Note: A tenant cannot be deleted if it has any data in it. To delete a non-empty tenant, you must first use a clear operation to delete all of its keys.
      Parameters:
      tr - The transaction used to delete the tenant.
      tenantName - The name of the tenant being deleted.
    • deleteTenant

      public static void deleteTenant(Transaction tr, Tuple tenantName)
      Deletes a tenant from the cluster. If the tenant does not exists, this operation will complete successfully without changing anything. The transaction must be committed for the deletion to take effect or to observe any errors.

      Note: A tenant cannot be deleted if it has any data in it. To delete a non-empty tenant, you must first use a clear operation to delete all of its keys.

      This is a convenience method that generates the tenant name by packing a Tuple.
      Parameters:
      tr - The transaction used to delete the tenant.
      tenantName - The name of the tenant being deleted, as a Tuple.
    • deleteTenant

      public static CompletableFuture<Void> deleteTenant(Database db, byte[] tenantName)
      Deletes a tenant from the cluster using a transaction created on the specified Database. This operation will first check whether the tenant exists, and if it does not it will set the CompletableFuture to a tenant_not_found error. Otherwise, it will attempt to delete the tenant in a retry loop. If the tenant is deleted concurrently by another transaction, this function may still return successfully.

      Note: A tenant cannot be deleted if it has any data in it. To delete a non-empty tenant, you must first use a clear operation to delete all of its keys.
      Parameters:
      db - The database used to create a transaction for deleting the tenant.
      tenantName - The name of the tenant being deleted.
      Returns:
      a CompletableFuture that when set without error will indicate that the tenant has been deleted.
    • deleteTenant

      public static CompletableFuture<Void> deleteTenant(Database db, Tuple tenantName)
      Deletes a tenant from the cluster using a transaction created on the specified Database. This operation will first check whether the tenant exists, and if it does not it will set the CompletableFuture to a tenant_not_found error. Otherwise, it will attempt to delete the tenant in a retry loop. If the tenant is deleted concurrently by another transaction, this function may still return successfully.

      Note: A tenant cannot be deleted if it has any data in it. To delete a non-empty tenant, you must first use a clear operation to delete all of its keys.

      This is a convenience method that generates the tenant name by packing a Tuple.
      Parameters:
      db - The database used to create a transaction for deleting the tenant.
      tenantName - The name of the tenant being deleted.
      Returns:
      a CompletableFuture that when set without error will indicate that the tenant has been deleted.
    • listTenants

      public static CloseableAsyncIterator<KeyValue> listTenants(Database db, byte[] begin, byte[] end, int limit)
      Lists all tenants in between the range specified. The number of tenants listed can be restricted.
      Parameters:
      db - The database used to create a transaction for listing the tenants.
      begin - The beginning of the range of tenants to list.
      end - The end of the range of the tenants to list.
      limit - The maximum number of tenants to return from this request.
      Returns:
      an iterator where each item is a KeyValue object where the key is the tenant name and the value is the unprocessed JSON string containing the tenant's metadata
    • listTenants

      public static CloseableAsyncIterator<KeyValue> listTenants(Database db, Tuple begin, Tuple end, int limit)
      Lists all tenants in between the range specified. The number of tenants listed can be restricted. This is a convenience method that generates the begin and end ranges by packing two Tuples.
      Parameters:
      db - The database used to create a transaction for listing the tenants.
      begin - The beginning of the range of tenants to list.
      end - The end of the range of the tenants to list.
      limit - The maximum number of tenants to return from this request.
      Returns:
      an iterator where each item is a KeyValue object where the key is the tenant name and the value is the unprocessed JSON string containing the tenant's metadata