mirror of
				https://github.com/InsanusMokrassar/TelegramBotAPI.git
				synced 2025-10-25 01:00:13 +00:00 
			
		
		
		
	| @@ -55,6 +55,18 @@ | ||||
| 
 | ||||
| * Fixes in `InputMedia` - `media` field was not included to serialization | ||||
| 
 | ||||
| ### 0.23.3 Project separating prepare version | ||||
| 
 | ||||
| __API Extensions__ | ||||
| 
 | ||||
| * Project created | ||||
| * For `SendPhoto` was added new functions for uploading of `MultipartFile` | ||||
| * `deleteWebhook` extension for `RequestsExecutor` was added | ||||
| 
 | ||||
| __Telegram Bot API__ | ||||
| 
 | ||||
| * All `RequestsExecutor` extensions related to Telegram Bots API was replaced into `API Extensions` project | ||||
| 
 | ||||
| ## 0.22.0 | ||||
| 
 | ||||
| * **`KtorCallFactory` must return `HttpStatement` instead of `HttpClientCall`** | ||||
							
								
								
									
										57
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										57
									
								
								README.md
									
									
									
									
									
								
							| @@ -37,7 +37,11 @@ of signed artifacts in Bintray). You can: | ||||
| [here](https://mvnrepository.com/artifact/com.github.insanusmokrassar/TelegramBotAPI)) | ||||
| * Add `jCenter` repository in build config | ||||
|  | ||||
| ### Maven | ||||
| ### TelegramBotAPI | ||||
|  | ||||
| Contains core and most required things, like types, requests and `KtorRequestsExecutor`. | ||||
|  | ||||
| #### Maven | ||||
|  | ||||
| Dependency config presented here: | ||||
|  | ||||
| @@ -49,7 +53,7 @@ Dependency config presented here: | ||||
| </dependency> | ||||
| ``` | ||||
|  | ||||
| ### Gradle | ||||
| #### Gradle | ||||
|  | ||||
| To use last versions you will need to add one line in repositories block of your `build.gradle`: | ||||
|  | ||||
| @@ -67,14 +71,49 @@ or for old gradle: | ||||
| compile "com.github.insanusmokrassar:TelegramBotAPI:$telegrambotapi_version" | ||||
| ``` | ||||
|  | ||||
| ### API extensions | ||||
|  | ||||
| Contains extensions for `RequestsExecutor` which usually more obvious than original ones in `TelegramBotAPI` and more | ||||
| useful. | ||||
|  | ||||
| #### Maven | ||||
|  | ||||
| Dependency config presented here: | ||||
|  | ||||
| ```xml | ||||
| <dependency> | ||||
|   <groupId>com.github.insanusmokrassar</groupId> | ||||
|   <artifactId>TelegramBotAPI-extensions-api</artifactId> | ||||
|   <version>${telegrambotapi.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-api:$telegrambotapi_version" | ||||
| ``` | ||||
|  | ||||
| or for old gradle: | ||||
|  | ||||
| ```groovy | ||||
| compile "com.github.insanusmokrassar:TelegramBotAPI-extensions-api:$telegrambotapi_version" | ||||
| ``` | ||||
|  | ||||
| ## How to work with library? | ||||
|  | ||||
| For now, this library have no some API god-object. Instead of this, this library has several | ||||
| important objects: | ||||
|  | ||||
| * [RequestsExecutor](https://github.com/InsanusMokrassar/TelegramBotAPI/blob/master/src/commonMain/kotlin/com/github/insanusmokrassar/TelegramBotAPI/bot/RequestsExecutor.kt) | ||||
| * [Requests](https://github.com/InsanusMokrassar/TelegramBotAPI/blob/master/src/commonMain/kotlin/com/github/insanusmokrassar/TelegramBotAPI/requests) | ||||
| * [Types](https://github.com/InsanusMokrassar/TelegramBotAPI/blob/master/src/commonMain/kotlin/com/github/insanusmokrassar/TelegramBotAPI/types) | ||||
| * [RequestsExecutor](https://github.com/InsanusMokrassar/TelegramBotAPI/blob/master/TelegramBotAPI/src/commonMain/kotlin/com/github/insanusmokrassar/TelegramBotAPI/bot/RequestsExecutor.kt) | ||||
| * [Requests](https://github.com/InsanusMokrassar/TelegramBotAPI/blob/master/TelegramBotAPI/src/commonMain/kotlin/com/github/insanusmokrassar/TelegramBotAPI/requests) | ||||
| * [Types](https://github.com/InsanusMokrassar/TelegramBotAPI/blob/master/TelegramBotAPI/src/commonMain/kotlin/com/github/insanusmokrassar/TelegramBotAPI/types) | ||||
|  | ||||
| ### Types | ||||
|  | ||||
| @@ -101,16 +140,16 @@ val requestsExecutor: RequestsExecutor = ... | ||||
| requestsExecutor.execute(GetMe()) | ||||
| ```  | ||||
|  | ||||
| Or you can use new syntax: | ||||
| Or you can use new syntax (available by implementing of project [API extensions](#API-extensions): | ||||
|  | ||||
| ```kotlin | ||||
| val bot: RequestsExecutor = ... | ||||
| bot.getMe() | ||||
| ``` | ||||
|  | ||||
| The result type of [GetMe (and getMe extension)](https://github.com/InsanusMokrassar/TelegramBotAPI/blob/master/src/commonMain/kotlin/com/github/insanusmokrassar/TelegramBotAPI/requests/GetMe.kt) | ||||
| The result type of [GetMe (and getMe extension)](https://github.com/InsanusMokrassar/TelegramBotAPI/blob/master/TelegramBotAPI/src/commonMain/kotlin/com/github/insanusmokrassar/TelegramBotAPI/requests/GetMe.kt) | ||||
| request is | ||||
| [ExtendedBot](https://github.com/InsanusMokrassar/TelegramBotAPI/blob/master/src/commonMain/kotlin/com/github/insanusmokrassar/TelegramBotAPI/types/User.kt). | ||||
| [ExtendedBot](https://github.com/InsanusMokrassar/TelegramBotAPI/blob/master/TelegramBotAPI/src/commonMain/kotlin/com/github/insanusmokrassar/TelegramBotAPI/types/User.kt). | ||||
|  | ||||
| ### RequestsExecutor | ||||
|  | ||||
| @@ -206,6 +245,6 @@ Here: | ||||
|  | ||||
| * `WEBHOOK_URL` - the url which will be used by Telegram system to send updates | ||||
| * `INTERNAL_PORT` - the port which will be used in bot for listening of updates | ||||
| * `filter` - instance of [UpdatesFilter](https://github.com/InsanusMokrassar/TelegramBotAPI/blob/master/src/commonMain/kotlin/com/github/insanusmokrassar/TelegramBotAPI/updateshandlers/UpdatesFilter.kt), | ||||
| * `filter` - instance of [UpdatesFilter](https://github.com/InsanusMokrassar/TelegramBotAPI/blob/master/TelegramBotAPI/src/commonMain/kotlin/com/github/insanusmokrassar/TelegramBotAPI/updateshandlers/UpdatesFilter.kt), | ||||
| which will be used to filter incoming updates | ||||
| * `ENGINE_FACTORY` - used factory name, for example, `CIO` in case of usage `io.ktor:ktor-server-cio` as server engine | ||||
|   | ||||
							
								
								
									
										48
									
								
								TelegramBotAPI-extensions-api/build.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								TelegramBotAPI-extensions-api/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 = "com.github.insanusmokrassar" | ||||
|  | ||||
| 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") { | ||||
|                     api "${project.group}:TelegramBotAPI:$library_version" | ||||
|                 } else { | ||||
|                     implementation project(":TelegramBotAPI") | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										57
									
								
								TelegramBotAPI-extensions-api/maven.publish.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								TelegramBotAPI-extensions-api/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 "API extensions which provide work with RequestsExecutor of TelegramBotAPI almost like it is described in original Telegram Bot API reference" | ||||
|                 name "Telegram Bot API Extensions for API" | ||||
|                 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" | ||||
|                         } | ||||
|                      | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										1
									
								
								TelegramBotAPI-extensions-api/mpp_publish_template.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								TelegramBotAPI-extensions-api/mpp_publish_template.json
									
									
									
									
									
										Normal file
									
								
							| @@ -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 Extensions for API","description":"API extensions which provide work with RequestsExecutor of TelegramBotAPI almost like it is described in original Telegram Bot API reference","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-api/publish.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								TelegramBotAPI-extensions-api/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,28 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.DeleteMessage | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.Message | ||||
|  | ||||
| suspend fun RequestsExecutor.deleteMessage( | ||||
|     chatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier | ||||
| ) = execute( | ||||
|     DeleteMessage(chatId, messageId) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.deleteMessage( | ||||
|     chat: Chat, | ||||
|     messageId: MessageIdentifier | ||||
| ) = deleteMessage(chat.id, messageId) | ||||
|  | ||||
| suspend fun RequestsExecutor.deleteMessage( | ||||
|     message: Message | ||||
| ) = deleteMessage(message.chat, message.messageId) | ||||
|  | ||||
| suspend fun Message.delete( | ||||
|     requestsExecutor: RequestsExecutor | ||||
| ) = requestsExecutor.deleteMessage(this) | ||||
| @@ -0,0 +1,50 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.ForwardMessage | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.Message | ||||
|  | ||||
| suspend fun RequestsExecutor.forwardMessage( | ||||
|     fromChatId: ChatIdentifier, | ||||
|     toChatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier, | ||||
|     disableNotification: Boolean = false | ||||
| ) = execute( | ||||
|     ForwardMessage(fromChatId, toChatId, messageId, disableNotification) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.forwardMessage( | ||||
|     fromChat: Chat, | ||||
|     toChatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier, | ||||
|     disableNotification: Boolean = false | ||||
| ) = forwardMessage(fromChat.id, toChatId, messageId, disableNotification) | ||||
|  | ||||
| suspend fun RequestsExecutor.forwardMessage( | ||||
|     fromChatId: ChatIdentifier, | ||||
|     toChat: Chat, | ||||
|     messageId: MessageIdentifier, | ||||
|     disableNotification: Boolean = false | ||||
| ) = forwardMessage(fromChatId, toChat.id, messageId, disableNotification) | ||||
|  | ||||
| suspend fun RequestsExecutor.forwardMessage( | ||||
|     fromChat: Chat, | ||||
|     toChat: Chat, | ||||
|     messageId: MessageIdentifier, | ||||
|     disableNotification: Boolean = false | ||||
| ) = forwardMessage(fromChat.id, toChat.id, messageId, disableNotification) | ||||
|  | ||||
| suspend fun RequestsExecutor.forwardMessage( | ||||
|     toChatId: ChatIdentifier, | ||||
|     message: Message, | ||||
|     disableNotification: Boolean = false | ||||
| ) = forwardMessage(message.chat, toChatId, message.messageId, disableNotification) | ||||
|  | ||||
| suspend fun RequestsExecutor.forwardMessage( | ||||
|     toChat: Chat, | ||||
|     message: Message, | ||||
|     disableNotification: Boolean = false | ||||
| ) = forwardMessage(message.chat, toChat, message.messageId, disableNotification) | ||||
| @@ -0,0 +1,6 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.GetMe | ||||
|  | ||||
| suspend fun RequestsExecutor.getMe() = execute(GetMe()) | ||||
| @@ -0,0 +1,27 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.GetUpdates | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ALL_UPDATES_LIST | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.UpdateIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.update.abstracts.Update | ||||
|  | ||||
| suspend fun RequestsExecutor.getUpdates( | ||||
|     offset: UpdateIdentifier? = null, | ||||
|     limit: Int? = null, | ||||
|     timeout: Int? = null, | ||||
|     allowed_updates: List<String>? = ALL_UPDATES_LIST | ||||
| ) = execute( | ||||
|     GetUpdates( | ||||
|         offset, limit, timeout, allowed_updates | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.getUpdates( | ||||
|     lastUpdate: Update, | ||||
|     limit: Int? = null, | ||||
|     timeout: Int? = null, | ||||
|     allowed_updates: List<String>? = ALL_UPDATES_LIST | ||||
| ) = getUpdates( | ||||
|     lastUpdate.updateId + 1, limit, timeout, allowed_updates | ||||
| ) | ||||
| @@ -0,0 +1,135 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.extensions.api.edit.LiveLocation.editLiveLocation | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.extensions.api.edit.LiveLocation.stopLiveLocation | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.SendLocation | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.InlineKeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.ContentMessage | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.content.LocationContent | ||||
| import com.soywiz.klock.DateTime | ||||
| import com.soywiz.klock.TimeSpan | ||||
| import io.ktor.utils.io.core.Closeable | ||||
| import kotlinx.coroutines.CoroutineScope | ||||
| import kotlinx.coroutines.launch | ||||
| import kotlin.math.ceil | ||||
|  | ||||
| private val livePeriodDelayMillis = (livePeriodLimit.last - 60L) * 1000L | ||||
| class LiveLocation internal constructor( | ||||
|     private val requestsExecutor: RequestsExecutor, | ||||
|     scope: CoroutineScope, | ||||
|     autoCloseTimeDelay: Double, | ||||
|     initMessage: ContentMessage<LocationContent> | ||||
| ) : Closeable { | ||||
|     private val doWhenClose = { | ||||
|         scope.launch { | ||||
|             requestsExecutor.stopLiveLocation(message) | ||||
|         } | ||||
|     } | ||||
|     private val autoCloseTime = DateTime.now() + TimeSpan(autoCloseTimeDelay) | ||||
|     val leftUntilCloseMillis: TimeSpan | ||||
|         get() = autoCloseTime - DateTime.now() | ||||
|  | ||||
|     var isClosed: Boolean = false | ||||
|         private set | ||||
|         get() = field || leftUntilCloseMillis.millisecondsLong < 0L | ||||
|  | ||||
|     private var message: ContentMessage<LocationContent> = initMessage | ||||
|     val lastLocation: Location | ||||
|         get() = message.content.location | ||||
|  | ||||
|     suspend fun updateLocation( | ||||
|         location: Location, | ||||
|         replyMarkup: InlineKeyboardMarkup? = null | ||||
|     ): Location { | ||||
|         if (!isClosed) { | ||||
|             message = requestsExecutor.editLiveLocation( | ||||
|                 message, | ||||
|                 location, | ||||
|                 replyMarkup | ||||
|             ) | ||||
|             return lastLocation | ||||
|         } else { | ||||
|             error("LiveLocation is closed") | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     override fun close() { | ||||
|         if (isClosed) { | ||||
|             return | ||||
|         } | ||||
|         isClosed = true | ||||
|         doWhenClose() | ||||
|     } | ||||
| } | ||||
|  | ||||
| suspend fun RequestsExecutor.startLiveLocation( | ||||
|     scope: CoroutineScope, | ||||
|     chatId: ChatIdentifier, | ||||
|     latitude: Double, | ||||
|     longitude: Double, | ||||
|     liveTimeMillis: Long = livePeriodDelayMillis, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ): LiveLocation { | ||||
|     val liveTimeAsDouble = liveTimeMillis.toDouble() | ||||
|     val locationMessage = execute( | ||||
|         SendLocation( | ||||
|             chatId, | ||||
|             latitude, | ||||
|             longitude, | ||||
|             ceil(liveTimeAsDouble / 1000).toLong(), | ||||
|             disableNotification, | ||||
|             replyToMessageId, | ||||
|             replyMarkup | ||||
|         ) | ||||
|     ) | ||||
|  | ||||
|     return LiveLocation( | ||||
|         this, | ||||
|         scope, | ||||
|         liveTimeAsDouble, | ||||
|         locationMessage | ||||
|     ) | ||||
| } | ||||
|  | ||||
| suspend fun RequestsExecutor.startLiveLocation( | ||||
|     scope: CoroutineScope, | ||||
|     chat: Chat, | ||||
|     latitude: Double, | ||||
|     longitude: Double, | ||||
|     liveTimeMillis: Long = livePeriodDelayMillis, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ): LiveLocation = startLiveLocation( | ||||
|     scope, chat.id, latitude, longitude, liveTimeMillis, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.startLiveLocation( | ||||
|     scope: CoroutineScope, | ||||
|     chatId: ChatId, | ||||
|     location: Location, | ||||
|     liveTimeMillis: Long = livePeriodDelayMillis, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ): LiveLocation = startLiveLocation( | ||||
|     scope, chatId, location.latitude, location.longitude, liveTimeMillis, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.startLiveLocation( | ||||
|     scope: CoroutineScope, | ||||
|     chat: Chat, | ||||
|     location: Location, | ||||
|     liveTimeMillis: Long = livePeriodDelayMillis, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ): LiveLocation = startLiveLocation( | ||||
|     scope, chat.id, location.latitude, location.longitude, liveTimeMillis, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
| @@ -0,0 +1,34 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.StopPoll | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.InlineKeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.Message | ||||
|  | ||||
| suspend fun RequestsExecutor.stopPoll( | ||||
|     chatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     StopPoll(chatId, messageId, replyMarkup) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.stopPoll( | ||||
|     chat: Chat, | ||||
|     messageId: MessageIdentifier, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = stopPoll(chat.id, messageId, replyMarkup) | ||||
|  | ||||
| suspend fun RequestsExecutor.stopPoll( | ||||
|     chatId: ChatId, | ||||
|     message: Message, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = stopPoll(chatId, message.messageId, replyMarkup) | ||||
|  | ||||
| suspend fun RequestsExecutor.stopPoll( | ||||
|     chat: Chat, | ||||
|     message: Message, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = stopPoll(chat.id, message.messageId, replyMarkup) | ||||
| @@ -0,0 +1,22 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.answers | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.answers.AnswerCallbackQuery | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.CallbackQuery.CallbackQuery | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.CallbackQueryIdentifier | ||||
|  | ||||
| suspend fun RequestsExecutor.answerCallbackQuery( | ||||
|     callbackQueryId: CallbackQueryIdentifier, | ||||
|     text: String? = null, | ||||
|     showAlert: Boolean? = null, | ||||
|     url: String? = null, | ||||
|     cachedTimeSeconds: Int? = null | ||||
| ) = execute(AnswerCallbackQuery(callbackQueryId, text, showAlert, url, cachedTimeSeconds)) | ||||
|  | ||||
| suspend fun RequestsExecutor.answerCallbackQuery( | ||||
|     callbackQuery: CallbackQuery, | ||||
|     text: String? = null, | ||||
|     showAlert: Boolean? = null, | ||||
|     url: String? = null, | ||||
|     cachedTimeSeconds: Int? = null | ||||
| ) = answerCallbackQuery(callbackQuery.id, text, showAlert, url, cachedTimeSeconds) | ||||
| @@ -0,0 +1,29 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.answers | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.answers.AnswerInlineQuery | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.InlineQueries.InlineQueryResult.abstracts.InlineQueryResult | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.InlineQueries.abstracts.InlineQuery | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.InlineQueryIdentifier | ||||
|  | ||||
| suspend fun RequestsExecutor.answerInlineQuery( | ||||
|     inlineQueryID: InlineQueryIdentifier, | ||||
|     results: List<InlineQueryResult> = emptyList(), | ||||
|     cachedTime: Int? = null, | ||||
|     isPersonal: Boolean? = null, | ||||
|     nextOffset: String? = null, | ||||
|     switchPmText: String? = null, | ||||
|     switchPmParameter: String? = null | ||||
| ) = execute( | ||||
|     AnswerInlineQuery(inlineQueryID, results, cachedTime, isPersonal, nextOffset, switchPmText, switchPmParameter) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.answerInlineQuery( | ||||
|     inlineQuery: InlineQuery, | ||||
|     results: List<InlineQueryResult> = emptyList(), | ||||
|     cachedTime: Int? = null, | ||||
|     isPersonal: Boolean? = null, | ||||
|     nextOffset: String? = null, | ||||
|     switchPmText: String? = null, | ||||
|     switchPmParameter: String? = null | ||||
| ) = answerInlineQuery(inlineQuery.id, results, cachedTime, isPersonal, nextOffset, switchPmText, switchPmParameter) | ||||
| @@ -0,0 +1,23 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.answers.payments | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.answers.payments.AnswerPreCheckoutQueryError | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.answers.payments.AnswerPreCheckoutQueryOk | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.PreCheckoutQueryId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.payments.PreCheckoutQuery | ||||
|  | ||||
| suspend fun RequestsExecutor.answerPreCheckoutQueryOk( | ||||
|     id: PreCheckoutQueryId | ||||
| ) = execute(AnswerPreCheckoutQueryOk(id)) | ||||
| suspend fun RequestsExecutor.answerPreCheckoutQueryOk( | ||||
|     preCheckoutQuery: PreCheckoutQuery | ||||
| ) = answerPreCheckoutQueryOk(preCheckoutQuery.id) | ||||
|  | ||||
| suspend fun RequestsExecutor.answerPreCheckoutQueryError( | ||||
|     id: PreCheckoutQueryId, | ||||
|     error: String | ||||
| ) = execute(AnswerPreCheckoutQueryError(id, error)) | ||||
| suspend fun RequestsExecutor.answerPreCheckoutQueryError( | ||||
|     preCheckoutQuery: PreCheckoutQuery, | ||||
|     error: String | ||||
| ) = answerPreCheckoutQueryError(preCheckoutQuery.id, error) | ||||
| @@ -0,0 +1,28 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.answers.payments | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.answers.payments.AnswerShippingQueryError | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.answers.payments.AnswerShippingQueryOk | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ShippingQueryIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.payments.ShippingOption | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.payments.ShippingQuery | ||||
|  | ||||
| suspend fun RequestsExecutor.answerShippingQueryOk( | ||||
|     id: ShippingQueryIdentifier, | ||||
|     shippingOptions: List<ShippingOption> | ||||
| ) = execute(AnswerShippingQueryOk(id, shippingOptions)) | ||||
| suspend fun RequestsExecutor.answerShippingQueryOk( | ||||
|     shippingQuery: ShippingQuery, | ||||
|     shippingOptions: List<ShippingOption> | ||||
| ) = answerShippingQueryOk(shippingQuery.id, shippingOptions) | ||||
|  | ||||
| suspend fun RequestsExecutor.answerShippingQueryError( | ||||
|     id: ShippingQueryIdentifier, | ||||
|     error: String | ||||
| ) = execute(AnswerShippingQueryError(id, error)) | ||||
| suspend fun RequestsExecutor.answerShippingQueryError( | ||||
|     shippingQuery: ShippingQuery, | ||||
|     error: String | ||||
| ) = answerShippingQueryError(shippingQuery.id, error) | ||||
|  | ||||
|  | ||||
| @@ -0,0 +1,14 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.ExportChatInviteLink | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
|  | ||||
| suspend fun RequestsExecutor.exportChatInviteLink( | ||||
|     chatId: ChatIdentifier | ||||
| ) = execute(ExportChatInviteLink(chatId)) | ||||
|  | ||||
| suspend fun RequestsExecutor.exportChatInviteLink( | ||||
|     chat: PublicChat | ||||
| ) = exportChatInviteLink(chat.id) | ||||
| @@ -0,0 +1,14 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.LeaveChat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
|  | ||||
| suspend fun RequestsExecutor.leaveChat( | ||||
|     chatId: ChatIdentifier | ||||
| ) = execute(LeaveChat(chatId)) | ||||
|  | ||||
| suspend fun RequestsExecutor.leaveChat( | ||||
|     chat: PublicChat | ||||
| ) = leaveChat(chat.id) | ||||
| @@ -0,0 +1,14 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.get | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.get.GetChat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
|  | ||||
| suspend fun RequestsExecutor.getChat( | ||||
|     chatId: ChatIdentifier | ||||
| ) = execute(GetChat(chatId)) | ||||
|  | ||||
| suspend fun RequestsExecutor.getChat( | ||||
|     chat: Chat | ||||
| ) = getChat(chat.id) | ||||
| @@ -0,0 +1,14 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.get | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.get.GetChatAdministrators | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
|  | ||||
| suspend fun RequestsExecutor.getChatAdministrators( | ||||
|     chatId: ChatIdentifier | ||||
| ) = execute(GetChatAdministrators(chatId)) | ||||
|  | ||||
| suspend fun RequestsExecutor.getChatAdministrators( | ||||
|     chat: PublicChat | ||||
| ) = getChatAdministrators(chat.id) | ||||
| @@ -0,0 +1,14 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.get | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.get.GetChatMembersCount | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
|  | ||||
| suspend fun RequestsExecutor.getChatMembersCount( | ||||
|     chatId: ChatIdentifier | ||||
| ) = execute(GetChatMembersCount(chatId)) | ||||
|  | ||||
| suspend fun RequestsExecutor.getChatMembersCount( | ||||
|     chat: PublicChat | ||||
| ) = getChatMembersCount(chat.id) | ||||
| @@ -0,0 +1,26 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.members | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.members.GetChatMember | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
|  | ||||
| suspend fun RequestsExecutor.getChatMember( | ||||
|     chatId: ChatIdentifier, | ||||
|     userId: UserId | ||||
| ) = execute(GetChatMember(chatId, userId)) | ||||
|  | ||||
| suspend fun RequestsExecutor.getChatMember( | ||||
|     chat: PublicChat, | ||||
|     userId: UserId | ||||
| ) = getChatMember(chat.id, userId) | ||||
|  | ||||
| suspend fun RequestsExecutor.getChatMember( | ||||
|     chatId: ChatId, | ||||
|     user: User | ||||
| ) = getChatMember(chatId, user.id) | ||||
|  | ||||
| suspend fun RequestsExecutor.getChatMember( | ||||
|     chat: PublicChat, | ||||
|     user: User | ||||
| ) = getChatMember(chat.id, user.id) | ||||
| @@ -0,0 +1,30 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.members | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.members.KickChatMember | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
|  | ||||
| suspend fun RequestsExecutor.kickChatMember( | ||||
|     chatId: ChatIdentifier, | ||||
|     userId: UserId, | ||||
|     untilDate: TelegramDate? = null | ||||
| ) = execute(KickChatMember(chatId, userId, untilDate)) | ||||
|  | ||||
| suspend fun RequestsExecutor.kickChatMember( | ||||
|     chat: PublicChat, | ||||
|     userId: UserId, | ||||
|     untilDate: TelegramDate? = null | ||||
| ) = kickChatMember(chat.id, userId, untilDate) | ||||
|  | ||||
| suspend fun RequestsExecutor.kickChatMember( | ||||
|     chatId: ChatId, | ||||
|     user: User, | ||||
|     untilDate: TelegramDate? = null | ||||
| ) = kickChatMember(chatId, user.id, untilDate) | ||||
|  | ||||
| suspend fun RequestsExecutor.kickChatMember( | ||||
|     chat: PublicChat, | ||||
|     user: User, | ||||
|     untilDate: TelegramDate? = null | ||||
| ) = kickChatMember(chat.id, user.id, untilDate) | ||||
| @@ -0,0 +1,112 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.members | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.members.PromoteChatMember | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
|  | ||||
| suspend fun RequestsExecutor.promoteChatMember( | ||||
|     chatId: ChatIdentifier, | ||||
|     userId: UserId, | ||||
|     untilDate: TelegramDate? = null, | ||||
|     canChangeInfo: Boolean? = null, | ||||
|     canPostMessages: Boolean? = null, | ||||
|     canEditMessages: Boolean? = null, | ||||
|     canDeleteMessages: Boolean? = null, | ||||
|     canInviteUsers: Boolean? = null, | ||||
|     canRestrictMembers: Boolean? = null, | ||||
|     canPinMessages: Boolean? = null, | ||||
|     canPromoteMembers: Boolean? = null | ||||
| ) = execute( | ||||
|     PromoteChatMember( | ||||
|         chatId, | ||||
|         userId, | ||||
|         untilDate, | ||||
|         canChangeInfo, | ||||
|         canPostMessages, | ||||
|         canEditMessages, | ||||
|         canDeleteMessages, | ||||
|         canInviteUsers, | ||||
|         canRestrictMembers, | ||||
|         canPinMessages, | ||||
|         canPromoteMembers | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.promoteChatMember( | ||||
|     chat: PublicChat, | ||||
|     userId: UserId, | ||||
|     untilDate: TelegramDate? = null, | ||||
|     canChangeInfo: Boolean? = null, | ||||
|     canPostMessages: Boolean? = null, | ||||
|     canEditMessages: Boolean? = null, | ||||
|     canDeleteMessages: Boolean? = null, | ||||
|     canInviteUsers: Boolean? = null, | ||||
|     canRestrictMembers: Boolean? = null, | ||||
|     canPinMessages: Boolean? = null, | ||||
|     canPromoteMembers: Boolean? = null | ||||
| ) = promoteChatMember( | ||||
|     chat.id, | ||||
|     userId, | ||||
|     untilDate, | ||||
|     canChangeInfo, | ||||
|     canPostMessages, | ||||
|     canEditMessages, | ||||
|     canDeleteMessages, | ||||
|     canInviteUsers, | ||||
|     canRestrictMembers, | ||||
|     canPinMessages, | ||||
|     canPromoteMembers | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.promoteChatMember( | ||||
|     chatId: ChatId, | ||||
|     user: User, | ||||
|     untilDate: TelegramDate? = null, | ||||
|     canChangeInfo: Boolean? = null, | ||||
|     canPostMessages: Boolean? = null, | ||||
|     canEditMessages: Boolean? = null, | ||||
|     canDeleteMessages: Boolean? = null, | ||||
|     canInviteUsers: Boolean? = null, | ||||
|     canRestrictMembers: Boolean? = null, | ||||
|     canPinMessages: Boolean? = null, | ||||
|     canPromoteMembers: Boolean? = null | ||||
| ) = promoteChatMember( | ||||
|     chatId, | ||||
|     user.id, | ||||
|     untilDate, | ||||
|     canChangeInfo, | ||||
|     canPostMessages, | ||||
|     canEditMessages, | ||||
|     canDeleteMessages, | ||||
|     canInviteUsers, | ||||
|     canRestrictMembers, | ||||
|     canPinMessages, | ||||
|     canPromoteMembers | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.promoteChatMember( | ||||
|     chat: PublicChat, | ||||
|     user: User, | ||||
|     untilDate: TelegramDate? = null, | ||||
|     canChangeInfo: Boolean? = null, | ||||
|     canPostMessages: Boolean? = null, | ||||
|     canEditMessages: Boolean? = null, | ||||
|     canDeleteMessages: Boolean? = null, | ||||
|     canInviteUsers: Boolean? = null, | ||||
|     canRestrictMembers: Boolean? = null, | ||||
|     canPinMessages: Boolean? = null, | ||||
|     canPromoteMembers: Boolean? = null | ||||
| ) = promoteChatMember( | ||||
|     chat.id, | ||||
|     user.id, | ||||
|     untilDate, | ||||
|     canChangeInfo, | ||||
|     canPostMessages, | ||||
|     canEditMessages, | ||||
|     canDeleteMessages, | ||||
|     canInviteUsers, | ||||
|     canRestrictMembers, | ||||
|     canPinMessages, | ||||
|     canPromoteMembers | ||||
| ) | ||||
| @@ -0,0 +1,36 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.members | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.members.RestrictChatMember | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.ChatPermissions | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
|  | ||||
| suspend fun RequestsExecutor.restrictChatMember( | ||||
|     chatId: ChatIdentifier, | ||||
|     userId: UserId, | ||||
|     untilDate: TelegramDate? = null, | ||||
|     permissions: ChatPermissions = ChatPermissions() | ||||
| ) = execute(RestrictChatMember(chatId, userId, untilDate, permissions)) | ||||
|  | ||||
| suspend fun RequestsExecutor.restrictChatMember( | ||||
|     chat: PublicChat, | ||||
|     userId: UserId, | ||||
|     untilDate: TelegramDate? = null, | ||||
|     permissions: ChatPermissions = ChatPermissions() | ||||
| ) = restrictChatMember(chat.id, userId, untilDate, permissions) | ||||
|  | ||||
| suspend fun RequestsExecutor.restrictChatMember( | ||||
|     chatId: ChatId, | ||||
|     user: User, | ||||
|     untilDate: TelegramDate? = null, | ||||
|     permissions: ChatPermissions = ChatPermissions() | ||||
| ) = restrictChatMember(chatId, user.id, untilDate, permissions) | ||||
|  | ||||
| suspend fun RequestsExecutor.restrictChatMember( | ||||
|     chat: PublicChat, | ||||
|     user: User, | ||||
|     untilDate: TelegramDate? = null, | ||||
|     permissions: ChatPermissions = ChatPermissions() | ||||
| ) = restrictChatMember(chat.id, user.id, untilDate, permissions) | ||||
|  | ||||
| @@ -0,0 +1,30 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.members | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.members.SetChatAdministratorCustomTitle | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
|  | ||||
| suspend fun RequestsExecutor.setChatAdministratorCustomTitle( | ||||
|     chatId: ChatId, | ||||
|     userId: UserId, | ||||
|     customTitle: String | ||||
| ) = execute(SetChatAdministratorCustomTitle(chatId, userId, customTitle)) | ||||
|  | ||||
| suspend fun RequestsExecutor.setChatAdministratorCustomTitle( | ||||
|     chat: PublicChat, | ||||
|     userId: UserId, | ||||
|     customTitle: String | ||||
| ) = setChatAdministratorCustomTitle(chat.id, userId, customTitle) | ||||
|  | ||||
| suspend fun RequestsExecutor.setChatAdministratorCustomTitle( | ||||
|     chatId: ChatId, | ||||
|     user: User, | ||||
|     customTitle: String | ||||
| ) = setChatAdministratorCustomTitle(chatId, user.id, customTitle) | ||||
|  | ||||
| suspend fun RequestsExecutor.setChatAdministratorCustomTitle( | ||||
|     chat: PublicChat, | ||||
|     user: User, | ||||
|     customTitle: String | ||||
| ) = setChatAdministratorCustomTitle(chat.id, user.id, customTitle) | ||||
| @@ -0,0 +1,27 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.members | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.members.UnbanChatMember | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
|  | ||||
| suspend fun RequestsExecutor.unbanChatMember( | ||||
|     chatId: ChatIdentifier, | ||||
|     userId: UserId | ||||
| ) = execute(UnbanChatMember(chatId, userId)) | ||||
|  | ||||
| suspend fun RequestsExecutor.unbanChatMember( | ||||
|     chat: PublicChat, | ||||
|     userId: UserId | ||||
| ) = unbanChatMember(chat.id, userId) | ||||
|  | ||||
| suspend fun RequestsExecutor.unbanChatMember( | ||||
|     chatId: ChatId, | ||||
|     user: User | ||||
| ) = unbanChatMember(chatId, user.id) | ||||
|  | ||||
| suspend fun RequestsExecutor.unbanChatMember( | ||||
|     chat: PublicChat, | ||||
|     user: User | ||||
| ) = unbanChatMember(chat.id, user.id) | ||||
|  | ||||
| @@ -0,0 +1,14 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.modify | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.modify.DeleteChatPhoto | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
|  | ||||
| suspend fun RequestsExecutor.deleteChatPhoto( | ||||
|     chatId: ChatIdentifier | ||||
| ) = execute(DeleteChatPhoto(chatId)) | ||||
|  | ||||
| suspend fun RequestsExecutor.deleteChatPhoto( | ||||
|     chat: PublicChat | ||||
| ) = deleteChatPhoto(chat.id) | ||||
| @@ -0,0 +1,29 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.modify | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.modify.PinChatMessage | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.Message | ||||
|  | ||||
| suspend fun RequestsExecutor.pinChatMessage( | ||||
|     chatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier, | ||||
|     disableNotification: Boolean = false | ||||
| ) = execute(PinChatMessage(chatId, messageId, disableNotification)) | ||||
|  | ||||
| suspend fun RequestsExecutor.pinChatMessage( | ||||
|     chat: PublicChat, | ||||
|     messageId: MessageIdentifier, | ||||
|     disableNotification: Boolean = false | ||||
| ) = pinChatMessage(chat.id, messageId, disableNotification) | ||||
|  | ||||
| suspend fun RequestsExecutor.pinChatMessage( | ||||
|     message: Message, | ||||
|     disableNotification: Boolean = false | ||||
| ) = if (message.chat is PublicChat) { | ||||
|     pinChatMessage(message.chat.id, message.messageId, disableNotification) | ||||
| } else { | ||||
|     error("It is possible to pin messages only in non one-to-one chats") | ||||
| } | ||||
| @@ -0,0 +1,16 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.modify | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.modify.SetChatDescription | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
|  | ||||
| suspend fun RequestsExecutor.setChatDescription( | ||||
|     chatId: ChatIdentifier, | ||||
|     description: String | ||||
| ) = execute(SetChatDescription(chatId, description)) | ||||
|  | ||||
| suspend fun RequestsExecutor.setChatDescription( | ||||
|     chat: PublicChat, | ||||
|     description: String | ||||
| ) = setChatDescription(chat.id, description) | ||||
| @@ -0,0 +1,17 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.modify | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.modify.SetChatPermissions | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.ChatPermissions | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
|  | ||||
| suspend fun RequestsExecutor.setDefaultChatMembersPermissions( | ||||
|     chatId: ChatIdentifier, | ||||
|     permissions: ChatPermissions | ||||
| ) = execute(SetChatPermissions(chatId, permissions)) | ||||
|  | ||||
| suspend fun RequestsExecutor.setDefaultChatMembersPermissions( | ||||
|     chat: PublicChat, | ||||
|     permissions: ChatPermissions | ||||
| ) = setDefaultChatMembersPermissions(chat.id, permissions) | ||||
| @@ -0,0 +1,17 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.modify | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.MultipartFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.modify.SetChatPhoto | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
|  | ||||
| suspend fun RequestsExecutor.setChatPhoto( | ||||
|     chatId: ChatIdentifier, | ||||
|     photo: MultipartFile | ||||
| ) = execute(SetChatPhoto(chatId, photo)) | ||||
|  | ||||
| suspend fun RequestsExecutor.setChatPhoto( | ||||
|     chat: PublicChat, | ||||
|     photo: MultipartFile | ||||
| ) = setChatPhoto(chat.id, photo) | ||||
| @@ -0,0 +1,16 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.modify | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.modify.SetChatTitle | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
|  | ||||
| suspend fun RequestsExecutor.setChatTitle( | ||||
|     chatId: ChatIdentifier, | ||||
|     title: String | ||||
| ) = execute(SetChatTitle(chatId, title)) | ||||
|  | ||||
| suspend fun RequestsExecutor.setChatTitle( | ||||
|     chat: PublicChat, | ||||
|     title: String | ||||
| ) = setChatTitle(chat.id, title) | ||||
| @@ -0,0 +1,14 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.modify | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.modify.UnpinChatMessage | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.PublicChat | ||||
|  | ||||
| suspend fun RequestsExecutor.unpinChatMessage( | ||||
|     chatId: ChatIdentifier | ||||
| ) = execute(UnpinChatMessage(chatId)) | ||||
|  | ||||
| suspend fun RequestsExecutor.unpinChatMessage( | ||||
|     chat: PublicChat | ||||
| ) = unpinChatMessage(chat.id) | ||||
| @@ -0,0 +1,14 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.stickers | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.stickers.DeleteChatStickerSet | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.SupergroupChat | ||||
|  | ||||
| suspend fun RequestsExecutor.deleteChatStickerSet( | ||||
|     chatId: ChatIdentifier | ||||
| ) = execute(DeleteChatStickerSet(chatId)) | ||||
|  | ||||
| suspend fun RequestsExecutor.deleteChatStickerSet( | ||||
|     chat: SupergroupChat | ||||
| ) = deleteChatStickerSet(chat.id) | ||||
| @@ -0,0 +1,17 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.chat.stickers | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.chat.stickers.SetChatStickerSet | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.StickerSetName | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.SupergroupChat | ||||
|  | ||||
| suspend fun RequestsExecutor.setChatStickerSet( | ||||
|     chatId: ChatIdentifier, | ||||
|     stickerSetName: StickerSetName | ||||
| ) = execute(SetChatStickerSet(chatId, stickerSetName)) | ||||
|  | ||||
| suspend fun RequestsExecutor.setChatStickerSet( | ||||
|     chat: SupergroupChat, | ||||
|     stickerSetName: StickerSetName | ||||
| ) = setChatStickerSet(chat.id, stickerSetName) | ||||
| @@ -0,0 +1,60 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.edit.LiveLocation | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.edit.LiveLocation.EditChatMessageLiveLocation | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.InlineKeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.ContentMessage | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.content.LocationContent | ||||
|  | ||||
| suspend fun RequestsExecutor.editLiveLocation( | ||||
|     chatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier, | ||||
|     latitude: Double, | ||||
|     longitude: Double, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     EditChatMessageLiveLocation( | ||||
|         chatId, messageId, latitude, longitude, replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.editLiveLocation( | ||||
|     chat: Chat, | ||||
|     messageId: MessageIdentifier, | ||||
|     latitude: Double, | ||||
|     longitude: Double, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = editLiveLocation(chat.id, messageId, latitude, longitude, replyMarkup) | ||||
|  | ||||
| suspend fun RequestsExecutor.editLiveLocation( | ||||
|     message: ContentMessage<LocationContent>, | ||||
|     latitude: Double, | ||||
|     longitude: Double, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = editLiveLocation(message.chat, message.messageId, latitude, longitude, replyMarkup) | ||||
|  | ||||
| suspend fun RequestsExecutor.editLiveLocation( | ||||
|     chatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier, | ||||
|     location: Location, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     EditChatMessageLiveLocation( | ||||
|         chatId, messageId, location.latitude, location.longitude, replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.editLiveLocation( | ||||
|     chat: Chat, | ||||
|     messageId: MessageIdentifier, | ||||
|     location: Location, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = editLiveLocation(chat.id, messageId, location.latitude, location.longitude, replyMarkup) | ||||
|  | ||||
| suspend fun RequestsExecutor.editLiveLocation( | ||||
|     message: ContentMessage<LocationContent>, | ||||
|     location: Location, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = editLiveLocation(message.chat, message.messageId, location.latitude, location.longitude, replyMarkup) | ||||
| @@ -0,0 +1,23 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.edit.LiveLocation | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.edit.LiveLocation.EditInlineMessageLiveLocation | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.InlineMessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.Location | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.InlineKeyboardMarkup | ||||
|  | ||||
| suspend fun RequestsExecutor.editLiveLocation( | ||||
|     inlineMessageId: InlineMessageIdentifier, | ||||
|     latitude: Double, | ||||
|     longitude: Double, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     EditInlineMessageLiveLocation( | ||||
|         inlineMessageId, latitude, longitude, replyMarkup | ||||
|     ) | ||||
| ) | ||||
| suspend fun RequestsExecutor.editLiveLocation( | ||||
|     inlineMessageId: InlineMessageIdentifier, | ||||
|     location: Location, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = editLiveLocation(inlineMessageId, location.latitude, location.longitude, replyMarkup) | ||||
| @@ -0,0 +1,31 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.edit.LiveLocation | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.edit.LiveLocation.StopChatMessageLiveLocation | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.InlineKeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.ContentMessage | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.content.LocationContent | ||||
|  | ||||
| suspend fun RequestsExecutor.stopLiveLocation( | ||||
|     chatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     StopChatMessageLiveLocation( | ||||
|         chatId, messageId, replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.stopLiveLocation( | ||||
|     chat: Chat, | ||||
|     messageId: MessageIdentifier, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = stopLiveLocation(chat.id, messageId, replyMarkup) | ||||
|  | ||||
| suspend fun RequestsExecutor.stopLiveLocation( | ||||
|     message: ContentMessage<LocationContent>, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = stopLiveLocation(message.chat, message.messageId, replyMarkup) | ||||
| @@ -0,0 +1,15 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.edit.LiveLocation | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.edit.LiveLocation.StopInlineMessageLiveLocation | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.InlineMessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.InlineKeyboardMarkup | ||||
|  | ||||
| suspend fun RequestsExecutor.stopLiveLocation( | ||||
|     inlineMessageId: InlineMessageIdentifier, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     StopInlineMessageLiveLocation( | ||||
|         inlineMessageId, replyMarkup | ||||
|     ) | ||||
| ) | ||||
| @@ -0,0 +1,29 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.edit.ReplyMarkup | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.edit.ReplyMarkup.EditChatMessageReplyMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.InlineKeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.Message | ||||
|  | ||||
| suspend fun RequestsExecutor.editMessageReplyMarkup( | ||||
|     chatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     EditChatMessageReplyMarkup(chatId, messageId, replyMarkup) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.editMessageReplyMarkup( | ||||
|     chat: Chat, | ||||
|     messageId: MessageIdentifier, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = editMessageReplyMarkup(chat.id, messageId, replyMarkup) | ||||
|  | ||||
| suspend fun RequestsExecutor.editMessageReplyMarkup( | ||||
|     message: Message, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = editMessageReplyMarkup(message.chat.id, message.messageId, replyMarkup) | ||||
|  | ||||
| @@ -0,0 +1,11 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.edit.ReplyMarkup | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.edit.ReplyMarkup.EditInlineMessageReplyMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.InlineMessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.InlineKeyboardMarkup | ||||
|  | ||||
| suspend fun RequestsExecutor.editMessageReplyMarkup( | ||||
|     inlineMessageId: InlineMessageIdentifier, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute(EditInlineMessageReplyMarkup(inlineMessageId, replyMarkup)) | ||||
| @@ -0,0 +1,39 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.edit.caption | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.CommonAbstracts.CaptionedInput | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.edit.caption.EditChatMessageCaption | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ParseMode.ParseMode | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.InlineKeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.ContentMessage | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.content.abstracts.MediaContent | ||||
|  | ||||
| suspend fun RequestsExecutor.editMessageCaption( | ||||
|     chatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier, | ||||
|     text: String, | ||||
|     parseMode: ParseMode? = null, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     EditChatMessageCaption(chatId, messageId, text, parseMode, replyMarkup) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.editMessageCaption( | ||||
|     chat: Chat, | ||||
|     messageId: MessageIdentifier, | ||||
|     text: String, | ||||
|     parseMode: ParseMode? = null, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = editMessageCaption(chat.id, messageId, text, parseMode, replyMarkup) | ||||
|  | ||||
| suspend fun <T> RequestsExecutor.editMessageCaption( | ||||
|     message: ContentMessage<T>, | ||||
|     text: String, | ||||
|     parseMode: ParseMode? = null, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ): ContentMessage<MediaContent> where T : CaptionedInput, T : MediaContent { | ||||
|     return editMessageCaption(message.chat.id, message.messageId, text, parseMode, replyMarkup) | ||||
| } | ||||
| @@ -0,0 +1,14 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.edit.caption | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.edit.caption.EditInlineMessageCaption | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.InlineMessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ParseMode.ParseMode | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.InlineKeyboardMarkup | ||||
|  | ||||
| suspend fun RequestsExecutor.editMessageCaption( | ||||
|     inlineMessageId: InlineMessageIdentifier, | ||||
|     text: String, | ||||
|     parseMode: ParseMode? = null, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute(EditInlineMessageCaption(inlineMessageId, text, parseMode, replyMarkup)) | ||||
| @@ -0,0 +1,33 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.edit.media | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.edit.media.EditChatMessageMedia | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.InputMedia.InputMedia | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.InlineKeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.ContentMessage | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.content.abstracts.MediaContent | ||||
|  | ||||
| suspend fun RequestsExecutor.editMessageMedia( | ||||
|     chatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier, | ||||
|     media: InputMedia, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     EditChatMessageMedia(chatId, messageId, media, replyMarkup) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.editMessageMedia( | ||||
|     chat: Chat, | ||||
|     messageId: MessageIdentifier, | ||||
|     media: InputMedia, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = editMessageMedia(chat.id, messageId, media, replyMarkup) | ||||
|  | ||||
| suspend fun RequestsExecutor.editMessageMedia( | ||||
|     message: ContentMessage<out MediaContent>, | ||||
|     media: InputMedia, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = editMessageMedia(message.chat.id, message.messageId, media, replyMarkup) | ||||
| @@ -0,0 +1,13 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.edit.media | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.edit.media.EditInlineMessageMedia | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.InlineMessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.InputMedia.InputMedia | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.InlineKeyboardMarkup | ||||
|  | ||||
| suspend fun RequestsExecutor.editMessageCaption( | ||||
|     inlineMessageId: InlineMessageIdentifier, | ||||
|     media: InputMedia, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute(EditInlineMessageMedia(inlineMessageId, media, replyMarkup)) | ||||
| @@ -0,0 +1,39 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.edit.text | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.edit.text.EditChatMessageText | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ParseMode.ParseMode | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.InlineKeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.ContentMessage | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.content.TextContent | ||||
|  | ||||
| suspend fun RequestsExecutor.editMessageText( | ||||
|     chatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier, | ||||
|     text: String, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableWebPagePreview: Boolean? = null, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     EditChatMessageText(chatId, messageId, text, parseMode, disableWebPagePreview, replyMarkup) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.editMessageText( | ||||
|     chat: Chat, | ||||
|     messageId: MessageIdentifier, | ||||
|     text: String, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableWebPagePreview: Boolean? = null, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = editMessageText(chat.id, messageId, text, parseMode, disableWebPagePreview, replyMarkup) | ||||
|  | ||||
| suspend fun RequestsExecutor.editMessageText( | ||||
|     message: ContentMessage<TextContent>, | ||||
|     text: String, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableWebPagePreview: Boolean? = null, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = editMessageText(message.chat.id, message.messageId, text, parseMode, disableWebPagePreview, replyMarkup) | ||||
| @@ -0,0 +1,15 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.edit.text | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.edit.text.EditInlineMessageText | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.InlineMessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ParseMode.ParseMode | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.InlineKeyboardMarkup | ||||
|  | ||||
| suspend fun RequestsExecutor.editMessageText( | ||||
|     inlineMessageId: InlineMessageIdentifier, | ||||
|     text: String, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableWebPagePreview: Boolean? = null, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute(EditInlineMessageText(inlineMessageId, text, parseMode, disableWebPagePreview, replyMarkup)) | ||||
| @@ -0,0 +1,54 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.games | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.games.GetGameHighScoresByChat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.ContentMessage | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.content.GameContent | ||||
|  | ||||
| suspend fun RequestsExecutor.getGameScore( | ||||
|     userId: UserId, | ||||
|     chatId: ChatId, | ||||
|     messageId: MessageIdentifier | ||||
| ) = execute( | ||||
|     GetGameHighScoresByChat(userId, chatId, messageId) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.getGameScore( | ||||
|     user: CommonUser, | ||||
|     chatId: ChatId, | ||||
|     messageId: MessageIdentifier | ||||
| ) = getGameScore( | ||||
|     user.id, chatId, messageId | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.getGameScore( | ||||
|     userId: UserId, | ||||
|     chat: Chat, | ||||
|     messageId: MessageIdentifier | ||||
| ) = getGameScore( | ||||
|     userId, chat.id, messageId | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.getGameScore( | ||||
|     user: CommonUser, | ||||
|     chat: Chat, | ||||
|     messageId: MessageIdentifier | ||||
| ) = getGameScore( | ||||
|     user.id, chat.id, messageId | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.getGameScore( | ||||
|     userId: UserId, | ||||
|     message: ContentMessage<GameContent> | ||||
| ) = getGameScore( | ||||
|     userId, message.chat.id, message.messageId | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.getGameScore( | ||||
|     user: CommonUser, | ||||
|     message: ContentMessage<GameContent> | ||||
| ) = getGameScore( | ||||
|     user.id, message.chat.id, message.messageId | ||||
| ) | ||||
| @@ -0,0 +1,19 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.games | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.games.GetGameHighScoresByInlineMessageId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
|  | ||||
| suspend fun RequestsExecutor.getGameScore( | ||||
|     userId: UserId, | ||||
|     inlineMessageId: InlineMessageIdentifier | ||||
| ) = execute( | ||||
|     GetGameHighScoresByInlineMessageId( | ||||
|         userId, inlineMessageId | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.getGameScore( | ||||
|     user: CommonUser, | ||||
|     inlineMessageId: InlineMessageIdentifier | ||||
| ) = getGameScore(user.id, inlineMessageId) | ||||
| @@ -0,0 +1,72 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.games | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.games.SetGameScoreByChatId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.abstracts.ContentMessage | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.message.content.GameContent | ||||
|  | ||||
| suspend fun RequestsExecutor.setGameScore( | ||||
|     userId: UserId, | ||||
|     score: Long, | ||||
|     chatId: ChatId, | ||||
|     messageId: MessageIdentifier, | ||||
|     force: Boolean = false, | ||||
|     disableEditMessage: Boolean = false | ||||
| ) = execute( | ||||
|     SetGameScoreByChatId(userId, score, chatId, messageId, force, disableEditMessage) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.setGameScore( | ||||
|     user: CommonUser, | ||||
|     score: Long, | ||||
|     chatId: ChatId, | ||||
|     messageId: MessageIdentifier, | ||||
|     force: Boolean = false, | ||||
|     disableEditMessage: Boolean = false | ||||
| ) = setGameScore( | ||||
|     user.id, score, chatId, messageId, force, disableEditMessage | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.setGameScore( | ||||
|     userId: UserId, | ||||
|     score: Long, | ||||
|     chat: Chat, | ||||
|     messageId: MessageIdentifier, | ||||
|     force: Boolean = false, | ||||
|     disableEditMessage: Boolean = false | ||||
| ) = setGameScore( | ||||
|     userId, score, chat.id, messageId, force, disableEditMessage | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.setGameScore( | ||||
|     user: CommonUser, | ||||
|     score: Long, | ||||
|     chat: Chat, | ||||
|     messageId: MessageIdentifier, | ||||
|     force: Boolean = false, | ||||
|     disableEditMessage: Boolean = false | ||||
| ) = setGameScore( | ||||
|     user.id, score, chat.id, messageId, force, disableEditMessage | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.setGameScore( | ||||
|     userId: UserId, | ||||
|     score: Long, | ||||
|     message: ContentMessage<GameContent>, | ||||
|     force: Boolean = false, | ||||
|     disableEditMessage: Boolean = false | ||||
| ) = setGameScore( | ||||
|     userId, score, message.chat.id, message.messageId, force, disableEditMessage | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.setGameScore( | ||||
|     user: CommonUser, | ||||
|     score: Long, | ||||
|     message: ContentMessage<GameContent>, | ||||
|     force: Boolean = false, | ||||
|     disableEditMessage: Boolean = false | ||||
| ) = setGameScore( | ||||
|     user.id, score, message.chat.id, message.messageId, force, disableEditMessage | ||||
| ) | ||||
| @@ -0,0 +1,25 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.games | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.games.SetGameScoreByInlineMessageId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
|  | ||||
| suspend fun RequestsExecutor.setGameScore( | ||||
|     userId: UserId, | ||||
|     score: Long, | ||||
|     inlineMessageId: InlineMessageIdentifier, | ||||
|     force: Boolean = false, | ||||
|     disableEditMessage: Boolean = false | ||||
| ) = execute( | ||||
|     SetGameScoreByInlineMessageId( | ||||
|         userId, score, inlineMessageId, force, disableEditMessage | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.setGameScore( | ||||
|     user: CommonUser, | ||||
|     score: Long, | ||||
|     inlineMessageId: InlineMessageIdentifier, | ||||
|     force: Boolean = false, | ||||
|     disableEditMessage: Boolean = false | ||||
| ) = setGameScore(user.id, score, inlineMessageId, force, disableEditMessage) | ||||
| @@ -0,0 +1,16 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.get | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.FileId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.get.GetFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.abstracts.TelegramMediaFile | ||||
|  | ||||
| suspend fun RequestsExecutor.getFileAdditionalInfo( | ||||
|     fileId: FileId | ||||
| ) = execute( | ||||
|     GetFile(fileId) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.getFileAdditionalInfo( | ||||
|     file: TelegramMediaFile | ||||
| ) = getFileAdditionalInfo(file.fileId) | ||||
| @@ -0,0 +1,17 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.get | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.get.GetStickerSet | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.Sticker | ||||
|  | ||||
| suspend fun RequestsExecutor.getStickerSet( | ||||
|     name: String | ||||
| ) = execute( | ||||
|     GetStickerSet(name) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.getStickerSet( | ||||
|     sticker: Sticker | ||||
| ) = getStickerSet( | ||||
|     sticker.stickerSetName ?: error("Sticker must contains stickerSetName to be correctly used in getStickerSet method") | ||||
| ) | ||||
| @@ -0,0 +1,22 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.get | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.get.GetUserProfilePhotos | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.CommonUser | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.UserId | ||||
|  | ||||
| suspend fun RequestsExecutor.getUserProfilePhotos( | ||||
|     userId: UserId, | ||||
|     offset: Int? = null, | ||||
|     limit: Int? = null | ||||
| ) = execute( | ||||
|     GetUserProfilePhotos( | ||||
|         userId, offset, limit | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.getUserProfilePhotos( | ||||
|     user: CommonUser, | ||||
|     offset: Int? = null, | ||||
|     limit: Int? = null | ||||
| ) = getUserProfilePhotos(user.id, offset, limit) | ||||
| @@ -0,0 +1,102 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.SendAction | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.actions.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
|  | ||||
| suspend fun RequestsExecutor.sendBotAction( | ||||
|     chatId: ChatIdentifier, | ||||
|     action: BotAction | ||||
| ) = execute( | ||||
|     SendAction(chatId, action) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendBotAction( | ||||
|     chat: Chat, | ||||
|     action: BotAction | ||||
| ) = sendBotAction(chat.id, action) | ||||
|  | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionTyping( | ||||
|     chatId: ChatIdentifier | ||||
| ) = sendBotAction(chatId, TypingAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionUploadPhoto( | ||||
|     chatId: ChatIdentifier | ||||
| ) = sendBotAction(chatId, UploadPhotoAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionRecordVideo( | ||||
|     chatId: ChatIdentifier | ||||
| ) = sendBotAction(chatId, RecordVideoAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionUploadVideo( | ||||
|     chatId: ChatIdentifier | ||||
| ) = sendBotAction(chatId, UploadVideoAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionRecordAudio( | ||||
|     chatId: ChatIdentifier | ||||
| ) = sendBotAction(chatId, RecordAudioAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionUploadAudio( | ||||
|     chatId: ChatIdentifier | ||||
| ) = sendBotAction(chatId, UploadAudioAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionUploadDocument( | ||||
|     chatId: ChatIdentifier | ||||
| ) = sendBotAction(chatId, UploadDocumentAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionFindLocation( | ||||
|     chatId: ChatIdentifier | ||||
| ) = sendBotAction(chatId, FindLocationAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionRecordVideoNote( | ||||
|     chatId: ChatIdentifier | ||||
| ) = sendBotAction(chatId, RecordVideoNoteAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionUploadVideoNote( | ||||
|     chatId: ChatIdentifier | ||||
| ) = sendBotAction(chatId, UploadVideoNoteAction) | ||||
|  | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionTyping( | ||||
|     chat: Chat | ||||
| ) = sendBotAction(chat, TypingAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionUploadPhoto( | ||||
|     chat: Chat | ||||
| ) = sendBotAction(chat, UploadPhotoAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionRecordVideo( | ||||
|     chat: Chat | ||||
| ) = sendBotAction(chat, RecordVideoAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionUploadVideo( | ||||
|     chat: Chat | ||||
| ) = sendBotAction(chat, UploadVideoAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionRecordAudio( | ||||
|     chat: Chat | ||||
| ) = sendBotAction(chat, RecordAudioAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionUploadAudio( | ||||
|     chat: Chat | ||||
| ) = sendBotAction(chat, UploadAudioAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionUploadDocument( | ||||
|     chat: Chat | ||||
| ) = sendBotAction(chat, UploadDocumentAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionFindLocation( | ||||
|     chat: Chat | ||||
| ) = sendBotAction(chat, FindLocationAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionRecordVideoNote( | ||||
|     chat: Chat | ||||
| ) = sendBotAction(chat, RecordVideoNoteAction) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendActionUploadVideoNote( | ||||
|     chat: Chat | ||||
| ) = sendBotAction(chat, UploadVideoNoteAction) | ||||
|  | ||||
| @@ -0,0 +1,55 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.SendContact | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
|  | ||||
| suspend fun RequestsExecutor.sendContact( | ||||
|     chatId: ChatIdentifier, | ||||
|     phoneNumber: String, | ||||
|     firstName: String, | ||||
|     lastName: String? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendContact( | ||||
|         chatId, phoneNumber, firstName, lastName, disableNotification, replyToMessageId, replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendContact( | ||||
|     chatId: ChatIdentifier, | ||||
|     contact: Contact, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendContact( | ||||
|         chatId, contact, disableNotification, replyToMessageId, replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendContact( | ||||
|     chat: Chat, | ||||
|     phoneNumber: String, | ||||
|     firstName: String, | ||||
|     lastName: String? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendContact( | ||||
|     chat.id, phoneNumber, firstName, lastName, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendContact( | ||||
|     chat: Chat, | ||||
|     contact: Contact, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendContact( | ||||
|     chat.id, contact, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
| @@ -0,0 +1,71 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.SendLocation | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
|  | ||||
| suspend fun RequestsExecutor.sendLocation( | ||||
|     chatId: ChatIdentifier, | ||||
|     latitude: Double, | ||||
|     longitude: Double, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendLocation( | ||||
|         chatId, | ||||
|         latitude, | ||||
|         longitude, | ||||
|         disableNotification = disableNotification, | ||||
|         replyToMessageId = replyToMessageId, | ||||
|         replyMarkup = replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendLocation( | ||||
|     chatId: ChatIdentifier, | ||||
|     location: Location, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendLocation( | ||||
|     chatId, | ||||
|     location.latitude, | ||||
|     location.longitude, | ||||
|     disableNotification, | ||||
|     replyToMessageId, | ||||
|     replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendLocation( | ||||
|     chat: Chat, | ||||
|     latitude: Double, | ||||
|     longitude: Double, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendLocation( | ||||
|     chat.id, | ||||
|     latitude, | ||||
|     longitude, | ||||
|     disableNotification, | ||||
|     replyToMessageId, | ||||
|     replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendLocation( | ||||
|     chat: Chat, | ||||
|     location: Location, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendLocation( | ||||
|     chat.id, | ||||
|     location.latitude, | ||||
|     location.longitude, | ||||
|     disableNotification, | ||||
|     replyToMessageId, | ||||
|     replyMarkup | ||||
| ) | ||||
| @@ -0,0 +1,54 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.SendTextMessage | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ParseMode.ParseMode | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
|  | ||||
| suspend fun RequestsExecutor.sendMessage( | ||||
|     chatId: ChatIdentifier, | ||||
|     text: String, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableWebPagePreview: Boolean? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendTextMessage(chatId, text, parseMode, disableWebPagePreview, disableNotification, replyToMessageId, replyMarkup) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendTextMessage( | ||||
|     chatId: ChatIdentifier, | ||||
|     text: String, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableWebPagePreview: Boolean? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendMessage( | ||||
|     chatId, text, parseMode, disableWebPagePreview, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendMessage( | ||||
|     chat: Chat, | ||||
|     text: String, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableWebPagePreview: Boolean? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendMessage(chat.id, text, parseMode, disableWebPagePreview, disableNotification, replyToMessageId, replyMarkup) | ||||
|  | ||||
|  | ||||
| suspend fun RequestsExecutor.sendTextMessage( | ||||
|     chat: Chat, | ||||
|     text: String, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableWebPagePreview: Boolean? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendTextMessage(chat.id, text, parseMode, disableWebPagePreview, disableNotification, replyToMessageId, replyMarkup) | ||||
| @@ -0,0 +1,59 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.SendVenue | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVenue( | ||||
|     chatId: ChatIdentifier, | ||||
|     latitude: Double, | ||||
|     longitude: Double, | ||||
|     title: String, | ||||
|     address: String, | ||||
|     foursquareId: String? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendVenue( | ||||
|         chatId, latitude, longitude, title, address, foursquareId, disableNotification, replyToMessageId, replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVenue( | ||||
|     chat: Chat, | ||||
|     latitude: Double, | ||||
|     longitude: Double, | ||||
|     title: String, | ||||
|     address: String, | ||||
|     foursquareId: String? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendVenue( | ||||
|     chat.id, latitude, longitude, title, address, foursquareId, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVenue( | ||||
|     chatId: ChatIdentifier, | ||||
|     venue: Venue, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendVenue( | ||||
|         chatId, venue, disableNotification, replyToMessageId, replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVenue( | ||||
|     chat: Chat, | ||||
|     venue: Venue, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendVenue( | ||||
|     chat.id, venue, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
| @@ -0,0 +1,51 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send.games | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.games.SendGame | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.games.Game | ||||
|  | ||||
| suspend fun RequestsExecutor.sendGame( | ||||
|     chatId: ChatIdentifier, | ||||
|     gameShortName: String, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendGame( | ||||
|         chatId, gameShortName, disableNotification, replyToMessageId, replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendGame( | ||||
|     chat: Chat, | ||||
|     gameShortName: String, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendGame( | ||||
|     chat.id, gameShortName, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendGame( | ||||
|     chatId: ChatIdentifier, | ||||
|     game: Game, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendGame( | ||||
|     chatId, game.title, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendGame( | ||||
|     chat: Chat, | ||||
|     game: Game, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendGame( | ||||
|     chat.id, game.title, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
| @@ -0,0 +1,167 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send.media | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.FileId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.MultipartFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.media.SendAnimation | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ParseMode.ParseMode | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.AnimationFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.PhotoSize | ||||
|  | ||||
| suspend fun RequestsExecutor.sendAnimation( | ||||
|     chatId: ChatIdentifier, | ||||
|     animation: FileId, | ||||
|     thumb: FileId? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     width: Int? = null, | ||||
|     height: Int? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendAnimation( | ||||
|         chatId, | ||||
|         animation, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         width, | ||||
|         height, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendAnimation( | ||||
|     chatId: ChatIdentifier, | ||||
|     animation: AnimationFile, | ||||
|     thumb: PhotoSize? = animation.thumb, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendAnimation( | ||||
|     chatId, animation.fileId, thumb ?.fileId, text, parseMode, animation.duration, animation.width, animation.height, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendAnimation( | ||||
|     chatId: ChatIdentifier, | ||||
|     animation: MultipartFile, | ||||
|     thumb: FileId? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     width: Int? = null, | ||||
|     height: Int? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendAnimation( | ||||
|         chatId, | ||||
|         animation, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         width, | ||||
|         height, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendAnimation( | ||||
|     chatId: ChatIdentifier, | ||||
|     animation: MultipartFile, | ||||
|     thumb: MultipartFile? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     width: Int? = null, | ||||
|     height: Int? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendAnimation( | ||||
|         chatId, | ||||
|         animation, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         width, | ||||
|         height, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendAnimation( | ||||
|     chatId: ChatIdentifier, | ||||
|     animation: FileId, | ||||
|     thumb: MultipartFile, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     width: Int? = null, | ||||
|     height: Int? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendAnimation( | ||||
|         chatId, | ||||
|         animation, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         width, | ||||
|         height, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendAnimation( | ||||
|     chatId: ChatIdentifier, | ||||
|     animation: MultipartFile, | ||||
|     thumb: PhotoSize? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     width: Int? = null, | ||||
|     height: Int? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendAnimation( | ||||
|     chatId, animation, thumb ?.fileId , text, parseMode, duration, width, height, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendAnimation( | ||||
|     chatId: ChatIdentifier, | ||||
|     animation: AnimationFile, | ||||
|     thumb: MultipartFile, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendAnimation( | ||||
|     chatId, animation.fileId, thumb, text, parseMode, animation.duration, animation.width, animation.height, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| @@ -0,0 +1,168 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send.media | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.FileId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.MultipartFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.media.SendAudio | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ParseMode.ParseMode | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.AudioFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.PhotoSize | ||||
|  | ||||
| suspend fun RequestsExecutor.sendAudio( | ||||
|     chatId: ChatIdentifier, | ||||
|     audio: FileId, | ||||
|     thumb: FileId? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     performer: String? = null, | ||||
|     title: String? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendAudio( | ||||
|         chatId, | ||||
|         audio, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         performer, | ||||
|         title, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendAudio( | ||||
|     chatId: ChatIdentifier, | ||||
|     audio: AudioFile, | ||||
|     thumb: PhotoSize? = audio.thumb, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     title: String? = audio.title, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendAudio( | ||||
|     chatId, audio.fileId, thumb ?.fileId, text, parseMode, audio.duration, audio.performer, title, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendAudio( | ||||
|     chatId: ChatIdentifier, | ||||
|     audio: MultipartFile, | ||||
|     thumb: FileId? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     performer: String? = null, | ||||
|     title: String? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendAudio( | ||||
|         chatId, | ||||
|         audio, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         performer, | ||||
|         title, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendAudio( | ||||
|     chatId: ChatIdentifier, | ||||
|     audio: MultipartFile, | ||||
|     thumb: MultipartFile? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     performer: String? = null, | ||||
|     title: String? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendAudio( | ||||
|         chatId, | ||||
|         audio, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         performer, | ||||
|         title, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendAudio( | ||||
|     chatId: ChatIdentifier, | ||||
|     audio: FileId, | ||||
|     thumb: MultipartFile, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     performer: String? = null, | ||||
|     title: String? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendAudio( | ||||
|         chatId, | ||||
|         audio, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         performer, | ||||
|         title, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendAudio( | ||||
|     chatId: ChatIdentifier, | ||||
|     audio: MultipartFile, | ||||
|     thumb: PhotoSize? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     performer: String? = null, | ||||
|     title: String? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendAudio( | ||||
|     chatId, audio, thumb ?.fileId , text, parseMode, duration, performer, title, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendAudio( | ||||
|     chatId: ChatIdentifier, | ||||
|     audio: AudioFile, | ||||
|     thumb: MultipartFile, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     title: String? = audio.title, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendAudio( | ||||
|     chatId, audio.fileId, thumb, text, parseMode, audio.duration, audio.performer, title, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
| @@ -0,0 +1,139 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send.media | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.FileId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.MultipartFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.media.SendDocument | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ParseMode.ParseMode | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.DocumentFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.PhotoSize | ||||
|  | ||||
| suspend fun RequestsExecutor.sendDocument( | ||||
|     chatId: ChatIdentifier, | ||||
|     document: FileId, | ||||
|     thumb: FileId? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendDocument( | ||||
|         chatId, | ||||
|         document, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendDocument( | ||||
|     chatId: ChatIdentifier, | ||||
|     document: DocumentFile, | ||||
|     thumb: PhotoSize? = document.thumb, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendDocument( | ||||
|     chatId, document.fileId, thumb ?.fileId, text, parseMode, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendDocument( | ||||
|     chatId: ChatIdentifier, | ||||
|     document: MultipartFile, | ||||
|     thumb: FileId? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendDocument( | ||||
|         chatId, | ||||
|         document, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendDocument( | ||||
|     chatId: ChatIdentifier, | ||||
|     document: MultipartFile, | ||||
|     thumb: MultipartFile? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendDocument( | ||||
|         chatId, | ||||
|         document, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendDocument( | ||||
|     chatId: ChatIdentifier, | ||||
|     document: FileId, | ||||
|     thumb: MultipartFile, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendDocument( | ||||
|         chatId, | ||||
|         document, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendDocument( | ||||
|     chatId: ChatIdentifier, | ||||
|     document: MultipartFile, | ||||
|     thumb: PhotoSize? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendDocument( | ||||
|     chatId, document, thumb ?.fileId , text, parseMode, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendDocument( | ||||
|     chatId: ChatIdentifier, | ||||
|     document: DocumentFile, | ||||
|     thumb: MultipartFile, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendDocument( | ||||
|     chatId, document.fileId, thumb, text, parseMode, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
| @@ -0,0 +1,28 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send.media | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.media.SendMediaGroup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.InputMedia.MediaGroupMemberInputMedia | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
|  | ||||
| suspend fun RequestsExecutor.sendMediaGroup( | ||||
|     chatId: ChatIdentifier, | ||||
|     media: List<MediaGroupMemberInputMedia>, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null | ||||
| ) = execute( | ||||
|     SendMediaGroup( | ||||
|         chatId, media, disableNotification, replyToMessageId | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendMediaGroup( | ||||
|     chat: Chat, | ||||
|     media: List<MediaGroupMemberInputMedia>, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null | ||||
| ) = sendMediaGroup( | ||||
|     chat.id, media, disableNotification, replyToMessageId | ||||
| ) | ||||
| @@ -0,0 +1,136 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send.media | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.FileId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.MultipartFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.media.SendPhoto | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ParseMode.ParseMode | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.* | ||||
|  | ||||
| suspend fun RequestsExecutor.sendPhoto( | ||||
|     chatId: ChatIdentifier, | ||||
|     fileId: FileId, | ||||
|     caption: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendPhoto( | ||||
|         chatId, | ||||
|         fileId, | ||||
|         caption, | ||||
|         parseMode, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendPhoto( | ||||
|     chatId: ChatIdentifier, | ||||
|     photo: MultipartFile, | ||||
|     caption: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendPhoto( | ||||
|         chatId, | ||||
|         photo, | ||||
|         caption, | ||||
|         parseMode, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendPhoto( | ||||
|     chatId: ChatIdentifier, | ||||
|     file: PhotoSize, | ||||
|     caption: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendPhoto( | ||||
|     chatId, file.fileId, caption, parseMode, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendPhoto( | ||||
|     chatId: ChatIdentifier, | ||||
|     photo: Photo, | ||||
|     caption: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendPhoto( | ||||
|     chatId, photo.biggest() ?: throw IllegalArgumentException("Photo $photo is empty"), caption, parseMode, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendPhoto( | ||||
|     chat: Chat, | ||||
|     fileId: FileId, | ||||
|     caption: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendPhoto( | ||||
|     chat.id, | ||||
|     fileId, | ||||
|     caption, | ||||
|     parseMode, | ||||
|     disableNotification, | ||||
|     replyToMessageId, | ||||
|     replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendPhoto( | ||||
|     chat: Chat, | ||||
|     file: PhotoSize, | ||||
|     caption: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendPhoto( | ||||
|     chat.id, file.fileId, caption, parseMode, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendPhoto( | ||||
|     chat: Chat, | ||||
|     photo: Photo, | ||||
|     caption: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendPhoto( | ||||
|     chat.id, photo.biggest() ?: throw IllegalArgumentException("Photo $photo is empty"), caption, parseMode, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendPhoto( | ||||
|     chat: Chat, | ||||
|     fileId: MultipartFile, | ||||
|     caption: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendPhoto( | ||||
|     chat.id, | ||||
|     fileId, | ||||
|     caption, | ||||
|     parseMode, | ||||
|     disableNotification, | ||||
|     replyToMessageId, | ||||
|     replyMarkup | ||||
| ) | ||||
| @@ -0,0 +1,66 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send.media | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.FileId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.MultipartFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.media.SendSticker | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.Sticker | ||||
|  | ||||
| suspend fun RequestsExecutor.sendSticker( | ||||
|     chatId: ChatIdentifier, | ||||
|     sticker: FileId, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendSticker(chatId, sticker, disableNotification, replyToMessageId, replyMarkup) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendSticker( | ||||
|     chatId: ChatIdentifier, | ||||
|     sticker: MultipartFile, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendSticker(chatId, sticker, disableNotification, replyToMessageId, replyMarkup) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendSticker( | ||||
|     chat: Chat, | ||||
|     sticker: FileId, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendSticker(chat.id, sticker, disableNotification, replyToMessageId, replyMarkup) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendSticker( | ||||
|     chat: Chat, | ||||
|     sticker: MultipartFile, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendSticker(chat.id, sticker, disableNotification, replyToMessageId, replyMarkup) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendSticker( | ||||
|     chatId: ChatIdentifier, | ||||
|     sticker: Sticker, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendSticker( | ||||
|     chatId, sticker.fileId, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendSticker( | ||||
|     chat: Chat, | ||||
|     sticker: Sticker, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendSticker(chat.id, sticker.fileId, disableNotification, replyToMessageId, replyMarkup) | ||||
|  | ||||
| @@ -0,0 +1,135 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send.media | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.FileId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.MultipartFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.media.SendVideo | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ParseMode.ParseMode | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.PhotoSize | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.VideoFile | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVideo( | ||||
|     chatId: ChatIdentifier, | ||||
|     video: FileId, | ||||
|     thumb: FileId? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     width: Int? = null, | ||||
|     height: Int? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendVideo( | ||||
|         chatId, | ||||
|         video, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         width, | ||||
|         height, | ||||
|         null, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVideo( | ||||
|     chatId: ChatIdentifier, | ||||
|     video: VideoFile, | ||||
|     thumb: PhotoSize? = video.thumb, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendVideo( | ||||
|     chatId, video.fileId, thumb ?.fileId, text, parseMode, video.duration, video.width, video.height, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVideo( | ||||
|     chatId: ChatIdentifier, | ||||
|     video: MultipartFile, | ||||
|     thumb: FileId? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     width: Int? = null, | ||||
|     height: Int? = null, | ||||
|     supportStreaming: Boolean? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendVideo(chatId, video, thumb, text, parseMode, duration, width, height, supportStreaming, disableNotification, replyToMessageId, replyMarkup) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVideo( | ||||
|     chatId: ChatIdentifier, | ||||
|     video: MultipartFile, | ||||
|     thumb: MultipartFile? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     width: Int? = null, | ||||
|     height: Int? = null, | ||||
|     supportStreaming: Boolean? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendVideo(chatId, video, thumb, text, parseMode, duration, width, height, supportStreaming, disableNotification, replyToMessageId, replyMarkup) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVideo( | ||||
|     chatId: ChatIdentifier, | ||||
|     video: FileId, | ||||
|     thumb: MultipartFile, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     width: Int? = null, | ||||
|     height: Int? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendVideo(chatId, video, thumb, text, parseMode, duration, width, height, null, disableNotification, replyToMessageId, replyMarkup) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVideo( | ||||
|     chatId: ChatIdentifier, | ||||
|     video: MultipartFile, | ||||
|     thumb: PhotoSize? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     width: Int? = null, | ||||
|     height: Int? = null, | ||||
|     supportStreaming: Boolean? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendVideo( | ||||
|     chatId, video, thumb ?.fileId , text, parseMode, duration, width, height, supportStreaming, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVideo( | ||||
|     chatId: ChatIdentifier, | ||||
|     video: VideoFile, | ||||
|     thumb: MultipartFile, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendVideo( | ||||
|     chatId, video.fileId, thumb, text, parseMode, video.duration, video.width, video.height, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| @@ -0,0 +1,157 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send.media | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.FileId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.MultipartFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.media.SendVideoNote | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ParseMode.ParseMode | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.PhotoSize | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.VideoFile | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVideoNote( | ||||
|     chatId: ChatIdentifier, | ||||
|     videoNote: FileId, | ||||
|     thumb: FileId? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     size: Int? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendVideoNote( | ||||
|         chatId, | ||||
|         videoNote, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         size, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVideoNote( | ||||
|     chatId: ChatIdentifier, | ||||
|     videoNote: VideoFile, | ||||
|     thumb: PhotoSize? = videoNote.thumb, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendVideoNote( | ||||
|     chatId, videoNote.fileId, thumb ?.fileId, text, parseMode, videoNote.duration, videoNote.width, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVideoNote( | ||||
|     chatId: ChatIdentifier, | ||||
|     videoNote: MultipartFile, | ||||
|     thumb: FileId? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     size: Int? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendVideoNote( | ||||
|         chatId, | ||||
|         videoNote, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         size, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVideoNote( | ||||
|     chatId: ChatIdentifier, | ||||
|     videoNote: MultipartFile, | ||||
|     thumb: MultipartFile? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     size: Int? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendVideoNote( | ||||
|         chatId, | ||||
|         videoNote, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         size, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVideoNote( | ||||
|     chatId: ChatIdentifier, | ||||
|     videoNote: FileId, | ||||
|     thumb: MultipartFile, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     size: Int? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendVideoNote( | ||||
|         chatId, | ||||
|         videoNote, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         size, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVideoNote( | ||||
|     chatId: ChatIdentifier, | ||||
|     videoNote: MultipartFile, | ||||
|     thumb: PhotoSize? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     size: Int? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendVideoNote( | ||||
|     chatId, videoNote, thumb ?.fileId , text, parseMode, duration, size, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVideoNote( | ||||
|     chatId: ChatIdentifier, | ||||
|     videoNote: VideoFile, | ||||
|     thumb: MultipartFile, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendVideoNote( | ||||
|     chatId, videoNote.fileId, thumb, text, parseMode, videoNote.duration, videoNote.width, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
| @@ -0,0 +1,149 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send.media | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.FileId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.MultipartFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.media.SendVoice | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ParseMode.ParseMode | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.AudioFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.PhotoSize | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVoice( | ||||
|     chatId: ChatIdentifier, | ||||
|     voice: FileId, | ||||
|     thumb: FileId? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendVoice( | ||||
|         chatId, | ||||
|         voice, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVoice( | ||||
|     chatId: ChatIdentifier, | ||||
|     voice: AudioFile, | ||||
|     thumb: PhotoSize? = voice.thumb, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendVoice( | ||||
|     chatId, voice.fileId, thumb ?.fileId, text, parseMode, voice.duration, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVoice( | ||||
|     chatId: ChatIdentifier, | ||||
|     voice: MultipartFile, | ||||
|     thumb: FileId? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendVoice( | ||||
|         chatId, | ||||
|         voice, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVoice( | ||||
|     chatId: ChatIdentifier, | ||||
|     voice: MultipartFile, | ||||
|     thumb: MultipartFile? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendVoice( | ||||
|         chatId, | ||||
|         voice, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVoice( | ||||
|     chatId: ChatIdentifier, | ||||
|     voice: FileId, | ||||
|     thumb: MultipartFile, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendVoice( | ||||
|         chatId, | ||||
|         voice, | ||||
|         thumb, | ||||
|         text, | ||||
|         parseMode, | ||||
|         duration, | ||||
|         disableNotification, | ||||
|         replyToMessageId, | ||||
|         replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVoice( | ||||
|     chatId: ChatIdentifier, | ||||
|     voice: MultipartFile, | ||||
|     thumb: PhotoSize? = null, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     duration: Long? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendVoice( | ||||
|     chatId, voice, thumb ?.fileId , text, parseMode, duration, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendVoice( | ||||
|     chatId: ChatIdentifier, | ||||
|     voice: AudioFile, | ||||
|     thumb: MultipartFile, | ||||
|     text: String? = null, | ||||
|     parseMode: ParseMode? = null, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendVoice( | ||||
|     chatId, voice.fileId, thumb, text, parseMode, voice.duration, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| @@ -0,0 +1,54 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send.payments | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.payments.SendInvoice | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.* | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.InlineKeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.payments.LabeledPrice | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.payments.abstracts.Currency | ||||
|  | ||||
| suspend fun RequestsExecutor.sendInvoice( | ||||
|     chatId: ChatId, | ||||
|     title: String, | ||||
|     description: String, | ||||
|     payload: String, | ||||
|     providerToken: String, | ||||
|     startParameter: StartParameter, | ||||
|     currency: Currency, | ||||
|     prices: List<LabeledPrice>, | ||||
|     providerData: String? = null, | ||||
|     requireName: Boolean = false, | ||||
|     requirePhoneNumber: Boolean = false, | ||||
|     requireEmail: Boolean = false, | ||||
|     requireShippingAddress: Boolean = false, | ||||
|     shouldSendPhoneNumberToProvider: Boolean = false, | ||||
|     shouldSendEmailToProvider: Boolean = false, | ||||
|     priceDependOnShipAddress: Boolean = false, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendInvoice(chatId, title, description, payload, providerToken, startParameter, currency, prices, providerData, requireName, requirePhoneNumber, requireEmail, requireShippingAddress, shouldSendPhoneNumberToProvider, shouldSendEmailToProvider, priceDependOnShipAddress, disableNotification, replyToMessageId, replyMarkup) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendInvoice( | ||||
|     user: CommonUser, | ||||
|     title: String, | ||||
|     description: String, | ||||
|     payload: String, | ||||
|     providerToken: String, | ||||
|     startParameter: StartParameter, | ||||
|     currency: Currency, | ||||
|     prices: List<LabeledPrice>, | ||||
|     providerData: String? = null, | ||||
|     requireName: Boolean = false, | ||||
|     requirePhoneNumber: Boolean = false, | ||||
|     requireEmail: Boolean = false, | ||||
|     requireShippingAddress: Boolean = false, | ||||
|     shouldSendPhoneNumberToProvider: Boolean = false, | ||||
|     shouldSendEmailToProvider: Boolean = false, | ||||
|     priceDependOnShipAddress: Boolean = false, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = sendInvoice(user.id, title, description, payload, providerToken, startParameter, currency, prices, providerData, requireName, requirePhoneNumber, requireEmail, requireShippingAddress, shouldSendPhoneNumberToProvider, shouldSendEmailToProvider, priceDependOnShipAddress, disableNotification, replyToMessageId, replyMarkup) | ||||
| @@ -0,0 +1,135 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.send.polls | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.polls.SendQuizPoll | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.send.polls.SendRegularPoll | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.ChatIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.MessageIdentifier | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.buttons.KeyboardMarkup | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.chat.abstracts.Chat | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.polls.QuizPoll | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.polls.RegularPoll | ||||
|  | ||||
| suspend fun RequestsExecutor.sendRegularPoll( | ||||
|     chatId: ChatIdentifier, | ||||
|     question: String, | ||||
|     options: List<String>, | ||||
|     isAnonymous: Boolean = true, | ||||
|     isClosed: Boolean = false, | ||||
|     allowMultipleAnswers: Boolean = false, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendRegularPoll( | ||||
|         chatId, question, options, isAnonymous, isClosed, allowMultipleAnswers, disableNotification, replyToMessageId, replyMarkup | ||||
|     ) | ||||
| ) | ||||
| suspend fun RequestsExecutor.sendRegularPoll( | ||||
|     chatId: ChatIdentifier, | ||||
|     poll: RegularPoll, | ||||
|     isClosed: Boolean = false, | ||||
|     question: String = poll.question, | ||||
|     options: List<String> = poll.options.map { it.text }, | ||||
|     isAnonymous: Boolean = poll.isAnonymous, | ||||
|     allowMultipleAnswers: Boolean = poll.allowMultipleAnswers, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendRegularPoll( | ||||
|         chatId, question, options, isAnonymous, isClosed, allowMultipleAnswers, disableNotification, replyToMessageId, replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendRegularPoll( | ||||
|     chat: Chat, | ||||
|     question: String, | ||||
|     options: List<String>, | ||||
|     isAnonymous: Boolean = true, | ||||
|     isClosed: Boolean = false, | ||||
|     allowMultipleAnswers: Boolean = false, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendRegularPoll( | ||||
|     chat.id, question, options, isAnonymous, isClosed, allowMultipleAnswers, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendRegularPoll( | ||||
|     chat: Chat, | ||||
|     poll: RegularPoll, | ||||
|     isClosed: Boolean = false, | ||||
|     question: String = poll.question, | ||||
|     options: List<String> = poll.options.map { it.text }, | ||||
|     isAnonymous: Boolean = poll.isAnonymous, | ||||
|     allowMultipleAnswers: Boolean = poll.allowMultipleAnswers, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendRegularPoll( | ||||
|     chat.id, question, options, isAnonymous, isClosed, allowMultipleAnswers, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
|  | ||||
| suspend fun RequestsExecutor.sendQuizPoll( | ||||
|     chatId: ChatIdentifier, | ||||
|     question: String, | ||||
|     options: List<String>, | ||||
|     correctOptionId: Int, | ||||
|     isAnonymous: Boolean = true, | ||||
|     isClosed: Boolean = false, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendQuizPoll( | ||||
|         chatId, question, options, correctOptionId, isAnonymous, isClosed, disableNotification, replyToMessageId, replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendQuizPoll( | ||||
|     chat: Chat, | ||||
|     question: String, | ||||
|     options: List<String>, | ||||
|     correctOptionId: Int, | ||||
|     isAnonymous: Boolean = true, | ||||
|     isClosed: Boolean = false, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendQuizPoll( | ||||
|     chat.id, question, options, correctOptionId, isAnonymous, isClosed, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendQuizPoll( | ||||
|     chatId: ChatIdentifier, | ||||
|     isClosed: Boolean = false, | ||||
|     quizPoll: QuizPoll, | ||||
|     question: String = quizPoll.question, | ||||
|     options: List<String> = quizPoll.options.map { it.text }, | ||||
|     correctOptionId: Int = quizPoll.correctOptionId ?: error("Correct option ID must be provided by income QuizPoll or by developer"), | ||||
|     isAnonymous: Boolean = quizPoll.isAnonymous, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = execute( | ||||
|     SendQuizPoll( | ||||
|         chatId, question, options, correctOptionId, isAnonymous, isClosed, disableNotification, replyToMessageId, replyMarkup | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.sendQuizPoll( | ||||
|     chat: Chat, | ||||
|     isClosed: Boolean = false, | ||||
|     quizPoll: QuizPoll, | ||||
|     question: String = quizPoll.question, | ||||
|     options: List<String> = quizPoll.options.map { it.text }, | ||||
|     correctOptionId: Int = quizPoll.correctOptionId ?: error("Correct option ID must be provided by income QuizPoll or by developer"), | ||||
|     isAnonymous: Boolean = quizPoll.isAnonymous, | ||||
|     disableNotification: Boolean = false, | ||||
|     replyToMessageId: MessageIdentifier? = null, | ||||
|     replyMarkup: KeyboardMarkup? = null | ||||
| ) = sendQuizPoll( | ||||
|     chat.id, question, options, correctOptionId, isAnonymous, isClosed, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
| @@ -0,0 +1,90 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.stickers | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.FileId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.MultipartFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.stickers.AddStickerToSet | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.CommonUser | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.UserId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.stickers.MaskPosition | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.stickers.StickerSet | ||||
|  | ||||
| suspend fun RequestsExecutor.addStickerToSet( | ||||
|     userId: UserId, | ||||
|     stickerSetName: String, | ||||
|     sticker: FileId, | ||||
|     emojis: String, | ||||
|     maskPosition: MaskPosition? = null | ||||
| ) = execute( | ||||
|     AddStickerToSet(userId, stickerSetName, sticker, emojis, maskPosition) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.addStickerToSet( | ||||
|     userId: UserId, | ||||
|     stickerSetName: String, | ||||
|     sticker: MultipartFile, | ||||
|     emojis: String, | ||||
|     maskPosition: MaskPosition? = null | ||||
| ) = execute( | ||||
|     AddStickerToSet(userId, stickerSetName, sticker, emojis, maskPosition) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.addStickerToSet( | ||||
|     user: CommonUser, | ||||
|     stickerSetName: String, | ||||
|     sticker: FileId, | ||||
|     emojis: String, | ||||
|     maskPosition: MaskPosition? = null | ||||
| ) = addStickerToSet( | ||||
|     user.id, stickerSetName, sticker, emojis, maskPosition | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.addStickerToSet( | ||||
|     user: CommonUser, | ||||
|     stickerSetName: String, | ||||
|     sticker: MultipartFile, | ||||
|     emojis: String, | ||||
|     maskPosition: MaskPosition? = null | ||||
| ) = addStickerToSet( | ||||
|     user.id, stickerSetName, sticker, emojis, maskPosition | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.addStickerToSet( | ||||
|     userId: UserId, | ||||
|     stickerSet: StickerSet, | ||||
|     sticker: FileId, | ||||
|     emojis: String, | ||||
|     maskPosition: MaskPosition? = null | ||||
| ) = addStickerToSet( | ||||
|     userId, stickerSet.name, sticker, emojis, maskPosition | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.addStickerToSet( | ||||
|     userId: UserId, | ||||
|     stickerSet: StickerSet, | ||||
|     sticker: MultipartFile, | ||||
|     emojis: String, | ||||
|     maskPosition: MaskPosition? = null | ||||
| ) = addStickerToSet( | ||||
|     userId, stickerSet.name, sticker, emojis, maskPosition | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.addStickerToSet( | ||||
|     user: CommonUser, | ||||
|     stickerSet: StickerSet, | ||||
|     sticker: FileId, | ||||
|     emojis: String, | ||||
|     maskPosition: MaskPosition? = null | ||||
| ) = addStickerToSet( | ||||
|     user.id, stickerSet.name, sticker, emojis, maskPosition | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.addStickerToSet( | ||||
|     user: CommonUser, | ||||
|     stickerSet: StickerSet, | ||||
|     sticker: MultipartFile, | ||||
|     emojis: String, | ||||
|     maskPosition: MaskPosition? = null | ||||
| ) = addStickerToSet( | ||||
|     user.id, stickerSet.name, sticker, emojis, maskPosition | ||||
| ) | ||||
| @@ -0,0 +1,54 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.stickers | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.FileId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.MultipartFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.stickers.CreateNewStickerSet | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.CommonUser | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.UserId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.stickers.MaskPosition | ||||
|  | ||||
| suspend fun RequestsExecutor.createNewStickerSet( | ||||
|     userId: UserId, | ||||
|     name: String, | ||||
|     sticker: FileId, | ||||
|     emojis: String, | ||||
|     containsMasks: Boolean? = null, | ||||
|     maskPosition: MaskPosition? = null | ||||
| ) = execute( | ||||
|     CreateNewStickerSet(userId, name, sticker, emojis, containsMasks, maskPosition) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.createNewStickerSet( | ||||
|     userId: UserId, | ||||
|     name: String, | ||||
|     sticker: MultipartFile, | ||||
|     emojis: String, | ||||
|     containsMasks: Boolean? = null, | ||||
|     maskPosition: MaskPosition? = null | ||||
| ) = execute( | ||||
|     CreateNewStickerSet(userId, name, sticker, emojis, containsMasks, maskPosition) | ||||
| ) | ||||
|  | ||||
|  | ||||
| suspend fun RequestsExecutor.createNewStickerSet( | ||||
|     user: CommonUser, | ||||
|     name: String, | ||||
|     sticker: FileId, | ||||
|     emojis: String, | ||||
|     containsMasks: Boolean? = null, | ||||
|     maskPosition: MaskPosition? = null | ||||
| ) = createNewStickerSet( | ||||
|     user.id, name, sticker, emojis, containsMasks, maskPosition | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.createNewStickerSet( | ||||
|     user: CommonUser, | ||||
|     name: String, | ||||
|     sticker: MultipartFile, | ||||
|     emojis: String, | ||||
|     containsMasks: Boolean? = null, | ||||
|     maskPosition: MaskPosition? = null | ||||
| ) = createNewStickerSet( | ||||
|     user.id, name, sticker, emojis, containsMasks, maskPosition | ||||
| ) | ||||
| @@ -0,0 +1,20 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.stickers | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.FileId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.stickers.DeleteStickerFromSet | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.Sticker | ||||
|  | ||||
| suspend fun RequestsExecutor.deleteStickerFromSet( | ||||
|     sticker: FileId | ||||
| ) = execute( | ||||
|     DeleteStickerFromSet( | ||||
|         sticker | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.deleteStickerFromSet( | ||||
|     sticker: Sticker | ||||
| ) = deleteStickerFromSet( | ||||
|     sticker.fileId | ||||
| ) | ||||
| @@ -0,0 +1,24 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.stickers | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.FileId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.stickers.SetStickerPositionInSet | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.files.Sticker | ||||
|  | ||||
| suspend fun RequestsExecutor.setStickerPositionInSet( | ||||
|     sticker: FileId, | ||||
|     position: Int | ||||
| ) = execute( | ||||
|     SetStickerPositionInSet( | ||||
|         sticker, | ||||
|         position | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.setStickerPositionInSet( | ||||
|     sticker: Sticker, | ||||
|     position: Int | ||||
| ) = setStickerPositionInSet( | ||||
|     sticker.fileId, | ||||
|     position | ||||
| ) | ||||
| @@ -0,0 +1,21 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.stickers | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.MultipartFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.stickers.UploadStickerFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.CommonUser | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.types.UserId | ||||
|  | ||||
| suspend fun RequestsExecutor.uploadStickerFile( | ||||
|     userId: UserId, | ||||
|     sticker: MultipartFile | ||||
| ) = execute( | ||||
|     UploadStickerFile(userId, sticker) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.uploadStickerFile( | ||||
|     user: CommonUser, | ||||
|     sticker: MultipartFile | ||||
| ) = execute( | ||||
|     UploadStickerFile(user.id, sticker) | ||||
| ) | ||||
| @@ -0,0 +1,6 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.webhook | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.webhook.DeleteWebhook | ||||
|  | ||||
| suspend fun RequestsExecutor.deleteWebhook() = execute(DeleteWebhook()) | ||||
| @@ -0,0 +1,6 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.webhook | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.webhook.GetWebhookInfo | ||||
|  | ||||
| suspend fun RequestsExecutor.getWebhookInfo() = execute(GetWebhookInfo()) | ||||
| @@ -0,0 +1,28 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.extensions.api.webhook | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.RequestsExecutor | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.FileId | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.MultipartFile | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.webhook.SetWebhook | ||||
|  | ||||
| suspend fun RequestsExecutor.setWebhookInfo( | ||||
|     url: String, | ||||
|     certificate: FileId, | ||||
|     maxAllowedConnections: Int? = null, | ||||
|     allowedUpdates: List<String>? = null | ||||
| ) = execute( | ||||
|     SetWebhook( | ||||
|         url, certificate, maxAllowedConnections, allowedUpdates | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| suspend fun RequestsExecutor.setWebhookInfo( | ||||
|     url: String, | ||||
|     certificate: MultipartFile, | ||||
|     maxAllowedConnections: Int? = null, | ||||
|     allowedUpdates: List<String>? = null | ||||
| ) = execute( | ||||
|     SetWebhook( | ||||
|         url, certificate, maxAllowedConnections, allowedUpdates | ||||
|     ) | ||||
| ) | ||||
| @@ -24,6 +24,7 @@ data class DeleteMessage( | ||||
|         get() = serializer() | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.deleteMessage( | ||||
|     chatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier | ||||
| @@ -31,11 +32,13 @@ suspend fun RequestsExecutor.deleteMessage( | ||||
|     DeleteMessage(chatId, messageId) | ||||
| ) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.deleteMessage( | ||||
|     chat: Chat, | ||||
|     messageId: MessageIdentifier | ||||
| ) = deleteMessage(chat.id, messageId) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.deleteMessage( | ||||
|     message: Message | ||||
| ) = deleteMessage(message.chat, message.messageId) | ||||
|   | ||||
| @@ -32,6 +32,7 @@ data class ForwardMessage( | ||||
|         get() = serializer() | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.forwardMessage( | ||||
|     fromChatId: ChatIdentifier, | ||||
|     toChatId: ChatIdentifier, | ||||
| @@ -41,6 +42,7 @@ suspend fun RequestsExecutor.forwardMessage( | ||||
|     ForwardMessage(fromChatId, toChatId, messageId, disableNotification) | ||||
| ) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.forwardMessage( | ||||
|     fromChat: Chat, | ||||
|     toChatId: ChatIdentifier, | ||||
| @@ -48,6 +50,7 @@ suspend fun RequestsExecutor.forwardMessage( | ||||
|     disableNotification: Boolean = false | ||||
| ) = forwardMessage(fromChat.id, toChatId, messageId, disableNotification) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.forwardMessage( | ||||
|     fromChatId: ChatIdentifier, | ||||
|     toChat: Chat, | ||||
| @@ -55,6 +58,7 @@ suspend fun RequestsExecutor.forwardMessage( | ||||
|     disableNotification: Boolean = false | ||||
| ) = forwardMessage(fromChatId, toChat.id, messageId, disableNotification) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.forwardMessage( | ||||
|     fromChat: Chat, | ||||
|     toChat: Chat, | ||||
| @@ -62,12 +66,14 @@ suspend fun RequestsExecutor.forwardMessage( | ||||
|     disableNotification: Boolean = false | ||||
| ) = forwardMessage(fromChat.id, toChat.id, messageId, disableNotification) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.forwardMessage( | ||||
|     toChatId: ChatIdentifier, | ||||
|     message: Message, | ||||
|     disableNotification: Boolean = false | ||||
| ) = forwardMessage(message.chat, toChatId, message.messageId, disableNotification) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.forwardMessage( | ||||
|     toChat: Chat, | ||||
|     message: Message, | ||||
|   | ||||
| @@ -14,4 +14,5 @@ class GetMe : SimpleRequest<ExtendedBot> { | ||||
|         get() = serializer() | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.getMe() = execute(GetMe()) | ||||
| @@ -29,6 +29,7 @@ data class GetUpdates( | ||||
|         get() = serializer() | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.getUpdates( | ||||
|     offset: UpdateIdentifier? = null, | ||||
|     limit: Int? = null, | ||||
| @@ -40,6 +41,7 @@ suspend fun RequestsExecutor.getUpdates( | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.getUpdates( | ||||
|     lastUpdate: Update, | ||||
|     limit: Int? = null, | ||||
|   | ||||
| @@ -18,6 +18,7 @@ import kotlinx.coroutines.launch | ||||
| import kotlin.math.ceil | ||||
|  | ||||
| private val livePeriodDelayMillis = (livePeriodLimit.last - 60L) * 1000L | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| class LiveLocation internal constructor( | ||||
|     private val requestsExecutor: RequestsExecutor, | ||||
|     scope: CoroutineScope, | ||||
| @@ -66,6 +67,7 @@ class LiveLocation internal constructor( | ||||
|     } | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.startLiveLocation( | ||||
|     scope: CoroutineScope, | ||||
|     chatId: ChatIdentifier, | ||||
| @@ -97,6 +99,7 @@ suspend fun RequestsExecutor.startLiveLocation( | ||||
|     ) | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.startLiveLocation( | ||||
|     scope: CoroutineScope, | ||||
|     chat: Chat, | ||||
| @@ -110,6 +113,7 @@ suspend fun RequestsExecutor.startLiveLocation( | ||||
|     scope, chat.id, latitude, longitude, liveTimeMillis, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.startLiveLocation( | ||||
|     scope: CoroutineScope, | ||||
|     chatId: ChatId, | ||||
| @@ -122,6 +126,7 @@ suspend fun RequestsExecutor.startLiveLocation( | ||||
|     scope, chatId, location.latitude, location.longitude, liveTimeMillis, disableNotification, replyToMessageId, replyMarkup | ||||
| ) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.startLiveLocation( | ||||
|     scope: CoroutineScope, | ||||
|     chat: Chat, | ||||
|   | ||||
| @@ -27,6 +27,7 @@ data class StopPoll( | ||||
|         get() = serializer() | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.stopPoll( | ||||
|     chatId: ChatIdentifier, | ||||
|     messageId: MessageIdentifier, | ||||
| @@ -35,18 +36,21 @@ suspend fun RequestsExecutor.stopPoll( | ||||
|     StopPoll(chatId, messageId, replyMarkup) | ||||
| ) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.stopPoll( | ||||
|     chat: Chat, | ||||
|     messageId: MessageIdentifier, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = stopPoll(chat.id, messageId, replyMarkup) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.stopPoll( | ||||
|     chatId: ChatId, | ||||
|     message: Message, | ||||
|     replyMarkup: InlineKeyboardMarkup? = null | ||||
| ) = stopPoll(chatId, message.messageId, replyMarkup) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.stopPoll( | ||||
|     chat: Chat, | ||||
|     message: Message, | ||||
|   | ||||
| @@ -34,6 +34,7 @@ fun CallbackQuery.createAnswer( | ||||
|     cachedTimeSeconds: Int? = null | ||||
| ): AnswerCallbackQuery = AnswerCallbackQuery(id, text, showAlert, url, cachedTimeSeconds) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.answerCallbackQuery( | ||||
|     callbackQueryId: CallbackQueryIdentifier, | ||||
|     text: String? = null, | ||||
| @@ -42,6 +43,7 @@ suspend fun RequestsExecutor.answerCallbackQuery( | ||||
|     cachedTimeSeconds: Int? = null | ||||
| ) = execute(AnswerCallbackQuery(callbackQueryId, text, showAlert, url, cachedTimeSeconds)) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.answerCallbackQuery( | ||||
|     callbackQuery: CallbackQuery, | ||||
|     text: String? = null, | ||||
|   | ||||
| @@ -52,6 +52,7 @@ fun InlineQuery.createAnswer( | ||||
|     switchPmParameter | ||||
| ) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.answerInlineQuery( | ||||
|     inlineQueryID: InlineQueryIdentifier, | ||||
|     results: List<InlineQueryResult> = emptyList(), | ||||
| @@ -64,6 +65,7 @@ suspend fun RequestsExecutor.answerInlineQuery( | ||||
|     AnswerInlineQuery(inlineQueryID, results, cachedTime, isPersonal, nextOffset, switchPmText, switchPmParameter) | ||||
| ) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.answerInlineQuery( | ||||
|     inlineQuery: InlineQuery, | ||||
|     results: List<InlineQueryResult> = emptyList(), | ||||
|   | ||||
| @@ -42,17 +42,21 @@ fun PreCheckoutQuery.createAnswerError( | ||||
|     error | ||||
| ) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.answerPreCheckoutQueryOk( | ||||
|     id: PreCheckoutQueryId | ||||
| ) = execute(AnswerPreCheckoutQueryOk(id)) | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.answerPreCheckoutQueryOk( | ||||
|     preCheckoutQuery: PreCheckoutQuery | ||||
| ) = answerPreCheckoutQueryOk(preCheckoutQuery.id) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.answerPreCheckoutQueryError( | ||||
|     id: PreCheckoutQueryId, | ||||
|     error: String | ||||
| ) = execute(AnswerPreCheckoutQueryError(id, error)) | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.answerPreCheckoutQueryError( | ||||
|     preCheckoutQuery: PreCheckoutQuery, | ||||
|     error: String | ||||
|   | ||||
| @@ -53,19 +53,23 @@ fun ShippingQuery.createAnswerError( | ||||
|     error | ||||
| ) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.answerShippingQueryOk( | ||||
|     id: ShippingQueryIdentifier, | ||||
|     shippingOptions: List<ShippingOption> | ||||
| ) = execute(AnswerShippingQueryOk(id, shippingOptions)) | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.answerShippingQueryOk( | ||||
|     shippingQuery: ShippingQuery, | ||||
|     shippingOptions: List<ShippingOption> | ||||
| ) = answerShippingQueryOk(shippingQuery.id, shippingOptions) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.answerShippingQueryError( | ||||
|     id: ShippingQueryIdentifier, | ||||
|     error: String | ||||
| ) = execute(AnswerShippingQueryError(id, error)) | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.answerShippingQueryError( | ||||
|     shippingQuery: ShippingQuery, | ||||
|     error: String | ||||
|   | ||||
| @@ -21,10 +21,12 @@ data class ExportChatInviteLink( | ||||
|         get() = serializer() | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.exportChatInviteLink( | ||||
|     chatId: ChatIdentifier | ||||
| ) = execute(ExportChatInviteLink(chatId)) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.exportChatInviteLink( | ||||
|     chat: PublicChat | ||||
| ) = exportChatInviteLink(chat.id) | ||||
|   | ||||
| @@ -21,10 +21,12 @@ data class LeaveChat( | ||||
|         get() = serializer() | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.leaveChat( | ||||
|     chatId: ChatIdentifier | ||||
| ) = execute(LeaveChat(chatId)) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.leaveChat( | ||||
|     chat: PublicChat | ||||
| ) = leaveChat(chat.id) | ||||
|   | ||||
| @@ -22,10 +22,12 @@ data class GetChat( | ||||
|         get() = serializer() | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.getChat( | ||||
|     chatId: ChatIdentifier | ||||
| ) = execute(GetChat(chatId)) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.getChat( | ||||
|     chat: Chat | ||||
| ) = getChat(chat.id) | ||||
|   | ||||
| @@ -27,10 +27,12 @@ data class GetChatAdministrators( | ||||
|         get() = serializer() | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.getChatAdministrators( | ||||
|     chatId: ChatIdentifier | ||||
| ) = execute(GetChatAdministrators(chatId)) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.getChatAdministrators( | ||||
|     chat: PublicChat | ||||
| ) = getChatAdministrators(chat.id) | ||||
|   | ||||
| @@ -21,10 +21,12 @@ data class GetChatMembersCount( | ||||
|         get() = serializer() | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.getChatMembersCount( | ||||
|     chatId: ChatIdentifier | ||||
| ) = execute(GetChatMembersCount(chatId)) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.getChatMembersCount( | ||||
|     chat: PublicChat | ||||
| ) = getChatMembersCount(chat.id) | ||||
|   | ||||
| @@ -22,21 +22,25 @@ data class GetChatMember( | ||||
|         get() = serializer() | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.getChatMember( | ||||
|     chatId: ChatIdentifier, | ||||
|     userId: UserId | ||||
| ) = execute(GetChatMember(chatId, userId)) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.getChatMember( | ||||
|     chat: PublicChat, | ||||
|     userId: UserId | ||||
| ) = getChatMember(chat.id, userId) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.getChatMember( | ||||
|     chatId: ChatId, | ||||
|     user: User | ||||
| ) = getChatMember(chatId, user.id) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.getChatMember( | ||||
|     chat: PublicChat, | ||||
|     user: User | ||||
|   | ||||
| @@ -24,24 +24,28 @@ data class KickChatMember( | ||||
|         get() = serializer() | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.kickChatMember( | ||||
|     chatId: ChatIdentifier, | ||||
|     userId: UserId, | ||||
|     untilDate: TelegramDate? = null | ||||
| ) = execute(KickChatMember(chatId, userId, untilDate)) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.kickChatMember( | ||||
|     chat: PublicChat, | ||||
|     userId: UserId, | ||||
|     untilDate: TelegramDate? = null | ||||
| ) = kickChatMember(chat.id, userId, untilDate) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.kickChatMember( | ||||
|     chatId: ChatId, | ||||
|     user: User, | ||||
|     untilDate: TelegramDate? = null | ||||
| ) = kickChatMember(chatId, user.id, untilDate) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.kickChatMember( | ||||
|     chat: PublicChat, | ||||
|     user: User, | ||||
|   | ||||
| @@ -40,6 +40,7 @@ data class PromoteChatMember( | ||||
|         get() = serializer() | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.promoteChatMember( | ||||
|     chatId: ChatIdentifier, | ||||
|     userId: UserId, | ||||
| @@ -68,6 +69,7 @@ suspend fun RequestsExecutor.promoteChatMember( | ||||
|     ) | ||||
| ) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.promoteChatMember( | ||||
|     chat: PublicChat, | ||||
|     userId: UserId, | ||||
| @@ -94,6 +96,7 @@ suspend fun RequestsExecutor.promoteChatMember( | ||||
|     canPromoteMembers | ||||
| ) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.promoteChatMember( | ||||
|     chatId: ChatId, | ||||
|     user: User, | ||||
| @@ -120,6 +123,7 @@ suspend fun RequestsExecutor.promoteChatMember( | ||||
|     canPromoteMembers | ||||
| ) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.promoteChatMember( | ||||
|     chat: PublicChat, | ||||
|     user: User, | ||||
|   | ||||
| @@ -27,6 +27,7 @@ data class RestrictChatMember( | ||||
|         get() = serializer() | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.restrictChatMember( | ||||
|     chatId: ChatIdentifier, | ||||
|     userId: UserId, | ||||
| @@ -34,6 +35,7 @@ suspend fun RequestsExecutor.restrictChatMember( | ||||
|     permissions: ChatPermissions = ChatPermissions() | ||||
| ) = execute(RestrictChatMember(chatId, userId, untilDate, permissions)) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.restrictChatMember( | ||||
|     chat: PublicChat, | ||||
|     userId: UserId, | ||||
| @@ -41,6 +43,7 @@ suspend fun RequestsExecutor.restrictChatMember( | ||||
|     permissions: ChatPermissions = ChatPermissions() | ||||
| ) = restrictChatMember(chat.id, userId, untilDate, permissions) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.restrictChatMember( | ||||
|     chatId: ChatId, | ||||
|     user: User, | ||||
| @@ -48,6 +51,7 @@ suspend fun RequestsExecutor.restrictChatMember( | ||||
|     permissions: ChatPermissions = ChatPermissions() | ||||
| ) = restrictChatMember(chatId, user.id, untilDate, permissions) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.restrictChatMember( | ||||
|     chat: PublicChat, | ||||
|     user: User, | ||||
|   | ||||
| @@ -34,24 +34,28 @@ data class SetChatAdministratorCustomTitle( | ||||
|     } | ||||
| } | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.setChatAdministratorCustomTitle( | ||||
|     chatId: ChatId, | ||||
|     userId: UserId, | ||||
|     customTitle: String | ||||
| ) = execute(SetChatAdministratorCustomTitle(chatId, userId, customTitle)) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.setChatAdministratorCustomTitle( | ||||
|     chat: PublicChat, | ||||
|     userId: UserId, | ||||
|     customTitle: String | ||||
| ) = setChatAdministratorCustomTitle(chat.id, userId, customTitle) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.setChatAdministratorCustomTitle( | ||||
|     chatId: ChatId, | ||||
|     user: User, | ||||
|     customTitle: String | ||||
| ) = setChatAdministratorCustomTitle(chatId, user.id, customTitle) | ||||
|  | ||||
| @Deprecated("Deprecated due to extracting into separated library") | ||||
| suspend fun RequestsExecutor.setChatAdministratorCustomTitle( | ||||
|     chat: PublicChat, | ||||
|     user: User, | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user