Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
TelegramBot
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kulya
TelegramBot
Commits
1549a4fd
Commit
1549a4fd
authored
May 26, 2016
by
Jack'lul
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #198 from jacklul/apiupdate
API 2.1
parents
52e1ef1e
dbeb0d84
Changes
10
Show whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
336 additions
and
26 deletions
+336
-26
EditedmessageCommand.php
src/Commands/SystemCommands/EditedmessageCommand.php
+36
-0
DB.php
src/DB.php
+88
-10
ChatMember.php
src/Entities/ChatMember.php
+41
-0
Message.php
src/Entities/Message.php
+9
-0
MessageEntity.php
src/Entities/MessageEntity.php
+7
-0
ServerResponse.php
src/Entities/ServerResponse.php
+22
-9
Update.php
src/Entities/Update.php
+11
-0
Request.php
src/Request.php
+93
-0
Telegram.php
src/Telegram.php
+1
-1
structure.sql
structure.sql
+28
-6
No files found.
src/Commands/SystemCommands/EditedmessageCommand.php
0 → 100644
View file @
1549a4fd
<?php
/**
* This file is part of the TelegramBot package.
*
* (c) Avtandil Kikabidze aka LONGMAN <akalongman@gmail.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace
Longman\TelegramBot\Commands\SystemCommands
;
use
Longman\TelegramBot\Commands\SystemCommand
;
/**
* Edited message command
*/
class
EditedmessageCommand
extends
SystemCommand
{
/**#@+
* {@inheritdoc}
*/
protected
$name
=
'editedmessage'
;
protected
$description
=
'User edited message'
;
protected
$version
=
'1.0.0'
;
/**#@-*/
/**
* {@inheritdoc}
*/
/*public function execute()
{
$update = $this->getUpdate();
$edited_message = $update->getEditedMessage();
}*/
}
src/DB.php
View file @
1549a4fd
...
@@ -134,6 +134,9 @@ class DB
...
@@ -134,6 +134,9 @@ class DB
if
(
!
defined
(
'TB_MESSAGE'
))
{
if
(
!
defined
(
'TB_MESSAGE'
))
{
define
(
'TB_MESSAGE'
,
self
::
$table_prefix
.
'message'
);
define
(
'TB_MESSAGE'
,
self
::
$table_prefix
.
'message'
);
}
}
if
(
!
defined
(
'TB_EDITED_MESSAGE'
))
{
define
(
'TB_EDITED_MESSAGE'
,
self
::
$table_prefix
.
'edited_message'
);
}
if
(
!
defined
(
'TB_INLINE_QUERY'
))
{
if
(
!
defined
(
'TB_INLINE_QUERY'
))
{
define
(
'TB_INLINE_QUERY'
,
self
::
$table_prefix
.
'inline_query'
);
define
(
'TB_INLINE_QUERY'
,
self
::
$table_prefix
.
'inline_query'
);
}
}
...
@@ -260,13 +263,14 @@ class DB
...
@@ -260,13 +263,14 @@ class DB
* @param int $inline_query_id
* @param int $inline_query_id
* @param int $chosen_inline_result_id
* @param int $chosen_inline_result_id
* @param int $callback_query_id
* @param int $callback_query_id
* @param int $edited_message_id
*
*
* @return bool|null
* @return bool|null
*/
*/
public
static
function
insertTelegramUpdate
(
$id
,
$chat_id
,
$message_id
,
$inline_query_id
,
$chosen_inline_result_id
,
$callback_query_id
)
public
static
function
insertTelegramUpdate
(
$id
,
$chat_id
,
$message_id
,
$inline_query_id
,
$chosen_inline_result_id
,
$callback_query_id
,
$edited_message_id
)
{
{
if
(
is_null
(
$message_id
)
&&
is_null
(
$inline_query_id
)
&&
is_null
(
$chosen_inline_result_id
)
&&
is_null
(
$callback_query_id
))
{
if
(
is_null
(
$message_id
)
&&
is_null
(
$inline_query_id
)
&&
is_null
(
$chosen_inline_result_id
)
&&
is_null
(
$callback_query_id
)
&&
is_null
(
$edited_message_id
)
)
{
throw
new
TelegramException
(
'
Error both query_id and message_id are
null'
);
throw
new
TelegramException
(
'
message_id, inline_query_id, chosen_inline_result_id, callback_query_id, edited_message_id are all
null'
);
}
}
if
(
!
self
::
isDbConnected
())
{
if
(
!
self
::
isDbConnected
())
{
...
@@ -277,10 +281,10 @@ class DB
...
@@ -277,10 +281,10 @@ class DB
//telegram_update table
//telegram_update table
$sth_insert_telegram_update
=
self
::
$pdo
->
prepare
(
'INSERT IGNORE INTO `'
.
TB_TELEGRAM_UPDATE
.
'`
$sth_insert_telegram_update
=
self
::
$pdo
->
prepare
(
'INSERT IGNORE INTO `'
.
TB_TELEGRAM_UPDATE
.
'`
(
(
`id`, `chat_id`, `message_id`, `inline_query_id`, `chosen_inline_result_id`, `callback_query_id`
`id`, `chat_id`, `message_id`, `inline_query_id`, `chosen_inline_result_id`, `callback_query_id`
, `edited_message_id`
)
)
VALUES (
VALUES (
:id, :chat_id, :message_id, :inline_query_id, :chosen_inline_result_id, :callback_query_id
:id, :chat_id, :message_id, :inline_query_id, :chosen_inline_result_id, :callback_query_id
, :edited_message_id
)
)
'
);
'
);
...
@@ -290,6 +294,7 @@ class DB
...
@@ -290,6 +294,7 @@ class DB
$sth_insert_telegram_update
->
bindParam
(
':inline_query_id'
,
$inline_query_id
,
\PDO
::
PARAM_INT
);
$sth_insert_telegram_update
->
bindParam
(
':inline_query_id'
,
$inline_query_id
,
\PDO
::
PARAM_INT
);
$sth_insert_telegram_update
->
bindParam
(
':chosen_inline_result_id'
,
$chosen_inline_result_id
,
\PDO
::
PARAM_INT
);
$sth_insert_telegram_update
->
bindParam
(
':chosen_inline_result_id'
,
$chosen_inline_result_id
,
\PDO
::
PARAM_INT
);
$sth_insert_telegram_update
->
bindParam
(
':callback_query_id'
,
$callback_query_id
,
\PDO
::
PARAM_INT
);
$sth_insert_telegram_update
->
bindParam
(
':callback_query_id'
,
$callback_query_id
,
\PDO
::
PARAM_INT
);
$sth_insert_telegram_update
->
bindParam
(
':edited_message_id'
,
$edited_message_id
,
\PDO
::
PARAM_INT
);
$status
=
$sth_insert_telegram_update
->
execute
();
$status
=
$sth_insert_telegram_update
->
execute
();
}
catch
(
PDOException
$e
)
{
}
catch
(
PDOException
$e
)
{
...
@@ -419,6 +424,8 @@ class DB
...
@@ -419,6 +424,8 @@ class DB
/**
/**
* Insert request into database
* Insert request into database
*
*
* @todo self::$pdo->lastInsertId() - unsafe usage if expected previous insert fails?
*
* @param Entities\Update &$update
* @param Entities\Update &$update
*
*
* @return bool
* @return bool
...
@@ -431,22 +438,28 @@ class DB
...
@@ -431,22 +438,28 @@ class DB
$message_id
=
$message
->
getMessageId
();
$message_id
=
$message
->
getMessageId
();
$chat_id
=
$message
->
getChat
()
->
getId
();
$chat_id
=
$message
->
getChat
()
->
getId
();
self
::
insertMessageRequest
(
$message
);
self
::
insertMessageRequest
(
$message
);
return
self
::
insertTelegramUpdate
(
$update_id
,
$chat_id
,
$message_id
,
null
,
null
,
null
);
return
self
::
insertTelegramUpdate
(
$update_id
,
$chat_id
,
$message_id
,
null
,
null
,
null
,
null
);
}
elseif
(
$update
->
getUpdateType
()
==
'edited_message'
)
{
$edited_message
=
$update
->
getEditedMessage
();
$chat_id
=
$edited_message
->
getChat
()
->
getId
();
self
::
insertEditedMessageRequest
(
$edited_message
);
$edited_message_local_id
=
self
::
$pdo
->
lastInsertId
();
return
self
::
insertTelegramUpdate
(
$update_id
,
$chat_id
,
null
,
null
,
null
,
null
,
$edited_message_local_id
);
}
elseif
(
$update
->
getUpdateType
()
==
'inline_query'
)
{
}
elseif
(
$update
->
getUpdateType
()
==
'inline_query'
)
{
$inline_query
=
$update
->
getInlineQuery
();
$inline_query
=
$update
->
getInlineQuery
();
$inline_query_id
=
$inline_query
->
getId
();
$inline_query_id
=
$inline_query
->
getId
();
self
::
insertInlineQueryRequest
(
$inline_query
);
self
::
insertInlineQueryRequest
(
$inline_query
);
return
self
::
insertTelegramUpdate
(
$update_id
,
null
,
null
,
$inline_query_id
,
null
,
null
);
return
self
::
insertTelegramUpdate
(
$update_id
,
null
,
null
,
$inline_query_id
,
null
,
null
,
null
);
}
elseif
(
$update
->
getUpdateType
()
==
'chosen_inline_result'
)
{
}
elseif
(
$update
->
getUpdateType
()
==
'chosen_inline_result'
)
{
$chosen_inline_result
=
$update
->
getChosenInlineResult
();
$chosen_inline_result
=
$update
->
getChosenInlineResult
();
self
::
insertChosenInlineResultRequest
(
$chosen_inline_result
);
self
::
insertChosenInlineResultRequest
(
$chosen_inline_result
);
$chosen_inline_result_local_id
=
self
::
$pdo
->
lastInsertId
();
$chosen_inline_result_local_id
=
self
::
$pdo
->
lastInsertId
();
return
self
::
insertTelegramUpdate
(
$update_id
,
null
,
null
,
null
,
$chosen_inline_result_local_id
,
null
);
return
self
::
insertTelegramUpdate
(
$update_id
,
null
,
null
,
null
,
$chosen_inline_result_local_id
,
null
,
null
);
}
elseif
(
$update
->
getUpdateType
()
==
'callback_query'
)
{
}
elseif
(
$update
->
getUpdateType
()
==
'callback_query'
)
{
$callback_query
=
$update
->
getCallbackQuery
();
$callback_query
=
$update
->
getCallbackQuery
();
$callback_query_id
=
$callback_query
->
getId
();
$callback_query_id
=
$callback_query
->
getId
();
self
::
insertCallbackQueryRequest
(
$callback_query
);
self
::
insertCallbackQueryRequest
(
$callback_query
);
return
self
::
insertTelegramUpdate
(
$update_id
,
null
,
null
,
null
,
null
,
$callback_query_id
);
return
self
::
insertTelegramUpdate
(
$update_id
,
null
,
null
,
null
,
null
,
$callback_query_id
,
null
);
}
}
}
}
...
@@ -552,7 +565,6 @@ class DB
...
@@ -552,7 +565,6 @@ class DB
}
}
}
}
/**
/**
* Insert callback query request into database
* Insert callback query request into database
*
*
...
@@ -800,6 +812,72 @@ class DB
...
@@ -800,6 +812,72 @@ class DB
return
true
;
return
true
;
}
}
/**
* Insert Edited Message request in db
*
* @param Entities\Message &$edited_message
*
* @return bool If the insert was successful
*/
public
static
function
insertEditedMessageRequest
(
Message
&
$edited_message
)
{
if
(
!
self
::
isDbConnected
())
{
return
false
;
}
$from
=
$edited_message
->
getFrom
();
$chat
=
$edited_message
->
getChat
();
$chat_id
=
$chat
->
getId
();
$edit_date
=
self
::
getTimestamp
(
$edited_message
->
getEditDate
());
$entities
=
$edited_message
->
getEntities
();
try
{
//edited_message Table
$sth
=
self
::
$pdo
->
prepare
(
'INSERT IGNORE INTO `'
.
TB_EDITED_MESSAGE
.
'`
(
`chat_id`, `message_id`, `user_id`, `edit_date`, `text`, `entities`, `caption`
)
VALUES (
:chat_id, :message_id, :user_id, :date, :text, :entities, :caption
)'
);
$message_id
=
$edited_message
->
getMessageId
();
$from_id
=
$from
->
getId
();
$text
=
$edited_message
->
getText
();
$caption
=
$edited_message
->
getCaption
();
$sth
->
bindParam
(
':chat_id'
,
$chat_id
,
\PDO
::
PARAM_INT
);
$sth
->
bindParam
(
':message_id'
,
$message_id
,
\PDO
::
PARAM_INT
);
$sth
->
bindParam
(
':user_id'
,
$from_id
,
\PDO
::
PARAM_INT
);
$sth
->
bindParam
(
':date'
,
$edit_date
,
\PDO
::
PARAM_STR
);
$var
=
[];
if
(
is_array
(
$entities
))
{
foreach
(
$entities
as
$elm
)
{
$var
[]
=
json_decode
(
$elm
,
true
);
}
$entities
=
json_encode
(
$var
);
}
else
{
$entities
=
null
;
}
$sth
->
bindParam
(
':text'
,
$text
,
\PDO
::
PARAM_STR
);
$sth
->
bindParam
(
':entities'
,
$entities
,
\PDO
::
PARAM_STR
);
$sth
->
bindParam
(
':caption'
,
$caption
,
\PDO
::
PARAM_STR
);
$status
=
$sth
->
execute
();
}
catch
(
PDOException
$e
)
{
throw
new
TelegramException
(
$e
->
getMessage
());
}
return
true
;
}
/**
/**
* Select Group and single Chats
* Select Group and single Chats
*
*
...
...
src/Entities/ChatMember.php
0 → 100644
View file @
1549a4fd
<?php
/**
* This file is part of the TelegramBot package.
*
* (c) Avtandil Kikabidze aka LONGMAN <akalongman@gmail.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace
Longman\TelegramBot\Entities
;
class
ChatMember
extends
Entity
{
protected
$user
;
protected
$status
;
public
function
__construct
(
array
$data
)
{
$this
->
user
=
isset
(
$data
[
'user'
])
?
$data
[
'user'
]
:
null
;
if
(
empty
(
$this
->
user
))
{
throw
new
TelegramException
(
'user is empty!'
);
}
$this
->
user
=
new
User
(
$data
[
'user'
]);
$this
->
status
=
isset
(
$data
[
'status'
])
?
$data
[
'status'
]
:
null
;
if
(
$this
->
status
===
''
)
{
throw
new
TelegramException
(
'status is empty!'
);
}
}
public
function
getUser
()
{
return
$this
->
user
;
}
public
function
getStatus
()
{
return
$this
->
status
;
}
}
src/Entities/Message.php
View file @
1549a4fd
...
@@ -28,6 +28,8 @@ class Message extends Entity
...
@@ -28,6 +28,8 @@ class Message extends Entity
protected
$forward_date
;
protected
$forward_date
;
protected
$edit_date
;
protected
$reply_to_message
;
protected
$reply_to_message
;
protected
$text
;
protected
$text
;
...
@@ -131,6 +133,8 @@ class Message extends Entity
...
@@ -131,6 +133,8 @@ class Message extends Entity
$this
->
forward_date
=
isset
(
$data
[
'forward_date'
])
?
$data
[
'forward_date'
]
:
null
;
$this
->
forward_date
=
isset
(
$data
[
'forward_date'
])
?
$data
[
'forward_date'
]
:
null
;
$this
->
edit_date
=
isset
(
$data
[
'edit_date'
])
?
$data
[
'edit_date'
]
:
null
;
$this
->
text
=
isset
(
$data
[
'text'
])
?
$data
[
'text'
]
:
null
;
$this
->
text
=
isset
(
$data
[
'text'
])
?
$data
[
'text'
]
:
null
;
$command
=
$this
->
getCommand
();
$command
=
$this
->
getCommand
();
if
(
!
empty
(
$command
))
{
if
(
!
empty
(
$command
))
{
...
@@ -360,6 +364,11 @@ class Message extends Entity
...
@@ -360,6 +364,11 @@ class Message extends Entity
return
$this
->
forward_date
;
return
$this
->
forward_date
;
}
}
public
function
getEditDate
()
{
return
$this
->
edit_date
;
}
public
function
getReplyToMessage
()
public
function
getReplyToMessage
()
{
{
return
$this
->
reply_to_message
;
return
$this
->
reply_to_message
;
...
...
src/Entities/MessageEntity.php
View file @
1549a4fd
...
@@ -16,6 +16,7 @@ class MessageEntity extends Entity
...
@@ -16,6 +16,7 @@ class MessageEntity extends Entity
protected
$offset
;
protected
$offset
;
protected
$length
;
protected
$length
;
protected
$url
;
protected
$url
;
protected
$user
;
/**
/**
* @todo check for type value from this list: https://core.telegram.org/bots/api#messageentity
* @todo check for type value from this list: https://core.telegram.org/bots/api#messageentity
...
@@ -38,6 +39,7 @@ class MessageEntity extends Entity
...
@@ -38,6 +39,7 @@ class MessageEntity extends Entity
}
}
$this
->
url
=
isset
(
$data
[
'url'
])
?
$data
[
'url'
]
:
null
;
$this
->
url
=
isset
(
$data
[
'url'
])
?
$data
[
'url'
]
:
null
;
$this
->
user
=
isset
(
$data
[
'user'
])
?
new
User
(
$data
[
'user'
])
:
null
;
}
}
public
function
getType
()
public
function
getType
()
...
@@ -59,4 +61,9 @@ class MessageEntity extends Entity
...
@@ -59,4 +61,9 @@ class MessageEntity extends Entity
{
{
return
$this
->
url
;
return
$this
->
url
;
}
}
public
function
getUser
()
{
return
$this
->
user
;
}
}
}
src/Entities/ServerResponse.php
View file @
1549a4fd
...
@@ -14,32 +14,42 @@ use Longman\TelegramBot\Exception\TelegramException;
...
@@ -14,32 +14,42 @@ use Longman\TelegramBot\Exception\TelegramException;
class
ServerResponse
extends
Entity
class
ServerResponse
extends
Entity
{
{
protected
$ok
;
protected
$ok
;
protected
$result
;
protected
$result
;
protected
$error_code
;
protected
$error_code
;
protected
$description
;
protected
$description
;
public
function
__construct
(
array
$data
,
$bot_name
)
public
function
__construct
(
array
$data
,
$bot_name
)
{
{
if
(
isset
(
$data
[
'ok'
])
&
isset
(
$data
[
'result'
]))
{
if
(
isset
(
$data
[
'ok'
])
&
isset
(
$data
[
'result'
]))
{
if
(
is_array
(
$data
[
'result'
]))
{
if
(
is_array
(
$data
[
'result'
]))
{
if
(
$data
[
'ok'
]
&
!
$this
->
isAssoc
(
$data
[
'result'
]))
{
if
(
$data
[
'ok'
]
&
!
$this
->
isAssoc
(
$data
[
'result'
])
&
!
isset
(
$data
[
'result'
][
0
][
'user'
])
)
{
//
get u
pdate
//
Get U
pdate
foreach
(
$data
[
'result'
]
as
$update
)
{
foreach
(
$data
[
'result'
]
as
$update
)
{
$this
->
result
[]
=
new
Update
(
$update
,
$bot_name
);
$this
->
result
[]
=
new
Update
(
$update
,
$bot_name
);
}
}
}
elseif
(
$data
[
'ok'
]
&
!
$this
->
isAssoc
(
$data
[
'result'
])
&
isset
(
$data
[
'result'
][
0
][
'user'
]))
{
//Response from getChatAdministrators
$this
->
result
=
[];
foreach
(
$data
[
'result'
]
as
$user
)
{
array_push
(
$this
->
result
,
new
ChatMember
(
$user
));
}
}
elseif
(
$data
[
'ok'
]
&
$this
->
isAssoc
(
$data
[
'result'
]))
{
}
elseif
(
$data
[
'ok'
]
&
$this
->
isAssoc
(
$data
[
'result'
]))
{
if
(
isset
(
$data
[
'result'
][
'total_count'
]))
{
if
(
isset
(
$data
[
'result'
][
'total_count'
]))
{
//getUserProfilePhotos
//
Response from
getUserProfilePhotos
$this
->
result
=
new
UserProfilePhotos
(
$data
[
'result'
]);
$this
->
result
=
new
UserProfilePhotos
(
$data
[
'result'
]);
}
elseif
(
isset
(
$data
[
'result'
][
'file_id'
]))
{
}
elseif
(
isset
(
$data
[
'result'
][
'file_id'
]))
{
//Response getFile
//Response
from
getFile
$this
->
result
=
new
File
(
$data
[
'result'
]);
$this
->
result
=
new
File
(
$data
[
'result'
]);
}
elseif
(
isset
(
$data
[
'result'
][
'username'
]))
{
}
elseif
(
isset
(
$data
[
'result'
][
'username'
]))
{
//Response getMe
//Response
from
getMe
$this
->
result
=
new
User
(
$data
[
'result'
]);
$this
->
result
=
new
User
(
$data
[
'result'
]);
}
elseif
(
isset
(
$data
[
'result'
][
'id'
]))
{
//Response from getChat
$this
->
result
=
new
Chat
(
$data
[
'result'
]);
}
elseif
(
isset
(
$data
[
'result'
][
'user'
]))
{
//Response from getChatMember
$this
->
result
=
new
ChatMember
(
$data
[
'result'
]);
}
else
{
}
else
{
//Response from sendMessage
//Response from sendMessage
$this
->
result
=
new
Message
(
$data
[
'result'
],
$bot_name
);
$this
->
result
=
new
Message
(
$data
[
'result'
],
$bot_name
);
...
@@ -50,7 +60,7 @@ class ServerResponse extends Entity
...
@@ -50,7 +60,7 @@ class ServerResponse extends Entity
$this
->
error_code
=
null
;
$this
->
error_code
=
null
;
$this
->
description
=
null
;
$this
->
description
=
null
;
}
else
{
}
else
{
if
(
$data
[
'ok'
]
&
$data
[
'result'
]
==
true
)
{
if
(
$data
[
'ok'
]
&
$data
[
'result'
]
==
=
true
)
{
//Response from setWebhook set
//Response from setWebhook set
$this
->
ok
=
$data
[
'ok'
];
$this
->
ok
=
$data
[
'ok'
];
$this
->
result
=
true
;
$this
->
result
=
true
;
...
@@ -61,6 +71,9 @@ class ServerResponse extends Entity
...
@@ -61,6 +71,9 @@ class ServerResponse extends Entity
}
else
{
}
else
{
$this
->
description
=
''
;
$this
->
description
=
''
;
}
}
}
elseif
(
is_numeric
(
$data
[
'result'
]))
{
//Response from getChatMembersCount
$this
->
result
=
$data
[
'result'
];
}
else
{
}
else
{
$this
->
ok
=
false
;
$this
->
ok
=
false
;
$this
->
result
=
null
;
$this
->
result
=
null
;
...
...
src/Entities/Update.php
View file @
1549a4fd
...
@@ -17,6 +17,7 @@ class Update extends Entity
...
@@ -17,6 +17,7 @@ class Update extends Entity
protected
$update_id
;
protected
$update_id
;
protected
$message
;
protected
$message
;
protected
$edited_message
;
protected
$inline_query
;
protected
$inline_query
;
protected
$chosen_inline_result
;
protected
$chosen_inline_result
;
protected
$callback_query
;
protected
$callback_query
;
...
@@ -37,6 +38,12 @@ class Update extends Entity
...
@@ -37,6 +38,12 @@ class Update extends Entity
$this
->
update_type
=
'message'
;
$this
->
update_type
=
'message'
;
}
}
$this
->
edited_message
=
isset
(
$data
[
'edited_message'
])
?
$data
[
'edited_message'
]
:
null
;
if
(
!
empty
(
$this
->
edited_message
))
{
$this
->
edited_message
=
new
Message
(
$this
->
edited_message
,
$bot_name
);
$this
->
update_type
=
'edited_message'
;
}
if
(
empty
(
$update_id
))
{
if
(
empty
(
$update_id
))
{
throw
new
TelegramException
(
'update_id is empty!'
);
throw
new
TelegramException
(
'update_id is empty!'
);
}
}
...
@@ -69,6 +76,10 @@ class Update extends Entity
...
@@ -69,6 +76,10 @@ class Update extends Entity
{
{
return
$this
->
message
;
return
$this
->
message
;
}
}
public
function
getEditedMessage
()
{
return
$this
->
edited_message
;
}
public
function
getInlineQuery
()
public
function
getInlineQuery
()
{
{
return
$this
->
inline_query
;
return
$this
->
inline_query
;
...
...
src/Request.php
View file @
1549a4fd
...
@@ -56,7 +56,12 @@ class Request
...
@@ -56,7 +56,12 @@ class Request
'getUserProfilePhotos'
,
'getUserProfilePhotos'
,
'getFile'
,
'getFile'
,
'kickChatMember'
,
'kickChatMember'
,
'leaveChat'
,
'unbanChatMember'
,
'unbanChatMember'
,
'getChat'
,
'getChatAdministrators'
,
'getChatMember'
,
'getChatMembersCount'
,
'answerCallbackQuery'
,
'answerCallbackQuery'
,
'answerInlineQuery'
,
'answerInlineQuery'
,
'editMessageText'
,
'editMessageText'
,
...
@@ -658,6 +663,22 @@ class Request
...
@@ -658,6 +663,22 @@ class Request
return
self
::
send
(
'kickChatMember'
,
$data
);
return
self
::
send
(
'kickChatMember'
,
$data
);
}
}
/**
* Leave Chat
*
* @param array $data
*
* @return mixed
*/
public
static
function
leaveChat
(
array
$data
)
{
if
(
empty
(
$data
))
{
throw
new
TelegramException
(
'Data is empty!'
);
}
return
self
::
send
(
'leaveChat'
,
$data
);
}
/**
/**
* Unban Chat Member
* Unban Chat Member
*
*
...
@@ -674,6 +695,78 @@ class Request
...
@@ -674,6 +695,78 @@ class Request
return
self
::
send
(
'unbanChatMember'
,
$data
);
return
self
::
send
(
'unbanChatMember'
,
$data
);
}
}
/**
* Get Chat
*
* @todo add get response in ServerResponse.php?
*
* @param array $data
*
* @return mixed
*/
public
static
function
getChat
(
array
$data
)
{
if
(
empty
(
$data
))
{
throw
new
TelegramException
(
'Data is empty!'
);
}
return
self
::
send
(
'getChat'
,
$data
);
}
/**
* Get Chat Administrators
*
* @todo add get response in ServerResponse.php?
*
* @param array $data
*
* @return mixed
*/
public
static
function
getChatAdministrators
(
array
$data
)
{
if
(
empty
(
$data
))
{
throw
new
TelegramException
(
'Data is empty!'
);
}
return
self
::
send
(
'getChatAdministrators'
,
$data
);
}
/**
* Get Chat Members Count
*
* @todo add get response in ServerResponse.php?
*
* @param array $data
*
* @return mixed
*/
public
static
function
getChatMembersCount
(
array
$data
)
{
if
(
empty
(
$data
))
{
throw
new
TelegramException
(
'Data is empty!'
);
}
return
self
::
send
(
'getChatMembersCount'
,
$data
);
}
/**
* Get Chat Member
*
* @todo add get response in ServerResponse.php?
*
* @param array $data
*
* @return mixed
*/
public
static
function
getChatMember
(
array
$data
)
{
if
(
empty
(
$data
))
{
throw
new
TelegramException
(
'Data is empty!'
);
}
return
self
::
send
(
'getChatMember'
,
$data
);
}
/**
/**
* Answer callback query
* Answer callback query
*
*
...
...
src/Telegram.php
View file @
1549a4fd
...
@@ -455,7 +455,7 @@ class Telegram
...
@@ -455,7 +455,7 @@ class Telegram
$command
=
'genericmessage'
;
$command
=
'genericmessage'
;
$update_type
=
$this
->
update
->
getUpdateType
();
$update_type
=
$this
->
update
->
getUpdateType
();
if
(
in_array
(
$update_type
,
[
'inline_query'
,
'chosen_inline_result'
,
'callback_query'
]))
{
if
(
in_array
(
$update_type
,
[
'inline_query'
,
'chosen_inline_result'
,
'callback_query'
,
'edited_message'
]))
{
$command
=
$this
->
getCommandFromType
(
$update_type
);
$command
=
$this
->
getCommandFromType
(
$update_type
);
}
elseif
(
$update_type
===
'message'
)
{
}
elseif
(
$update_type
===
'message'
)
{
$message
=
$this
->
update
->
getMessage
();
$message
=
$this
->
update
->
getMessage
();
...
...
structure.sql
View file @
1549a4fd
...
@@ -121,13 +121,32 @@ CREATE TABLE IF NOT EXISTS `message` (
...
@@ -121,13 +121,32 @@ CREATE TABLE IF NOT EXISTS `message` (
FOREIGN
KEY
(
`chat_id`
)
REFERENCES
`chat`
(
`id`
),
FOREIGN
KEY
(
`chat_id`
)
REFERENCES
`chat`
(
`id`
),
FOREIGN
KEY
(
`forward_from`
)
REFERENCES
`user`
(
`id`
),
FOREIGN
KEY
(
`forward_from`
)
REFERENCES
`user`
(
`id`
),
FOREIGN
KEY
(
`forward_from_chat`
)
REFERENCES
`chat`
(
`id`
),
FOREIGN
KEY
(
`forward_from_chat`
)
REFERENCES
`chat`
(
`id`
),
FOREIGN
KEY
(
`reply_to_chat`
,
`reply_to_message`
)
REFERENCES
`message`
(
`chat_id`
,
`id`
),
FOREIGN
KEY
(
`reply_to_chat`
,
`reply_to_message`
)
REFERENCES
`message`
(
`chat_id`
,
`id`
),
FOREIGN
KEY
(
`forward_from`
)
REFERENCES
`user`
(
`id`
),
FOREIGN
KEY
(
`forward_from`
)
REFERENCES
`user`
(
`id`
),
FOREIGN
KEY
(
`new_chat_member`
)
REFERENCES
`user`
(
`id`
),
FOREIGN
KEY
(
`new_chat_member`
)
REFERENCES
`user`
(
`id`
),
FOREIGN
KEY
(
`left_chat_member`
)
REFERENCES
`user`
(
`id`
)
FOREIGN
KEY
(
`left_chat_member`
)
REFERENCES
`user`
(
`id`
)
)
ENGINE
=
InnoDB
DEFAULT
CHARSET
=
utf8mb4
COLLATE
=
utf8mb4_unicode_520_ci
;
)
ENGINE
=
InnoDB
DEFAULT
CHARSET
=
utf8mb4
COLLATE
=
utf8mb4_unicode_520_ci
;
CREATE
TABLE
IF
NOT
EXISTS
`edited_message`
(
`id`
bigint
UNSIGNED
AUTO_INCREMENT
COMMENT
'Unique identifier for this entry.'
,
`chat_id`
bigint
COMMENT
'Chat identifier.'
,
`message_id`
bigint
UNSIGNED
COMMENT
'Unique message identifier'
,
`user_id`
bigint
NULL
COMMENT
'User identifier'
,
`edit_date`
timestamp
NULL
DEFAULT
NULL
COMMENT
'Date the message was sent in timestamp format'
,
`text`
TEXT
DEFAULT
NULL
COMMENT
'For text messages, the actual UTF-8 text of the message max message length 4096 char utf8'
,
`entities`
TEXT
DEFAULT
NULL
COMMENT
'For text messages, special entities like usernames, URLs, bot commands, etc. that appear in the text'
,
`caption`
TEXT
DEFAULT
NULL
COMMENT
'For message with caption, the actual UTF-8 text of the caption'
,
PRIMARY
KEY
(
`id`
),
KEY
`chat_id`
(
`chat_id`
),
KEY
`message_id`
(
`message_id`
),
KEY
`user_id`
(
`user_id`
),
FOREIGN
KEY
(
`chat_id`
)
REFERENCES
`chat`
(
`id`
),
FOREIGN
KEY
(
`chat_id`
,
`message_id`
)
REFERENCES
`message`
(
`chat_id`
,
`id`
),
FOREIGN
KEY
(
`user_id`
)
REFERENCES
`user`
(
`id`
)
)
ENGINE
=
InnoDB
DEFAULT
CHARSET
=
utf8mb4
COLLATE
=
utf8mb4_unicode_520_ci
;
CREATE
TABLE
IF
NOT
EXISTS
`telegram_update`
(
CREATE
TABLE
IF
NOT
EXISTS
`telegram_update`
(
`id`
bigint
UNSIGNED
COMMENT
'The update
\'
s unique identifier.'
,
`id`
bigint
UNSIGNED
COMMENT
'The update
\'
s unique identifier.'
,
`chat_id`
bigint
NULL
DEFAULT
NULL
COMMENT
'Chat identifier.'
,
`chat_id`
bigint
NULL
DEFAULT
NULL
COMMENT
'Chat identifier.'
,
...
@@ -135,17 +154,20 @@ CREATE TABLE IF NOT EXISTS `telegram_update` (
...
@@ -135,17 +154,20 @@ CREATE TABLE IF NOT EXISTS `telegram_update` (
`inline_query_id`
bigint
UNSIGNED
DEFAULT
NULL
COMMENT
'The inline query unique identifier.'
,
`inline_query_id`
bigint
UNSIGNED
DEFAULT
NULL
COMMENT
'The inline query unique identifier.'
,
`chosen_inline_result_id`
bigint
UNSIGNED
DEFAULT
NULL
COMMENT
'The chosen query unique identifier.'
,
`chosen_inline_result_id`
bigint
UNSIGNED
DEFAULT
NULL
COMMENT
'The chosen query unique identifier.'
,
`callback_query_id`
bigint
UNSIGNED
DEFAULT
NULL
COMMENT
'The callback query unique identifier.'
,
`callback_query_id`
bigint
UNSIGNED
DEFAULT
NULL
COMMENT
'The callback query unique identifier.'
,
`edited_message_id`
bigint
UNSIGNED
DEFAULT
NULL
COMMENT
'Unique edited message identifier'
,
PRIMARY
KEY
(
`id`
),
PRIMARY
KEY
(
`id`
),
KEY
`message_id`
(
`chat_id`
,
`message_id`
),
KEY
`message_id`
(
`chat_id`
,
`message_id`
),
KEY
`inline_query_id`
(
`inline_query_id`
),
KEY
`inline_query_id`
(
`inline_query_id`
),
KEY
`chosen_inline_result_id`
(
`chosen_inline_result_id`
),
KEY
`chosen_inline_result_id`
(
`chosen_inline_result_id`
),
KEY
`callback_query_id`
(
`callback_query_id`
),
KEY
`callback_query_id`
(
`callback_query_id`
),
KEY
`edited_message_id`
(
`edited_message_id`
),
FOREIGN
KEY
(
`chat_id`
,
`message_id`
)
REFERENCES
`message`
(
`chat_id`
,
`id`
),
FOREIGN
KEY
(
`chat_id`
,
`message_id`
)
REFERENCES
`message`
(
`chat_id`
,
`id`
),
FOREIGN
KEY
(
`inline_query_id`
)
REFERENCES
`inline_query`
(
`id`
),
FOREIGN
KEY
(
`inline_query_id`
)
REFERENCES
`inline_query`
(
`id`
),
FOREIGN
KEY
(
`chosen_inline_result_id`
)
REFERENCES
`chosen_inline_result`
(
`id`
),
FOREIGN
KEY
(
`chosen_inline_result_id`
)
REFERENCES
`chosen_inline_result`
(
`id`
),
FOREIGN
KEY
(
`callback_query_id`
)
REFERENCES
`callback_query`
(
`id`
)
FOREIGN
KEY
(
`callback_query_id`
)
REFERENCES
`callback_query`
(
`id`
),
FOREIGN
KEY
(
`edited_message_id`
)
REFERENCES
`edited_message`
(
`id`
)
)
ENGINE
=
InnoDB
DEFAULT
CHARSET
=
utf8mb4
COLLATE
=
utf8mb4_unicode_520_ci
;
)
ENGINE
=
InnoDB
DEFAULT
CHARSET
=
utf8mb4
COLLATE
=
utf8mb4_unicode_520_ci
;
CREATE
TABLE
IF
NOT
EXISTS
`conversation`
(
CREATE
TABLE
IF
NOT
EXISTS
`conversation`
(
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment