mirror of
				https://github.com/InsanusMokrassar/TelegramBotAPI.git
				synced 2025-10-25 17:20:07 +00:00 
			
		
		
		
	
							
								
								
									
										30
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -38,6 +38,36 @@ | |||||||
|     and size of retrieved updates is equal to 100 (max count of retrieved updates) |     and size of retrieved updates is equal to 100 (max count of retrieved updates) | ||||||
|     * Extensions `getUpdates` now will receive only not nullable `limit` parameter |     * Extensions `getUpdates` now will receive only not nullable `limit` parameter | ||||||
|  |  | ||||||
|  | ### 0.26.2 | ||||||
|  |  | ||||||
|  | * `TelegramBotAPI`: | ||||||
|  |     * Now `EditMediaGroupUpdate` also extends `BaseEditMessageUpdate` | ||||||
|  |     * **EXPERIMENTALLY** Now all `TextSource` realisations will contain `source` field as a property inside of them | ||||||
|  | * `TelegramBotAPI-extensions-api`: | ||||||
|  |     * `startGettingFlowsUpdates` extension which do not require filter (but return a new one) was added | ||||||
|  | * `TelegramBotAPI-extensions-utils`: | ||||||
|  |     * Subproject was added | ||||||
|  |     * `filterBaseMessageUpdates`, `filterSentMediaGroupUpdates` and `filterEditMediaGroupUpdates` extensions was added | ||||||
|  |     * `filterCommandsWithArgs`, `filterExactCommands` and `filterCommandsInsideTextMessages` extensions was added | ||||||
|  |     * `asContentMessagesFlow`, `asChatEventsFlow` and `asUnknownMessagesFlow` extensions was added | ||||||
|  |     * `withContentType` extension was added | ||||||
|  |         * `onlyAnimationContentMessages` extension was added | ||||||
|  |         * `onlyAudioContentMessages` extension was added | ||||||
|  |         * `onlyContactContentMessages` extension was added | ||||||
|  |         * `onlyDiceContentMessages` extension was added | ||||||
|  |         * `onlyDocumentContentMessages` extension was added | ||||||
|  |         * `onlyGameContentMessages` extension was added | ||||||
|  |         * `onlyInvoiceContentMessages` extension was added | ||||||
|  |         * `onlyLocationContentMessages` extension was added | ||||||
|  |         * `onlyPhotoContentMessages` extension was added | ||||||
|  |         * `onlyPollContentMessages` extension was added | ||||||
|  |         * `onlyStickerContentMessages` extension was added | ||||||
|  |         * `onlyTextContentMessages` extension was added | ||||||
|  |         * `onlyVenueContentMessages` extension was added | ||||||
|  |         * `onlyVideoContentMessages` extension was added | ||||||
|  |         * `onlyVideoNoteContentMessages` extension was added | ||||||
|  |         * `onlyVoiceContentMessages` extension was added | ||||||
|  |  | ||||||
| ### 0.26.1 | ### 0.26.1 | ||||||
|  |  | ||||||
| * `TelegramBotAPI`: | * `TelegramBotAPI`: | ||||||
|   | |||||||
							
								
								
									
										26
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,27 +1,35 @@ | |||||||
| # TelegramBotAPI | # TelegramBotAPI | ||||||
|  |  | ||||||
| | Common info                           | [](https://github.com/KotlinBy/awesome-kotlin) [](https://t.me/InMoTelegramBotAPI) [](https://travis-ci.com/InsanusMokrassar/TelegramBotAPI)                                                                                                                                                          | | | Common info                           | [](https://github.com/KotlinBy/awesome-kotlin) [](https://t.me/InMoTelegramBotAPI) [](https://travis-ci.com/InsanusMokrassar/TelegramBotAPI)                                                                                                                                                          | | ||||||
| | -----------:|:--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | | -------------------------------------:|:------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | | ||||||
| | TelegramBotAPI status                 | [](https://bintray.com/insanusmokrassar/StandardRepository/TelegramBotAPI/_latestVersion) [](https://maven-badges.herokuapp.com/maven-central/com.github.insanusmokrassar/TelegramBotAPI)                                                             | | | TelegramBotAPI status                 | [](https://bintray.com/insanusmokrassar/StandardRepository/TelegramBotAPI/_latestVersion) [](https://maven-badges.herokuapp.com/maven-central/com.github.insanusmokrassar/TelegramBotAPI)                                                             | | ||||||
| | TelegramBotAPI Extensions status      | [](https://bintray.com/insanusmokrassar/StandardRepository/TelegramBotAPI-extensions-api/_latestVersion) [](https://maven-badges.herokuapp.com/maven-central/com.github.insanusmokrassar/TelegramBotAPI-extensions-api) | | | TelegramBotAPI Extensions status      | [](https://bintray.com/insanusmokrassar/StandardRepository/TelegramBotAPI-extensions-api/_latestVersion) [](https://maven-badges.herokuapp.com/maven-central/com.github.insanusmokrassar/TelegramBotAPI-extensions-api) | | ||||||
|  | | TelegramBotAPI Util Extensions status | [](https://bintray.com/insanusmokrassar/StandardRepository/TelegramBotAPI-extensions-utils/_latestVersion) [](https://maven-badges.herokuapp.com/maven-central/com.github.insanusmokrassar/TelegramBotAPI-extensions-utils) | | ||||||
|  |  | ||||||
| It is a complex of libraries for working with `TelegramBotAPI` in type-safe and strict way as much as it possible. In | It is a complex of libraries for working with `TelegramBotAPI` in type-safe and strict way as much as it possible. In | ||||||
| the list of this complex currently next projects: | the list of this complex currently next projects: | ||||||
|  |  | ||||||
| * [TelegramBotAPI](TelegramBotAPI/README.md) - core of library. In fact it is independent library and can be used alone | * [TelegramBotAPI](TelegramBotAPI/README.md) - core of library. In fact it is independent library and can be used alone | ||||||
| without any additional library |   without any additional library | ||||||
| * [TelegramBotAPI Extensions](TelegramBotAPI-extensions-api/README.md) - contains extensions (mostly for | * [TelegramBotAPI Extensions](TelegramBotAPI-extensions-api/README.md) - contains extensions (mostly for | ||||||
| `RequestsExecutor`), which allows to use the core library in more pleasant way |   `RequestsExecutor`), which allows to use the core library in more pleasant way | ||||||
|  | * [TelegramBotAPI Util Extensions](TelegramBotAPI-extensions-utils/README.md) - contains extensions for more comfortable | ||||||
|  | work with commands, updates and other different things | ||||||
|  |  | ||||||
| Most part of some specific solves or unuseful | Most part of some specific solves or unuseful | ||||||
| moments are describing by official [Telegram Bot API](https://core.telegram.org/bots/api). | moments are describing by official [Telegram Bot API](https://core.telegram.org/bots/api). | ||||||
|  |  | ||||||
| ## Ok, where should I start? | ## Ok, where should I start? | ||||||
|  |  | ||||||
| Firstly, look at the [TelegramBotAPI](TelegramBotAPI/README.md). Here you can find all information about currently | In most cases, the most simple way will be to implement | ||||||
| covered Telegram Bot API and other things. After this you can look at the | [TelegramBotAPI Extensions](TelegramBotAPI-extensions-api/README.md) and | ||||||
| [TelegramBotAPI Extensions](TelegramBotAPI-extensions-api/README.md). | [TelegramBotAPI Util Extensions](TelegramBotAPI-extensions-utils/README.md) for the reason that they contains more | ||||||
|  | simple tools. If you want to dive deeper in the core of library or develop something for it - welcome to | ||||||
|  | [TelegramBotAPI](TelegramBotAPI/README.md). | ||||||
|  |  | ||||||
| Anyway, all libraries are very typical inside of them. For example, any request in TelegramBotAPI look like | Anyway, all libraries are very typical inside of them. Examples: | ||||||
| `requestsExecutor.execute(SomeRequest())`. |  | ||||||
|  | * In `TelegramBotAPI` common request look like `requestsExecutor.execute(SomeRequest())` | ||||||
|  | * `TelegramBotAPI-extensions-api` typical syntax look like `requestsExecutor.someRequest()` (in most cases it would be | ||||||
|  | better to understand to use `bot` name instead of `requestsExecutor`) | ||||||
|  | * `TelegramBotAPI-extensions-utils` will look like `filter.filterBaseMessageUpdates(chatId).filterExactCommands(Regex("^.*$"))...` | ||||||
|   | |||||||
| @@ -1,9 +1,7 @@ | |||||||
| # TelegramBotAPI extensions | # TelegramBotAPI extensions | ||||||
|  |  | ||||||
| [](https://github.com/KotlinBy/awesome-kotlin) |  | ||||||
| [ ](https://bintray.com/insanusmokrassar/StandardRepository/TelegramBotAPI-extensions-api/_latestVersion) | [ ](https://bintray.com/insanusmokrassar/StandardRepository/TelegramBotAPI-extensions-api/_latestVersion) | ||||||
| [](https://maven-badges.herokuapp.com/maven-central/com.github.insanusmokrassar/TelegramBotAPI-extensions-api) | [](https://maven-badges.herokuapp.com/maven-central/com.github.insanusmokrassar/TelegramBotAPI-extensions-api) | ||||||
| [](https://jenkins.insanusmokrassar.com/job/TelegramBotAPI-extensions-api_master__publishing/) |  | ||||||
|  |  | ||||||
| ## What is it? | ## What is it? | ||||||
|  |  | ||||||
| @@ -99,3 +97,21 @@ filter.messageFlow.mapNotNull { | |||||||
|     CoroutineScope(Dispatchers.Default) |     CoroutineScope(Dispatchers.Default) | ||||||
| ) | ) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | ### Alternative way | ||||||
|  |  | ||||||
|  | There is an alternative way to get updates. In fact it is almost the same, but could be more useful for some cases: | ||||||
|  |  | ||||||
|  | ```kotlin | ||||||
|  | val filter = bot.startGettingOfUpdates( | ||||||
|  |     scope = CoroutineScope(Dispatchers.Default) | ||||||
|  | ) { // Here as reveiver will be FlowsUpdatesFilter | ||||||
|  |     messageFlow.mapNotNull { | ||||||
|  |         it.data as? ContentMessage<*> | ||||||
|  |     }.onEach { | ||||||
|  |         println(it) | ||||||
|  |     }.launchIn( | ||||||
|  |         CoroutineScope(Dispatchers.Default) | ||||||
|  |     ) | ||||||
|  | } | ||||||
|  | ``` | ||||||
|   | |||||||
| @@ -10,6 +10,7 @@ import com.github.insanusmokrassar.TelegramBotAPI.types.update.* | |||||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.update.MediaGroupUpdates.* | import com.github.insanusmokrassar.TelegramBotAPI.types.update.MediaGroupUpdates.* | ||||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.update.abstracts.Update | import com.github.insanusmokrassar.TelegramBotAPI.types.update.abstracts.Update | ||||||
| import com.github.insanusmokrassar.TelegramBotAPI.updateshandlers.* | import com.github.insanusmokrassar.TelegramBotAPI.updateshandlers.* | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.utils.PreviewFeature | ||||||
| import io.ktor.client.features.HttpRequestTimeoutException | import io.ktor.client.features.HttpRequestTimeoutException | ||||||
| import kotlinx.coroutines.* | import kotlinx.coroutines.* | ||||||
|  |  | ||||||
| @@ -63,6 +64,24 @@ fun RequestsExecutor.startGettingOfUpdates( | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * This method will create a new one [FlowsUpdatesFilter]. This method could be unsafe due to the fact that it will start | ||||||
|  |  * getting updates IMMEDIATELY. That means that your bot will be able to skip some of them until you will call | ||||||
|  |  * [kotlinx.coroutines.flow.Flow.collect] on one of [FlowsUpdatesFilter] flows. To avoid it, you can pass | ||||||
|  |  * [flowUpdatesPreset] lambda - it will be called BEFORE starting updates getting | ||||||
|  |  */ | ||||||
|  | @PreviewFeature | ||||||
|  | fun RequestsExecutor.startGettingFlowsUpdates( | ||||||
|  |     timeoutSeconds: Seconds = 30, | ||||||
|  |     scope: CoroutineScope = CoroutineScope(Dispatchers.Default), | ||||||
|  |     exceptionsHandler: (suspend (Exception) -> Unit)? = null, | ||||||
|  |     flowsUpdatesFilterUpdatesKeeperCount: Int = 64, | ||||||
|  |     flowUpdatesPreset: FlowsUpdatesFilter.() -> Unit = {} | ||||||
|  | ): FlowsUpdatesFilter = FlowsUpdatesFilter(flowsUpdatesFilterUpdatesKeeperCount).apply { | ||||||
|  |     flowUpdatesPreset() | ||||||
|  |     startGettingOfUpdates(timeoutSeconds, scope, exceptionsHandler, allowedUpdates, asUpdateReceiver) | ||||||
|  | } | ||||||
|  |  | ||||||
| fun RequestsExecutor.startGettingOfUpdates( | fun RequestsExecutor.startGettingOfUpdates( | ||||||
|     updatesFilter: UpdatesFilter, |     updatesFilter: UpdatesFilter, | ||||||
|     timeoutSeconds: Seconds = 30, |     timeoutSeconds: Seconds = 30, | ||||||
|   | |||||||
							
								
								
									
										81
									
								
								TelegramBotAPI-extensions-utils/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										81
									
								
								TelegramBotAPI-extensions-utils/README.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,81 @@ | |||||||
|  | # TelegramBotAPI Util  Extensions | ||||||
|  |  | ||||||
|  | [ ](https://bintray.com/insanusmokrassar/StandardRepository/TelegramBotAPI-extensions-utils/_latestVersion) | ||||||
|  | [](https://maven-badges.herokuapp.com/maven-central/com.github.insanusmokrassar/TelegramBotAPI-extensions-utils) | ||||||
|  |  | ||||||
|  | ## What is it? | ||||||
|  |  | ||||||
|  | It is wrapper library for [TelegramBotAPI](../TelegramBotAPI/README.md). Currently, this library contains some usefull filters for commands, updates types and different others. | ||||||
|  |  | ||||||
|  | ## How to implement library? | ||||||
|  |  | ||||||
|  | Common ways to implement this library are presented here. In some cases it will require additional steps | ||||||
|  | like inserting of additional libraries (like `kotlin stdlib`). In the examples will be used variable | ||||||
|  | `telegrambotapi-extensions-utils_version`, which must be set up by developer. Available versions are presented on | ||||||
|  | [bintray](https://bintray.com/insanusmokrassar/StandardRepository/TelegramBotAPI-extensions-utils), next version is last published: | ||||||
|  |  | ||||||
|  | [ ](https://bintray.com/insanusmokrassar/StandardRepository/TelegramBotAPI-extensions-utils/_latestVersion) | ||||||
|  |  | ||||||
|  | ### Maven | ||||||
|  |  | ||||||
|  | Dependency config presented here: | ||||||
|  |  | ||||||
|  | ```xml | ||||||
|  | <dependency> | ||||||
|  |   <groupId>com.github.insanusmokrassar</groupId> | ||||||
|  |   <artifactId>TelegramBotAPI-extensions-utils</artifactId> | ||||||
|  |   <version>${telegrambotapi-extensions-utils_version}</version> | ||||||
|  | </dependency> | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### Gradle | ||||||
|  |  | ||||||
|  | To use last versions you will need to add one line in repositories block of your `build.gradle`: | ||||||
|  |  | ||||||
|  | `jcenter()` or `mavenCentral()` | ||||||
|  |  | ||||||
|  | And add next line to your dependencies block: | ||||||
|  |  | ||||||
|  | ```groovy | ||||||
|  | implementation "com.github.insanusmokrassar:TelegramBotAPI-extensions-utils:$telegrambotapi-extensions-utils_version" | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | or for old gradle: | ||||||
|  |  | ||||||
|  | ```groovy | ||||||
|  | compile "com.github.insanusmokrassar:TelegramBotAPI-extensions-utils:$telegrambotapi-extensions-utils_version" | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## How to use? | ||||||
|  |  | ||||||
|  | Here will be presented several examples of usage. In all cases it is expected that you have created your bot and filter: | ||||||
|  |  | ||||||
|  | ```kotlin | ||||||
|  | val bot: RequestsExecutor = KtorRequestsExecutor( | ||||||
|  |     TelegramAPIUrlsKeeper(BOT_TOKEN) | ||||||
|  | ) | ||||||
|  | val filter = FlowsUpdatesFilter(64) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Alternative way to use the things below: | ||||||
|  |  | ||||||
|  | ```kotlin | ||||||
|  | val filter = bot.startGettingUpdates( | ||||||
|  |     scope = CoroutineScope(Dispatchers.Default) | ||||||
|  | ) { | ||||||
|  |     // place code from examples here with replacing of `filter` by `this` | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### Getting of only text incoming messages | ||||||
|  |  | ||||||
|  | ```kotlin | ||||||
|  | filter.asContentMessagesFlow().onlyTextContentMessages().onEach { | ||||||
|  |     println(it.content) | ||||||
|  |     println(it.fullEntitiesList()) | ||||||
|  | }.launchIn( | ||||||
|  |     CoroutineScope(Dispatchers.Default) | ||||||
|  | ) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | As a result, each received message which will be just text message will be printed out with full list of its internal entities | ||||||
							
								
								
									
										48
									
								
								TelegramBotAPI-extensions-utils/build.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								TelegramBotAPI-extensions-utils/build.gradle
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,48 @@ | |||||||
|  | buildscript { | ||||||
|  |     repositories { | ||||||
|  |         mavenLocal() | ||||||
|  |         jcenter() | ||||||
|  |         mavenCentral() | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     dependencies { | ||||||
|  |         classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" | ||||||
|  |         classpath "org.jetbrains.kotlin:kotlin-serialization:$kotlin_version" | ||||||
|  |         classpath "com.jfrog.bintray.gradle:gradle-bintray-plugin:$gradle_bintray_plugin_version" | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | plugins { | ||||||
|  |     id "org.jetbrains.kotlin.multiplatform" version "$kotlin_version" | ||||||
|  |     id "org.jetbrains.kotlin.plugin.serialization" version "$kotlin_version" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | project.version = "$library_version" | ||||||
|  | project.group = "$library_group" | ||||||
|  |  | ||||||
|  | apply from: "publish.gradle" | ||||||
|  |  | ||||||
|  | repositories { | ||||||
|  |     mavenLocal() | ||||||
|  |     jcenter() | ||||||
|  |     mavenCentral() | ||||||
|  |     maven { url "https://kotlin.bintray.com/kotlinx" } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | kotlin { | ||||||
|  |     jvm() | ||||||
|  |     js() | ||||||
|  |  | ||||||
|  |     sourceSets { | ||||||
|  |         commonMain { | ||||||
|  |             dependencies { | ||||||
|  |                 implementation kotlin('stdlib') | ||||||
|  |                 if ((project.hasProperty('RELEASE_MODE') && project.property('RELEASE_MODE') == "true") || System.getenv('RELEASE_MODE') == "true") { | ||||||
|  |                     api "${project.group}:TelegramBotAPI:$library_version" | ||||||
|  |                 } else { | ||||||
|  |                     implementation project(":TelegramBotAPI") | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										57
									
								
								TelegramBotAPI-extensions-utils/maven.publish.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								TelegramBotAPI-extensions-utils/maven.publish.gradle
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,57 @@ | |||||||
|  | apply plugin: 'maven-publish' | ||||||
|  |  | ||||||
|  | task javadocsJar(type: Jar) { | ||||||
|  |     classifier = 'javadoc' | ||||||
|  | } | ||||||
|  |  | ||||||
|  | afterEvaluate { | ||||||
|  |     project.publishing.publications.all { | ||||||
|  |         // rename artifacts | ||||||
|  |         groupId "${project.group}" | ||||||
|  |         if (it.name.contains('kotlinMultiplatform')) { | ||||||
|  |             artifactId = "${project.name}" | ||||||
|  |         } else { | ||||||
|  |             artifactId = "${project.name}-$name" | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | publishing { | ||||||
|  |     publications.all { | ||||||
|  |         artifact javadocsJar | ||||||
|  |  | ||||||
|  |         pom.withXml { | ||||||
|  |             asNode().children().last() + { | ||||||
|  |                 resolveStrategy = Closure.DELEGATE_FIRST | ||||||
|  |  | ||||||
|  |                 description "Util extensions for more useful work with updates and other things" | ||||||
|  |                 name "Telegram Bot API Utility Extensions" | ||||||
|  |                 url "https://insanusmokrassar.github.io/TelegramBotAPI" | ||||||
|  |  | ||||||
|  |                 scm { | ||||||
|  |                     developerConnection "scm:git:[fetch=]https://github.com/insanusmokrassar/TelegramBotAPI.git[push=]https://github.com/insanusmokrassar/TelegramBotAPI.git" | ||||||
|  |                     url "https://github.com/insanusmokrassar/TelegramBotAPI.git" | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 developers { | ||||||
|  |                      | ||||||
|  |                         developer { | ||||||
|  |                             id "InsanusMokrassar" | ||||||
|  |                             name "Ovsiannikov Aleksei" | ||||||
|  |                             email "ovsyannikov.alexey95@gmail.com" | ||||||
|  |                         } | ||||||
|  |                      | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 licenses { | ||||||
|  |                      | ||||||
|  |                         license { | ||||||
|  |                             name "Apache Software License 2.0" | ||||||
|  |                             url "https://github.com/InsanusMokrassar/TelegramBotAPI/blob/master/LICENSE" | ||||||
|  |                         } | ||||||
|  |                      | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1 @@ | |||||||
|  | {"bintrayConfig":{"repo":"StandardRepository","packageName":"${project.name}","packageVcs":"https://github.com/InsanusMokrassar/TelegramBotAPI"},"licenses":[{"id":"Apache-2.0","title":"Apache Software License 2.0","url":"https://github.com/InsanusMokrassar/TelegramBotAPI/blob/master/LICENSE"}],"mavenConfig":{"name":"Telegram Bot API Utility Extensions","description":"Util extensions for more useful work with updates and other things","url":"https://insanusmokrassar.github.io/TelegramBotAPI","vcsUrl":"https://github.com/insanusmokrassar/TelegramBotAPI.git","developers":[{"id":"InsanusMokrassar","name":"Ovsiannikov Aleksei","eMail":"ovsyannikov.alexey95@gmail.com"}]},"type":"Multiplatform"} | ||||||
							
								
								
									
										55
									
								
								TelegramBotAPI-extensions-utils/publish.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								TelegramBotAPI-extensions-utils/publish.gradle
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | |||||||
|  | apply plugin: 'com.jfrog.bintray' | ||||||
|  |  | ||||||
|  | apply from: "maven.publish.gradle" | ||||||
|  |  | ||||||
|  | bintray { | ||||||
|  |     user = project.hasProperty('BINTRAY_USER') ? project.property('BINTRAY_USER') : System.getenv('BINTRAY_USER') | ||||||
|  |     key = project.hasProperty('BINTRAY_KEY') ? project.property('BINTRAY_KEY') : System.getenv('BINTRAY_KEY') | ||||||
|  |     filesSpec { | ||||||
|  |         from "${buildDir}/publications/" | ||||||
|  |         eachFile { | ||||||
|  |             String directorySubname = it.getFile().parentFile.name | ||||||
|  |             if (it.getName() == "module.json") { | ||||||
|  |                 if (directorySubname == "kotlinMultiplatform") { | ||||||
|  |                     it.setPath("${project.name}/${project.version}/${project.name}-${project.version}.module") | ||||||
|  |                 } else { | ||||||
|  |                     it.setPath("${project.name}-${directorySubname}/${project.version}/${project.name}-${directorySubname}-${project.version}.module") | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 if (directorySubname == "kotlinMultiplatform" && it.getName() == "pom-default.xml") { | ||||||
|  |                     it.setPath("${project.name}/${project.version}/${project.name}-${project.version}.pom") | ||||||
|  |                 } else { | ||||||
|  |                     it.exclude() | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         into "${project.group}".replace(".", "/") | ||||||
|  |     } | ||||||
|  |     pkg { | ||||||
|  |         repo = "StandardRepository" | ||||||
|  |         name = "${project.name}" | ||||||
|  |         vcsUrl = "https://github.com/InsanusMokrassar/TelegramBotAPI" | ||||||
|  |         licenses = ["Apache-2.0"] | ||||||
|  |         version { | ||||||
|  |             name = "${project.version}" | ||||||
|  |             released = new Date() | ||||||
|  |             vcsTag = "${project.version}" | ||||||
|  |             gpg { | ||||||
|  |                 sign = true | ||||||
|  |                 passphrase = project.hasProperty('signing.gnupg.passphrase') ? project.property('signing.gnupg.passphrase') : System.getenv('signing.gnupg.passphrase') | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bintrayUpload.doFirst { | ||||||
|  |     publications = publishing.publications.collect { | ||||||
|  |         if (it.name.contains('kotlinMultiplatform')) { | ||||||
|  |             null | ||||||
|  |         } else { | ||||||
|  |             it.name | ||||||
|  |         } | ||||||
|  |     } - null | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bintrayUpload.dependsOn publishToMavenLocal | ||||||
| @@ -0,0 +1,12 @@ | |||||||
|  | package com.github.insanusmokrassar.TelegramBotAPI.extensions.utils | ||||||
|  |  | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.CallbackQuery.* | ||||||
|  | import kotlinx.coroutines.flow.Flow | ||||||
|  | import kotlinx.coroutines.flow.mapNotNull | ||||||
|  |  | ||||||
|  | fun <T : CallbackQuery> Flow<T>.onlyMessageDataCallbackQueries() = mapNotNull { | ||||||
|  |     it as? MessageDataCallbackQuery | ||||||
|  | } | ||||||
|  | fun <T : CallbackQuery> Flow<T>.onlyInlineMessageIdDataCallbackQueries() = mapNotNull { | ||||||
|  |     it as? InlineMessageIdDataCallbackQuery | ||||||
|  | } | ||||||
| @@ -0,0 +1,36 @@ | |||||||
|  | package com.github.insanusmokrassar.TelegramBotAPI.extensions.utils | ||||||
|  |  | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.ContentMessage | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.message.content.* | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.message.content.abstracts.MessageContent | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.message.content.media.* | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.message.payments.InvoiceContent | ||||||
|  | import kotlinx.coroutines.flow.Flow | ||||||
|  | import kotlinx.coroutines.flow.mapNotNull | ||||||
|  | import kotlin.reflect.KClass | ||||||
|  |  | ||||||
|  | fun <T : MessageContent> Flow<ContentMessage<*>>.withContentType(contentType: KClass<T>) = mapNotNull { | ||||||
|  |     if (contentType.isInstance(it.content)) { | ||||||
|  |         @Suppress("UNCHECKED_CAST") | ||||||
|  |         it as ContentMessage<T> | ||||||
|  |     } else { | ||||||
|  |         null | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fun Flow<ContentMessage<*>>.onlyAnimationContentMessages() = withContentType(AnimationContent::class) | ||||||
|  | fun Flow<ContentMessage<*>>.onlyAudioContentMessages() = withContentType(AudioContent::class) | ||||||
|  | fun Flow<ContentMessage<*>>.onlyContactContentMessages() = withContentType(ContactContent::class) | ||||||
|  | fun Flow<ContentMessage<*>>.onlyDiceContentMessages() = withContentType(DiceContent::class) | ||||||
|  | fun Flow<ContentMessage<*>>.onlyDocumentContentMessages() = withContentType(DocumentContent::class) | ||||||
|  | fun Flow<ContentMessage<*>>.onlyGameContentMessages() = withContentType(GameContent::class) | ||||||
|  | fun Flow<ContentMessage<*>>.onlyInvoiceContentMessages() = withContentType(InvoiceContent::class) | ||||||
|  | fun Flow<ContentMessage<*>>.onlyLocationContentMessages() = withContentType(LocationContent::class) | ||||||
|  | fun Flow<ContentMessage<*>>.onlyPhotoContentMessages() = withContentType(PhotoContent::class) | ||||||
|  | fun Flow<ContentMessage<*>>.onlyPollContentMessages() = withContentType(PollContent::class) | ||||||
|  | fun Flow<ContentMessage<*>>.onlyStickerContentMessages() = withContentType(StickerContent::class) | ||||||
|  | fun Flow<ContentMessage<*>>.onlyTextContentMessages() = withContentType(TextContent::class) | ||||||
|  | fun Flow<ContentMessage<*>>.onlyVenueContentMessages() = withContentType(VenueContent::class) | ||||||
|  | fun Flow<ContentMessage<*>>.onlyVideoContentMessages() = withContentType(VideoContent::class) | ||||||
|  | fun Flow<ContentMessage<*>>.onlyVideoNoteContentMessages() = withContentType(VideoNoteContent::class) | ||||||
|  | fun Flow<ContentMessage<*>>.onlyVoiceContentMessages() = withContentType(VoiceContent::class) | ||||||
| @@ -0,0 +1,16 @@ | |||||||
|  | package com.github.insanusmokrassar.TelegramBotAPI.extensions.utils.updates | ||||||
|  |  | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.CallbackQuery.* | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.update.CallbackQueryUpdate | ||||||
|  | import kotlinx.coroutines.flow.Flow | ||||||
|  | import kotlinx.coroutines.flow.mapNotNull | ||||||
|  |  | ||||||
|  | fun Flow<CallbackQueryUpdate>.asDataCallbackQueryFlow() = mapNotNull { | ||||||
|  |     it.data as? DataCallbackQuery | ||||||
|  | } | ||||||
|  | fun Flow<CallbackQueryUpdate>.asGameShortNameCallbackQueryFlow() = mapNotNull { | ||||||
|  |     it.data as? GameShortNameCallbackQuery | ||||||
|  | } | ||||||
|  | fun Flow<CallbackQueryUpdate>.asUnknownCallbackQueryFlow() = mapNotNull { | ||||||
|  |     it.data as? UnknownCallbackQueryType | ||||||
|  | } | ||||||
| @@ -0,0 +1,53 @@ | |||||||
|  | package com.github.insanusmokrassar.TelegramBotAPI.extensions.utils.updates | ||||||
|  |  | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.CommonAbstracts.TextSource | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.extensions.utils.onlyTextContentMessages | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.MessageEntity.textsources.BotCommandTextSource | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.MessageEntity.textsources.RegularTextSource | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.message.content.fullEntitiesList | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.update.abstracts.BaseSentMessageUpdate | ||||||
|  | import kotlinx.coroutines.flow.* | ||||||
|  |  | ||||||
|  | fun <T : BaseSentMessageUpdate> Flow<T>.filterExactCommands( | ||||||
|  |     commandRegex: Regex | ||||||
|  | ) = asContentMessagesFlow().onlyTextContentMessages().filter { contentMessage -> | ||||||
|  |     (contentMessage.content.fullEntitiesList().singleOrNull() as? BotCommandTextSource) ?.let { commandRegex.matches(it.command) } == true | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fun <T : BaseSentMessageUpdate> Flow<T>.filterCommandsInsideTextMessages( | ||||||
|  |     commandRegex: Regex | ||||||
|  | ) = asContentMessagesFlow().onlyTextContentMessages().filter { contentMessage -> | ||||||
|  |     contentMessage.content.fullEntitiesList().any { | ||||||
|  |         (it as? BotCommandTextSource) ?.let { commandRegex.matches(it.command) } == true | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @return Result [Flow] will emit all [TextSource]s to the collector ONLY IN CASE if first [TextSource] is | ||||||
|  |  * [BotCommandTextSource] and its [BotCommandTextSource.command] is [Regex.matches] to incoming [commandRegex]. Internal | ||||||
|  |  * behaviour contains next rules: all incoming text sources will be passed as is, [RegularTextSource] will be divided | ||||||
|  |  * by " " for several [RegularTextSource] which will contains not empty args without spaces | ||||||
|  |  */ | ||||||
|  | fun <T : BaseSentMessageUpdate> Flow<T>.filterCommandsWithArgs( | ||||||
|  |     commandRegex: Regex | ||||||
|  | ): Flow<List<TextSource>> = asContentMessagesFlow().onlyTextContentMessages().mapNotNull { contentMessage -> | ||||||
|  |     val allEntities = contentMessage.content.fullEntitiesList() | ||||||
|  |     (allEntities.firstOrNull() as? BotCommandTextSource) ?.let { | ||||||
|  |         if (commandRegex.matches(it.command)) { | ||||||
|  |             allEntities.flatMap { | ||||||
|  |                 when (it) { | ||||||
|  |                     is RegularTextSource -> it.source.split(" ").mapNotNull { regularTextSourcePart -> | ||||||
|  |                         if (regularTextSourcePart.isNotBlank()) { | ||||||
|  |                             RegularTextSource(regularTextSourcePart) | ||||||
|  |                         } else { | ||||||
|  |                             null | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                     else -> listOf(it) | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } else { | ||||||
|  |             null | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,18 @@ | |||||||
|  | package com.github.insanusmokrassar.TelegramBotAPI.extensions.utils.updates | ||||||
|  |  | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.* | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.update.abstracts.BaseSentMessageUpdate | ||||||
|  | import kotlinx.coroutines.flow.Flow | ||||||
|  | import kotlinx.coroutines.flow.mapNotNull | ||||||
|  |  | ||||||
|  | fun <T : BaseSentMessageUpdate> Flow<T>.asContentMessagesFlow() = mapNotNull { | ||||||
|  |     it.data as? ContentMessage<*> | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fun <T : BaseSentMessageUpdate> Flow<T>.asChatEventsFlow() = mapNotNull { | ||||||
|  |     it.data as? ChatEventMessage | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fun <T : BaseSentMessageUpdate> Flow<T>.asUnknownMessagesFlow() = mapNotNull { | ||||||
|  |     it.data as? UnknownMessageType | ||||||
|  | } | ||||||
| @@ -0,0 +1,19 @@ | |||||||
|  | package com.github.insanusmokrassar.TelegramBotAPI.extensions.utils.updates | ||||||
|  |  | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.ChatId | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.update.MediaGroupUpdates.* | ||||||
|  | import com.github.insanusmokrassar.TelegramBotAPI.types.update.abstracts.BaseMessageUpdate | ||||||
|  | import kotlinx.coroutines.flow.Flow | ||||||
|  | import kotlinx.coroutines.flow.filter | ||||||
|  |  | ||||||
|  | fun <T : BaseMessageUpdate> Flow<T>.filterBaseMessageUpdates(chatId: ChatId): Flow<T> = filter { | ||||||
|  |     it.data.chat.id == chatId | ||||||
|  | } | ||||||
|  | fun <T : BaseMessageUpdate> Flow<T>.filterBaseMessageUpdates(chat: Chat): Flow<T> = filterBaseMessageUpdates(chat.id) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | fun <T : SentMediaGroupUpdate> Flow<T>.filterSentMediaGroupUpdates(chatId: ChatId): Flow<T> = filter { | ||||||
|  |     it.data.first().chat.id == chatId | ||||||
|  | } | ||||||
|  | fun <T : SentMediaGroupUpdate> Flow<T>.filterSentMediaGroupUpdates(chat: Chat): Flow<T> = filterSentMediaGroupUpdates(chat.id) | ||||||
| @@ -1,9 +1,7 @@ | |||||||
| # TelegramBotAPI | # TelegramBotAPI | ||||||
|  |  | ||||||
| [](https://github.com/KotlinBy/awesome-kotlin) |  | ||||||
| [ ](https://bintray.com/insanusmokrassar/StandardRepository/TelegramBotAPI/_latestVersion) | [ ](https://bintray.com/insanusmokrassar/StandardRepository/TelegramBotAPI/_latestVersion) | ||||||
| [](https://maven-badges.herokuapp.com/maven-central/com.github.insanusmokrassar/TelegramBotAPI) | [](https://maven-badges.herokuapp.com/maven-central/com.github.insanusmokrassar/TelegramBotAPI) | ||||||
| [](https://jenkins.insanusmokrassar.com/job/TelegramBotAPI_master__publishing/) |  | ||||||
|  |  | ||||||
| ## What is it? | ## What is it? | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,6 +4,7 @@ interface TextSource { | |||||||
|     val asMarkdownSource: String |     val asMarkdownSource: String | ||||||
|     val asMarkdownV2Source: String |     val asMarkdownV2Source: String | ||||||
|     val asHtmlSource: String |     val asHtmlSource: String | ||||||
|  |     val source: String | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ import com.github.insanusmokrassar.TelegramBotAPI.CommonAbstracts.TextPart | |||||||
| import com.github.insanusmokrassar.TelegramBotAPI.utils.* | import com.github.insanusmokrassar.TelegramBotAPI.utils.* | ||||||
|  |  | ||||||
| class BoldTextSource( | class BoldTextSource( | ||||||
|     source: String, |     override val source: String, | ||||||
|     textParts: List<TextPart> |     textParts: List<TextPart> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val textParts: List<TextPart> by lazy { source.fullListOfSubSource(textParts) } |     override val textParts: List<TextPart> by lazy { source.fullListOfSubSource(textParts) } | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ import com.github.insanusmokrassar.TelegramBotAPI.utils.* | |||||||
| private val commandRegex = Regex("[/!][^@\\s]*") | private val commandRegex = Regex("[/!][^@\\s]*") | ||||||
|  |  | ||||||
| class BotCommandTextSource( | class BotCommandTextSource( | ||||||
|     source: String, |     override val source: String, | ||||||
|     textParts: List<TextPart> |     textParts: List<TextPart> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     val command: String by lazy { |     val command: String by lazy { | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ import com.github.insanusmokrassar.TelegramBotAPI.CommonAbstracts.TextPart | |||||||
| import com.github.insanusmokrassar.TelegramBotAPI.utils.* | import com.github.insanusmokrassar.TelegramBotAPI.utils.* | ||||||
|  |  | ||||||
| class CashTagTextSource( | class CashTagTextSource( | ||||||
|     source: String, |     override val source: String, | ||||||
|     textParts: List<TextPart> |     textParts: List<TextPart> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val textParts: List<TextPart> by lazy { source.fullListOfSubSource(textParts) } |     override val textParts: List<TextPart> by lazy { source.fullListOfSubSource(textParts) } | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ import com.github.insanusmokrassar.TelegramBotAPI.CommonAbstracts.TextSource | |||||||
| import com.github.insanusmokrassar.TelegramBotAPI.utils.* | import com.github.insanusmokrassar.TelegramBotAPI.utils.* | ||||||
|  |  | ||||||
| class CodeTextSource( | class CodeTextSource( | ||||||
|     source: String |     override val source: String | ||||||
| ) : TextSource { | ) : TextSource { | ||||||
|     override val asMarkdownSource: String by lazy { source.codeMarkdown() } |     override val asMarkdownSource: String by lazy { source.codeMarkdown() } | ||||||
|     override val asMarkdownV2Source: String by lazy { source.codeMarkdownV2() } |     override val asMarkdownV2Source: String by lazy { source.codeMarkdownV2() } | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ import com.github.insanusmokrassar.TelegramBotAPI.CommonAbstracts.TextPart | |||||||
| import com.github.insanusmokrassar.TelegramBotAPI.utils.* | import com.github.insanusmokrassar.TelegramBotAPI.utils.* | ||||||
|  |  | ||||||
| class EMailTextSource( | class EMailTextSource( | ||||||
|     source: String, |     override val source: String, | ||||||
|     textParts: List<TextPart> |     textParts: List<TextPart> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val textParts: List<TextPart> by lazy { source.fullListOfSubSource(textParts) } |     override val textParts: List<TextPart> by lazy { source.fullListOfSubSource(textParts) } | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ private val String.withoutSharp | |||||||
|     } |     } | ||||||
|  |  | ||||||
| class HashTagTextSource( | class HashTagTextSource( | ||||||
|     source: String, |     override val source: String, | ||||||
|     textParts: List<TextPart> |     textParts: List<TextPart> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val textParts: List<TextPart> by lazy { |     override val textParts: List<TextPart> by lazy { | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ import com.github.insanusmokrassar.TelegramBotAPI.CommonAbstracts.TextPart | |||||||
| import com.github.insanusmokrassar.TelegramBotAPI.utils.* | import com.github.insanusmokrassar.TelegramBotAPI.utils.* | ||||||
|  |  | ||||||
| class ItalicTextSource( | class ItalicTextSource( | ||||||
|     source: String, |     override val source: String, | ||||||
|     textParts: List<TextPart> |     textParts: List<TextPart> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val textParts: List<TextPart> by lazy { source.fullListOfSubSource(textParts) } |     override val textParts: List<TextPart> by lazy { source.fullListOfSubSource(textParts) } | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ private val String.withoutCommercialAt | |||||||
|     } |     } | ||||||
|  |  | ||||||
| class MentionTextSource( | class MentionTextSource( | ||||||
|     source: String, |     override val source: String, | ||||||
|     textParts: List<TextPart> |     textParts: List<TextPart> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val textParts: List<TextPart> by lazy { |     override val textParts: List<TextPart> by lazy { | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ import com.github.insanusmokrassar.TelegramBotAPI.CommonAbstracts.TextPart | |||||||
| import com.github.insanusmokrassar.TelegramBotAPI.utils.* | import com.github.insanusmokrassar.TelegramBotAPI.utils.* | ||||||
|  |  | ||||||
| class PhoneNumberTextSource( | class PhoneNumberTextSource( | ||||||
|     source: String, |     override val source: String, | ||||||
|     textParts: List<TextPart> |     textParts: List<TextPart> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val textParts: List<TextPart> by lazy { source.fullListOfSubSource(textParts) } |     override val textParts: List<TextPart> by lazy { source.fullListOfSubSource(textParts) } | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ import com.github.insanusmokrassar.TelegramBotAPI.CommonAbstracts.TextSource | |||||||
| import com.github.insanusmokrassar.TelegramBotAPI.utils.* | import com.github.insanusmokrassar.TelegramBotAPI.utils.* | ||||||
|  |  | ||||||
| class PreTextSource( | class PreTextSource( | ||||||
|     source: String, |     override val source: String, | ||||||
|     val language: String? = null |     val language: String? = null | ||||||
| ) : TextSource { | ) : TextSource { | ||||||
|     override val asMarkdownSource: String by lazy { source.preMarkdown(language) } |     override val asMarkdownSource: String by lazy { source.preMarkdown(language) } | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ import com.github.insanusmokrassar.TelegramBotAPI.CommonAbstracts.TextSource | |||||||
| import com.github.insanusmokrassar.TelegramBotAPI.utils.* | import com.github.insanusmokrassar.TelegramBotAPI.utils.* | ||||||
|  |  | ||||||
| class RegularTextSource( | class RegularTextSource( | ||||||
|     source: String |     override val source: String | ||||||
| ) : TextSource { | ) : TextSource { | ||||||
|     override val asMarkdownSource: String by lazy { source.regularMarkdown() } |     override val asMarkdownSource: String by lazy { source.regularMarkdown() } | ||||||
|     override val asMarkdownV2Source: String by lazy { source.regularMarkdownV2() } |     override val asMarkdownV2Source: String by lazy { source.regularMarkdownV2() } | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ import com.github.insanusmokrassar.TelegramBotAPI.CommonAbstracts.TextPart | |||||||
| import com.github.insanusmokrassar.TelegramBotAPI.utils.* | import com.github.insanusmokrassar.TelegramBotAPI.utils.* | ||||||
|  |  | ||||||
| class StrikethroughTextSource( | class StrikethroughTextSource( | ||||||
|     source: String, |     override val source: String, | ||||||
|     textParts: List<TextPart> |     textParts: List<TextPart> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val textParts: List<TextPart> by lazy { source.fullListOfSubSource(textParts) } |     override val textParts: List<TextPart> by lazy { source.fullListOfSubSource(textParts) } | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ import com.github.insanusmokrassar.TelegramBotAPI.CommonAbstracts.TextSource | |||||||
| import com.github.insanusmokrassar.TelegramBotAPI.utils.* | import com.github.insanusmokrassar.TelegramBotAPI.utils.* | ||||||
|  |  | ||||||
| class TextLinkTextSource( | class TextLinkTextSource( | ||||||
|     source: String, |     override val source: String, | ||||||
|     url: String |     url: String | ||||||
| ) : TextSource { | ) : TextSource { | ||||||
|     override val asMarkdownSource: String by lazy { source.linkMarkdown(url) } |     override val asMarkdownSource: String by lazy { source.linkMarkdown(url) } | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PrivateCh | |||||||
| import com.github.insanusmokrassar.TelegramBotAPI.utils.* | import com.github.insanusmokrassar.TelegramBotAPI.utils.* | ||||||
|  |  | ||||||
| class TextMentionTextSource( | class TextMentionTextSource( | ||||||
|     source: String, |     override val source: String, | ||||||
|     privateChat: PrivateChat, |     privateChat: PrivateChat, | ||||||
|     textParts: List<TextPart> |     textParts: List<TextPart> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ import com.github.insanusmokrassar.TelegramBotAPI.CommonAbstracts.TextSource | |||||||
| import com.github.insanusmokrassar.TelegramBotAPI.utils.* | import com.github.insanusmokrassar.TelegramBotAPI.utils.* | ||||||
|  |  | ||||||
| class URLTextSource( | class URLTextSource( | ||||||
|     source: String |     override val source: String | ||||||
| ) : TextSource { | ) : TextSource { | ||||||
|     override val asMarkdownSource: String by lazy { source.linkMarkdown(source) } |     override val asMarkdownSource: String by lazy { source.linkMarkdown(source) } | ||||||
|     override val asMarkdownV2Source: String by lazy { source.linkMarkdownV2(source) } |     override val asMarkdownV2Source: String by lazy { source.linkMarkdownV2(source) } | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ import com.github.insanusmokrassar.TelegramBotAPI.CommonAbstracts.TextPart | |||||||
| import com.github.insanusmokrassar.TelegramBotAPI.utils.* | import com.github.insanusmokrassar.TelegramBotAPI.utils.* | ||||||
|  |  | ||||||
| class UnderlineTextSource( | class UnderlineTextSource( | ||||||
|     source: String, |     override val source: String, | ||||||
|     textParts: List<TextPart> |     textParts: List<TextPart> | ||||||
| ) : MultilevelTextSource { | ) : MultilevelTextSource { | ||||||
|     override val textParts: List<TextPart> by lazy { source.fullListOfSubSource(textParts) } |     override val textParts: List<TextPart> by lazy { source.fullListOfSubSource(textParts) } | ||||||
|   | |||||||
| @@ -1,8 +1,7 @@ | |||||||
| package com.github.insanusmokrassar.TelegramBotAPI.types.update.MediaGroupUpdates | package com.github.insanusmokrassar.TelegramBotAPI.types.update.MediaGroupUpdates | ||||||
|  |  | ||||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.MediaGroupMessage | import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.MediaGroupMessage | ||||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.update.abstracts.BaseMessageUpdate | import com.github.insanusmokrassar.TelegramBotAPI.types.update.abstracts.* | ||||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.update.abstracts.Update |  | ||||||
|  |  | ||||||
| interface MediaGroupUpdate : Update | interface MediaGroupUpdate : Update | ||||||
|  |  | ||||||
| @@ -11,7 +10,7 @@ interface SentMediaGroupUpdate: MediaGroupUpdate { | |||||||
|     val origins: List<BaseMessageUpdate> |     val origins: List<BaseMessageUpdate> | ||||||
| } | } | ||||||
|  |  | ||||||
| interface EditMediaGroupUpdate : MediaGroupUpdate { | interface EditMediaGroupUpdate : BaseEditMessageUpdate, MediaGroupUpdate { | ||||||
|     override val data: MediaGroupMessage |     override val data: MediaGroupMessage | ||||||
|     val origin: BaseMessageUpdate |     val origin: BaseMessageUpdate | ||||||
| } | } | ||||||
|   | |||||||
| @@ -7,6 +7,6 @@ uuid_version=0.1.0 | |||||||
| ktor_version=1.3.2 | ktor_version=1.3.2 | ||||||
|  |  | ||||||
| library_group=com.github.insanusmokrassar | library_group=com.github.insanusmokrassar | ||||||
| library_version=0.26.1 | library_version=0.26.2 | ||||||
|  |  | ||||||
| gradle_bintray_plugin_version=1.8.4 | gradle_bintray_plugin_version=1.8.4 | ||||||
|   | |||||||
| @@ -1,2 +1,3 @@ | |||||||
| include ":TelegramBotAPI" | include ":TelegramBotAPI" | ||||||
| include ":TelegramBotAPI-extensions-api" | include ":TelegramBotAPI-extensions-api" | ||||||
|  | include ":TelegramBotAPI-extensions-utils" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user