TextGrid repository administration cli tool, based on tgclients
Project description
tgadmin
A command line tool for managing your projects in the TextGrid repository without TextGridLab.
Install
You may use this with venv or with pipx. With pipx you have the benefit of having the command available in your shell without further manual venv creation and activation.
Install pipx, e.g. on Debian/Ubuntu apt install pipx.
And add this tool from pypi.org
pipx install tgadmin
# or if uv is available (to enable managed python version)
uv tool --managed-python install tgadmin
```sh
Upgrade to a new version with
```sh
pipx upgrade tgadmin
If you do not want to use pipx have a look at the section "Development".
Usage
Export sessionID (SID)
and set as env var:
export TEXTGRID_SID=your_secret_sid_here
or set with --sid for every command
Get help
tgadmin
List projects
list your projects:
tgadmin list
Create project
if there is no suitable project, create one:
tgadmin create lab-import-test-20230605
Upload an aggregation object like editons, aggregations and collections
You can upload aggregations as new textgrid objects like
tgadmin --server http://test.textgridlab.org import -p TGPR-...fe eng003.edition
this would assume that you have an file containing the aggragtion with local paths in
eng003.edition and metadata description files like eng003.edition.meta. After initial uploads
you find an filename.imex which has a mapping of lokal file names to textgrid URIs.
This can be used to update the objects from the edition like:
tgadmin --server http://test.textgridlab.org import -i eng003.edition.imex .
BYOLR (Bring Your Own Link Rewriter ;-)
We use command line tools to rewrite links in TEI and aggregations. Our default choice is linkrewriter-cli but you are free to choose anything which implements the command line interface.
To use the link rewriter cli as native build (linux amd64 only for now):
wget https://gitlab.gwdg.de/api/v4/projects/45698/packages/generic/linkrewriter/0.1.23/linkrewriter-cli
chmod +x ./linkrewriter-cli
or on non linux-amd64 systems:
wget https://gitlab.gwdg.de/api/v4/projects/45698/packages/generic/linkrewriter/0.1.23/linkrewriter-cli.jar
echo -e '#!/bin/bash\njava -jar linkrewriter-cli.jar $@' > ./linkrewriter-cli
chmod +x ./linkrewriter-cli
If you are not on linux amd64, you may use linkrewriter with java. You may create a shell script calling java -jar linkrewriter-cli.jar $# then, or build something great with jbang.
Or if you are not happy with linkrewriter results, create a shell script, utilizing e.g. sed. Just call it linkrewriter-cli and make sure it implements the cli interface
-i imex_file_location-c configyou may ignore this-b basepath of xml relative to the imex file location (you may ignore this too)FILENAME
Advanced Usage
You may use the development or the test instance of the TextGrid Server.
To use tgadmin with the test instance do
tgadmin --server https://test.textgridlab.org list
for the dev system there is a shortcut, you may call
tgadmin --dev list
_TGADMIN_COMPLETE=bash_source tgadmin > tgadmin-complete.bash
. tgadmin-complete.bash
Development
clone repo
git clone https://gitlab.gwdg.de/dariah-de/textgridrep/tgadmin.git
cd tgadmin
and create venv
uv venv # or python3 -m venv .venv
source .venv/bin/activate
uv pip install --editable . # or pip install --editable .[dev]
afterwards tgadmin is in your venv as command and can be executed
tgadmin
run integration tests and check coverage
WARNING: do not provide a project ID where you have data, as objects from project may accidently get removed
export PROJECT_ID=[my-project-id]
export TEXTGRID_SID=[my-session-id]
coverage run -m pytest --junitxml=report.xml && coverage html
Contributing
Commit convention:
Style constraints:
- Code: PEP 8
- Documentation: Google style docstrings (Chapter 3.8 from Google styleguide)
Coding constraints:
For your convenience, pre-commit hooks are configured to check against these constraints. Provided, you have installed the development requirements (see above), activate pre-commit to run on every git commit:
pre-commit install
Badges
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file tgadmin-0.38.1.tar.gz.
File metadata
- Download URL: tgadmin-0.38.1.tar.gz
- Upload date:
- Size: 34.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
13c5bfcab16930f5a31a318d9726a32f6578e28aa72290a20c80c5b7ccc17da3
|
|
| MD5 |
c38ee25240f37ee05a97a607d05960e8
|
|
| BLAKE2b-256 |
72a649ea6dfe3ef7b0cd1594fadfff445f2a4e090bc6e91022549277897b266d
|
File details
Details for the file tgadmin-0.38.1-py3-none-any.whl.
File metadata
- Download URL: tgadmin-0.38.1-py3-none-any.whl
- Upload date:
- Size: 36.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
db272baad8e32191cac28aaf1526a646b8c45eb3cecb816d12b6785f2d79e273
|
|
| MD5 |
34721d89563366cc409bd5885feac1df
|
|
| BLAKE2b-256 |
8f71b7d527934f70e21cfc20971c3ee3011665745773e2cbf61d908bb4b80cc6
|