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

commonMain.io.realm.kotlin.mongodb.auth.ApiKeyAuth.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.auth

import io.realm.kotlin.mongodb.App
import io.realm.kotlin.mongodb.User
import io.realm.kotlin.mongodb.exceptions.AppException
import io.realm.kotlin.types.ObjectId
import org.mongodb.kbson.BsonObjectId

/**
 * Exposes functionality for a user to manage API keys under their control.
 */
public interface ApiKeyAuth {

    /**
     * The User that this instance in associated with.
     */
    public val user: User

    /**
     * The App that this instance in associated with.
     */
    public val app: App

    /**
     * Creates a user API key that can be used to authenticate as the user.
     * The value of the key must be persisted at this time as this is the only time it is visible.
     * The key is enabled when created. It can be disabled by calling the [disable] method.
     *
     * @param name the name of the key
     * @return the new API key for the user.
     *
     * @throws IllegalArgumentException if an invalid name for the key is sent to the server.
     * @throws io.realm.kotlin.mongodb.exceptions.ServiceException for other failures that can happen when
     * communicating with App Services. See [AppException] for details.
     */
    public suspend fun create(name: String): ApiKey

    /**
     * Deletes a specific API key created by the user.
     * Returns silently if no key is deleted.
     *
     * @param id the id of the key to delete.
     *
     * @throws io.realm.kotlin.mongodb.exceptions.ServiceException for failures that can happen when
     * communicating with App Services. See [AppException] for details.
     */
    public suspend fun delete(id: ObjectId)

    /**
     * Deletes a specific API key created by the user. The function would complete normally if the provided key does not exist.
     *
     * @param id the id of the key to disable.
     *
     * @throws IllegalArgumentException if a non existing API key is disabled.
     * @throws io.realm.kotlin.mongodb.exceptions.ServiceException for other failures that can happen when
     * communicating with App Services. See [AppException] for details.
     */
    public suspend fun disable(id: ObjectId)

    /**
     * Enables a specific API key created by the user.
     *
     * @param id the id of the key to disable.
     *
     * @throws IllegalArgumentException if a non existing API key is enabled.
     * @throws io.realm.kotlin.mongodb.exceptions.ServiceException for other failures that can happen when
     * communicating with App Services. See [AppException] for details.
     */
    public suspend fun enable(id: ObjectId)

    /**
     * Fetches a specific user API key associated with the user.
     *
     * @param id the id of the key to fetch.
     *
     * @throws IllegalArgumentException if a non existing API key is fetched.
     * @throws io.realm.kotlin.mongodb.exceptions.ServiceException for other failures that can happen when
     * communicating with App Services. See [AppException] for details.
     */
    public suspend fun fetch(id: ObjectId): ApiKey?

    /**
     * Deletes a specific API key created by the user.
     * Returns silently if no key is deleted.
     *
     * @param id the id of the key to delete.
     *
     * @throws io.realm.kotlin.mongodb.exceptions.ServiceException for failures that can happen when
     * communicating with App Services. See [AppException] for details.
     */
    public suspend fun delete(id: BsonObjectId)

    /**
     * Deletes a specific API key created by the user. The function would complete normally if the provided key does not exist.
     *
     * @param id the id of the key to disable.
     *
     * @throws IllegalArgumentException if a non existing API key is disabled.
     * @throws io.realm.kotlin.mongodb.exceptions.ServiceException for other failures that can happen when
     * communicating with App Services. See [AppException] for details.
     */
    public suspend fun disable(id: BsonObjectId)

    /**
     * Enables a specific API key created by the user.
     *
     * @param id the id of the key to disable.
     *
     * @throws IllegalArgumentException if a non existing API key is enabled.
     * @throws io.realm.kotlin.mongodb.exceptions.ServiceException for other failures that can happen when
     * communicating with App Services. See [AppException] for details.
     */
    public suspend fun enable(id: BsonObjectId)

    /**
     * Fetches a specific user API key associated with the user.
     *
     * @param id the id of the key to fetch.
     *
     * @throws IllegalArgumentException if a non existing API key is fetched.
     * @throws io.realm.kotlin.mongodb.exceptions.ServiceException for other failures that can happen when
     * communicating with App Services. See [AppException] for details.
     */
    public suspend fun fetch(id: BsonObjectId): ApiKey?

    /**
     * Fetches all API keys associated with the user.
     * Returns an empty list if no key is found.
     *
     * @throws io.realm.kotlin.mongodb.exceptions.ServiceException for failures that can happen when
     * communicating with App Services. See [AppException] for details.
     */
    public suspend fun fetchAll(): List
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy