Commit graph

171 commits

Author SHA1 Message Date
Kim Alvefur
98922d54b1 plugins: Prefix module imports with prosody namespace 2023-03-24 13:15:28 +01:00
Kim Alvefur
3605137656 mod_storage_sql: Remove module status on unknown 'debug' level
Expected this to be translated to 'core', but it logs an error instead.
See previous commit.
2023-01-31 07:52:33 +01:00
Kim Alvefur
89f652ff0b mod_storage_sql: Silence luacheck warning 2023-01-30 00:40:47 +01:00
Kim Alvefur
0147b972e0 mod_storage_sql: Record connection to database as module status
Allows retrieving this in e.g. a health reporting module

Thanks pfak
2023-01-30 00:38:26 +01:00
Kim Alvefur
4c14111c76 mod_storage_sql: Support SQLite3 without LuaDBI 2023-01-19 16:56:12 +01:00
Kim Alvefur
7c647e1cee Merge 0.12->trunk 2023-01-06 23:53:50 +01:00
Kim Alvefur
91a064bd49 mod_storage_sql: Fix #1639
Patch by Peter Kieser
2023-01-01 16:20:58 +01:00
Kim Alvefur
e9a7490f67 Merge 0.12->trunk 2022-12-29 18:28:50 +01:00
Kim Alvefur
2317f6a09f mod_storage_sql: Don't avoid initialization under prosodyctl (fix #1787)
Fixes `prosodyctl adduser` etc.

Prior to d580e6a57cbb the line did nothing.

Sometimes storage in the prosodyctl context does cause weirdness, as it
is not in a host context, but rather a variant of global.
2022-12-29 18:06:35 +01:00
Kim Alvefur
2dbbce2382 mod_storage_sql: Fix summary API with Postgres (fixes #1766)
The ORDER BY and LIMIT clauses are not needed and don't even make much
sense. This part was most likely a leftover from the :find method.

Tested with sqlite and postgres 14
2022-07-22 19:09:50 +02:00
Kim Alvefur
9f51add3a8 mod_storage_sql: Fix bypass of load procedure under prosodyctl
There's no 'prosody.prosodyctl' property other than this one, introduced
in 6216743c188c in 2015.

Guessing that the intent was to skip this when running as a prosodyctl
command. The module.command code does its own version of this
initialization, so this seems likely.

Thanks raja for noticing
2022-07-26 00:39:16 +02:00
Kim Alvefur
1dd9e547ce mod_storage_sql: Strip timestamp precision in queries to fix error (thanks muppeth)
Fixes
Error in SQL transaction: Error executing statement parameters: ERROR:  invalid input syntax for integer

This was handled for INSERT in 9524bb7f3944 but not SELECT.
2022-09-07 12:27:12 +02:00
Kim Alvefur
50304f83fd mod_storage_sql: Drop archive timestamp precision pending schema update
The "when" column is an INTEGER which will probably be unhappy about
storing higher precision timestamps, so we keep the older behavior for
now.
2022-08-14 17:29:39 +02:00
Kim Alvefur
9a375e4444 Merge 0.12->trunk 2022-07-29 17:10:31 +02:00
Kim Alvefur
7c8dd7ee42 Merge 0.12->trunk 2022-07-27 00:10:08 +02:00
Kim Alvefur
5251c9b686 compat: Remove handling of Lua 5.1 location of 'unpack' function 2022-07-11 19:07:38 +02:00
Kim Alvefur
2ec8fbe7e5 mod_storage_sql: Remove Lua 5.1 compatibility hack
Part of #1600
2022-07-02 17:30:06 +02:00
Kim Alvefur
0bb07b9711 mod_storage_sql: Return cached total where it makes sense
This should skip the summary SQL query when not needed, ie when the
cached value can be used directly.
2021-11-30 16:26:01 +01:00
Kim Alvefur
36bbf6b077 mod_storage_sql: Adjust handling of 'total' for multi-id queries
Otherwise a query for a set of ids may cause that value to be cached,
despite only covering a subset.
2021-11-30 15:58:23 +01:00
Kim Alvefur
0d9065ae80 mod_storage_sql: Fix traceback on multi-user deletion
jid.join(true, ...) fails.

Since we don't know which users this affects, best to clear the whole
cache.
2021-11-30 15:24:17 +01:00
Kim Alvefur
0a50cf1be4 mod_storage_sql: Expose multi-user deletion capability
archive_store:delete(true) deletes messages for all users, which would
allow some simplification when this is supported.
2021-11-30 01:21:02 +01:00
Kim Alvefur
d4c3f44ade mod_storage_sql: Fix for move of yes/no function (Thanks Kasim) 2021-06-21 17:31:17 +02:00
Kim Alvefur
0f0d32d335 mod_storage_sql: Implement map-like API for archives
Used by mod_http_file_share, muc moderation, etc.

Tests tweaked because they failed on stanza internals that happen
becasue of re-serialization. Namespaces differ since inheritance is
implicit when building but explicit after parsing.
2021-02-01 12:47:05 +01:00
Kim Alvefur
68bd24d94c mod_storage_sql: Fix compatibilty with Lua 5.1
string.rep() doesn't have the 3rd argument before Lua 5.2

Revert once we drop support for Lua 5.1
2021-01-13 15:33:44 +01:00
Kim Alvefur
3c919b0ad4 mod_storage_sql: Support query for set of IDs
Not compatible with Lua 5.1
2021-01-12 18:46:17 +01:00
Kim Alvefur
ae0d560197 mod_storage_sql: Advertise support for id range query
That is, a query for items between two IDs (not inclusive).
2021-01-09 21:08:33 +01:00
Kim Alvefur
18525691a4 mod_storage_sql: Measure hits/misses on the item count cache
A cache miss can be expensive so having numbers on how often this occurs
may be valuable.
2020-07-02 19:03:59 +02:00
Matthew Wild
371d05a0c6 mod_storage_sql: Fix incorrect results when fetching items before specific archive id
Copy/paste error, introduced in deb68066c7aa
2020-06-12 16:54:38 +01:00
Kim Alvefur
75a3d7758b mod_storage_sql: Log database connection parameters when creating engine
This is meant to help trace down an issue where Prosody apparently
creates multiple conflicting SQL engines, causing problems especially
with SQLite3, e.g. #616 #784.
2020-05-02 14:13:02 +02:00
Kim Alvefur
1724e9a271 Merge 0.11->trunk 2020-03-22 21:13:09 +01:00
Kim Alvefur
65a654d726 mod_storage_sql: Add index covering sort_id to improve performance (fixes #1505) 2020-03-22 21:05:59 +01:00
Matthew Wild
cb6148d155 storagemanager, mod_storage_sql: Rename methods to :get_all() and :delete_all() 2020-03-11 16:32:41 +00:00
Matthew Wild
33b9b2b91e mod_storage_sql: Add map_store:find_key() and map_store:delete_key() (+ tests) 2020-03-11 15:57:53 +00:00
Kim Alvefur
132191f6ff Merge 0.11->trunk 2020-02-22 16:26:20 +01:00
Kim Alvefur
6e53a3a601 mod_storage_sql: Move update limit check back one step, fixes traceback
0c00274528a4 moved it one step too far, so the check was performed
before connecting to the database instead of after.
2020-02-22 16:23:43 +01:00
Kim Alvefur
aa6a550ceb Merge 0.11->trunk 2020-02-21 23:01:43 +01:00
Kim Alvefur
84e0c87b7e mod_storage_sql: Fix check for deletion limits (fixes #1494)
The check was only performed if sql_manage_tables was set to true (the default)
It should always be performed
2020-02-21 23:00:44 +01:00
Kim Alvefur
96c1406bcd mod_storage_sql: Remove unused and not actually returned return value [luacheck]
The :delete throws an error, it does not return one like this.
2019-12-24 00:49:43 +01:00
Kim Alvefur
9d5e31fd48 mod_storage_*: Also include timestmap of first message in :summary API
For completeness along with most recent timestamp. Might be nice to be
able to order by oldest unread message.
2019-08-23 01:15:44 +02:00
Kim Alvefur
d3c559bcc8 mod_storage_*: Include timestamp of latest message in :summary API
Clients may want to show a list of conversations ordered by how
timestamp of most recent message.

The counts allow a badge with unread message counter.
2019-08-23 01:10:27 +02:00
Kim Alvefur
39cb87a158 mod_storage_*: Tweak :summary API to allow future expansion with more fields
Eg might want to include last message, timestamp, chat state or other info.
2019-08-23 01:04:00 +02:00
Kim Alvefur
e5423a5f05 mod_storage_sql: Handle SQLite DELETE with LIMIT being optional (fixes #1359) 2019-05-13 14:39:38 +02:00
Kim Alvefur
e54ee56ed1 mod_storage_sql: Move code out of if-else chain 2019-05-13 14:47:41 +02:00
Matthew Wild
813f69fd2b mod_storage_sql: Catch errors during schema upgrade (thanks Nothing4You) 2018-11-15 21:55:16 +00:00
Kim Alvefur
c5d487e42d mod_storage_sql: Handle Lua 5.3 move of unpack function 2018-10-21 21:12:38 +02:00
Matthew Wild
fcdc8d9ff1 mod_storage_sql: Fix issue number in comment that was fixed by 55b40f3fa659 (fixes #1073) 2018-10-13 08:17:58 +01:00
Matthew Wild
1faf1773a3 mod_storage_sql: Keep prosodyarchive_index unique constraint on non-MySQL DBs 2018-10-12 21:59:15 +01:00
Matthew Wild
06cdd9edcd mod_storage_sql: Change prosodyarchive_index to be non-unique (fixes #1087)
MySQL requires that the first 20 bytes are unique, even if they differ after
the first 20 bytes. This breaks e.g. pubsub/PEP nodes longer than 20 characters
that have common prefixes.
2018-10-11 19:23:21 +01:00
Matthew Wild
9423dbfdb3 mod_storage_sql: Have :users() throw an error on failure instead of returning non-iterator values 2018-10-11 19:15:46 +01:00
Matthew Wild
21e358c847 mod_storage_sql: Workaround MySQL not supporting LIMIT subquery in archive truncate operations, fixes #1200 2018-10-11 18:20:09 +01:00