5bdf837941
Support accessing repositories using DOI strings with optional subpaths
across ls, download, metadata, and file-metadata commands.
- Implement GET v3/doi/{id}/ API model and client calls
- Parse and resolve DOI paths into respective folder and files
- Extract common folder and file resolution logic to shared helpers
- Update README with example DOI-based shell commands
31 lines
1.2 KiB
Python
31 lines
1.2 KiB
Python
import json
|
|
from argparse import Namespace
|
|
from typing import Any
|
|
|
|
from mdrsclient.api import FoldersApi
|
|
from mdrsclient.commands.base import BaseCommand
|
|
|
|
|
|
class MetadataCommand(BaseCommand):
|
|
@classmethod
|
|
def register(cls, parsers: Any) -> None:
|
|
metadata_parser = parsers.add_parser("metadata", help="get a folder metadata")
|
|
metadata_parser.add_argument("-p", "--password", help="password to use when open locked folder")
|
|
metadata_parser.add_argument("remote_path", help="remote folder path (remote:/lab/path/)")
|
|
metadata_parser.set_defaults(func=cls.func)
|
|
|
|
@classmethod
|
|
def func(cls, args: Namespace) -> None:
|
|
remote_path = str(args.remote_path)
|
|
password = str(args.password) if args.password else None
|
|
cls.metadata(remote_path, password)
|
|
|
|
@classmethod
|
|
def metadata(cls, remote_path: str, password: str | None) -> None:
|
|
remote = remote_path.split(":", 1)[0] if ":" in remote_path else ""
|
|
connection = cls._create_connection(remote)
|
|
folder, laboratory = cls._resolve_folder(connection, remote_path, password)
|
|
folder_api = FoldersApi(connection)
|
|
metadata = folder_api.metadata(folder.id)
|
|
print(json.dumps(metadata, ensure_ascii=False))
|