From 3b4dcbbb6d7d28dcfb123ef45ba9aeae2740693b Mon Sep 17 00:00:00 2001 From: Arne Gudermann Date: Fri, 24 May 2024 11:36:31 +0200 Subject: [PATCH 1/4] Add getDefaultValue for RelationalBone --- src/viur/core/bones/relational.py | 28 +++++++++++++++++++++++++--- 1 file changed, 25 insertions(+), 3 deletions(-) diff --git a/src/viur/core/bones/relational.py b/src/viur/core/bones/relational.py index 7557ae75e..137bcdeca 100644 --- a/src/viur/core/bones/relational.py +++ b/src/viur/core/bones/relational.py @@ -296,6 +296,7 @@ def setSystemInitialized(self): self._refSkelCache = RefSkel.fromSkel(self.kind, *self.refKeys) self._skeletonInstanceClassRef = SkeletonInstance self._ref_keys = set(self._refSkelCache.__boneMap__.keys()) + # from viur.core.skeleton import RefSkel, skeletonByKind # self._refSkelCache = RefSkel.fromSkel(skeletonByKind(self.kind), *self.refKeys) # self._usingSkelCache = self.using() if self.using else None @@ -913,7 +914,7 @@ def buildDBSort( if origFilter is None or not "orderby" in rawFilter: # This query is unsatisfiable or not sorted return dbFilter if "orderby" in rawFilter and isinstance(rawFilter["orderby"], str) and rawFilter["orderby"].startswith( - f"{name}."): + f"{name}."): if not dbFilter.getKind() == "viur-relations" and self.multiple: # This query has not been rewritten (yet) name, skel, dbFilter, rawFilter = self._rewriteQuery(name, skel, dbFilter, rawFilter) key = rawFilter["orderby"] @@ -1208,12 +1209,12 @@ def setBoneValue( elif not self.multiple and self.using: if not isinstance(value, tuple) or len(value) != 2 or \ not (isinstance(value[0], str) or isinstance(value[0], db.Key)) or \ - not isinstance(value[1], self._skeletonInstanceClassRef): + not isinstance(value[1], self._skeletonInstanceClassRef): raise ValueError(f"You must supply a tuple of (Database-Key, relSkel) to {boneName}") realValue = value elif self.multiple and not self.using: if not (isinstance(value, str) or isinstance(value, db.Key)) and not (isinstance(value, list)) \ - and all([isinstance(x, str) or isinstance(x, db.Key) for x in value]): + and all([isinstance(x, str) or isinstance(x, db.Key) for x in value]): raise ValueError(f"You must supply a Database-Key or a list hereof to {boneName}") if isinstance(value, list): realValue = [(x, None) for x in value] @@ -1309,6 +1310,27 @@ def getUniquePropertyIndexValues(self, valuesCache: dict, name: str) -> list[str elif isinstance(value, list): return self._hashValueForUniquePropertyIndex([x["dest"]["key"] for x in value]) + def getDefaultValue(self, skeletonInstance): + if callable(self.defaultValue): + key = self.defaultValue(skeletonInstance, self) + elif isinstance(self.defaultValue, list): + key = self.defaultValue + elif isinstance(self.defaultValue, dict): + return self.defaultValue.copy() + else: + key = self.defaultValue + if not key: + return None + if self.multiple: + if isinstance(key, list): + return [self.createRelSkelFromKey(k) for k in key] + else: + return [self.createRelSkelFromKey(key)] + else: + if isinstance(key, list): + key = key[0] + return self.createRelSkelFromKey(key) + def structure(self) -> dict: return super().structure() | { "type": f"{self.type}.{self.kind}", From 768138eb310be7e6dd5e023c844a11e3689211b1 Mon Sep 17 00:00:00 2001 From: Arne Gudermann Date: Fri, 24 May 2024 11:38:28 +0200 Subject: [PATCH 2/4] Remove Formating --- src/viur/core/bones/relational.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/viur/core/bones/relational.py b/src/viur/core/bones/relational.py index 137bcdeca..eb5909156 100644 --- a/src/viur/core/bones/relational.py +++ b/src/viur/core/bones/relational.py @@ -914,7 +914,7 @@ def buildDBSort( if origFilter is None or not "orderby" in rawFilter: # This query is unsatisfiable or not sorted return dbFilter if "orderby" in rawFilter and isinstance(rawFilter["orderby"], str) and rawFilter["orderby"].startswith( - f"{name}."): + f"{name}."): if not dbFilter.getKind() == "viur-relations" and self.multiple: # This query has not been rewritten (yet) name, skel, dbFilter, rawFilter = self._rewriteQuery(name, skel, dbFilter, rawFilter) key = rawFilter["orderby"] @@ -1209,12 +1209,12 @@ def setBoneValue( elif not self.multiple and self.using: if not isinstance(value, tuple) or len(value) != 2 or \ not (isinstance(value[0], str) or isinstance(value[0], db.Key)) or \ - not isinstance(value[1], self._skeletonInstanceClassRef): + not isinstance(value[1], self._skeletonInstanceClassRef): raise ValueError(f"You must supply a tuple of (Database-Key, relSkel) to {boneName}") realValue = value elif self.multiple and not self.using: if not (isinstance(value, str) or isinstance(value, db.Key)) and not (isinstance(value, list)) \ - and all([isinstance(x, str) or isinstance(x, db.Key) for x in value]): + and all([isinstance(x, str) or isinstance(x, db.Key) for x in value]): raise ValueError(f"You must supply a Database-Key or a list hereof to {boneName}") if isinstance(value, list): realValue = [(x, None) for x in value] From 593398203183b3b5793adc66ac96b62e6dc93d46 Mon Sep 17 00:00:00 2001 From: Arne Gudermann Date: Fri, 24 May 2024 11:39:04 +0200 Subject: [PATCH 3/4] Remove Formating --- src/viur/core/bones/relational.py | 1 - 1 file changed, 1 deletion(-) diff --git a/src/viur/core/bones/relational.py b/src/viur/core/bones/relational.py index eb5909156..4d6fcbdcd 100644 --- a/src/viur/core/bones/relational.py +++ b/src/viur/core/bones/relational.py @@ -296,7 +296,6 @@ def setSystemInitialized(self): self._refSkelCache = RefSkel.fromSkel(self.kind, *self.refKeys) self._skeletonInstanceClassRef = SkeletonInstance self._ref_keys = set(self._refSkelCache.__boneMap__.keys()) - # from viur.core.skeleton import RefSkel, skeletonByKind # self._refSkelCache = RefSkel.fromSkel(skeletonByKind(self.kind), *self.refKeys) # self._usingSkelCache = self.using() if self.using else None From 65ce7d925ebe7d353244c459e003eb4372451a87 Mon Sep 17 00:00:00 2001 From: Arne Gudermann Date: Fri, 24 May 2024 15:33:43 +0200 Subject: [PATCH 4/4] Add case for dict --- src/viur/core/bones/relational.py | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/src/viur/core/bones/relational.py b/src/viur/core/bones/relational.py index 4d6fcbdcd..55813ea5c 100644 --- a/src/viur/core/bones/relational.py +++ b/src/viur/core/bones/relational.py @@ -1310,12 +1310,22 @@ def getUniquePropertyIndexValues(self, valuesCache: dict, name: str) -> list[str return self._hashValueForUniquePropertyIndex([x["dest"]["key"] for x in value]) def getDefaultValue(self, skeletonInstance): + def get_default_value_intern(value): + print(f"in get_default_value_intern ==") + if callable(value): + a= value(skeletonInstance, self) + print(a) + return a + return value + if callable(self.defaultValue): key = self.defaultValue(skeletonInstance, self) elif isinstance(self.defaultValue, list): key = self.defaultValue elif isinstance(self.defaultValue, dict): - return self.defaultValue.copy() + data= {k: self.createRelSkelFromKey(get_default_value_intern(v)) for k, v in self.defaultValue.items()} + #print(data) + return data else: key = self.defaultValue if not key: