Skip to content

A personal custom Anki sync server,aim to provide an easier way for deployment

License

Notifications You must be signed in to change notification settings

redmie/anki-sync-server-rs

 
 

Repository files navigation

anki-sync-server-rs

A cross-platform Anki sync server.

This is a rust (still sqlite c library backed) take on anki sync server (for a mature python one see ankicommunity/anki-sync-server).

How to use anki-sync-server-rs

  1. Install anki-sync-server-rs, see underneath or INSTALL.md for more information.
  2. Configure it (see template configuration ankisyncd.toml,Optional)
  3. Run the server
  4. Add user to the server
  5. Configure your client to sync with the custom server, see here

For https setup and support see certificate setup. See reverse proxy setup for setting up a reverse proxy in front of the sync server.

Quickstart guide

Linux/Windows/MacOS

  1. Grab binary from github releases and unpack it, each platform has its corresponding tag (e.g. windows_x86_64 for Windows 64bit,details see support platform ) , or even better build it from source (see INSTALL.md)
  2. Tweak the configuration ankisyncd.toml to your liking (if you want to use it,optional)
  3. Run server ./ankisyncd (./ankisyncd.exe or double click for windows,use --config ANKISYNCD_CONFIG_PATH if needed)
  4. Add user ./ankisyncd user --add username password (./ankisyncd.exe for windows use ./ankisyncd user --help for more on user management, add --config ANKISYNCD_CONFIG_PATH to the command when using a config file)
  5. Enjoy!

Containerized build/install(docker)

see containerized build/install

How to contribute

See CONTRIBUTING.md.

All contributions must be licensed under AGLP-v3.0 to comply with the license of the anki code used as the base of this project.

License

See LICENSE

Compatibility

Server

It should work on any tier 1/2 platform of the rust ecosystem. But have only been tested on the following.

Windows

Win 10 64bits

Linux

machine ENV
x86_64 Windows wsl2,tested
aarch64(arm64) cross-compiled on wsl2(ubuntu),tested on ubuntu aarch64 and termux
armv7(arm32) cross-compiled on wsl2(ubuntu)

Client

tested anki versions 2.1.15,2.1.28,2.1.35,2.1.50
tested process import a collection of decks and upload to server

REFERENCE

ankisyncd architecture or apis depend on ankicommunity/anki-sync-server and ankitects/anki. Sync APIs are based on anki/rslib 2.1.46

About

A personal custom Anki sync server,aim to provide an easier way for deployment

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Rust 89.8%
  • Shell 4.9%
  • Dockerfile 3.1%
  • Batchfile 2.2%