References

DriveKitDelegate

DriveKitDelegate is a protocol that can be passed as a parameter during the DriveKit Core module initialization. It gives useful events about the user lifecycle.

protocol DriveKitDelegate: AnyObject {
    func driveKitDidConnect(_ driveKit: DriveKit)
    func driveKitDidDisconnect(_ driveKit: DriveKit)
    func driveKit(_ driveKit: DriveKit, didReceiveAuthenticationError error: RequestError)
    func userIdUpdateStatusChanged(status: UpdateUserIdStatus, userId: String?)
    func driveKit(_ driveKit: DriveKit, accountDeletionCompleted status: DeleteAccountStatus)
}
MethodDescription

driveKitDidConnect(_ driveKit: DriveKit)

The user has been successfully logged

driveKitDidDisconnect(_ driveKit: DriveKit)

The user has been disconnected (manual logout or the account is disabled/deleted)

driveKit(_ driveKit: DriveKit, didReceiveAuthenticationError error: RequestError)

The login has failed due to a RequestError

userIdUpdateStatusChanged(status: UpdateUserIdStatus, userId: String?)

The update userId request has been processed with a UpdateUserIdStatus state value

onAccountDeleted(status: DeleteAccountStatus)

The delete account request has been processed with a DeleteAccountStatus state value.

UpdateUserIdStatus

UpdateUserIdStatus is an enum that explains the request status after a userId has asked to be changed.

public enum UpdateUserIdStatus: Int {
    case updated
    case failedToUpdate
    case invalidUserId
    case alreadyUsed
    case savedForRepost
}
ValueDescription

updated

The userId has been successfully updated

failedToUpdate

Occurs when DriveKit is not configured yet or if the new userId is the same as the old one

invalidUserId

Error returned when the new userId is blank

alreadyUsed

The new userId is already taken by another user

savedForRepost

The request failed but a retry will be done

RequestError

RequestError is an enum that describes the error type of a DriveKit request.

public enum RequestError: Int {
    case noNetwork
    case unauthenticated
    case forbidden
    case serverError
    case clientError
    case limitReached
    case unknownError
}
ValueDescription

noNetwork

The user has no connection or a bad one during the request.

unauthenticated

A request has been launched but the user is not logged (401 error).

forbidden

A 403 error occurred. You might don't have access to call that service. Please contact the DriveQuant to learn more.

serverError

Drivequant's backend responds with a 500 server error.

clientError

Drivequant's backend responds with a 400 error different than unauthenticated, forbidden and limitReached

unknownError

An unknown error occurred, please contact the Drivequant team to investigate the issue.

limitReached

The DriveKit API key has reached the accounts number limit. Please contact the Drivequant team.

DeleteAccountStatus

DeleteAccountStatus is an enum that describes the deletion status. It can have 3 values:

  • success: Account deleted successfully

  • failedToDelete: Account not deleted, an error has occurred

  • forbidden: Account deletion not activated for this team

DKWeather

DKWeather is an enum that describe each category of weather during a trip. It can have these values:

  • unknown

  • sun

  • cloud

  • fog

  • rain

  • snow

  • ice

Last updated