import java.util.Properties plugins { alias(libs.plugins.android.application) alias(libs.plugins.kotlin.android) alias(libs.plugins.kotlin.compose) alias(libs.plugins.kotlin.serialization) alias(libs.plugins.ksp) alias(libs.plugins.hilt) } // Релизная подпись: пароли/путь к keystore — в keystore.properties (в .gitignore). val keystorePropsFile = rootProject.file("keystore.properties") val keystoreProps = Properties().apply { if (keystorePropsFile.exists()) keystorePropsFile.inputStream().use { load(it) } } android { namespace = "com.radiola" compileSdk = 34 defaultConfig { applicationId = "com.radiola" minSdk = 26 targetSdk = 34 versionCode = 9 versionName = "1.8" testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner" vectorDrawables { useSupportLibrary = true } } signingConfigs { create("release") { if (keystorePropsFile.exists()) { storeFile = rootProject.file(keystoreProps.getProperty("storeFile")) storePassword = keystoreProps.getProperty("storePassword") keyAlias = keystoreProps.getProperty("keyAlias") keyPassword = keystoreProps.getProperty("keyPassword") } } } buildTypes { release { signingConfig = signingConfigs.getByName("release") isMinifyEnabled = false proguardFiles( getDefaultProguardFile("proguard-android-optimize.txt"), "proguard-rules.pro" ) } } // Каналы дистрибуции: store — для RuStore (без авто-апдейтера, без dev-тестера // и кнопки SOVA); sideload — прямой APK с авто-обновлением. flavorDimensions += "distribution" productFlavors { create("store") { dimension = "distribution" buildConfigField("boolean", "ENABLE_SELF_UPDATE", "false") buildConfigField("boolean", "SHOW_DEV_TOOLS", "false") } create("sideload") { dimension = "distribution" buildConfigField("boolean", "ENABLE_SELF_UPDATE", "true") buildConfigField("boolean", "SHOW_DEV_TOOLS", "true") } } compileOptions { sourceCompatibility = JavaVersion.VERSION_17 targetCompatibility = JavaVersion.VERSION_17 } kotlinOptions { jvmTarget = "17" } buildFeatures { compose = true buildConfig = true } composeOptions { kotlinCompilerExtensionVersion = "1.5.14" } packaging { resources { excludes += "/META-INF/{AL2.0,LGPL2.1}" } } testOptions { unitTests { isReturnDefaultValues = true isIncludeAndroidResources = true } } } dependencies { implementation(libs.androidx.core.ktx) implementation(libs.androidx.core.splashscreen) implementation(libs.androidx.lifecycle.runtime.ktx) implementation(libs.androidx.lifecycle.viewmodel.compose) implementation(libs.androidx.activity.compose) implementation(platform(libs.androidx.compose.bom)) implementation(libs.androidx.ui) implementation(libs.androidx.ui.graphics) implementation(libs.androidx.ui.tooling.preview) implementation(libs.androidx.material3) implementation(libs.androidx.navigation.compose) implementation(libs.androidx.hilt.navigation.compose) implementation(libs.hilt.android) ksp(libs.hilt.compiler) androidTestImplementation(libs.hilt.android.testing) kspAndroidTest(libs.hilt.compiler) implementation(libs.retrofit) implementation(libs.retrofit.converter.kotlinx.serialization) implementation(libs.kotlinx.serialization.json) implementation(libs.okhttp.logging) implementation(libs.room.runtime) implementation(libs.room.ktx) ksp(libs.room.compiler) testImplementation(libs.room.testing) implementation(libs.datastore.preferences) implementation(libs.media3.exoplayer) implementation(libs.media3.exoplayer.hls) implementation(libs.media3.session) implementation(libs.coil.compose) implementation(libs.lucide) implementation(libs.socket.io.client) testImplementation(libs.junit) testImplementation(libs.mockk) testImplementation(libs.turbine) testImplementation(libs.kotlinx.coroutines.test) androidTestImplementation(libs.androidx.junit) androidTestImplementation(libs.androidx.espresso.core) androidTestImplementation(platform(libs.androidx.compose.bom)) androidTestImplementation(libs.androidx.ui.test.junit4) debugImplementation(libs.androidx.ui.tooling) debugImplementation(libs.androidx.ui.test.manifest) }