Managing Repos
An ArrayLake Repo
is a repository for your array data.
All the data in a Repo
are tracked as part of a shared single version history.
Within a Repo
, data can easily be moved, renamed, deleted, and updated in a non-destructive way.
Moving data from one Repo
to another, however, requires a copy to be made.
Create a Repo
If you're just getting started, you probably only need one Repo
for your entire organization (see Organizations and Access for more detail).
For the purposes of this example, our org name will be earthmover
.
If running these commands interactively, replace earthmover
with your org name.
For this example, we are going to create a Repo called ocean
to hold oceanography data 🌊.
- CLI
- Python
- Python (asyncio)
arraylake repo create earthmover/ocean
from arraylake import Client
client = Client()
client.create_repo("earthmover/ocean")
from arraylake import AsyncClient
aclient = AsyncClient()
await aclient.create_repo("earthmover/ocean")
Open a Repo
If you're working in Python, you can open a Repo and start interacting with your data.
- Python
- Python (asyncio)
repo = client.get_repo("earthmover/ocean")
arepo = await aclient.get_repo("earthmover/ocean") # returns an AsyncRepo object
List Repos
You can list repos associated with an organization.
- CLI
- Python
- Python (asyncio)
arraylake repo list earthmover
client.list_repos("earthmover")
await aclient.list_repos("earthmover")
Delete a Repo
Finally, we can delete a repo.
Deleting a repo cannot be undone! Use this operation carefully.
- CLI
- Python
- Python (asyncio)
arraylake repo delete earthmover/ocean
client.delete_repo("earthmover/ocean", imsure=True, imreallysure=True)
await aclient.delete_repo("earthmover/ocean", imsure=True, imreallysure=True)