All Downloads are FREE. Search and download functionalities are using the official Maven repository.

commonMain.io.realm.kotlin.mongodb.sync.MutableSubscriptionSet.kt Maven / Gradle / Ivy

/*
 * Copyright 2022 Realm Inc.
 *
 * 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 io.realm.kotlin.mongodb.sync

import io.realm.kotlin.query.RealmQuery
import io.realm.kotlin.types.RealmObject
import kotlin.reflect.KClass

/**
 * A mutable subscription set makes it possible to add, remove or modify a
 * [SubscriptionSet]. It becomes available when calling [SubscriptionSet.update].
 *
 * @see SubscriptionSet for more information about subscription sets and Flexible Sync.
 */
public interface MutableSubscriptionSet : BaseSubscriptionSet {

    /**
     * Adds a new subscription to the subscription set. If an existing subscription exists
     * that matches the [query] and the [name], this operation does nothing and the existing
     * subscription will be returned.
     *
     * If an existing named subscription exists on a different query an [IllegalArgumentException]
     * will be thrown unless [updateExisting] is set to `true`, in which case the existing
     * subscription will be updated with the new query.
     *
     * @param query the query that will be subscribed to. Note, subscription queries have
     * restrictions compared to normal queries.
     * @param name the name of the subscription. If no name is provided, the subscription is
     * considered to be anonymous.
     * @param updateExisting determines the behaviour if an existing named subscription
     * already exists. This does nothing for anonymous subscriptions.
     * @return the newly added subscription.
     * @throws IllegalStateException if a subscription matching the provided one already exists
     * but on a different query and [updateExisting] was set to `false`.
     */
    public fun  add(query: RealmQuery, name: String? = null, updateExisting: Boolean = false): Subscription

    /**
     * Creates an anonymous [Subscription] in the current [MutableSubscriptionSet] directly from
     * a [RealmQuery].
     *
     * @return the [Subscription] that was added.
     */
    public fun RealmQuery.subscribe(): Subscription = add(this)

    /**
     * Creates a named [Subscription] in the current [MutableSubscriptionSet] directly from a
     * [RealmQuery].
     *
     * @param name name of the subscription.
     * @param updateExisting if a different query is already registered with the provided [name],
     * then set this to `true` to update the subscription. If set to `false` an exception is
     * thrown instead of updating the query.
     * @return the [Subscription] that was added or updated.
     * @throws IllegalArgumentException if [updateExisting] is false, and another query was already
     * registered with the given [name].
     */
    public fun RealmQuery.subscribe(name: String, updateExisting: Boolean = false): Subscription =
        add(this, name, updateExisting)

    /**
     * Remove a subscription.
     *
     * @param subscription subscription to remove
     * @return `true` if the subscription was removed, `false` if not.
     */
    public fun remove(subscription: Subscription): Boolean

    /**
     * Remove a named subscription.
     *
     * @param name name of the subscription to remove.
     * @return `true` if a matching subscription was removed, `false` if [Subscription] could be
     * found.
     */
    public fun remove(name: String): Boolean

    /**
     * Remove all subscriptions with queries on a given [Subscription.objectType].
     *
     * @param objectType subscriptions on this object type will be removed.
     * @return `true` if one or more subscriptions were removed, `false` if no
     * subscriptions were removed.
     * @throws IllegalArgumentException if [objectType] is not part of the Schema for this Realm.
     */
    public fun removeAll(objectType: String): Boolean

    /**
     * Remove all subscriptions with queries on a given model class.
     *
     * @param type subscriptions on this type will be removed.
     * @return `true` if one or more subscriptions were removed, `false` if no
     * subscriptions were removed.
     * @throws IllegalArgumentException if [objectType] is not part of the Schema for this Realm.
     */
    public fun  removeAll(type: KClass): Boolean

    /**
     * Remove all subscriptions in this subscription set.
     *
     * @param anonymousOnly whether or not to only remove anonymous subscriptions. If `true` only
     * anonymous subscriptions will be removed. If `false` both anonymous and named subscriptions
     * will be removed.
     * @return `true` if one or more subscriptions were removed, `false` if the subscription set
     * was empty.
     */
    public fun removeAll(anonymousOnly: Boolean = false): Boolean
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy