Skip to content

Commit

Permalink
Util: start using the GenQuery2 parser
Browse files Browse the repository at this point in the history
  • Loading branch information
lwesterhof committed Dec 18, 2024
1 parent 966dbd5 commit 9b6ebd8
Show file tree
Hide file tree
Showing 2 changed files with 49 additions and 65 deletions.
100 changes: 40 additions & 60 deletions util/collection.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,7 @@
__copyright__ = 'Copyright (c) 2019-2024, Utrecht University'
__license__ = 'GPLv3, see LICENSE'

import itertools
import json
from functools import reduce
from typing import Iterable, List, Tuple

import genquery
Expand All @@ -18,9 +16,12 @@

def exists(ctx: rule.Context, path: str) -> bool:
"""Check if a collection with the given path exists."""
return len(list(genquery.row_iterator(
"COLL_ID", "COLL_NAME = '{}'".format(path),
genquery.AS_LIST, ctx))) > 0
return len(list(genquery.Query(
ctx,
"COLL_ID",
f"COLL_NAME = '{path}'",
output=genquery.AS_LIST,
parser=genquery.Parser.GENQUERY2))) > 0


def owner(ctx: rule.Context, path: str) -> Tuple[str, str] | None:
Expand All @@ -34,28 +35,20 @@ def owner(ctx: rule.Context, path: str) -> Tuple[str, str] | None:

def empty(ctx: rule.Context, path: str) -> bool:
"""Check if a collection contains any data objects."""
return (len(list(genquery.row_iterator(
"DATA_ID",
"COLL_NAME = '{}'".format(path),
genquery.AS_LIST, ctx))) == 0
and len(list(genquery.row_iterator(
"DATA_ID",
"COLL_NAME like '{}/%'".format(path),
genquery.AS_LIST, ctx))) == 0)
return len(list(genquery.row_iterator(
ctx, "DATA_ID",
f"COLL_NAME = '{path}' or COLL_NAME like '{path}/%'",
output=genquery.AS_LIST,
parser=genquery.Parser.GENQUERY2))) == 0


def size(ctx: rule.Context, path: str) -> int:
"""Get a collection's size in bytes."""
def func(x: int, row: List) -> int:
return x + int(row[1])

return reduce(func,
itertools.chain(genquery.row_iterator("DATA_ID, DATA_SIZE",
"COLL_NAME like '{}'".format(path),
genquery.AS_LIST, ctx),
genquery.row_iterator("DATA_ID, DATA_SIZE",
"COLL_NAME like '{}/%'".format(path),
genquery.AS_LIST, ctx)), 0)
return sum(row[1] for row in genquery.Query(
ctx, "DATA_ID, DATA_SIZE",
f"COLL_NAME like '{path}' or COLL_NAME like '{path}/%'",
output=genquery.AS_LIST,
parser=genquery.Parser.GENQUERY2))


def data_count(ctx: rule.Context, path: str, recursive: bool = True) -> int:
Expand All @@ -73,11 +66,12 @@ def data_count(ctx: rule.Context, path: str, recursive: bool = True) -> int:

def collection_count(ctx: rule.Context, path: str, recursive: bool = True) -> int:
"""Get a collection's collection count (the amount of collections within a collection)."""
return sum(1 for _ in genquery.row_iterator(
"COLL_ID",
"COLL_NAME like '{}/%'".format(path) if recursive else
"COLL_PARENT_NAME = '{}' AND COLL_NAME like '{}/%'".format(path, path),
genquery.AS_LIST, ctx))
return sum(1 for _ in genquery.Query(
ctx, "COLL_ID",
f"COLL_NAME like '{path}/%'" if recursive else
f"COLL_PARENT_NAME = '{path}' AND COLL_NAME like '{path}/%'",
output=genquery.AS_LIST,
parser=genquery.Parser.GENQUERY2))


def subcollections(ctx: rule.Context, path: str, recursive: bool = False) -> Iterable:
Expand All @@ -96,22 +90,15 @@ def subcollections(ctx: rule.Context, path: str, recursive: bool = False) -> Ite
:returns: List of all subcollections in a collection
"""
# coll+subcoll name -> path
def to_absolute(row: List) -> str:
return '{}/{}'.format(*row)

q_root = genquery.row_iterator("COLL_PARENT_NAME, COLL_NAME",
"COLL_PARENT_NAME = '{}'".format(path),
genquery.AS_LIST, ctx)

if not recursive:
return map(to_absolute, q_root)
def to_absolute(row: List[str]) -> str:
return f"{row[0]}/{row[1]}"

# Recursive? Return a generator combining both queries.
q_sub = genquery.row_iterator("COLL_PARENT_NAME, COLL_NAME",
"COLL_PARENT_NAME like '{}/%'".format(path),
genquery.AS_LIST, ctx)

return map(to_absolute, itertools.chain(q_root, q_sub))
return map(to_absolute, genquery.Query(
ctx, "COLL_PARENT_NAME, COLL_NAME",
f"COLL_PARENT_NAME = '{path}'" if recursive else
f"COLL_PARENT_NAME = '{path}' OR COLL_PARENT_NAME like '{path}/%'",
output=genquery.AS_LIST,
parser=genquery.Parser.GENQUERY2))


def data_objects(ctx: rule.Context, path: str, recursive: bool = False) -> Iterable:
Expand All @@ -130,22 +117,15 @@ def data_objects(ctx: rule.Context, path: str, recursive: bool = False) -> Itera
:returns: List of all data objects in a collection
"""
# coll+data name -> path
def to_absolute(row: List) -> str:
return '{}/{}'.format(*row)

q_root = genquery.row_iterator("COLL_NAME, DATA_NAME",
"COLL_NAME = '{}'".format(path),
genquery.AS_LIST, ctx)

if not recursive:
return map(to_absolute, q_root)

# Recursive? Return a generator combining both queries.
q_sub = genquery.row_iterator("COLL_NAME, DATA_NAME",
"COLL_NAME like '{}/%'".format(path),
genquery.AS_LIST, ctx)
def to_absolute(row: List[str]) -> str:
return f"{row[0]}/{row[1]}"

return map(to_absolute, itertools.chain(q_root, q_sub))
return map(to_absolute, genquery.Query(
ctx, "COLL_NAME, DATA_NAME",
f"COLL_NAME = '{path}'" if recursive else
f"COLL_NAME = '{path}' OR COLL_NAME like '{path}/%'",
output=genquery.AS_LIST,
parser=genquery.Parser.GENQUERY2))


def create(ctx: rule.Context, path: str, entire_tree: str = '') -> None:
Expand Down Expand Up @@ -257,7 +237,7 @@ def id_from_name(ctx: rule.Context, coll_name: str) -> str:
:returns: Collection id
"""
return genquery.Query(ctx, "COLL_ID", "COLL_NAME = '{}'".format(coll_name)).first()
return genquery.Query(ctx, "COLL_ID", "COLL_NAME = '{coll_name}'", parser=genquery.Parser.GENQUERY2).first()


def name_from_id(ctx: rule.Context, coll_id: str) -> str:
Expand All @@ -268,4 +248,4 @@ def name_from_id(ctx: rule.Context, coll_id: str) -> str:
:returns: Collection name
"""
return genquery.Query(ctx, "COLL_NAME", "COLL_ID = '{}'".format(coll_id)).first()
return genquery.Query(ctx, "COLL_NAME", "COLL_ID = '{coll_id}'", parser=genquery.Parser.GENQUERY2).first()
14 changes: 9 additions & 5 deletions util/data_object.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,10 +19,12 @@

def exists(ctx: rule.Context, path: str) -> bool:
"""Check if a data object with the given path exists."""
return len(list(genquery.row_iterator(
"DATA_ID",
"COLL_NAME = '%s' AND DATA_NAME = '%s'" % pathutil.chop(path),
genquery.AS_LIST, ctx))) > 0
coll_name, data_name = pathutil.chop(path)
return len(list(genquery.Query(
ctx, "DATA_ID",
f"COLL_NAME = '{coll_name}' AND DATA_NAME = '{data_name}'",
output=genquery.AS_LIST,
parser=genquery.Parser.GENQUERY2))) > 0


def get_properties(ctx: rule.Context, data_id: str, resource: str) -> Dict | None:
Expand Down Expand Up @@ -247,8 +249,10 @@ def id_from_path(ctx: rule.Context, path: str) -> str:
:returns: Data object id
"""
coll_name, data_name = pathutil.chop(path)
return genquery.Query(ctx, "DATA_ID",
"COLL_NAME = '%s' AND DATA_NAME = '%s'" % pathutil.chop(path)).first()
f"COLL_NAME = '{coll_name}' AND DATA_NAME = '{data_name}'",
parser=genquery.Parser.GENQUERY2).first()


def decode_checksum(checksum: str) -> str:
Expand Down

0 comments on commit 9b6ebd8

Please sign in to comment.