diff --git a/CHANGELOG.md b/CHANGELOG.md
index d73d69a..f65c75f 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,3 +1,21 @@
+# 0.5.1
+
+##### Add
+* [issue#15](https://github.com/cianru/rustore-publish-gradle-plugin/issues/15) Support of `publishType` param to control the publish process.
+```kotlin
+ /**
+ * (Optional)
+ * CLI: `--publishType`
+ * ----| 'instantly' – the application will be published immediately after the review process is completed.
+ * ----| 'manual' – the application must be published manually by the developer after ther review process is completed.
+ * Gradle Extension DSL, available values:
+ * ----| ru.cian.rustore.publish.PublishType.INSTANTLY
+ * ----| ru.cian.rustore.publish.PublishType.MANUAL
+ * Default value: `instantly`
+ */
+ publishType = ru.cian.rustore.publish.PublishType.INSTANTLY
+```
+
# 0.5.0
##### Add
diff --git a/README.md b/README.md
index 088d40c..c0aef89 100644
--- a/README.md
+++ b/README.md
@@ -12,8 +12,8 @@
-![Version](https://img.shields.io/badge/GradlePortal-0.5.0-green.svg)
-![Version](https://img.shields.io/badge/Gradle-8.*-pink.svg)
+[//]: # (![Version](https://img.shields.io/badge/GradlePortal-0.5.0-green.svg))
+
[![License](https://img.shields.io/github/license/srs/gradle-node-plugin.svg)](http://www.apache.org/licenses/LICENSE-2.0.html)
The plugin use [Rustore API](https://help.rustore.ru/rustore/for_developers/work_with_RuStore_API/publish_RuStore_API) to publish Android build file to the [RuStore](https://rustore.ru).
@@ -123,7 +123,7 @@ rustorePublish {
* CLI: `--buildFormat`, available values:
* ----| 'apk'
* ----| 'aab'
- * Gradle Extention DSL, available values:
+ * Gradle Extension DSL, available values:
* ----| ru.cian.rustore.publish.BuildFormat.APK
* ----| ru.cian.rustore.publish.BuildFormat.AAB
* Default value: `apk`
@@ -182,7 +182,7 @@ rustorePublish {
* CLI: `--buildFormat`, available values:
* ----| 'apk'
* ----| 'aab'
- * Gradle Extention DSL, available values:
+ * Gradle Extension DSL, available values:
* ----| ru.cian.rustore.publish.BuildFormat.APK
* ----| ru.cian.rustore.publish.BuildFormat.AAB
* Default value: `apk`
@@ -203,7 +203,7 @@ rustorePublish {
* The time in seconds to wait for the publication to complete. Increase it if you build is large.
* Type: Long (Optional)
* Default value: `300` // (5min)
- * CLI: `--publishTimeoutMs`
+ * CLI: `--requestTimeout`
*/
requestTimeout = 300
@@ -215,13 +215,25 @@ rustorePublish {
* CLI: `--mobileServicesType`
* ----| 'Unknown'
* ----| 'HMS'
- * Gradle Extention DSL, available values:
+ * Gradle Extension DSL, available values:
* ----| ru.cian.rustore.publish.MobileServicesType.UNKNOWN
* ----| ru.cian.rustore.publish.MobileServicesType.HMS
* Default value: `Unknown`
*/
mobileServicesType = ru.cian.rustore.publish.MobileServicesType.UNKNOWN
+ /**
+ * (Optional)
+ * CLI: `--publishType`
+ * ----| 'instantly' – the application will be published immediately after the review process is completed.
+ * ----| 'manual' – the application must be published manually by the developer after ther review process is completed.
+ * Gradle Extension DSL, available values:
+ * ----| ru.cian.rustore.publish.PublishType.INSTANTLY
+ * ----| ru.cian.rustore.publish.PublishType.MANUAL
+ * Default value: `instantly`
+ */
+ publishType = ru.cian.rustore.publish.PublishType.INSTANTLY
+
/**
* (Optional)
* Release Notes settings. For mote info see ReleaseNote param desc.
@@ -270,7 +282,7 @@ rustorePublish {
credentialsPath = "$rootDir/rustore-credentials-release.json"
buildFormat = "apk"
buildFile = "$rootDir/app/build/outputs/apk/release/app-release.apk"
- requestTimeout = 60
+ requestTimeout = 60 // 1min
mobileServicesType = "Unknown"
releaseNotes = [
new ru.cian.rustore.publish.ReleaseNote(
@@ -334,6 +346,7 @@ CLI params are more priority than gradle configuration params.
--credentialsPath="/sample-kotlin/rustore-credentials.json" \
--buildFormat=apk \
--buildFile="/sample-kotlin/app/build/outputs/apk/release/app-release.apk" \
+ --requestTimeout=300 \ # 5min
--mobileServicesType="Unknown" \
--releaseNotes="ru_RU:/home//str/project/release_notes_ru.txt"
```
diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml
index 1367e9f..f78108b 100644
--- a/gradle/libs.versions.toml
+++ b/gradle/libs.versions.toml
@@ -13,7 +13,7 @@ kotlin = "1.9.23"
detekt = "1.23.4"
junitJupiter = "5.9.3"
androidGradlePlugin = "8.0.2"
-sampleRustorePlugin = "0.5.0-alpha02"
+sampleRustorePlugin = "0.5.1-alpha01"
[libraries]
appcompat = "androidx.appcompat:appcompat:1.6.1"
diff --git a/plugin/gradle.properties b/plugin/gradle.properties
index edcad30..e52b9c2 100644
--- a/plugin/gradle.properties
+++ b/plugin/gradle.properties
@@ -9,7 +9,7 @@ android.enableJetifier=true
####################################################################################################
GROUP_ID=ru.cian.rustore-plugin
-VERSION_NAME=0.5.0
+VERSION_NAME=0.5.1
POM_ARTIFACT_ID=rustore-publish-gradle-plugin
POM_NAME=Rustore Publish Gradle Plugin
diff --git a/plugin/src/main/kotlin/ru/cian/rustore/publish/PluginConfig.kt b/plugin/src/main/kotlin/ru/cian/rustore/publish/PluginConfig.kt
index 3c40e63..7d423d8 100644
--- a/plugin/src/main/kotlin/ru/cian/rustore/publish/PluginConfig.kt
+++ b/plugin/src/main/kotlin/ru/cian/rustore/publish/PluginConfig.kt
@@ -4,7 +4,7 @@ import java.io.File
internal data class PluginConfig(
val credentials: Credentials,
- val deployType: DeployType,
+ val publishType: PublishType,
val artifactFormat: BuildFormat,
val requestTimeout: Long?,
val mobileServicesType: MobileServicesType,
diff --git a/plugin/src/main/kotlin/ru/cian/rustore/publish/RustorePublishCli.kt b/plugin/src/main/kotlin/ru/cian/rustore/publish/RustorePublishCli.kt
index 43f2979..be05490 100644
--- a/plugin/src/main/kotlin/ru/cian/rustore/publish/RustorePublishCli.kt
+++ b/plugin/src/main/kotlin/ru/cian/rustore/publish/RustorePublishCli.kt
@@ -1,7 +1,7 @@
package ru.cian.rustore.publish
internal data class RustorePublishCli(
- val deployType: DeployType? = null,
+ val publishType: PublishType? = null,
val credentialsPath: String? = null,
val keyId: String? = null,
val clientSecret: String? = null,
diff --git a/plugin/src/main/kotlin/ru/cian/rustore/publish/RustorePublishExtension.kt b/plugin/src/main/kotlin/ru/cian/rustore/publish/RustorePublishExtension.kt
index b573b70..83b7a83 100644
--- a/plugin/src/main/kotlin/ru/cian/rustore/publish/RustorePublishExtension.kt
+++ b/plugin/src/main/kotlin/ru/cian/rustore/publish/RustorePublishExtension.kt
@@ -27,7 +27,7 @@ class RustorePublishExtensionConfig(
* var param by GradleProperty(project, String::class.java)
*/
var credentialsPath: String? = null
- var deployType = DeployType.PUBLISH
+ var publishType = PublishType.INSTANTLY
var requestTimeout: Long? = null
var mobileServicesType: MobileServicesType = MobileServicesType.UNKNOWN
var buildFormat: BuildFormat = BuildFormat.APK
@@ -52,7 +52,7 @@ class RustorePublishExtensionConfig(
return "RustorePublishExtensionConfig(" +
"name='$name', " +
"credentialsPath='$credentialsPath', " +
- "deployType='$deployType', " +
+ "deployType='$publishType', " +
"requestTimeout='$requestTimeout', " +
"mobileServicesType='$mobileServicesType', " +
"buildFormat='$buildFormat', " +
@@ -111,19 +111,19 @@ enum class MobileServicesType(val value: String) {
UNKNOWN("Unknown"),
}
-enum class DeployType {
+enum class PublishType {
/**
- * Deploy without draft saving and submit on users;
+ * Manual publication. After review you should publish it manually;
*/
- UPLOAD_ONLY,
+ MANUAL,
/**
- * Deploy and save as draft without submit on users;
+ * Automatically publish on all users after reviewing store approve;
*/
- DRAFT,
+ INSTANTLY,
/**
- * Deploy, save as draft and submit build on users;
+ * Delayed publication. You should set publishDateTime;
*/
- PUBLISH,
+// DELAYED, // FIXME: Implement delayed publication after adding of `publishDateTime` API param;
}
diff --git a/plugin/src/main/kotlin/ru/cian/rustore/publish/RustorePublishTask.kt b/plugin/src/main/kotlin/ru/cian/rustore/publish/RustorePublishTask.kt
index b3f5865..1c84a3e 100644
--- a/plugin/src/main/kotlin/ru/cian/rustore/publish/RustorePublishTask.kt
+++ b/plugin/src/main/kotlin/ru/cian/rustore/publish/RustorePublishTask.kt
@@ -39,14 +39,6 @@ open class RustorePublishTask
private val logger by lazy { Logger(project) }
- @get:Internal
- @set:Option(
- option = "deployType",
- description = "How to deploy build: 'publish' to all users or create 'draft' " +
- "without publishing or 'upload-only' without draft creation"
- )
- var deployType: DeployType? = null
-
@get:Internal
@set:Option(
option = "credentialsPath",
@@ -126,6 +118,13 @@ open class RustorePublishTask
)
var releaseNotes: String? = null
+ @get:Internal
+ @set:Option(
+ option = "publishType",
+ description = "How to publish build file. Available values: ['manual', 'instantly']."
+ )
+ var publishType: PublishType? = null
+
@get:Internal
@set:Option(option = "apiStub", description = "Use RestAPI stub instead of real RestAPI requests")
var apiStub: Boolean? = false
@@ -149,7 +148,7 @@ open class RustorePublishTask
)
val cli = RustorePublishCli(
- deployType = deployType,
+ publishType = publishType,
credentialsPath = credentialsPath,
keyId = keyId,
clientSecret = clientSecret,
@@ -212,6 +211,7 @@ open class RustorePublishTask
token = token,
applicationId = config.applicationId,
whatsNew = config.releaseNotes?.first()?.newFeatures ?: "",
+ publishType = config.publishType.name,
)
logger.v("5/6. Upload build file '${config.artifactFile}'")
diff --git a/plugin/src/main/kotlin/ru/cian/rustore/publish/models/request/AppDraftRequest.kt b/plugin/src/main/kotlin/ru/cian/rustore/publish/models/request/AppDraftRequest.kt
index f252c7d..dff3249 100644
--- a/plugin/src/main/kotlin/ru/cian/rustore/publish/models/request/AppDraftRequest.kt
+++ b/plugin/src/main/kotlin/ru/cian/rustore/publish/models/request/AppDraftRequest.kt
@@ -5,4 +5,6 @@ import com.google.gson.annotations.SerializedName
internal data class AppDraftRequest(
@SerializedName("whatsNew")
val whatsNew: String,
+ @SerializedName("publishType")
+ val publishType: String,
)
diff --git a/plugin/src/main/kotlin/ru/cian/rustore/publish/service/RustoreService.kt b/plugin/src/main/kotlin/ru/cian/rustore/publish/service/RustoreService.kt
index 2f5c014..63eb63c 100644
--- a/plugin/src/main/kotlin/ru/cian/rustore/publish/service/RustoreService.kt
+++ b/plugin/src/main/kotlin/ru/cian/rustore/publish/service/RustoreService.kt
@@ -18,6 +18,7 @@ internal interface RustoreService {
token: String,
applicationId: String,
whatsNew: String,
+ publishType: String,
): Int
@Suppress("LongParameterList")
diff --git a/plugin/src/main/kotlin/ru/cian/rustore/publish/service/RustoreServiceImpl.kt b/plugin/src/main/kotlin/ru/cian/rustore/publish/service/RustoreServiceImpl.kt
index c1c7cdb..21ef5a5 100644
--- a/plugin/src/main/kotlin/ru/cian/rustore/publish/service/RustoreServiceImpl.kt
+++ b/plugin/src/main/kotlin/ru/cian/rustore/publish/service/RustoreServiceImpl.kt
@@ -61,9 +61,11 @@ internal class RustoreServiceImpl(
token: String,
applicationId: String,
whatsNew: String,
+ publishType: String,
): Int {
val bodyRequest = AppDraftRequest(
whatsNew = whatsNew,
+ publishType = publishType,
)
logger.i("""
@@ -72,7 +74,8 @@ internal class RustoreServiceImpl(
--header 'Content-Type: application/json' \
--header 'Public-Token: $token' \
--data-raw '{
- "whatsNew": "$whatsNew"
+ "whatsNew": "$whatsNew",
+ "publishType": "$publishType"
}'
""".trimIndent())
@@ -111,10 +114,11 @@ internal class RustoreServiceImpl(
token = token,
applicationId = applicationId,
whatsNew = whatsNew,
+ publishType = publishType,
)
}
- logger.v("response=$response")
+ logger.i("response=$response")
return response.body
}
@@ -180,7 +184,7 @@ internal class RustoreServiceImpl(
headers = headers
)
- logger.v("response=$response")
+ logger.i("response=$response")
check(response.code == "OK") {
"Build file uploading is failed! " +
@@ -234,7 +238,7 @@ internal class RustoreServiceImpl(
),
)
- logger.v("response=$response")
+ logger.i("response=$response")
return response.code == "OK"
}
diff --git a/plugin/src/main/kotlin/ru/cian/rustore/publish/utils/ConfigProvider.kt b/plugin/src/main/kotlin/ru/cian/rustore/publish/utils/ConfigProvider.kt
index 2deb964..2de2463 100644
--- a/plugin/src/main/kotlin/ru/cian/rustore/publish/utils/ConfigProvider.kt
+++ b/plugin/src/main/kotlin/ru/cian/rustore/publish/utils/ConfigProvider.kt
@@ -22,7 +22,7 @@ internal class ConfigProvider(
val requestTimeout = cli.requestTimeout?.toLongOrNull() ?: extension.requestTimeout
val mobileServicesType = cli.mobileServicesType ?: extension.mobileServicesType
- val deployType = cli.deployType ?: extension.deployType
+ val publishType = cli.publishType ?: extension.publishType
val artifactFormat = cli.buildFormat ?: extension.buildFormat
val customBuildFilePath: String? = cli.buildFile ?: extension.buildFile
val releaseTime: String? = cli.releaseTime ?: extension.releaseTime
@@ -44,7 +44,7 @@ internal class ConfigProvider(
return PluginConfig(
credentials = credentialsConfig,
- deployType = deployType,
+ publishType = publishType,
requestTimeout = requestTimeout,
mobileServicesType = mobileServicesType,
artifactFormat = actualArtifactFormat,
diff --git a/plugin/src/test/kotlin/ru/cian/rustore/publish/utils/ConfigProviderTest.kt b/plugin/src/test/kotlin/ru/cian/rustore/publish/utils/ConfigProviderTest.kt
index 7605cbb..83d9a91 100644
--- a/plugin/src/test/kotlin/ru/cian/rustore/publish/utils/ConfigProviderTest.kt
+++ b/plugin/src/test/kotlin/ru/cian/rustore/publish/utils/ConfigProviderTest.kt
@@ -15,7 +15,7 @@ import org.junit.jupiter.api.Test
import org.junit.jupiter.api.TestInstance
import ru.cian.rustore.publish.BuildFormat
import ru.cian.rustore.publish.Credentials
-import ru.cian.rustore.publish.DeployType
+import ru.cian.rustore.publish.PublishType
import ru.cian.rustore.publish.RustorePublishCli
import ru.cian.rustore.publish.PluginConfig
import ru.cian.rustore.publish.MobileServicesType
@@ -134,7 +134,7 @@ internal class ConfigProviderTest {
val expectedConfig = PluginConfig(
credentials = Credentials("id", "secret"),
- deployType = DeployType.PUBLISH,
+ publishType = PublishType.INSTANTLY,
artifactFormat = BuildFormat.APK,
requestTimeout = null,
mobileServicesType = MobileServicesType.UNKNOWN,
@@ -182,7 +182,7 @@ internal class ConfigProviderTest {
val expectedConfig = PluginConfig(
credentials = Credentials("id123", "secret123"),
- deployType = DeployType.DRAFT,
+ publishType = PublishType.MANUAL,
artifactFormat = BuildFormat.AAB,
artifactFile = File(ARTIFACT_AAB_FILE_SECOND_PATH),
requestTimeout = 234_567L,
@@ -197,7 +197,7 @@ internal class ConfigProviderTest {
val inputExtensionConfig = extensionConfigInstance().apply {
credentialsPath = CREDENTIALS_FILE_PATH
- deployType = DeployType.PUBLISH
+ publishType = PublishType.INSTANTLY
buildFormat = BuildFormat.APK
requestTimeout = 123_456L
buildFile = ARTIFACT_APK_FILE_PATH
@@ -207,7 +207,7 @@ internal class ConfigProviderTest {
}
}
val inputCliConfig = RustorePublishCli(
- deployType = DeployType.DRAFT,
+ publishType = PublishType.MANUAL,
credentialsPath = CREDENTIALS_FILE_SECOND_PATH,
keyId = "id123",
clientSecret = "secret123",
@@ -236,7 +236,7 @@ internal class ConfigProviderTest {
val expectedConfig = PluginConfig(
credentials = Credentials("id", "secret"),
- deployType = DeployType.PUBLISH,
+ publishType = PublishType.INSTANTLY,
artifactFormat = BuildFormat.APK,
requestTimeout = null,
mobileServicesType = MobileServicesType.UNKNOWN,
@@ -249,7 +249,7 @@ internal class ConfigProviderTest {
tableOf("expectedValue", "actualValue")
.row(
- expectedConfig.copy(deployType = DeployType.PUBLISH),
+ expectedConfig.copy(publishType = PublishType.INSTANTLY),
ConfigProvider(
extension = extensionConfigInstance(),
cli = RustorePublishCli(),
@@ -259,10 +259,10 @@ internal class ConfigProviderTest {
)
)
.row(
- expectedConfig.copy(deployType = DeployType.DRAFT),
+ expectedConfig.copy(publishType = PublishType.MANUAL),
ConfigProvider(
extension = extensionConfigInstance().apply {
- deployType = DeployType.DRAFT
+ publishType = PublishType.MANUAL
},
cli = RustorePublishCli(),
buildFileProvider = buildFileProvider,
@@ -271,10 +271,10 @@ internal class ConfigProviderTest {
)
)
.row(
- expectedConfig.copy(deployType = DeployType.UPLOAD_ONLY),
+ expectedConfig.copy(publishType = PublishType.MANUAL),
ConfigProvider(
extension = extensionConfigInstance().apply {
- deployType = DeployType.UPLOAD_ONLY
+ publishType = PublishType.MANUAL
},
cli = RustorePublishCli(),
buildFileProvider = buildFileProvider,
@@ -283,13 +283,13 @@ internal class ConfigProviderTest {
)
)
.row(
- expectedConfig.copy(deployType = DeployType.DRAFT),
+ expectedConfig.copy(publishType = PublishType.INSTANTLY),
ConfigProvider(
extension = extensionConfigInstance().apply {
- deployType = DeployType.DRAFT
+ publishType = PublishType.INSTANTLY
},
cli = RustorePublishCli(
- deployType = null
+ publishType = null
),
buildFileProvider = buildFileProvider,
releaseNotesFileProvider = releaseNotesFileProvider,
@@ -297,13 +297,13 @@ internal class ConfigProviderTest {
)
)
.row(
- expectedConfig.copy(deployType = DeployType.UPLOAD_ONLY),
+ expectedConfig.copy(publishType = PublishType.MANUAL),
ConfigProvider(
extension = extensionConfigInstance().apply {
- deployType = DeployType.DRAFT
+ publishType = PublishType.INSTANTLY
},
cli = RustorePublishCli(
- deployType = DeployType.UPLOAD_ONLY
+ publishType = PublishType.MANUAL
),
buildFileProvider = buildFileProvider,
releaseNotesFileProvider = releaseNotesFileProvider,
@@ -334,7 +334,7 @@ internal class ConfigProviderTest {
fun `correct config with overriding release notes`() {
val expectedConfig = PluginConfig(
credentials = Credentials(keyId = "id", clientSecret = "secret"),
- deployType = DeployType.PUBLISH,
+ publishType = PublishType.INSTANTLY,
artifactFormat = BuildFormat.APK,
requestTimeout = null,
mobileServicesType = MobileServicesType.UNKNOWN,
diff --git a/sample-groovy/rustore-credentials-1.json b/sample-groovy/rustore-credentials-1.json
index 2240bee..024349b 100644
--- a/sample-groovy/rustore-credentials-1.json
+++ b/sample-groovy/rustore-credentials-1.json
@@ -1,4 +1,4 @@
{
- "key_id": "",
+ "key_id": "SAMPLE_KEY_ID",
"client_secret": "MIICWwIBAAKBgGjxhEWEQR4auTTG7Cj5OT72DAqJFW71/GC+P0XTUG1jBpghndcriUsgZ2YW7u0FgvjA5gpcgjpmKoGTz++emB4LUL8xt8LcbsurMFdDI4ak3FiS49+BHVjXnfw44Payrgc4vSYZUZuJpjI3n3PnQLhAXBzwjGJrUz4NP94m6JtTAgMBAAECgYAI+NUJKHR0wW4iH/uiySPmyRxgbjXh5a/tCXbZXmaa44N10DHxamxzetK8PKuyoez/nWZNbnlHyuJJb7ywTMvOcZQohtDSglvIm9FwbwJ32KTJDZpJj1cKPJwr0NuQf1iBDh5OoOtu6QOZnuYzYqPREb0pSAAKMCv7uJKU4S4OQQJBALY4TuCTxRttoxe3sulhtftwqaKt847inQKmeWhC9BNp3OEU62GL3cUjnoy60Fb1SZvGqidHryEN/XFfKNp21WECQQCTbz6bjagrLJxq/OcJh7/621FBqPYPiO2mWDeETEFEV+5HDiETVPySF0SlpZ6i7Udetqn43MsKBdb+jc5kqbkzAkA3szShP2pT/QqKmHOPFXgsWP7xpFy8A5ddFQgtj7HOMWD8SIm+8qMivMWdXQmMW0RZ4rtmcGofH4imXCE/zm1hAkAClSRHnUeg2fszdJKnfBVE06qst8T3qLJhA5KVYrCR/ehSnlC+AfMarAWr0SbiO73QTurTTSrRViDZ/Kns4Xw5AkEApWKMhxzGZ9t/ejwToCMoppfYsc8a2nueNIsPLGA0E5yCXiIs9WoAdkfN4wQHnkJdAeTg4ahQp293Om+sjqrEJQ=="
}
\ No newline at end of file
diff --git a/sample-groovy/rustore-credentials-2.json b/sample-groovy/rustore-credentials-2.json
index 811dc4c..e1c3fdd 100644
--- a/sample-groovy/rustore-credentials-2.json
+++ b/sample-groovy/rustore-credentials-2.json
@@ -1,4 +1,4 @@
{
- "key_id": "",
+ "key_id": "SAMPLE_KEY_ID",
"client_secret": "MIICXwIBAAKBgQCd15t5ksUK09BXtG0V0otnJE8WGkEOFBOIzxwwVTs7371K798ebT18aLvxxcxIacxsh1zU/n1en2GeemkQ0MaIMit6rUWmtxka5Sa9isfDmCA4LATHXev0rw2kOxUajEhcUhM+UGdh4B0ECpRQga5WUlkAo3/+2U+ZnVmInc3CpwIDAQABAoGBAJKXpbu5ResSYVKzLQSxb+qw3AqJA5ZRqvrKb0GsRsEKwMESGkQl7I7YroSS0XEHYWYCKYNff4wbtgv7YAzP+TEVxRJRbvdRPI+Y+UH3nUHaY4ZAMWIqX86wibWiJFMKANJzm+ThMPQcvr/3LChXLm3FA/39E9E0pgAWcUIlLM5BAkEA7eaudUT5l7XH8tOL2m71Fs9MDtBq4aaFpzRAkLon2+ivnO0v6exoaQs4w9g0+DuvegnqQCXcIIpQhfhnsee0sQJBAKnZtq6fRX7L5+pOCJwaSHiYdoiPG4m6/F/twPzo+Exflq7ylw5KXWq1ceqzDvJxNZStl1aeBMX7D1D+0wztotcCQQDqUIvCGxaOU0/FnpCfqyugtLof2S18ZQw83F0/buq1USAuuvq3Ns67r37QflHlsLurwrpDRkbikfivizNu6V1xAkEAirjMIXbn9ZVoRs+Q7J3yzrwHI6VuImFbuqWeV3GXShlQInbztLI79elXrw6riIu57UKSNiY9U82nRsm5afe0ZQJBAJYy5khRJ9Rboj1a0MwQGKgiJ3+orIJDLeGyC2jkDMFDwTGFF+AWmh7IleyXG4+qB40XtvPQg21fGk495ANT9ZU="
}
\ No newline at end of file
diff --git a/sample-kotlin/rustore-credentials.json b/sample-kotlin/rustore-credentials.json
index 7a63e19..3eed052 100644
--- a/sample-kotlin/rustore-credentials.json
+++ b/sample-kotlin/rustore-credentials.json
@@ -1,4 +1,4 @@
{
- "key_id": "",
+ "key_id": "SAMPLE_KEY_ID",
"client_secret": "MIICXAIBAAKBgQCO4cLoi9XIRs4Yl8Zjgx4pnD2jEMmre1JesPwzD1Orj9sZC+3zPsoHC0H2puL3HchV2YjTPwhFuTB9x33hFcz45/wnHslUSzBT+wFqLiYdkBLyCbVBitzrUiDtHW4/zoVWsfNinKt0yIHvpbfLnzz2KPMOGiGTlHR6koAcZBPdMQIDAQABAoGAC0n3FlyGBY7ilbrYJ+CiL3Nyw0F+TZgux+B/7KDXYYS6MN5qbH+Xgrr2+T/ySsgFnhLT5qziQHADTszGO1R3n0uxAANnU+e1dTJLG/bd/PTAm79XK3rsrJCsge442QqMxBkbdWFFMkCBNWwPr9Zw0Eb+uJd1Cpo77bTMTxer7EkCQQD2lxR1xMaa7mISa831GSx8PnxBAw7cRZik3QvRfdpD4DEjhWRicXMhPSoKtCVBqf4Fkh7L0m1rj60ys13zK9R7AkEAlFWQN7vpMzS/yeqiWsVchfV2FUhbHoP3vVRc9ZQUSsc6bSEKWoglKoJHXzxpcv+zn7hdcwMCNAp6ehngKPhzQwJAK0gDSFR8g48Z2Z/ga4e6nigdiQ+vWQxCKZW+0Etltwovtctg/kJpcckZiv1pmKfstS+bhizuFbYHMWH4OIlV5wJAMAv3BtaLFtcDOHgT1qsO6SU09nfVa/D7Egx9f95TJFWcCzUkkWaAA2DnlWWQEnvYxueE/XgAArNSMLKo9Rxk2QJBAM13tMCAJMe/ebG0iNn9sCijJueTJh12aOUkaq8LaxRd9MMral3Z9SiLhzE2RlKkzInm6lmRFXikZW1/Aeo6Uq4="
}
\ No newline at end of file