| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you 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.apache.syncope.core.persistence.jpa.dao; |
| |
| import java.util.List; |
| import org.apache.commons.lang3.tuple.Pair; |
| import org.apache.syncope.core.persistence.api.dao.PlainSchemaDAO; |
| import org.apache.syncope.core.persistence.api.entity.AnyUtils; |
| import org.apache.syncope.core.persistence.api.entity.PlainAttr; |
| import org.apache.syncope.core.persistence.api.entity.PlainAttrUniqueValue; |
| import org.apache.syncope.core.persistence.api.entity.PlainAttrValue; |
| import org.apache.syncope.core.persistence.api.entity.PlainSchema; |
| import org.apache.syncope.core.provisioning.api.serialization.POJOHelper; |
| import org.apache.syncope.core.persistence.api.entity.JSONPlainAttr; |
| |
| public class PGJPAJSONAnyDAO extends AbstractJPAJSONAnyDAO { |
| |
| public PGJPAJSONAnyDAO(final PlainSchemaDAO plainSchemaDAO) { |
| super(plainSchemaDAO); |
| } |
| |
| @Override |
| protected String queryBegin(final String table) { |
| return "SELECT DISTINCT id FROM " + table + " u," |
| + "jsonb_array_elements(u.plainAttrs) attrs," |
| + "jsonb_array_elements(COALESCE(attrs -> 'values', '[{}]'::jsonb)) attrValues "; |
| } |
| |
| @Override |
| protected String attrValueMatch( |
| final AnyUtils anyUtils, |
| final PlainSchema schema, |
| final PlainAttrValue attrValue, |
| final boolean ignoreCaseMatch) { |
| |
| Pair<String, Boolean> schemaInfo = schemaInfo(schema.getType(), ignoreCaseMatch); |
| if (schemaInfo.getRight()) { |
| return "attrs ->> 'schema' = ? " |
| + "AND " |
| + (schemaInfo.getRight() ? "LOWER(" : "") |
| + (schema.isUniqueConstraint() ? "attrs -> 'uniqueValue'" : "attrValues") |
| + " ->> '" + schemaInfo.getLeft() |
| + '\'' + (schemaInfo.getRight() ? ")" : "") |
| + " = " |
| + (schemaInfo.getRight() ? "LOWER(" : "") |
| + '?' |
| + (schemaInfo.getRight() ? ")" : ""); |
| } else { |
| PlainAttr<?> container = anyUtils.newPlainAttr(); |
| container.setSchema(schema); |
| if (attrValue instanceof PlainAttrUniqueValue) { |
| container.setUniqueValue((PlainAttrUniqueValue) attrValue); |
| } else { |
| ((JSONPlainAttr) container).add(attrValue); |
| } |
| return "plainAttrs::jsonb @> '" + POJOHelper.serialize(List.of(container)).replace("'", "''") + "'::jsonb"; |
| } |
| } |
| } |