aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/org/traccar/storage/query
diff options
context:
space:
mode:
authorAnton Tananaev <anton@traccar.org>2022-04-09 15:37:33 -0700
committerAnton Tananaev <anton@traccar.org>2022-04-09 15:37:33 -0700
commitdd8fa719d7726489e76944029d2aed214ba8a904 (patch)
treecd1c48f8d2adf5b841eb0d9fe4b5b8091a6687de /src/main/java/org/traccar/storage/query
parentc2c58a30ae0857c4e584b128899baa63a684a892 (diff)
downloadtrackermap-server-dd8fa719d7726489e76944029d2aed214ba8a904.tar.gz
trackermap-server-dd8fa719d7726489e76944029d2aed214ba8a904.tar.bz2
trackermap-server-dd8fa719d7726489e76944029d2aed214ba8a904.zip
Handle group permissions
Diffstat (limited to 'src/main/java/org/traccar/storage/query')
-rw-r--r--src/main/java/org/traccar/storage/query/Condition.java46
1 files changed, 45 insertions, 1 deletions
diff --git a/src/main/java/org/traccar/storage/query/Condition.java b/src/main/java/org/traccar/storage/query/Condition.java
index 304440698..91ede236c 100644
--- a/src/main/java/org/traccar/storage/query/Condition.java
+++ b/src/main/java/org/traccar/storage/query/Condition.java
@@ -1,5 +1,22 @@
+/*
+ * Copyright 2022 Anton Tananaev (anton@traccar.org)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
package org.traccar.storage.query;
+import org.traccar.model.GroupedModel;
+
import java.util.List;
public interface Condition {
@@ -132,11 +149,28 @@ public interface Condition {
private final Class<?> ownerClass;
private final long ownerId;
private final Class<?> propertyClass;
+ private final long propertyId;
+ private final boolean excludeGroups;
- public Permission(Class<?> ownerClass, long ownerId, Class<?> propertyClass) {
+ private Permission(
+ Class<?> ownerClass, long ownerId, Class<?> propertyClass, long propertyId, boolean excludeGroups) {
this.ownerClass = ownerClass;
this.ownerId = ownerId;
this.propertyClass = propertyClass;
+ this.propertyId = propertyId;
+ this.excludeGroups = excludeGroups;
+ }
+
+ public Permission(Class<?> ownerClass, long ownerId, Class<?> propertyClass) {
+ this(ownerClass, ownerId, propertyClass, 0, false);
+ }
+
+ public Permission(Class<?> ownerClass, Class<?> propertyClass, long propertyId) {
+ this(ownerClass, 0, propertyClass, propertyId, false);
+ }
+
+ public Permission excludeGroups() {
+ return new Permission(this.ownerClass, this.ownerId, this.propertyClass, this.propertyId, true);
}
public Class<?> getOwnerClass() {
@@ -150,6 +184,16 @@ public interface Condition {
public Class<?> getPropertyClass() {
return propertyClass;
}
+
+ public long getPropertyId() {
+ return propertyId;
+ }
+
+ public boolean getIncludeGroups() {
+ boolean ownerGroupModel = GroupedModel.class.isAssignableFrom(ownerClass);
+ boolean propertyGroupModel = GroupedModel.class.isAssignableFrom(propertyClass);
+ return (ownerGroupModel || propertyGroupModel) && !excludeGroups;
+ }
}
}