/* SPDX-License-Identifier: Apache-2.0 * * The OpenSearch Contributors require contributions made to * this file be licensed under the Apache-2.0 license or a * compatible open source license. */ /* * Modifications Copyright OpenSearch Contributors. See * GitHub history for details. * * Licensed to Elasticsearch B.V. under one or more contributor * license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright * ownership. Elasticsearch B.V. 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. */ using System.Runtime.Serialization; using OpenSearch.Net.Utf8Json; namespace OpenSearch.Client { /// /// The parent_id query can be used to find child documents which belong to a particular parent. /// [InterfaceDataContract] [ReadAs(typeof(ParentIdQuery))] public interface IParentIdQuery : IQuery { /// /// The id of the parent document to get children for. /// [DataMember(Name ="id")] Id Id { get; set; } /// /// When set to true this will ignore an unmapped type and will not match any documents for /// this query. This can be useful when querying multiple indexes which might have different mappings. /// [DataMember(Name ="ignore_unmapped")] bool? IgnoreUnmapped { get; set; } /// /// The child type. This must be a type with _parent field. /// [DataMember(Name ="type")] RelationName Type { get; set; } } public class ParentIdQuery : QueryBase, IParentIdQuery { public Id Id { get; set; } public bool? IgnoreUnmapped { get; set; } public RelationName Type { get; set; } protected override bool Conditionless => IsConditionless(this); internal override void InternalWrapInContainer(IQueryContainer c) => c.ParentId = this; internal static bool IsConditionless(IParentIdQuery q) => q.Type.IsConditionless() || q.Id.IsConditionless(); } [DataContract] public class ParentIdQueryDescriptor : QueryDescriptorBase, IParentIdQuery> , IParentIdQuery where T : class { protected override bool Conditionless => ParentIdQuery.IsConditionless(this); Id IParentIdQuery.Id { get; set; } bool? IParentIdQuery.IgnoreUnmapped { get; set; } RelationName IParentIdQuery.Type { get; set; } public ParentIdQueryDescriptor Id(Id id) => Assign(id, (a, v) => a.Id = v); public ParentIdQueryDescriptor Type(RelationName type) => Assign(type, (a, v) => a.Type = v); public ParentIdQueryDescriptor Type() => Assign(typeof(TChild), (a, v) => a.Type = v); public ParentIdQueryDescriptor IgnoreUnmapped(bool? ignoreUnmapped = true) => Assign(ignoreUnmapped, (a, v) => a.IgnoreUnmapped = v); } }