commonMain.io.realm.kotlin.mongodb.exceptions.ServiceExceptions.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.exceptions
import io.realm.kotlin.internal.interop.CodeDescription
/**
* This exception is considered the top-level or "catch-all" for problems related to HTTP requests
* made towards App Services. This covers both HTTP transport problems, problems passing JSON
* or the server considering the request invalid, for whatever reason.
*
* Generally, reacting to this exception will be hard, except to log the error for further
* analysis. But in many cases a more specific subtype will be thrown, which will be easier to
* react to. See the subclasses of this exception for more information about these.
*
* @see ConnectionException
* @see BadRequestException
* @see AuthException
*/
public open class ServiceException internal constructor(
message: String,
internal val errorCode: CodeDescription? = null
) : AppException(message)
/**
* Exception indicating that something went wrong with the underlying HTTP request to
* App Services. The exact cause is in the exception message.
*
* Errors resulting in this exception are outside the apps control and can be considered
* temporary. Retrying the action some time in the future should generally be safe, but since
* this potentially requires corrective measures in either the apps network environment
* or on the server, you should log this error for further analysis.
*
* Note, HTTP responses that indicate problems that can be fixed in the app will throw a more
* specific exception instead, e.g. `401 - AuthenticationRequired` will throw
* [InvalidCredentialsException].
*/
public open class ConnectionException internal constructor(message: String) :
ServiceException(message)
/**
* This exception is thrown when parameters sent to Atlas App Services are considered malformed.
* This can happen if e.g. tokens do not have the required length or contain garbage data. The
* exact reason will be in the error message.
*
* @see io.realm.kotlin.mongodb.auth.EmailPasswordAuth.resetPassword
* @see io.realm.kotlin.mongodb.auth.EmailPasswordAuth.retryCustomConfirmation
*/
public class BadRequestException internal constructor(message: String) : ServiceException(message)
/**
* This exception is considered the top-level or "catch-all" for problems related to user account
* actions. The exact reason for the error can be found in [Throwable.message].
*
* Generally, this exception does not need to be caught as more specific subtypes are available.
* These will be documented for the relevant API methods.
*
* @see UserAlreadyConfirmedException
* @see UserNotFoundException
* @see UserAlreadyExistsException
* @see InvalidCredentialsException
*/
public open class AuthException internal constructor(message: String) : ServiceException(message)
/**
* Thrown when trying to confirm a user that was already confirmed on the server.
*
* @see io.realm.kotlin.mongodb.auth.EmailPasswordAuth.confirmUser
* @see io.realm.kotlin.mongodb.auth.EmailPasswordAuth.resendConfirmationEmail
* @see io.realm.kotlin.mongodb.auth.EmailPasswordAuth.retryCustomConfirmation
*/
public class UserAlreadyConfirmedException internal constructor(message: String) :
AuthException(message)
/**
* Thrown when using an API that also require some kind of user identifier, but the server is
* not able to find the user.
*
* @see io.realm.kotlin.mongodb.auth.EmailPasswordAuth.resendConfirmationEmail
* @see io.realm.kotlin.mongodb.auth.EmailPasswordAuth.resetPassword
* @see io.realm.kotlin.mongodb.auth.EmailPasswordAuth.retryCustomConfirmation
* @see io.realm.kotlin.mongodb.auth.EmailPasswordAuth.sendResetPasswordEmail
*/
public class UserNotFoundException internal constructor(message: String) : AuthException(message)
/**
* Thrown when trying to register a new user with email and password, and the user already
* exists.
*
* @see io.realm.kotlin.mongodb.EmailPasswordAuth.registerUser
*/
public class UserAlreadyExistsException internal constructor(message: String) :
AuthException(message)
/**
* Thrown when credentials were rejected by the server when trying to log in. Only some
* authentication providers will return this error:
*
* - [io.realm.kotlin.mongodb.AuthenticationProvider.EMAIL_PASSWORD]
* - [io.realm.kotlin.mongodb.AuthenticationProvider.API_KEY]
* - [io.realm.kotlin.mongodb.AuthenticationProvider.JWT]
*
* The remaining authentication providers will throw a more general [AuthException] instead.
*
* @see io.realm.kotlin.mongodb.App.login
*/
public class InvalidCredentialsException internal constructor(message: String) :
AuthException(message)
/**
* Thrown when attempting to link credentials that are not supported.
*
* Reasons for this can e.g. be:
* - Linking an email account with an anonymous account. Only the other direction is supported, i.e.
* `anonymousUser.linkCredentials(Credentials.emailPassword(email, password))`
* - Linking two email accounts.
* - Linking an account with itself.
*
* The exact reason is found in the exception message.
*
* @see io.realm.kotlin.mongodb.User.linkCredentials
*/
public class CredentialsCannotBeLinkedException internal constructor(message: String) :
ServiceException(message)
/**
* Exception indicating that an Atlas Function failed to execute. The exact reason for the error can
* be found in [Throwable.message].
*
* @see [io.realm.kotlin.mongodb.Functions.call]
*/
public class FunctionExecutionException internal constructor(message: String) :
ServiceException(message)
© 2015 - 2025 Weber Informatics LLC | Privacy Policy