com.pubnub.internal.endpoints.access.RevokeTokenEndpoint.kt Maven / Gradle / Ivy
package com.pubnub.internal.endpoints.access
import com.pubnub.api.PubNubError
import com.pubnub.api.PubNubException
import com.pubnub.api.enums.PNOperationType
import com.pubnub.api.retry.RetryableEndpointGroup
import com.pubnub.api.v2.BasePNConfiguration.Companion.isValid
import com.pubnub.internal.EndpointCore
import com.pubnub.internal.PubNubCore
import com.pubnub.internal.models.server.access_manager.v3.RevokeTokenResponse
import retrofit2.Call
import retrofit2.Response
import java.net.URLEncoder
class RevokeTokenEndpoint(
pubnub: PubNubCore,
private val token: String,
) : EndpointCore(pubnub), RevokeTokenInterface {
override fun validateParams() {
super.validateParams()
if (!pubnub.configuration.secretKey.isValid()) {
throw PubNubException(PubNubError.SECRET_KEY_MISSING)
}
if (token.isBlank()) {
throw PubNubException(PubNubError.TOKEN_MISSING)
}
}
override fun doWork(queryParams: HashMap): Call {
return retrofitManager
.accessManagerService
.revokeToken(configuration.subscribeKey, repairEncoding(token), queryParams)
}
override fun createResponse(input: Response): Unit = Unit
override fun operationType(): PNOperationType = PNOperationType.PNAccessManagerRevokeToken
override fun isAuthRequired(): Boolean = false
override fun getEndpointGroupName(): RetryableEndpointGroup = RetryableEndpointGroup.ACCESS_MANAGER
private fun repairEncoding(token: String): String {
return URLEncoder.encode(token, "utf-8").replace("+", "%20")
}
}