a better way to manage your Jellyfin users, now in go.
Go to file
Harvey Tindall 69bf81b658
change comment
2021-01-05 17:34:27 +00:00
.github/ISSUE_TEMPLATE add issue template 2020-09-15 12:00:20 +01:00
common add rough error logging for read/write errors 2020-11-02 23:20:06 +00:00
config add URL base option for subfolder proxies 2020-11-22 16:36:43 +00:00
data separate head into template, add description meta tag 2020-12-07 22:46:17 +00:00
docs use esbuild to compile and minify ts 2020-09-29 20:35:06 +01:00
images small changes, new images and readme updated 2020-09-24 23:57:42 +01:00
jfapi Add ability to revert to non-hyphenated user IDs 2020-12-18 15:44:19 +00:00
mail use npx to avoid looking for node_modules, get rid of useless 2020-10-18 00:57:53 +01:00
ombi refactor; separate jfapi and ombi into modules 2020-11-02 00:53:08 +00:00
scss fix 10.7.0 compatibility, simplify scss 2020-11-29 18:01:10 +00:00
ts fix/improve parsing of last active dates 2020-12-03 20:49:50 +00:00
.drone.yml install requests dep for upload.py 2020-10-08 21:48:15 +01:00
.gitignore Rework typescript to use modules 2020-10-22 17:50:40 +01:00
.goreleaser.yml Fix smtp sending 2020-11-14 15:33:25 +00:00
Dockerfile use npx to avoid looking for node_modules, get rid of useless 2020-10-18 00:57:53 +01:00
LICENSE Added install step to makefile; start PKGBUILD 2020-08-19 12:10:34 +01:00
Makefile Rework typescript to use modules 2020-10-22 17:50:40 +01:00
README.md use bs5 alpha2, config description changes 2020-10-23 14:39:04 +01:00
api.go fix/improve parsing of last active dates 2020-12-03 20:49:50 +00:00
auth.go dont re-b64 the jwt 2020-11-12 21:25:52 +00:00
config.go add URL base option for subfolder proxies 2020-11-22 16:36:43 +00:00
daemon.go add URL base option for subfolder proxies 2020-11-22 16:36:43 +00:00
email.go add URL base option for subfolder proxies 2020-11-22 16:36:43 +00:00
esbuild.sh use esbuild to compile and minify ts 2020-09-29 20:35:06 +01:00
go.mod separate head into template, add description meta tag 2020-12-07 22:46:17 +00:00
go.sum separate head into template, add description meta tag 2020-12-07 22:46:17 +00:00
jfa-go.service add example systemd service 2020-09-03 21:32:59 +01:00
main.go Add ability to revert to non-hyphenated user IDs 2020-12-18 15:44:19 +00:00
models.go Move api models to separate file 2020-09-27 21:03:37 +01:00
package-lock.json Bump ini from 1.3.5 to 1.3.8 2020-12-13 04:01:02 +00:00
package.json upgrade to bs5-alpha3 2020-11-15 17:16:57 +00:00
pwreset.go add URL base option for subfolder proxies 2020-11-22 16:36:43 +00:00
pwval.go add URL base option for subfolder proxies 2020-11-22 16:36:43 +00:00
setup.go add cache_timeout option 2020-11-02 23:26:46 +00:00
storage.go change comment 2021-01-05 17:34:27 +00:00
version.py version based on current tag for makefile 2020-09-15 12:12:51 +01:00
views.go separate head into template, add description meta tag 2020-12-07 22:46:17 +00:00

README.md

jfa-go

jfa-go is a user management app for Jellyfin that provides invite-based account creation as well as other features that make one's instance much easier to manage.

I chose to rewrite the python jellyfin-accounts in Go mainly as a learning experience, but also to slightly improve speeds and efficiency.

Features

  • 🧑 Invite based account creation: Sends invites to your friends or family, and let them choose their own username and password without relying on you.
    • Send invites via a link and/or email
    • Granular control over invites: Validity period as well as number of uses can be specified.
    • Account profiles: Assign settings profiles to invites so new users have your predefined permissions, homescreen layout, etc. applied to their account on creation.
    • Password validation: Ensure users choose a strong password.
  • 🔗 Ombi Integration: Automatically creates Ombi accounts for new users using their email address and login details, and your own defined set of permissions.
  • Account management: Apply settings to your users individually or en masse, and delete users, optionally sending them an email notification with a reason.
  • 📨 Email storage: Add your existing users email addresses through the UI, and jfa-go will ask new users for them on account creation.
    • Email addresses can optionally be used instead of usernames
  • 🔑 Password resets: When user's forget their passwords and request a change in Jellyfin, jfa-go reads the PIN from the created file and sends it straight to the user via email.
  • Notifications: Get notified when someone creates an account, or an invite expires.
  • Authentication via Jellyfin: Instead of using separate credentials for jfa-go and Jellyfin, jfa-go can use it as the authentication provider.
    • Enables the usage of jfa-go by multiple people
  • 🌓 Customizable look
    • Specify contact and help messages to appear in emails and pages
    • Light and dark themes available
    • Optionally provide custom CSS

Interface

Invites tab Accounts tab

Install

Available on the AUR as jfa-go or jfa-go-git.

For other platforms, grab an archive from the release section for your platform (or nightly builds here), and extract jfa-go and data to the same directory.

  • For linux users, you can place them inside /opt/jfa-go and then run sudo ln -s /opt/jfa-go/jfa-go /usr/bin/jfa-go to place it in your PATH.

Run the executable to start.

For docker, run:

docker create \
             --name "jfa-go" \ # Whatever you want to name it
             -p 8056:8056 \
             -v /path/to/.config/jfa-go:/data \ # Path to wherever you want to store the config file and other data
             -v /path/to/jellyfin:/jf \ # Path to jellyfin config directory
             -v /etc/localtime:/etc/localtime:ro \ # Makes sure time is correct
             hrfee/jfa-go # hrfee/jfa-go:unstable for latest build from git

Build from source

If you're using docker, a Dockerfile is provided that builds from source.

Otherwise, full build instructions can be found here.

Usage

Simply run jfa-go to start the application. A setup wizard will start on localhost:8056 (or your own specified address). Upon completion, refresh the page.

Note: jfa-go does not run as a daemon by default. You'll need to figure this out yourself.

Usage of ./jfa-go:
  -config string
    	alternate path to config file. (default "~/.config/jfa-go/config.ini")
  -data string
    	alternate path to data directory. (default "~/.config/jfa-go")
  -debug
    	Enables debug logging and exposes pprof.
  -host string
    	alternate address to host web ui on.
  -port int
    	alternate port to host web ui on.
  -swagger
    	Enable swagger at /swagger/index.html

If you're switching from jellyfin-accounts, copy your existing ~/.jf-accounts to:

  • XDG_CONFIG_DIR/jfa-go (usually ~/.config/jfa-go) on *nix systems,
  • %AppData%/jfa-go on Windows,
  • ~/Library/Application Support/jfa-go on macOS.

(or specify config/data path with -config/-data respectively.)