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
5bda6e99
Commit
5bda6e99
authored
Jun 28, 2016
by
Marco Boretto
Committed by
GitHub
Jun 28, 2016
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #226 from jacklul/callback_sql_update
Small optimization
parents
22bda564
f1f192a4
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
53 additions
and
23 deletions
+53
-23
DB.php
src/DB.php
+35
-9
structure.sql
structure.sql
+18
-14
No files found.
src/DB.php
View file @
5bda6e99
...
@@ -569,7 +569,7 @@ class DB
...
@@ -569,7 +569,7 @@ class DB
$sth_insert_chosen_inline_result
->
bindParam
(
':result_id'
,
$result_id
,
\PDO
::
PARAM_STR
);
$sth_insert_chosen_inline_result
->
bindParam
(
':result_id'
,
$result_id
,
\PDO
::
PARAM_STR
);
$sth_insert_chosen_inline_result
->
bindParam
(
':user_id'
,
$user_id
,
\PDO
::
PARAM_INT
);
$sth_insert_chosen_inline_result
->
bindParam
(
':user_id'
,
$user_id
,
\PDO
::
PARAM_INT
);
$sth_insert_chosen_inline_result
->
bindParam
(
':location'
,
$location
,
\PDO
::
PARAM_INT
);
$sth_insert_chosen_inline_result
->
bindParam
(
':location'
,
$location
,
\PDO
::
PARAM_INT
);
$sth_insert_chosen_inline_result
->
bindParam
(
':inline_message_id'
,
$inline_message_id
,
\PDO
::
PARAM_
INT
);
$sth_insert_chosen_inline_result
->
bindParam
(
':inline_message_id'
,
$inline_message_id
,
\PDO
::
PARAM_
STR
);
$sth_insert_chosen_inline_result
->
bindParam
(
':query'
,
$query
,
\PDO
::
PARAM_STR
);
$sth_insert_chosen_inline_result
->
bindParam
(
':query'
,
$query
,
\PDO
::
PARAM_STR
);
$sth_insert_chosen_inline_result
->
bindParam
(
':created_at'
,
$date
,
\PDO
::
PARAM_STR
);
$sth_insert_chosen_inline_result
->
bindParam
(
':created_at'
,
$date
,
\PDO
::
PARAM_STR
);
...
@@ -596,10 +596,10 @@ class DB
...
@@ -596,10 +596,10 @@ class DB
try
{
try
{
$mysql_query
=
'INSERT IGNORE INTO `'
.
TB_CALLBACK_QUERY
.
'`
$mysql_query
=
'INSERT IGNORE INTO `'
.
TB_CALLBACK_QUERY
.
'`
(
(
`id`, `user_id`, `
message
`, `inline_message_id`, `data`, `created_at`
`id`, `user_id`, `
chat_id`, `message_id
`, `inline_message_id`, `data`, `created_at`
)
)
VALUES (
VALUES (
:callback_query_id, :user_id, :
message
, :inline_message_id, :data, :created_at
:callback_query_id, :user_id, :
chat_id, :message_id
, :inline_message_id, :data, :created_at
)'
;
)'
;
$sth_insert_callback_query
=
self
::
$pdo
->
prepare
(
$mysql_query
);
$sth_insert_callback_query
=
self
::
$pdo
->
prepare
(
$mysql_query
);
...
@@ -615,12 +615,30 @@ class DB
...
@@ -615,12 +615,30 @@ class DB
}
}
$message
=
$callback_query
->
getMessage
();
$message
=
$callback_query
->
getMessage
();
$chat_id
=
null
;
$message_id
=
null
;
if
(
$message
)
{
$chat_id
=
$message
->
getChat
()
->
getId
();
$message_id
=
$message
->
getMessageId
();
$sth
=
self
::
$pdo
->
prepare
(
'SELECT * FROM `'
.
TB_MESSAGE
.
'`
WHERE `id` = '
.
$message_id
.
' AND `chat_id` = '
.
$chat_id
.
' LIMIT 1'
);
$sth
->
execute
();
if
(
$sth
->
rowCount
()
>
0
)
{
self
::
insertEditedMessageRequest
(
$message
);
}
else
{
self
::
insertMessageRequest
(
$message
);
}
}
$inline_message_id
=
$callback_query
->
getInlineMessageId
();
$inline_message_id
=
$callback_query
->
getInlineMessageId
();
$data
=
$callback_query
->
getData
();
$data
=
$callback_query
->
getData
();
$sth_insert_callback_query
->
bindParam
(
':callback_query_id'
,
$callback_query_id
,
\PDO
::
PARAM_INT
);
$sth_insert_callback_query
->
bindParam
(
':callback_query_id'
,
$callback_query_id
,
\PDO
::
PARAM_INT
);
$sth_insert_callback_query
->
bindParam
(
':user_id'
,
$user_id
,
\PDO
::
PARAM_INT
);
$sth_insert_callback_query
->
bindParam
(
':user_id'
,
$user_id
,
\PDO
::
PARAM_INT
);
$sth_insert_callback_query
->
bindParam
(
':message'
,
$message
,
\PDO
::
PARAM_STR
);
$sth_insert_callback_query
->
bindParam
(
':chat_id'
,
$chat_id
,
\PDO
::
PARAM_INT
);
$sth_insert_callback_query
->
bindParam
(
':message_id'
,
$message_id
,
\PDO
::
PARAM_INT
);
$sth_insert_callback_query
->
bindParam
(
':inline_message_id'
,
$inline_message_id
,
\PDO
::
PARAM_STR
);
$sth_insert_callback_query
->
bindParam
(
':inline_message_id'
,
$inline_message_id
,
\PDO
::
PARAM_STR
);
$sth_insert_callback_query
->
bindParam
(
':data'
,
$data
,
\PDO
::
PARAM_STR
);
$sth_insert_callback_query
->
bindParam
(
':data'
,
$data
,
\PDO
::
PARAM_STR
);
$sth_insert_callback_query
->
bindParam
(
':created_at'
,
$date
,
\PDO
::
PARAM_STR
);
$sth_insert_callback_query
->
bindParam
(
':created_at'
,
$date
,
\PDO
::
PARAM_STR
);
...
@@ -651,6 +669,7 @@ class DB
...
@@ -651,6 +669,7 @@ class DB
$chat_id
=
$chat
->
getId
();
$chat_id
=
$chat
->
getId
();
$date
=
self
::
getTimestamp
(
$message
->
getDate
());
$date
=
self
::
getTimestamp
(
$message
->
getDate
());
$forward_from
=
$message
->
getForwardFrom
();
$forward_from
=
$message
->
getForwardFrom
();
$forward_from_chat
=
$message
->
getForwardFromChat
();
$forward_from_chat
=
$message
->
getForwardFromChat
();
$photo
=
$message
->
getPhoto
();
$photo
=
$message
->
getPhoto
();
...
@@ -681,7 +700,7 @@ class DB
...
@@ -681,7 +700,7 @@ class DB
self
::
insertChat
(
$forward_from_chat
,
$forward_date
);
self
::
insertChat
(
$forward_from_chat
,
$forward_date
);
$forward_from_chat
=
$forward_from_chat
->
getId
();
$forward_from_chat
=
$forward_from_chat
->
getId
();
}
}
//New and left chat member
//New and left chat member
if
(
$new_chat_member
)
{
if
(
$new_chat_member
)
{
//Insert the new chat user
//Insert the new chat user
...
@@ -696,7 +715,7 @@ class DB
...
@@ -696,7 +715,7 @@ class DB
try
{
try
{
$sth
=
self
::
$pdo
->
prepare
(
'INSERT IGNORE INTO `'
.
TB_MESSAGE
.
'`
$sth
=
self
::
$pdo
->
prepare
(
'INSERT IGNORE INTO `'
.
TB_MESSAGE
.
'`
(
(
`id`, `user_id`, `
date`, `chat_id
`, `forward_from`, `forward_from_chat`,
`id`, `user_id`, `
chat_id`, `date
`, `forward_from`, `forward_from_chat`,
`forward_date`, `reply_to_chat`, `reply_to_message`, `text`, `entities`, `audio`, `document`,
`forward_date`, `reply_to_chat`, `reply_to_message`, `text`, `entities`, `audio`, `document`,
`photo`, `sticker`, `video`, `voice`, `caption`, `contact`,
`photo`, `sticker`, `video`, `voice`, `caption`, `contact`,
`location`, `venue`, `new_chat_member`, `left_chat_member`,
`location`, `venue`, `new_chat_member`, `left_chat_member`,
...
@@ -705,14 +724,15 @@ class DB
...
@@ -705,14 +724,15 @@ class DB
`migrate_from_chat_id`, `migrate_to_chat_id`, `pinned_message`
`migrate_from_chat_id`, `migrate_to_chat_id`, `pinned_message`
)
)
VALUES (
VALUES (
:message_id, :user_id, :
date, :chat_id
, :forward_from, :forward_from_chat,
:message_id, :user_id, :
chat_id, :date
, :forward_from, :forward_from_chat,
:forward_date, :reply_to_chat, :reply_to_message, :text, :entities, :audio, :document,
:forward_date, :reply_to_chat, :reply_to_message, :text, :entities, :audio, :document,
:photo, :sticker, :video, :voice, :caption, :contact,
:photo, :sticker, :video, :voice, :caption, :contact,
:location, :venue, :new_chat_member, :left_chat_member,
:location, :venue, :new_chat_member, :left_chat_member,
:new_chat_title, :new_chat_photo, :delete_chat_photo, :group_chat_created,
:new_chat_title, :new_chat_photo, :delete_chat_photo, :group_chat_created,
:supergroup_chat_created, :channel_chat_created,
:supergroup_chat_created, :channel_chat_created,
:migrate_from_chat_id, :migrate_to_chat_id, :pinned_message
:migrate_from_chat_id, :migrate_to_chat_id, :pinned_message
)'
);
)
'
);
$message_id
=
$message
->
getMessageId
();
$message_id
=
$message
->
getMessageId
();
$from_id
=
$from
->
getId
();
$from_id
=
$from
->
getId
();
...
@@ -849,8 +869,14 @@ class DB
...
@@ -849,8 +869,14 @@ class DB
$entities
=
$edited_message
->
getEntities
();
$entities
=
$edited_message
->
getEntities
();
//Insert chat
self
::
insertChat
(
$chat
,
$edit_date
);
//Insert user and the relation with the chat
self
::
insertUser
(
$from
,
$edit_date
,
$chat
);
try
{
try
{
$sth
=
self
::
$pdo
->
prepare
(
'INSERT I
GNORE I
NTO `'
.
TB_EDITED_MESSAGE
.
'`
$sth
=
self
::
$pdo
->
prepare
(
'INSERT INTO `'
.
TB_EDITED_MESSAGE
.
'`
(
(
`chat_id`, `message_id`, `user_id`, `edit_date`, `text`, `entities`, `caption`
`chat_id`, `message_id`, `user_id`, `edit_date`, `text`, `entities`, `caption`
)
)
...
...
structure.sql
View file @
5bda6e99
...
@@ -63,20 +63,6 @@ CREATE TABLE IF NOT EXISTS `chosen_inline_result` (
...
@@ -63,20 +63,6 @@ CREATE TABLE IF NOT EXISTS `chosen_inline_result` (
FOREIGN
KEY
(
`user_id`
)
REFERENCES
`user`
(
`id`
)
FOREIGN
KEY
(
`user_id`
)
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
`callback_query`
(
`id`
bigint
UNSIGNED
COMMENT
'Unique identifier for this query'
,
`user_id`
bigint
NULL
COMMENT
'Unique user identifier'
,
`message`
text
NULL
COMMENT
'Message with the callback button that originated the query'
,
`inline_message_id`
CHAR
(
255
)
NULL
DEFAULT
NULL
COMMENT
'Identifier of the message sent via the bot in inline mode, that originated the query'
,
`data`
CHAR
(
255
)
NOT
NULL
DEFAULT
''
COMMENT
'Data associated with the callback button'
,
`created_at`
timestamp
NULL
DEFAULT
NULL
COMMENT
'Entry date creation'
,
PRIMARY
KEY
(
`id`
),
KEY
`user_id`
(
`user_id`
),
FOREIGN
KEY
(
`user_id`
)
REFERENCES
`user`
(
`id`
)
)
ENGINE
=
InnoDB
DEFAULT
CHARSET
=
utf8mb4
COLLATE
=
utf8mb4_unicode_520_ci
;
CREATE
TABLE
IF
NOT
EXISTS
`message`
(
CREATE
TABLE
IF
NOT
EXISTS
`message`
(
`chat_id`
bigint
COMMENT
'Unique chat identifier'
,
`chat_id`
bigint
COMMENT
'Unique chat identifier'
,
`id`
bigint
UNSIGNED
COMMENT
'Unique message identifier'
,
`id`
bigint
UNSIGNED
COMMENT
'Unique message identifier'
,
...
@@ -132,6 +118,24 @@ CREATE TABLE IF NOT EXISTS `message` (
...
@@ -132,6 +118,24 @@ CREATE TABLE IF NOT EXISTS `message` (
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
`callback_query`
(
`id`
bigint
UNSIGNED
COMMENT
'Unique identifier for this query'
,
`user_id`
bigint
NULL
COMMENT
'Unique user identifier'
,
`chat_id`
bigint
NULL
COMMENT
'Unique chat identifier'
,
`message_id`
bigint
UNSIGNED
COMMENT
'Unique message identifier'
,
`inline_message_id`
CHAR
(
255
)
NULL
DEFAULT
NULL
COMMENT
'Identifier of the message sent via the bot in inline mode, that originated the query'
,
`data`
CHAR
(
255
)
NOT
NULL
DEFAULT
''
COMMENT
'Data associated with the callback button'
,
`created_at`
timestamp
NULL
DEFAULT
NULL
COMMENT
'Entry date creation'
,
PRIMARY
KEY
(
`id`
),
KEY
`user_id`
(
`user_id`
),
KEY
`chat_id`
(
`chat_id`
),
KEY
`message_id`
(
`message_id`
),
FOREIGN
KEY
(
`user_id`
)
REFERENCES
`user`
(
`id`
),
FOREIGN
KEY
(
`chat_id`
,
`message_id`
)
REFERENCES
`message`
(
`chat_id`
,
`id`
)
)
ENGINE
=
InnoDB
DEFAULT
CHARSET
=
utf8mb4
COLLATE
=
utf8mb4_unicode_520_ci
;
CREATE
TABLE
IF
NOT
EXISTS
`edited_message`
(
CREATE
TABLE
IF
NOT
EXISTS
`edited_message`
(
`id`
bigint
UNSIGNED
AUTO_INCREMENT
COMMENT
'Unique identifier for this entry'
,
`id`
bigint
UNSIGNED
AUTO_INCREMENT
COMMENT
'Unique identifier for this entry'
,
`chat_id`
bigint
COMMENT
'Unique chat identifier'
,
`chat_id`
bigint
COMMENT
'Unique chat identifier'
,
...
...
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