Commit Graph

21 Commits

Author SHA1 Message Date
06d864d49f
fix error with sqlite ≥ 3.34
Since sqlite 3.34[1] deleting a record in a fts5 table that doesn't
exist became an error. The resuls it that adding a torrent "corrupts"
the database and magnetico fails with this error:

    Could not add new torrent to the database.
    tx.Exec (INSERT OR REPLACE INTO torrents) database disk image is malformed

The problem can be simply avoided by setting modified_on = discovered_on
when inserting the torrent, instead of updating it afterwards with a
trigger.

[1]: 86f477edaa
2024-07-25 13:46:36 +02:00
Bora M. Alper
376dba5810
staticcheck guided refactoring 2020-11-27 18:06:43 +00:00
Bora M. Alper
202cfc7c5b
fix formatting 2020-04-16 08:59:25 +03:00
Matt Joiner
29543dae95 Include file: and escape paths passed through to sqlite3
Fixes #240.
2020-02-24 11:40:00 +11:00
Bora M. Alper
e01a3bed40
better error handling at sqlite3.go 2018-12-30 08:24:44 +03:00
Bora M. Alper
5fd07f7ab5
fixed (v2) "unable to open database file" 2018-12-25 18:34:19 +03:00
Bora M. Alper
64543d71d7
fixed "unable to open database file" (potentially), and errors wrapped in pkg/persistence 2018-12-24 18:27:36 +03:00
Bora Alper
afbe7cd384 persistence: fixed tons of things, read the full description
- value returned from last_insert_rowid() is now checked
- INSERT OR IGNORE INTO torrents is removed in favour of explicitly checking if the torrent is in the database
- changed trigger names for keeping 'torrents_idx' up to date
- fixed 'modified_on' once again, but this time for sure (it seems...)
2018-08-16 13:41:25 +03:00
Bora Alper
1ee35d02c6 persistence: fixed nil error on empty 'torrents' and changed "modified_on" 2018-08-15 11:53:07 +03:00
Bora Alper
4b9b354171 fixed some go vet warnings, fixed formatting 2018-08-03 15:40:04 +03:00
Bora Alper
dc420da802 cumulative commit! (see the description for changes)
magneticod:
!!! disabled the gradual increase in congestion control, for some reason we still can't detect congestion...
- `*net.UDPAddr` in dht/mainline instead of `net.Addr`
- fixed a bug when a very small extension message received
- simplified how peer adress is handled in bittorrent/metadata/sink
- simplified TrawlingResult in dht/mainline

magneticow:
- use WAL for sqlite3

persistence:
- use URL.String() instead of url.Path in sql.Open() so that URL parameters are not lost...
2018-08-03 11:28:50 +03:00
Bora Alper
c07daa3eca magneticod: metadata leech refactored heavily, now much more readable <3
+ persistence: we now make sure that rows are always closed using `defer`
2018-07-24 15:41:13 +03:00
Bora Alper
ba1be368cf magneticow & api: statistics are now working! 2018-07-07 14:56:34 +03:00
Bora Alper
cab54c6ec1 persistence: now using Row Value Comparsions as it should been using 2018-07-01 17:29:42 +03:00
Bora Alper
e20cdca890 magneticow: orderBy now works at API endpoint, no web interface yet 2018-06-29 20:08:00 +03:00
Bora Alper
3a45f17647 now torrent pages work too!
- Changed the URL structure of torrent pages:
  Before:
    /torrents/{{infoHash}}/{{name}}
  After:
    /torrents/{{infoHash}}
2018-06-29 18:58:57 +03:00
Bora Alper
0501fc3e3c magneticow: search now works perfectly!
- support for ordering is yet to be implemented
2018-06-19 18:49:46 +03:00
Bora Alper
0c54cc80dc [magneticow] the search now works, but need to change our approach 2018-04-25 21:33:50 +01:00
Bora Alper
ac7d0a514f QueryTorrents() of sqlite3 is complete! (testing needed) 2018-04-21 10:05:12 +01:00
Bora Alper
7e2a2bc5d9 persistence/sqlite3 torrents_idx FTS5 table is created in user_version 3 (+ some other code improvements) 2018-03-04 11:07:53 +00:00
Bora Alper
7a49acb50a created /cmd and /pkg directories 2018-03-02 18:56:17 +00:00