Skip to content

Commit

Permalink
Add custom serializers
Browse files Browse the repository at this point in the history
  • Loading branch information
uniumuniu committed Nov 7, 2023
1 parent 4e36ebd commit 6ddf82c
Show file tree
Hide file tree
Showing 19 changed files with 374 additions and 183 deletions.
3 changes: 2 additions & 1 deletion build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,8 @@ import org.gradle.api.tasks.testing.logging.TestLogEvent

plugins {
// Apply the org.jetbrains.kotlin.jvm Plugin to add support for Kotlin.
id("org.jetbrains.kotlin.jvm") version "1.8.20"
kotlin("jvm") version "1.9.20"
kotlin("plugin.serialization") version "1.9.20"

// Apply the java-library plugin for API and implementation separation.
`java-library`
Expand Down
52 changes: 24 additions & 28 deletions src/main/kotlin/com/featurevisor/sdk/Conditions.kt
Original file line number Diff line number Diff line change
@@ -1,33 +1,29 @@
package com.featurevisor.sdk

import com.featurevisor.types.AttributeValue
import com.featurevisor.types.Condition
import com.featurevisor.types.Condition.And
import com.featurevisor.types.Condition.Not
import com.featurevisor.types.Condition.Or
import com.featurevisor.types.Condition.Plain
import com.featurevisor.types.ConditionValue
import com.featurevisor.types.Context
import com.featurevisor.types.Operator.AFTER
import com.featurevisor.types.Operator.BEFORE
import com.featurevisor.types.Operator.CONTAINS
import com.featurevisor.types.Operator.ENDS_WITH
import com.featurevisor.types.Operator.EQUALS
import com.featurevisor.types.Operator.GREATER_THAN
import com.featurevisor.types.Operator.GREATER_THAN_OR_EQUAL
import com.featurevisor.types.Operator.IN_ARRAY
import com.featurevisor.types.Operator.LESS_THAN
import com.featurevisor.types.Operator.LESS_THAN_OR_EQUAL
import com.featurevisor.types.Operator.NOT_CONTAINS
import com.featurevisor.types.Operator.NOT_EQUALS
import com.featurevisor.types.Operator.NOT_IN_ARRAY
import com.featurevisor.types.Operator.SEMVER_EQUALS
import com.featurevisor.types.Operator.SEMVER_GREATER_THAN
import com.featurevisor.types.Operator.SEMVER_GREATER_THAN_OR_EQUAL
import com.featurevisor.types.Operator.SEMVER_LESS_THAN
import com.featurevisor.types.Operator.SEMVER_LESS_THAN_OR_EQUAL
import com.featurevisor.types.Operator.SEMVER_NOT_EQUALS
import com.featurevisor.types.Operator.STARTS_WITH
import com.featurevisor.sdk.Condition.And
import com.featurevisor.sdk.Condition.Not
import com.featurevisor.sdk.Condition.Or
import com.featurevisor.sdk.Condition.Plain
import com.featurevisor.sdk.Operator.AFTER
import com.featurevisor.sdk.Operator.BEFORE
import com.featurevisor.sdk.Operator.CONTAINS
import com.featurevisor.sdk.Operator.ENDS_WITH
import com.featurevisor.sdk.Operator.EQUALS
import com.featurevisor.sdk.Operator.GREATER_THAN
import com.featurevisor.sdk.Operator.GREATER_THAN_OR_EQUAL
import com.featurevisor.sdk.Operator.IN_ARRAY
import com.featurevisor.sdk.Operator.LESS_THAN
import com.featurevisor.sdk.Operator.LESS_THAN_OR_EQUAL
import com.featurevisor.sdk.Operator.NOT_CONTAINS
import com.featurevisor.sdk.Operator.NOT_EQUALS
import com.featurevisor.sdk.Operator.NOT_IN_ARRAY
import com.featurevisor.sdk.Operator.SEMVER_EQUALS
import com.featurevisor.sdk.Operator.SEMVER_GREATER_THAN
import com.featurevisor.sdk.Operator.SEMVER_GREATER_THAN_OR_EQUAL
import com.featurevisor.sdk.Operator.SEMVER_LESS_THAN
import com.featurevisor.sdk.Operator.SEMVER_LESS_THAN_OR_EQUAL
import com.featurevisor.sdk.Operator.SEMVER_NOT_EQUALS
import com.featurevisor.sdk.Operator.STARTS_WITH
import net.swiftzer.semver.SemVer

object Conditions {
Expand Down
10 changes: 1 addition & 9 deletions src/main/kotlin/com/featurevisor/sdk/DatafileReader.kt
Original file line number Diff line number Diff line change
@@ -1,13 +1,5 @@
package com.featurevisor.sdk

import com.featurevisor.types.Attribute
import com.featurevisor.types.AttributeKey
import com.featurevisor.types.DatafileContent
import com.featurevisor.types.Feature
import com.featurevisor.types.FeatureKey
import com.featurevisor.types.Segment
import com.featurevisor.types.SegmentKey

class DatafileReader constructor(
datafileJson: DatafileContent,
) {
Expand All @@ -34,7 +26,7 @@ class DatafileReader constructor(
return attributes.find { attribute -> attribute.key == attributeKey }
}

fun getSegment(segmentKey: SegmentKey): Segment? {
fun getSegment(segmentKey: String): Segment? {
return segments.find { segment -> segment.key == segmentKey }
}

Expand Down
2 changes: 0 additions & 2 deletions src/main/kotlin/com/featurevisor/sdk/Emitter.kt
Original file line number Diff line number Diff line change
@@ -1,7 +1,5 @@
package com.featurevisor.sdk

import com.featurevisor.types.EventName

class Emitter {

private val listeners = mutableMapOf<EventName, (Array<out Any>) -> Unit>()
Expand Down
6 changes: 1 addition & 5 deletions src/main/kotlin/com/featurevisor/sdk/Instance+Activation.kt
Original file line number Diff line number Diff line change
@@ -1,10 +1,6 @@
package com.featurevisor.sdk

import com.featurevisor.types.AttributeValue
import com.featurevisor.types.Context
import com.featurevisor.types.EventName.ACTIVATION
import com.featurevisor.types.FeatureKey
import com.featurevisor.types.VariationValue
import com.featurevisor.sdk.EventName.ACTIVATION

fun FeaturevisorInstance.activate(featureKey: FeatureKey, context: Context = emptyMap()): VariationValue? {
val evaluation = evaluateVariation(featureKey, context)
Expand Down
19 changes: 1 addition & 18 deletions src/main/kotlin/com/featurevisor/sdk/Instance+Evaluation.kt
Original file line number Diff line number Diff line change
Expand Up @@ -2,23 +2,6 @@ package com.featurevisor.sdk

import com.featurevisor.sdk.Conditions.allConditionsAreMatched
import com.featurevisor.sdk.EvaluationReason.*
import com.featurevisor.types.AttributeKey
import com.featurevisor.types.AttributeValue
import com.featurevisor.types.BucketBy
import com.featurevisor.types.BucketKey
import com.featurevisor.types.BucketValue
import com.featurevisor.types.Context
import com.featurevisor.types.Feature
import com.featurevisor.types.FeatureKey
import com.featurevisor.types.OverrideFeature
import com.featurevisor.types.Required
import com.featurevisor.types.RuleKey
import com.featurevisor.types.Traffic
import com.featurevisor.types.VariableKey
import com.featurevisor.types.VariableSchema
import com.featurevisor.types.VariableValue
import com.featurevisor.types.Variation
import com.featurevisor.types.VariationValue
import kotlinx.serialization.Serializable
import kotlinx.serialization.json.Json
import kotlinx.serialization.json.decodeFromJsonElement
Expand Down Expand Up @@ -612,7 +595,7 @@ private fun FeaturevisorInstance.getBucketKey(feature: Feature, context: Context

is BucketBy.Or -> {
type = "or"
attributeKeys = bucketBy.bucketBy.or
attributeKeys = bucketBy.bucketBy
}
}

Expand Down
7 changes: 1 addition & 6 deletions src/main/kotlin/com/featurevisor/sdk/Instance+Feature.kt
Original file line number Diff line number Diff line change
@@ -1,13 +1,8 @@
package com.featurevisor.sdk

import com.featurevisor.sdk.Conditions.allConditionsAreMatched
import com.featurevisor.types.Allocation
import com.featurevisor.types.Context
import com.featurevisor.types.Feature
import com.featurevisor.types.Force
import com.featurevisor.types.Traffic

internal fun FeaturevisorInstance.getFeatureByKey(featureKey: String): Feature? {
fun FeaturevisorInstance.getFeatureByKey(featureKey: String): Feature? {
return datafileReader.getFeature(featureKey)
}

Expand Down
29 changes: 21 additions & 8 deletions src/main/kotlin/com/featurevisor/sdk/Instance+Fetch.kt
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
package com.featurevisor.sdk

import com.featurevisor.types.DatafileContent
import java.io.IOException
import okhttp3.*
import kotlinx.serialization.json.Json
Expand Down Expand Up @@ -39,21 +38,35 @@ private fun fetchDatafileContentFromUrl(
}
}

private inline fun <reified T> fetch(
const val BODY_BYTE_COUNT = 1000000L
private inline fun fetch(
request: Request,
crossinline completion: (Result<T>) -> Unit,
crossinline completion: (Result<DatafileContent>) -> Unit,
) {
val client = OkHttpClient()
val call = client.newCall(request)
call.enqueue(object : Callback {
override fun onResponse(call: Call, response: Response) {
val responseBody = response.body
if (response.isSuccessful && responseBody != null) {
val json = Json { ignoreUnknownKeys = true }
val content = json.decodeFromString<T>(responseBody.string())
val responseBody = response.peekBody(BODY_BYTE_COUNT)
if (response.isSuccessful) {
val json = Json {
ignoreUnknownKeys = true
serializersModule = this.serializersModule.apply {

}
}
val responseBodyString = responseBody.string()
val content = json.decodeFromString<DatafileContent>(responseBodyString)
completion(Result.success(content))
} else {
completion(Result.failure(FeaturevisorError.UnparsableJson(responseBody?.string(), response.message)))
completion(
Result.failure(
FeaturevisorError.UnparsableJson(
responseBody.string(),
response.message
)
)
)
}
}

Expand Down
1 change: 0 additions & 1 deletion src/main/kotlin/com/featurevisor/sdk/Instance+Refresh.kt
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package com.featurevisor.sdk

import com.featurevisor.sdk.FeaturevisorError.*
import com.featurevisor.types.EventName
import kotlinx.coroutines.CoroutineScope
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.delay
Expand Down
7 changes: 1 addition & 6 deletions src/main/kotlin/com/featurevisor/sdk/Instance+Segments.kt
Original file line number Diff line number Diff line change
@@ -1,12 +1,7 @@
package com.featurevisor.sdk

import com.featurevisor.sdk.Conditions.allConditionsAreMatched
import com.featurevisor.types.Context
import com.featurevisor.types.FeatureKey
import com.featurevisor.types.GroupSegment
import com.featurevisor.types.GroupSegment.*
import com.featurevisor.types.Segment
import com.featurevisor.types.VariationValue
import com.featurevisor.sdk.GroupSegment.*

internal fun FeaturevisorInstance.segmentIsMatched(
featureKey: FeatureKey,
Expand Down
6 changes: 1 addition & 5 deletions src/main/kotlin/com/featurevisor/sdk/Instance+Variable.kt
Original file line number Diff line number Diff line change
@@ -1,10 +1,6 @@
package com.featurevisor.sdk

import com.featurevisor.types.Context
import com.featurevisor.types.FeatureKey
import com.featurevisor.types.VariableKey
import com.featurevisor.types.VariableValue
import com.featurevisor.types.VariableValue.*
import com.featurevisor.sdk.VariableValue.*
import kotlinx.serialization.json.Json
import kotlinx.serialization.json.decodeFromJsonElement
import kotlinx.serialization.json.encodeToJsonElement
Expand Down
4 changes: 0 additions & 4 deletions src/main/kotlin/com/featurevisor/sdk/Instance+Variation.kt
Original file line number Diff line number Diff line change
@@ -1,9 +1,5 @@
package com.featurevisor.sdk

import com.featurevisor.types.Context
import com.featurevisor.types.FeatureKey
import com.featurevisor.types.VariationValue

internal fun FeaturevisorInstance.getVariation(featureKey: FeatureKey, context: Context): VariationValue? {
val evaluation = evaluateVariation(featureKey, context)
return when {
Expand Down
17 changes: 5 additions & 12 deletions src/main/kotlin/com/featurevisor/sdk/Instance.kt
Original file line number Diff line number Diff line change
Expand Up @@ -5,17 +5,10 @@ package com.featurevisor.sdk

import com.featurevisor.sdk.FeaturevisorError.FetchingDataFileFailed
import com.featurevisor.sdk.FeaturevisorError.MissingDatafileOptions
import com.featurevisor.types.BucketKey
import com.featurevisor.types.BucketValue
import com.featurevisor.types.Context
import com.featurevisor.types.DatafileContent
import com.featurevisor.types.EventName
import com.featurevisor.types.EventName.ACTIVATION
import com.featurevisor.types.EventName.READY
import com.featurevisor.types.EventName.REFRESH
import com.featurevisor.types.EventName.UPDATE
import com.featurevisor.types.Feature
import com.featurevisor.types.StickyFeatures
import com.featurevisor.sdk.EventName.ACTIVATION
import com.featurevisor.sdk.EventName.READY
import com.featurevisor.sdk.EventName.REFRESH
import com.featurevisor.sdk.EventName.UPDATE
import kotlinx.coroutines.Job
import kotlinx.serialization.json.Json

Expand Down Expand Up @@ -96,7 +89,7 @@ class FeaturevisorInstance private constructor(options: InstanceOptions) {
if (result.isSuccess) {
datafileReader = DatafileReader(result.getOrThrow())
statuses.ready = true
emitter.emit(READY)
emitter.emit(READY, result.getOrThrow())
if (refreshInterval != null) startRefreshing()
} else {
logger?.error("Failed to fetch datafile: $result")
Expand Down
4 changes: 0 additions & 4 deletions src/main/kotlin/com/featurevisor/sdk/InstanceOptions.kt
Original file line number Diff line number Diff line change
@@ -1,9 +1,5 @@
package com.featurevisor.sdk

import com.featurevisor.types.DatafileContent
import com.featurevisor.types.InitialFeatures
import com.featurevisor.types.StickyFeatures

typealias Listener = (Array<out Any>) -> Unit

data class InstanceOptions(
Expand Down
Loading

0 comments on commit 6ddf82c

Please sign in to comment.