Simple bookmark manager built with Go
Find a file
Paco Esteban 02247b215b
refactor: allow specific sqlite engine for OpenBSD (#780)
* remove dependencies that use syscall.Syscall*

OpenBSD will be removing direct access to `syscall(2)` soon.
Shiori will stop working because of this, as some of its dependencies
rely heavily on the use of `syscall.Syscall*`, which ends up using
`syscall(2)`.  This commit removes those dependencies by reverting back
to use github.com/mattn/go-sqlite3 instead of modernc.org/sqlite to deal
with the sqlite database backend.

* add ~emersion/go-sqlite3-fts5

* enable cgo to check ci

* fts5 build flag

* split sqlite logic using build flags

* disable cgo again

* added ci test for bsd systems

* remove openbsd ci

* Revert "remove openbsd ci"

This reverts commit f394148385.

* fix makefile go_test_flags

---------

Co-authored-by: Felipe M <me@fmartingr.com>
Co-authored-by: Felipe Martin <812088+fmartingr@users.noreply.github.com>
2024-05-02 16:38:16 +02:00
.githooks Add GitHub Action for tests & coverage 2020-08-06 21:08:43 +02:00
.github refactor: allow specific sqlite engine for OpenBSD (#780) 2024-05-02 16:38:16 +02:00
docs feat: api endpoint to serve readable content (#885) 2024-04-21 00:59:03 +02:00
internal refactor: allow specific sqlite engine for OpenBSD (#780) 2024-05-02 16:38:16 +02:00
scripts fix: fixes path issues on windows (#829) 2024-02-05 10:21:23 +01:00
testdata fix: Ensure bookmark files are correctly downloaded before deleting current ones (#683) 2023-08-20 18:20:13 +02:00
.dockerignore Setup new CI/CD workflows (#365) 2022-02-13 16:38:54 +01:00
.gitignore feat: build css from less files locally (#735) 2023-09-16 19:58:55 +02:00
.golangci.yml fix(ci): renamed deprecated golangci property (#887) 2024-04-13 09:18:31 +02:00
.goreleaser.yaml ci: create zip archives for windows builds (#884) 2024-04-13 09:16:01 +02:00
.prettierignore chore: frontend formatting (#764) 2023-11-05 11:02:31 +01:00
.prettierrc chore: frontend formatting (#764) 2023-11-05 11:02:31 +01:00
app.json Revert "Restructure build files" 2019-09-26 16:25:19 +07:00
bun.lockb chore: frontend formatting (#764) 2023-11-05 11:02:31 +01:00
CODE_OF_CONDUCT.md Update links and email addresses 2020-08-06 22:26:59 +02:00
coverage.txt Start working on new REST API. Refactor logic in domains. (#497) 2023-07-17 14:30:18 +01:00
docker-compose.yaml fix: properly parse mysql connection string, docs update (#730) 2023-09-13 18:31:41 +02:00
Dockerfile deps: updated docker image versions (#809) 2023-12-30 08:03:10 +01:00
Dockerfile.compose deps: updated docker image versions (#809) 2023-12-30 08:03:10 +01:00
go.mod refactor: allow specific sqlite engine for OpenBSD (#780) 2024-05-02 16:38:16 +02:00
go.sum refactor: allow specific sqlite engine for OpenBSD (#780) 2024-05-02 16:38:16 +02:00
LICENSE Update LICENSE 2019-01-06 17:00:20 +07:00
main.go feat: new migrations system (#876) 2024-04-27 07:46:36 +02:00
Makefile refactor: allow specific sqlite engine for OpenBSD (#780) 2024-05-02 16:38:16 +02:00
package.json chore: frontend formatting (#764) 2023-11-05 11:02:31 +01:00
Procfile fix: fix problems that may be raised from a 1.5.5 upgrade (#837) 2024-02-08 09:26:33 +01:00
README.md chore: remove irc badge from readme (#674) 2023-07-26 09:10:35 +02:00

Shiori

IC Go Report Card #shiori-general:matrix.org Containers

Check out our latest Announcements

Shiori is a simple bookmarks manager written in the Go language. Intended as a simple clone of Pocket. You can use it as a command line application or as a web application. This application is distributed as a single binary, which means it can be installed and used easily.

Screenshot

Features

  • Basic bookmarks management i.e. add, edit, delete and search.
  • Import and export bookmarks from and to Netscape Bookmark file.
  • Import bookmarks from Pocket.
  • Simple and clean command line interface.
  • Simple and pretty web interface for those who don't want to use a command line app.
  • Portable, thanks to its single binary format.
  • Support for sqlite3, PostgreSQL and MySQL as its database.
  • Where possible, by default shiori will parse the readable content and create an offline archive of the webpage.
  • [BETA] web extension support for Firefox and Chrome.

Comparison of reader mode and archive mode

Documentation

All documentation is available in the docs folder. If you think there is incomplete or incorrect information, feel free to edit it by submitting a pull request.

License

Shiori is distributed under the terms of the MIT license, which means you can use it and modify it however you want. However, if you make an enhancement for it, if possible, please send a pull request.