{-# LANGUAGE DataKinds #-}
{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE CPP #-}
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE TypeOperators #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE LambdaCase #-}
module Telegram.Bot.API.Stickers where
import Control.Monad.IO.Class
import Data.Aeson
#if MIN_VERSION_aeson(2,0,0)
import Data.Aeson.Key (fromText)
#endif
import Data.Aeson.Text
import Data.Bool
import Data.Text (Text)
import qualified Data.Text as T
import qualified Data.Text.Lazy as TL
import Data.Proxy
import GHC.Generics (Generic)
import Servant.API
import Servant.Client hiding (Response)
import Servant.Multipart.API
import Servant.Multipart.Client
import Telegram.Bot.API.Internal.Utils
import Telegram.Bot.API.MakingRequests (Response)
import Telegram.Bot.API.Types
import Data.Maybe (catMaybes, maybeToList)
import Data.Functor
data StickerType
= PngSticker
| TgsSticker
| WebmSticker
stickerLabel :: StickerType -> T.Text
stickerLabel :: StickerType -> Text
stickerLabel = \case
StickerType
PngSticker -> Text
"png_sticker"
StickerType
TgsSticker -> Text
"tgs_sticker"
StickerType
WebmSticker -> Text
"webm_sticker"
data StickerFile = StickerFile {StickerFile -> InputFile
stickerFileSticker :: InputFile, StickerFile -> StickerType
stickerFileLabel :: StickerType}
data SendStickerRequest = SendStickerRequest
{ SendStickerRequest -> SomeChatId
sendStickerChatId :: SomeChatId
, SendStickerRequest -> Maybe MessageThreadId
sendStickerMessageThreadId :: Maybe MessageThreadId
, SendStickerRequest -> InputFile
sendStickerSticker :: InputFile
, SendStickerRequest -> Maybe Bool
sendStickerDisableNotification :: Maybe Bool
, SendStickerRequest -> Maybe Bool
sendStickerProtectContent :: Maybe Bool
, SendStickerRequest -> Maybe MessageId
sendStickerReplyToMessageId :: Maybe MessageId
, SendStickerRequest -> Maybe Bool
sendStickerAllowSendingWithoutReply :: Maybe Bool
, SendStickerRequest -> Maybe InlineKeyboardMarkup
sendStickerReplyMarkup :: Maybe InlineKeyboardMarkup
}
deriving forall x. Rep SendStickerRequest x -> SendStickerRequest
forall x. SendStickerRequest -> Rep SendStickerRequest x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep SendStickerRequest x -> SendStickerRequest
$cfrom :: forall x. SendStickerRequest -> Rep SendStickerRequest x
Generic
instance ToJSON SendStickerRequest where toJSON :: SendStickerRequest -> Value
toJSON = forall a (d :: Meta) (f :: * -> *).
(Generic a, GToJSON Zero (Rep a), Rep a ~ D1 d f, Datatype d) =>
a -> Value
gtoJSON
instance ToMultipart Tmp SendStickerRequest where
toMultipart :: SendStickerRequest -> MultipartData Tmp
toMultipart SendStickerRequest{Maybe Bool
Maybe MessageThreadId
Maybe MessageId
Maybe InlineKeyboardMarkup
SomeChatId
InputFile
sendStickerReplyMarkup :: Maybe InlineKeyboardMarkup
sendStickerAllowSendingWithoutReply :: Maybe Bool
sendStickerReplyToMessageId :: Maybe MessageId
sendStickerProtectContent :: Maybe Bool
sendStickerDisableNotification :: Maybe Bool
sendStickerSticker :: InputFile
sendStickerMessageThreadId :: Maybe MessageThreadId
sendStickerChatId :: SomeChatId
sendStickerReplyMarkup :: SendStickerRequest -> Maybe InlineKeyboardMarkup
sendStickerAllowSendingWithoutReply :: SendStickerRequest -> Maybe Bool
sendStickerReplyToMessageId :: SendStickerRequest -> Maybe MessageId
sendStickerProtectContent :: SendStickerRequest -> Maybe Bool
sendStickerDisableNotification :: SendStickerRequest -> Maybe Bool
sendStickerSticker :: SendStickerRequest -> InputFile
sendStickerMessageThreadId :: SendStickerRequest -> Maybe MessageThreadId
sendStickerChatId :: SendStickerRequest -> SomeChatId
..} =
Text -> InputFile -> MultipartData Tmp -> MultipartData Tmp
makeFile Text
"sticker" InputFile
sendStickerSticker (forall tag. [Input] -> [FileData tag] -> MultipartData tag
MultipartData [Input]
fields []) where
fields :: [Input]
fields =
[ Text -> Text -> Input
Input Text
"chat_id" forall a b. (a -> b) -> a -> b
$ case SomeChatId
sendStickerChatId of
SomeChatId (ChatId Integer
chat_id) -> String -> Text
T.pack forall a b. (a -> b) -> a -> b
$ forall a. Show a => a -> String
show Integer
chat_id
SomeChatUsername Text
txt -> Text
txt
] forall a. Semigroup a => a -> a -> a
<> forall a. [Maybe a] -> [a]
catMaybes
[ Maybe MessageThreadId
sendStickerMessageThreadId forall (f :: * -> *) a b. Functor f => f a -> (a -> b) -> f b
<&>
\MessageThreadId
t -> Text -> Text -> Input
Input Text
"message_thread_id" (String -> Text
T.pack forall a b. (a -> b) -> a -> b
$ forall a. Show a => a -> String
show MessageThreadId
t)
, Maybe Bool
sendStickerDisableNotification forall (f :: * -> *) a b. Functor f => f a -> (a -> b) -> f b
<&>
\Bool
t -> Text -> Text -> Input
Input Text
"disable_notification" (forall a. a -> a -> Bool -> a
bool Text
"false" Text
"true" Bool
t)
, Maybe Bool
sendStickerProtectContent forall (f :: * -> *) a b. Functor f => f a -> (a -> b) -> f b
<&>
\Bool
t -> Text -> Text -> Input
Input Text
"protect_content" (forall a. a -> a -> Bool -> a
bool Text
"false" Text
"true" Bool
t)
, Maybe MessageId
sendStickerReplyToMessageId forall (f :: * -> *) a b. Functor f => f a -> (a -> b) -> f b
<&>
\MessageId
t -> Text -> Text -> Input
Input Text
"reply_to_message_id" (Text -> Text
TL.toStrict forall a b. (a -> b) -> a -> b
$ forall a. ToJSON a => a -> Text
encodeToLazyText MessageId
t)
, Maybe Bool
sendStickerAllowSendingWithoutReply forall (f :: * -> *) a b. Functor f => f a -> (a -> b) -> f b
<&>
\Bool
t -> Text -> Text -> Input
Input Text
"allow_sending_without_reply" (forall a. a -> a -> Bool -> a
bool Text
"false" Text
"true" Bool
t)
, Maybe InlineKeyboardMarkup
sendStickerReplyMarkup forall (f :: * -> *) a b. Functor f => f a -> (a -> b) -> f b
<&>
\InlineKeyboardMarkup
t -> Text -> Text -> Input
Input Text
"reply_markup" (Text -> Text
TL.toStrict forall a b. (a -> b) -> a -> b
$ forall a. ToJSON a => a -> Text
encodeToLazyText InlineKeyboardMarkup
t)
]
type SendStickerContent
= "sendSticker"
:> MultipartForm Tmp SendStickerRequest
:> Post '[JSON] (Response Message)
type SendStickerLink
= "sendSticker"
:> ReqBody '[JSON] SendStickerRequest
:> Post '[JSON] (Response Message)
sendSticker :: SendStickerRequest -> ClientM (Response Message)
sendSticker :: SendStickerRequest -> ClientM (Response Message)
sendSticker SendStickerRequest
r =
case SendStickerRequest -> InputFile
sendStickerSticker SendStickerRequest
r of
InputFile{} -> do
ByteString
boundary <- forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO IO ByteString
genBoundary
forall api.
HasClient ClientM api =>
Proxy api -> Client ClientM api
client (forall {k} (t :: k). Proxy t
Proxy @SendStickerContent) (ByteString
boundary, SendStickerRequest
r)
InputFile
_ -> forall api.
HasClient ClientM api =>
Proxy api -> Client ClientM api
client (forall {k} (t :: k). Proxy t
Proxy @SendStickerLink) SendStickerRequest
r
data GetCustomEmojiStickersRequest = GetCustomEmojiStickersRequest
{ GetCustomEmojiStickersRequest -> [Text]
getCustomEmojiStickersRequestCustomEmojiIds :: [Text]
}
deriving forall x.
Rep GetCustomEmojiStickersRequest x
-> GetCustomEmojiStickersRequest
forall x.
GetCustomEmojiStickersRequest
-> Rep GetCustomEmojiStickersRequest x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep GetCustomEmojiStickersRequest x
-> GetCustomEmojiStickersRequest
$cfrom :: forall x.
GetCustomEmojiStickersRequest
-> Rep GetCustomEmojiStickersRequest x
Generic
instance ToJSON GetCustomEmojiStickersRequest where toJSON :: GetCustomEmojiStickersRequest -> Value
toJSON = forall a (d :: Meta) (f :: * -> *).
(Generic a, GToJSON Zero (Rep a), Rep a ~ D1 d f, Datatype d) =>
a -> Value
gtoJSON
type GetCustomEmojiStickers
= "getCustomEmojiStickers"
:> ReqBody '[JSON] GetCustomEmojiStickersRequest
:> Post '[JSON] (Response [Sticker])
data UploadStickerFileRequest = UploadStickerFileRequest
{ UploadStickerFileRequest -> UserId
uploadStickerFileUserId :: UserId
, UploadStickerFileRequest -> InputFile
uploadStickerFilePngSticker :: InputFile
} deriving forall x.
Rep UploadStickerFileRequest x -> UploadStickerFileRequest
forall x.
UploadStickerFileRequest -> Rep UploadStickerFileRequest x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep UploadStickerFileRequest x -> UploadStickerFileRequest
$cfrom :: forall x.
UploadStickerFileRequest -> Rep UploadStickerFileRequest x
Generic
instance ToJSON UploadStickerFileRequest where toJSON :: UploadStickerFileRequest -> Value
toJSON = forall a (d :: Meta) (f :: * -> *).
(Generic a, GToJSON Zero (Rep a), Rep a ~ D1 d f, Datatype d) =>
a -> Value
gtoJSON
instance ToMultipart Tmp UploadStickerFileRequest where
toMultipart :: UploadStickerFileRequest -> MultipartData Tmp
toMultipart UploadStickerFileRequest{UserId
InputFile
uploadStickerFilePngSticker :: InputFile
uploadStickerFileUserId :: UserId
uploadStickerFilePngSticker :: UploadStickerFileRequest -> InputFile
uploadStickerFileUserId :: UploadStickerFileRequest -> UserId
..} =
Text -> InputFile -> MultipartData Tmp -> MultipartData Tmp
makeFile Text
"png_sticker" InputFile
uploadStickerFilePngSticker (forall tag. [Input] -> [FileData tag] -> MultipartData tag
MultipartData [Input]
fields []) where
fields :: [Input]
fields = [ Text -> Text -> Input
Input Text
"user_id" forall a b. (a -> b) -> a -> b
$ String -> Text
T.pack forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. Show a => a -> String
show forall a b. (a -> b) -> a -> b
$ UserId
uploadStickerFileUserId ]
type UploadStickerFileContent
= "uploadStickerFile"
:> MultipartForm Tmp UploadStickerFileRequest
:> Post '[JSON] (Response File)
type UploadStickerFileLink
= "uploadStickerFile"
:> ReqBody '[JSON] UploadStickerFileRequest
:> Post '[JSON] (Response File)
uploadStickerFile :: UploadStickerFileRequest -> ClientM (Response File)
uploadStickerFile :: UploadStickerFileRequest -> ClientM (Response File)
uploadStickerFile UploadStickerFileRequest
r =
case UploadStickerFileRequest -> InputFile
uploadStickerFilePngSticker UploadStickerFileRequest
r of
InputFile{} -> do
ByteString
boundary <- forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO IO ByteString
genBoundary
forall api.
HasClient ClientM api =>
Proxy api -> Client ClientM api
client (forall {k} (t :: k). Proxy t
Proxy @UploadStickerFileContent) (ByteString
boundary, UploadStickerFileRequest
r)
InputFile
_ -> forall api.
HasClient ClientM api =>
Proxy api -> Client ClientM api
client (forall {k} (t :: k). Proxy t
Proxy @UploadStickerFileLink) UploadStickerFileRequest
r
data CreateNewStickerSetRequest = CreateNewStickerSetRequest
{ CreateNewStickerSetRequest -> UserId
createNewStickerSetUserId :: UserId
, CreateNewStickerSetRequest -> Text
createNewStickerSetName :: T.Text
, CreateNewStickerSetRequest -> Text
createNewStickerSetTitle :: T.Text
, CreateNewStickerSetRequest -> StickerFile
createNewStickerSetSticker :: StickerFile
, CreateNewStickerSetRequest -> Text
createNewStickerSetEmojis :: T.Text
, CreateNewStickerSetRequest -> Maybe Bool
createNewStickerSetContainsMasks :: Maybe Bool
, CreateNewStickerSetRequest -> Maybe MaskPosition
createNewStickerSetMaskPosition :: Maybe MaskPosition
} deriving forall x.
Rep CreateNewStickerSetRequest x -> CreateNewStickerSetRequest
forall x.
CreateNewStickerSetRequest -> Rep CreateNewStickerSetRequest x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep CreateNewStickerSetRequest x -> CreateNewStickerSetRequest
$cfrom :: forall x.
CreateNewStickerSetRequest -> Rep CreateNewStickerSetRequest x
Generic
instance ToJSON CreateNewStickerSetRequest where
toJSON :: CreateNewStickerSetRequest -> Value
toJSON CreateNewStickerSetRequest{Maybe Bool
Maybe MaskPosition
Text
UserId
StickerFile
createNewStickerSetMaskPosition :: Maybe MaskPosition
createNewStickerSetContainsMasks :: Maybe Bool
createNewStickerSetEmojis :: Text
createNewStickerSetSticker :: StickerFile
createNewStickerSetTitle :: Text
createNewStickerSetName :: Text
createNewStickerSetUserId :: UserId
createNewStickerSetMaskPosition :: CreateNewStickerSetRequest -> Maybe MaskPosition
createNewStickerSetContainsMasks :: CreateNewStickerSetRequest -> Maybe Bool
createNewStickerSetEmojis :: CreateNewStickerSetRequest -> Text
createNewStickerSetSticker :: CreateNewStickerSetRequest -> StickerFile
createNewStickerSetTitle :: CreateNewStickerSetRequest -> Text
createNewStickerSetName :: CreateNewStickerSetRequest -> Text
createNewStickerSetUserId :: CreateNewStickerSetRequest -> UserId
..} = [Pair] -> Value
object
[ Key
"user_id" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
.= UserId
createNewStickerSetUserId
, Key
"name" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
.= Text
createNewStickerSetName
, Key
"title" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
.= Text
createNewStickerSetTitle
#if MIN_VERSION_aeson(2,0,0)
, Text -> Key
fromText (StickerType -> Text
stickerLabel StickerType
stickerFileLabel) forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
.= InputFile
stickerFileSticker
#else
, stickerLabel stickerFileLabel .= stickerFileSticker
#endif
, Key
"emojis" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
.= Text
createNewStickerSetEmojis
, Key
"contains_mask" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
.= Maybe Bool
createNewStickerSetContainsMasks
, Key
"mask_position" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
.= Maybe MaskPosition
createNewStickerSetMaskPosition
]
where
StickerFile{InputFile
StickerType
stickerFileSticker :: InputFile
stickerFileLabel :: StickerType
stickerFileLabel :: StickerFile -> StickerType
stickerFileSticker :: StickerFile -> InputFile
..} = StickerFile
createNewStickerSetSticker
instance ToMultipart Tmp CreateNewStickerSetRequest where
toMultipart :: CreateNewStickerSetRequest -> MultipartData Tmp
toMultipart CreateNewStickerSetRequest{Maybe Bool
Maybe MaskPosition
Text
UserId
StickerFile
createNewStickerSetMaskPosition :: Maybe MaskPosition
createNewStickerSetContainsMasks :: Maybe Bool
createNewStickerSetEmojis :: Text
createNewStickerSetSticker :: StickerFile
createNewStickerSetTitle :: Text
createNewStickerSetName :: Text
createNewStickerSetUserId :: UserId
createNewStickerSetMaskPosition :: CreateNewStickerSetRequest -> Maybe MaskPosition
createNewStickerSetContainsMasks :: CreateNewStickerSetRequest -> Maybe Bool
createNewStickerSetEmojis :: CreateNewStickerSetRequest -> Text
createNewStickerSetSticker :: CreateNewStickerSetRequest -> StickerFile
createNewStickerSetTitle :: CreateNewStickerSetRequest -> Text
createNewStickerSetName :: CreateNewStickerSetRequest -> Text
createNewStickerSetUserId :: CreateNewStickerSetRequest -> UserId
..} =
Text -> InputFile -> MultipartData Tmp -> MultipartData Tmp
makeFile (StickerType -> Text
stickerLabel StickerType
stickerFileLabel) InputFile
stickerFileSticker (forall tag. [Input] -> [FileData tag] -> MultipartData tag
MultipartData [Input]
fields []) where
fields :: [Input]
fields =
[ Text -> Text -> Input
Input Text
"user_id" forall a b. (a -> b) -> a -> b
$ String -> Text
T.pack forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. Show a => a -> String
show forall a b. (a -> b) -> a -> b
$ UserId
createNewStickerSetUserId
, Text -> Text -> Input
Input Text
"name" Text
createNewStickerSetName
, Text -> Text -> Input
Input Text
"title" Text
createNewStickerSetTitle
, Text -> Text -> Input
Input Text
"emojis" Text
createNewStickerSetEmojis
] forall a. Semigroup a => a -> a -> a
<> forall a. [Maybe a] -> [a]
catMaybes
[ Maybe Bool
createNewStickerSetContainsMasks forall (f :: * -> *) a b. Functor f => f a -> (a -> b) -> f b
<&>
\Bool
t -> Text -> Text -> Input
Input Text
"contains_masks" (forall a. a -> a -> Bool -> a
bool Text
"false" Text
"true" Bool
t)
, Maybe MaskPosition
createNewStickerSetMaskPosition forall (f :: * -> *) a b. Functor f => f a -> (a -> b) -> f b
<&>
\MaskPosition
t -> Text -> Text -> Input
Input Text
"mask_position" (Text -> Text
TL.toStrict forall a b. (a -> b) -> a -> b
$ forall a. ToJSON a => a -> Text
encodeToLazyText MaskPosition
t)
]
StickerFile {InputFile
StickerType
stickerFileSticker :: InputFile
stickerFileLabel :: StickerType
stickerFileLabel :: StickerFile -> StickerType
stickerFileSticker :: StickerFile -> InputFile
..} = StickerFile
createNewStickerSetSticker
type CreateNewStickerSetContent
= "createNewStickerSet"
:> MultipartForm Tmp CreateNewStickerSetRequest
:> Post '[JSON] (Response Bool)
type CreateNewStickerSetLink
= "createNewStickerSet"
:> ReqBody '[JSON] CreateNewStickerSetRequest
:> Post '[JSON] (Response Bool)
createNewStickerSet :: CreateNewStickerSetRequest -> ClientM (Response Bool)
createNewStickerSet :: CreateNewStickerSetRequest -> ClientM (Response Bool)
createNewStickerSet CreateNewStickerSetRequest
r =
case StickerFile -> InputFile
stickerFileSticker forall a b. (a -> b) -> a -> b
$ CreateNewStickerSetRequest -> StickerFile
createNewStickerSetSticker CreateNewStickerSetRequest
r of
InputFile{} -> do
ByteString
boundary <- forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO IO ByteString
genBoundary
forall api.
HasClient ClientM api =>
Proxy api -> Client ClientM api
client (forall {k} (t :: k). Proxy t
Proxy @CreateNewStickerSetContent) (ByteString
boundary, CreateNewStickerSetRequest
r)
InputFile
_ -> forall api.
HasClient ClientM api =>
Proxy api -> Client ClientM api
client (forall {k} (t :: k). Proxy t
Proxy @CreateNewStickerSetLink) CreateNewStickerSetRequest
r
data AddStickerToSetRequest = AddStickerToSetRequest
{ AddStickerToSetRequest -> UserId
addStickerToSetUserId :: UserId
, AddStickerToSetRequest -> Text
addStickerToSetName :: T.Text
, AddStickerToSetRequest -> StickerFile
addStickerToSetSticker :: StickerFile
, AddStickerToSetRequest -> Text
addStickerToSetEmojis :: T.Text
, AddStickerToSetRequest -> Maybe MaskPosition
addStickerToSetMaskPosition :: Maybe MaskPosition
} deriving forall x. Rep AddStickerToSetRequest x -> AddStickerToSetRequest
forall x. AddStickerToSetRequest -> Rep AddStickerToSetRequest x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep AddStickerToSetRequest x -> AddStickerToSetRequest
$cfrom :: forall x. AddStickerToSetRequest -> Rep AddStickerToSetRequest x
Generic
instance ToJSON AddStickerToSetRequest where
toJSON :: AddStickerToSetRequest -> Value
toJSON AddStickerToSetRequest{Maybe MaskPosition
Text
UserId
StickerFile
addStickerToSetMaskPosition :: Maybe MaskPosition
addStickerToSetEmojis :: Text
addStickerToSetSticker :: StickerFile
addStickerToSetName :: Text
addStickerToSetUserId :: UserId
addStickerToSetMaskPosition :: AddStickerToSetRequest -> Maybe MaskPosition
addStickerToSetEmojis :: AddStickerToSetRequest -> Text
addStickerToSetSticker :: AddStickerToSetRequest -> StickerFile
addStickerToSetName :: AddStickerToSetRequest -> Text
addStickerToSetUserId :: AddStickerToSetRequest -> UserId
..} = [Pair] -> Value
object
[ Key
"user_id" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
.= UserId
addStickerToSetUserId
, Key
"name" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
.= Text
addStickerToSetName
#if MIN_VERSION_aeson(2,0,0)
, Text -> Key
fromText (StickerType -> Text
stickerLabel StickerType
stickerFileLabel) forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
.= InputFile
stickerFileSticker
#else
, stickerLabel stickerFileLabel .= stickerFileSticker
#endif
, Key
"emojis" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
.= Text
addStickerToSetEmojis
, Key
"mask_position" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
.= Maybe MaskPosition
addStickerToSetMaskPosition
]
where
StickerFile{InputFile
StickerType
stickerFileSticker :: InputFile
stickerFileLabel :: StickerType
stickerFileLabel :: StickerFile -> StickerType
stickerFileSticker :: StickerFile -> InputFile
..} = StickerFile
addStickerToSetSticker
instance ToMultipart Tmp AddStickerToSetRequest where
toMultipart :: AddStickerToSetRequest -> MultipartData Tmp
toMultipart AddStickerToSetRequest{Maybe MaskPosition
Text
UserId
StickerFile
addStickerToSetMaskPosition :: Maybe MaskPosition
addStickerToSetEmojis :: Text
addStickerToSetSticker :: StickerFile
addStickerToSetName :: Text
addStickerToSetUserId :: UserId
addStickerToSetMaskPosition :: AddStickerToSetRequest -> Maybe MaskPosition
addStickerToSetEmojis :: AddStickerToSetRequest -> Text
addStickerToSetSticker :: AddStickerToSetRequest -> StickerFile
addStickerToSetName :: AddStickerToSetRequest -> Text
addStickerToSetUserId :: AddStickerToSetRequest -> UserId
..} =
Text -> InputFile -> MultipartData Tmp -> MultipartData Tmp
makeFile (StickerType -> Text
stickerLabel StickerType
stickerFileLabel) InputFile
stickerFileSticker (forall tag. [Input] -> [FileData tag] -> MultipartData tag
MultipartData [Input]
fields []) where
fields :: [Input]
fields =
[ Text -> Text -> Input
Input Text
"user_id" forall a b. (a -> b) -> a -> b
$ String -> Text
T.pack forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. Show a => a -> String
show forall a b. (a -> b) -> a -> b
$ UserId
addStickerToSetUserId
, Text -> Text -> Input
Input Text
"name" Text
addStickerToSetName
, Text -> Text -> Input
Input Text
"emojis" Text
addStickerToSetEmojis
] forall a. Semigroup a => a -> a -> a
<> forall a. Maybe a -> [a]
maybeToList
( Maybe MaskPosition
addStickerToSetMaskPosition forall (f :: * -> *) a b. Functor f => f a -> (a -> b) -> f b
<&>
\MaskPosition
t -> Text -> Text -> Input
Input Text
"mask_position" (Text -> Text
TL.toStrict forall a b. (a -> b) -> a -> b
$ forall a. ToJSON a => a -> Text
encodeToLazyText MaskPosition
t)
)
StickerFile {InputFile
StickerType
stickerFileSticker :: InputFile
stickerFileLabel :: StickerType
stickerFileLabel :: StickerFile -> StickerType
stickerFileSticker :: StickerFile -> InputFile
..} = StickerFile
addStickerToSetSticker
type AddStickerToSetContent
= "addStickerToSet"
:> MultipartForm Tmp AddStickerToSetRequest
:> Post '[JSON] (Response Bool)
type AddStickerToSetLink
= "addStickerToSet"
:> ReqBody '[JSON] AddStickerToSetRequest
:> Post '[JSON] (Response Bool)
addStickerToSet :: AddStickerToSetRequest -> ClientM (Response Bool)
addStickerToSet :: AddStickerToSetRequest -> ClientM (Response Bool)
addStickerToSet AddStickerToSetRequest
r =
case StickerFile -> InputFile
stickerFileSticker forall a b. (a -> b) -> a -> b
$ AddStickerToSetRequest -> StickerFile
addStickerToSetSticker AddStickerToSetRequest
r of
InputFile{} -> do
ByteString
boundary <- forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO IO ByteString
genBoundary
forall api.
HasClient ClientM api =>
Proxy api -> Client ClientM api
client (forall {k} (t :: k). Proxy t
Proxy @AddStickerToSetContent) (ByteString
boundary, AddStickerToSetRequest
r)
InputFile
_ -> forall api.
HasClient ClientM api =>
Proxy api -> Client ClientM api
client (forall {k} (t :: k). Proxy t
Proxy @AddStickerToSetLink) AddStickerToSetRequest
r
type GetStickerSet
= "getStickerSet"
:> RequiredQueryParam "name" T.Text
:> Get '[JSON] (Response StickerSet)
getStickerSet :: T.Text
-> ClientM (Response StickerSet)
getStickerSet :: Text -> ClientM (Response StickerSet)
getStickerSet = forall api.
HasClient ClientM api =>
Proxy api -> Client ClientM api
client (forall {k} (t :: k). Proxy t
Proxy @GetStickerSet)
type SetStickerPositionInSet
= "setStickerPositionInSet"
:> RequiredQueryParam "sticker" T.Text
:> RequiredQueryParam "position" Integer
:> Post '[JSON] (Response Bool)
setStickerPositionInSet :: T.Text
-> Integer
-> ClientM (Response Bool)
setStickerPositionInSet :: Text -> Integer -> ClientM (Response Bool)
setStickerPositionInSet = forall api.
HasClient ClientM api =>
Proxy api -> Client ClientM api
client (forall {k} (t :: k). Proxy t
Proxy @SetStickerPositionInSet)
type DeleteStickerFromSet
= "deleteStickerFromSet"
:> RequiredQueryParam "sticker" T.Text
:> Post '[JSON] (Response Bool)
deleteStickerFromSet :: T.Text
-> ClientM (Response Bool)
deleteStickerFromSet :: Text -> ClientM (Response Bool)
deleteStickerFromSet = forall api.
HasClient ClientM api =>
Proxy api -> Client ClientM api
client (forall {k} (t :: k). Proxy t
Proxy @DeleteStickerFromSet)
data SetStickerSetThumbRequest = SetStickerSetThumbRequest
{ SetStickerSetThumbRequest -> Text
setStickerSetThumbName :: T.Text
, SetStickerSetThumbRequest -> UserId
setStickerSetThumbUserId :: UserId
, SetStickerSetThumbRequest -> InputFile
setStickerSetThumbThumb :: InputFile
} deriving forall x.
Rep SetStickerSetThumbRequest x -> SetStickerSetThumbRequest
forall x.
SetStickerSetThumbRequest -> Rep SetStickerSetThumbRequest x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep SetStickerSetThumbRequest x -> SetStickerSetThumbRequest
$cfrom :: forall x.
SetStickerSetThumbRequest -> Rep SetStickerSetThumbRequest x
Generic
instance ToJSON SetStickerSetThumbRequest where toJSON :: SetStickerSetThumbRequest -> Value
toJSON = forall a (d :: Meta) (f :: * -> *).
(Generic a, GToJSON Zero (Rep a), Rep a ~ D1 d f, Datatype d) =>
a -> Value
gtoJSON
instance ToMultipart Tmp SetStickerSetThumbRequest where
toMultipart :: SetStickerSetThumbRequest -> MultipartData Tmp
toMultipart SetStickerSetThumbRequest{Text
UserId
InputFile
setStickerSetThumbThumb :: InputFile
setStickerSetThumbUserId :: UserId
setStickerSetThumbName :: Text
setStickerSetThumbThumb :: SetStickerSetThumbRequest -> InputFile
setStickerSetThumbUserId :: SetStickerSetThumbRequest -> UserId
setStickerSetThumbName :: SetStickerSetThumbRequest -> Text
..} =
Text -> InputFile -> MultipartData Tmp -> MultipartData Tmp
makeFile Text
"png_sticker" InputFile
setStickerSetThumbThumb (forall tag. [Input] -> [FileData tag] -> MultipartData tag
MultipartData [Input]
fields []) where
fields :: [Input]
fields =
[ Text -> Text -> Input
Input Text
"user_id" forall a b. (a -> b) -> a -> b
$ String -> Text
T.pack forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. Show a => a -> String
show forall a b. (a -> b) -> a -> b
$ UserId
setStickerSetThumbUserId
, Text -> Text -> Input
Input Text
"name" Text
setStickerSetThumbName
]
type SetStickerSetThumbContent
= "setStickerSetThumb"
:> MultipartForm Tmp SetStickerSetThumbRequest
:> Post '[JSON] (Response Bool)
type SetStickerSetThumbLink
= "setStickerSetThumb"
:> ReqBody '[JSON] SetStickerSetThumbRequest
:> Post '[JSON] (Response Bool)
setStickerSetThumb :: SetStickerSetThumbRequest -> ClientM (Response Bool)
setStickerSetThumb :: SetStickerSetThumbRequest -> ClientM (Response Bool)
setStickerSetThumb SetStickerSetThumbRequest
r =
case SetStickerSetThumbRequest -> InputFile
setStickerSetThumbThumb SetStickerSetThumbRequest
r of
InputFile{} -> do
ByteString
boundary <- forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO IO ByteString
genBoundary
forall api.
HasClient ClientM api =>
Proxy api -> Client ClientM api
client (forall {k} (t :: k). Proxy t
Proxy @SetStickerSetThumbContent) (ByteString
boundary, SetStickerSetThumbRequest
r)
InputFile
_ -> forall api.
HasClient ClientM api =>
Proxy api -> Client ClientM api
client (forall {k} (t :: k). Proxy t
Proxy @SetStickerSetThumbLink) SetStickerSetThumbRequest
r