mirror of
				https://github.com/InsanusMokrassar/TelegramBotAPI.git
				synced 2025-10-25 09:10:07 +00:00 
			
		
		
		
	
							
								
								
									
										10
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,5 +1,15 @@ | |||||||
| # TelegramBotAPI changelog | # TelegramBotAPI changelog | ||||||
|  |  | ||||||
|  | ## 1.1.1 | ||||||
|  |  | ||||||
|  | * `Versions`: | ||||||
|  |     * `MicroUtils.Crypto` will not be provided with that library anymore. Instead, it is recommended to use `Korlibs.Krypto`. You still can add crypto from microutils using next groovy dependency: `dev.inmo:micro_utils.crypto:$micro_utils_version` | ||||||
|  | * `Core`: | ||||||
|  |     * Improvements in `TelegramAPIUrlsKeeper#checkWebAppLink` | ||||||
|  |     * New field in `TelegramAPIUrlsKeeper#webAppDataSecretKeyHash` | ||||||
|  | * `Behaviour Builder`: | ||||||
|  |     * Extension `TelegramBot#buildBehaviour` now returns `BehaviourContext` | ||||||
|  |  | ||||||
| ## 1.1.0 | ## 1.1.0 | ||||||
|  |  | ||||||
| * `Utils`: | * `Utils`: | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ kotlin.incremental.js=true | |||||||
| kotlin_version=1.6.21 | kotlin_version=1.6.21 | ||||||
| kotlin_coroutines_version=1.6.1 | kotlin_coroutines_version=1.6.1 | ||||||
| kotlin_serialisation_runtime_version=1.3.3 | kotlin_serialisation_runtime_version=1.3.3 | ||||||
| klock_version=2.7.0 | korlibs_version=2.7.0 | ||||||
| uuid_version=0.4.0 | uuid_version=0.4.0 | ||||||
| ktor_version=2.0.1 | ktor_version=2.0.1 | ||||||
|  |  | ||||||
| @@ -20,6 +20,6 @@ javax_activation_version=1.1.1 | |||||||
| dokka_version=1.6.21 | dokka_version=1.6.21 | ||||||
|  |  | ||||||
| library_group=dev.inmo | library_group=dev.inmo | ||||||
| library_version=1.1.0 | library_version=1.1.1 | ||||||
|  |  | ||||||
| github_release_plugin_version=2.3.7 | github_release_plugin_version=2.3.7 | ||||||
|   | |||||||
| @@ -7,8 +7,7 @@ import dev.inmo.tgbotapi.extensions.utils.updates.retrieving.longPolling | |||||||
| import dev.inmo.tgbotapi.extensions.utils.updates.retrieving.startGettingOfUpdatesByLongPolling | import dev.inmo.tgbotapi.extensions.utils.updates.retrieving.startGettingOfUpdatesByLongPolling | ||||||
| import dev.inmo.tgbotapi.updateshandlers.FlowsUpdatesFilter | import dev.inmo.tgbotapi.updateshandlers.FlowsUpdatesFilter | ||||||
| import dev.inmo.tgbotapi.utils.PreviewFeature | import dev.inmo.tgbotapi.utils.PreviewFeature | ||||||
| import kotlinx.coroutines.CoroutineScope | import kotlinx.coroutines.* | ||||||
| import kotlinx.coroutines.plus |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * This function is used in [buildBehaviour] extensions to provide default [CoroutineScope] and allow to avoid all |  * This function is used in [buildBehaviour] extensions to provide default [CoroutineScope] and allow to avoid all | ||||||
| @@ -30,18 +29,18 @@ suspend fun TelegramBot.buildBehaviour( | |||||||
|     scope: CoroutineScope = defaultCoroutineScopeProvider(), |     scope: CoroutineScope = defaultCoroutineScopeProvider(), | ||||||
|     defaultExceptionsHandler: ExceptionHandler<Unit>? = null, |     defaultExceptionsHandler: ExceptionHandler<Unit>? = null, | ||||||
|     block: BehaviourContextReceiver<Unit> |     block: BehaviourContextReceiver<Unit> | ||||||
| ) { | ): BehaviourContext = BehaviourContext( | ||||||
|     BehaviourContext( |     this, | ||||||
|         this, |     scope.let { | ||||||
|         scope.let { |           if (defaultExceptionsHandler == null) { | ||||||
|               if (defaultExceptionsHandler == null) { |               it | ||||||
|                   it |           } else { | ||||||
|               } else { |               it + ContextSafelyExceptionHandler(defaultExceptionsHandler) | ||||||
|                   it + ContextSafelyExceptionHandler(defaultExceptionsHandler) |           } | ||||||
|               } |     }, | ||||||
|         }, |     flowUpdatesFilter | ||||||
|         flowUpdatesFilter | ).apply { | ||||||
|     ).block() |     block() | ||||||
| } | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -56,15 +55,14 @@ suspend fun TelegramBot.buildBehaviourWithLongPolling( | |||||||
|     scope: CoroutineScope = defaultCoroutineScopeProvider(), |     scope: CoroutineScope = defaultCoroutineScopeProvider(), | ||||||
|     defaultExceptionsHandler: ExceptionHandler<Unit>? = null, |     defaultExceptionsHandler: ExceptionHandler<Unit>? = null, | ||||||
|     block: BehaviourContextReceiver<Unit> |     block: BehaviourContextReceiver<Unit> | ||||||
| ) = FlowsUpdatesFilter().let { | ): Job { | ||||||
|     buildBehaviour( |     val behaviourContext = buildBehaviour( | ||||||
|         it, |         scope = scope, | ||||||
|         scope, |         defaultExceptionsHandler = defaultExceptionsHandler, | ||||||
|         defaultExceptionsHandler, |         block = block | ||||||
|         block |  | ||||||
|     ) |     ) | ||||||
|     longPolling( |     return longPolling( | ||||||
|         it, |         behaviourContext, | ||||||
|         scope = scope |         scope = behaviourContext | ||||||
|     ) |     ) | ||||||
| } | } | ||||||
|   | |||||||
| @@ -47,10 +47,10 @@ kotlin { | |||||||
|                 api "org.jetbrains.kotlinx:kotlinx-serialization-json:$kotlin_serialisation_runtime_version" |                 api "org.jetbrains.kotlinx:kotlinx-serialization-json:$kotlin_serialisation_runtime_version" | ||||||
|                 api "org.jetbrains.kotlinx:kotlinx-serialization-properties:$kotlin_serialisation_runtime_version" |                 api "org.jetbrains.kotlinx:kotlinx-serialization-properties:$kotlin_serialisation_runtime_version" | ||||||
|  |  | ||||||
|                 api "com.soywiz.korlibs.klock:klock:$klock_version" |                 api "com.soywiz.korlibs.klock:klock:$korlibs_version" | ||||||
|  |                 api "com.soywiz.korlibs.krypto:krypto:$korlibs_version" | ||||||
|                 api "com.benasher44:uuid:$uuid_version" |                 api "com.benasher44:uuid:$uuid_version" | ||||||
|  |  | ||||||
|                 api "dev.inmo:micro_utils.crypto:$micro_utils_version" |  | ||||||
|                 api "dev.inmo:micro_utils.coroutines:$micro_utils_version" |                 api "dev.inmo:micro_utils.coroutines:$micro_utils_version" | ||||||
|                 api "dev.inmo:micro_utils.serialization.base64:$micro_utils_version" |                 api "dev.inmo:micro_utils.serialization.base64:$micro_utils_version" | ||||||
|                 api "dev.inmo:micro_utils.serialization.encapsulator:$micro_utils_version" |                 api "dev.inmo:micro_utils.serialization.encapsulator:$micro_utils_version" | ||||||
|   | |||||||
| @@ -1,7 +1,8 @@ | |||||||
| package dev.inmo.tgbotapi.utils | package dev.inmo.tgbotapi.utils | ||||||
|  |  | ||||||
| import dev.inmo.micro_utils.crypto.hex | import com.soywiz.krypto.* | ||||||
| import dev.inmo.micro_utils.crypto.hmacSha256 | import io.ktor.http.decodeURLQueryComponent | ||||||
|  | import io.ktor.utils.io.core.toByteArray | ||||||
|  |  | ||||||
| const val telegramBotAPIDefaultUrl = "https://api.telegram.org" | const val telegramBotAPIDefaultUrl = "https://api.telegram.org" | ||||||
|  |  | ||||||
| @@ -22,9 +23,11 @@ class TelegramAPIUrlsKeeper( | |||||||
|     hostUrl: String = telegramBotAPIDefaultUrl, |     hostUrl: String = telegramBotAPIDefaultUrl, | ||||||
|     urlsSuffixes: String = "" |     urlsSuffixes: String = "" | ||||||
| ) { | ) { | ||||||
|     val webAppDataSecretKey by lazy { |     val webAppDataSecretKeyHash by lazy { | ||||||
|         token.hmacSha256("WebAppData") |         HMAC.hmacSHA256("WebAppData".toByteArray(), token.toByteArray()) | ||||||
|     } |     } | ||||||
|  |     val webAppDataSecretKey | ||||||
|  |         get() = webAppDataSecretKeyHash.hexLower | ||||||
|  |  | ||||||
|     val commonAPIUrl: String |     val commonAPIUrl: String | ||||||
|     val fileBaseUrl: String |     val fileBaseUrl: String | ||||||
| @@ -47,5 +50,14 @@ class TelegramAPIUrlsKeeper( | |||||||
|      * @param rawData Data from [dev.inmo.tgbotapi.webapps.WebApp.initData] |      * @param rawData Data from [dev.inmo.tgbotapi.webapps.WebApp.initData] | ||||||
|      * @param hash Data from [dev.inmo.tgbotapi.webapps.WebApp.initDataUnsafe] from the field [dev.inmo.tgbotapi.webapps.WebAppInitData.hash] |      * @param hash Data from [dev.inmo.tgbotapi.webapps.WebApp.initDataUnsafe] from the field [dev.inmo.tgbotapi.webapps.WebAppInitData.hash] | ||||||
|      */ |      */ | ||||||
|     fun checkWebAppLink(rawData: String, hash: String) = rawData.hmacSha256(webAppDataSecretKey).hex() == hash |     fun checkWebAppLink(rawData: String, hash: String): Boolean { | ||||||
|  |         val preparedData = rawData | ||||||
|  |             .decodeURLQueryComponent() | ||||||
|  |             .split("&") | ||||||
|  |             .filterNot { it.startsWith("hash=") } | ||||||
|  |             .sorted() | ||||||
|  |             .joinToString("\n") | ||||||
|  |  | ||||||
|  |         return HMAC.hmacSHA256(webAppDataSecretKeyHash.bytes, preparedData.toByteArray()).hexLower == hash.lowercase() | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -2,6 +2,8 @@ package dev.inmo.tgbotapi.webapps | |||||||
|  |  | ||||||
| import dev.inmo.micro_utils.crypto.CryptoJs | import dev.inmo.micro_utils.crypto.CryptoJs | ||||||
|  |  | ||||||
|  | @Deprecated("Useless") | ||||||
| fun CryptoJs.HmacSHA256(text: String, key: String) = this.asDynamic().HmacSHA256(text, key).unsafeCast<String>() | fun CryptoJs.HmacSHA256(text: String, key: String) = this.asDynamic().HmacSHA256(text, key).unsafeCast<String>() | ||||||
|  |  | ||||||
|  | @Deprecated("Useless") | ||||||
| fun CryptoJs.hex(text: String) = this.asDynamic().format.Hex(text).unsafeCast<String>() | fun CryptoJs.hex(text: String) = this.asDynamic().format.Hex(text).unsafeCast<String>() | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user