mirror of
https://github.com/hrfee/jfa-go.git
synced 2025-01-07 17:00:11 +00:00
Compare commits
3 Commits
9944cc2db9
...
af61549bf1
Author | SHA1 | Date | |
---|---|---|---|
af61549bf1 | |||
22a0d8925d | |||
59a014f681 |
@ -1,11 +1,4 @@
|
|||||||
### fixconfig
|
### fixconfig
|
||||||
|
|
||||||
Python's `json` library retains the order of data in a JSON file, which meant settings sent to the web page would be in the right order. Go's `encoding/json` and maps do not retain order, so this script opens the json file, and for each section, adds an "order" list which tells the web page in which order to display settings.
|
Python's `json` library retains the order of data in a JSON file, which meant settings sent to the web page would be in the right order. Go's `encoding/json` and maps do not retain order, so `enumerate/enumerate_config.py` opens the json file, and for each section, adds an "order" array which tells the web page in which order to display settings.
|
||||||
|
|
||||||
Specify the input and output files with `-i` and `-o` respectively.
|
Specify the input and output files with `-i` and `-o` respectively.
|
||||||
|
|
||||||
### jsontostruct
|
|
||||||
|
|
||||||
Generates a go struct from `config-base.json`. I wrote this because i was annoyed with the `ini` library, but i've since realised mapping the ini values onto it is painful.
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -469,13 +469,13 @@
|
|||||||
"description": "Path to the folder Jellyfin puts password-reset files."
|
"description": "Path to the folder Jellyfin puts password-reset files."
|
||||||
},
|
},
|
||||||
"link_reset": {
|
"link_reset": {
|
||||||
"name": "Use reset link instead of PIN",
|
"name": "Use reset link instead of PIN (Required for Ombi)",
|
||||||
"required": false,
|
"required": false,
|
||||||
"requires_restart": true,
|
"requires_restart": true,
|
||||||
"depends_true": "enabled",
|
"depends_true": "enabled",
|
||||||
"type": "bool",
|
"type": "bool",
|
||||||
"value": false,
|
"value": false,
|
||||||
"description": "Send users a link to reset their password instead of a PIN."
|
"description": "Send users a link to reset their password instead of a PIN. Must be enabled to reset Ombi password at the same time as the Jellyfin password."
|
||||||
},
|
},
|
||||||
"language": {
|
"language": {
|
||||||
"name": "Default reset link language",
|
"name": "Default reset link language",
|
||||||
@ -722,7 +722,7 @@
|
|||||||
"order": [],
|
"order": [],
|
||||||
"meta": {
|
"meta": {
|
||||||
"name": "Ombi Integration",
|
"name": "Ombi Integration",
|
||||||
"description": "Connect to Ombi to automatically create both Ombi and Jellyfin accounts for new users. You'll need to create a user template for this to work. Once enabled, refresh to see an option in settings for this."
|
"description": "Connect to Ombi to automatically create both Ombi and Jellyfin accounts for new users. You'll need to create a user template for this to work. Once enabled, refresh to see an option in settings for this. To handle password resets for Ombi & Jellyfin, enable \"Use reset link instead of PIN\"."
|
||||||
},
|
},
|
||||||
"settings": {
|
"settings": {
|
||||||
"enabled": {
|
"enabled": {
|
||||||
|
@ -1,541 +0,0 @@
|
|||||||
package main
|
|
||||||
|
|
||||||
type Metadata struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type Config struct{
|
|
||||||
Order []string `json:"order"`
|
|
||||||
Jellyfin struct{
|
|
||||||
Order []string `json:"order"`
|
|
||||||
Meta Metadata `json:"meta"`
|
|
||||||
Username struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"username"`
|
|
||||||
} `json:"username" cfg:"username"`
|
|
||||||
Password struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"password"`
|
|
||||||
} `json:"password" cfg:"password"`
|
|
||||||
Server struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"server"`
|
|
||||||
} `json:"server" cfg:"server"`
|
|
||||||
PublicServer struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"public_server"`
|
|
||||||
} `json:"public_server" cfg:"public_server"`
|
|
||||||
Client struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"client"`
|
|
||||||
} `json:"client" cfg:"client"`
|
|
||||||
Version struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"version"`
|
|
||||||
} `json:"version" cfg:"version"`
|
|
||||||
Device struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"device"`
|
|
||||||
} `json:"device" cfg:"device"`
|
|
||||||
DeviceId struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"device_id"`
|
|
||||||
} `json:"device_id" cfg:"device_id"`
|
|
||||||
} `json:"jellyfin"`
|
|
||||||
Ui struct{
|
|
||||||
Order []string `json:"order"`
|
|
||||||
Meta Metadata `json:"meta"`
|
|
||||||
Theme struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Options []string `json:"options"`
|
|
||||||
Value string `json:"value" cfg:"theme"`
|
|
||||||
} `json:"theme" cfg:"theme"`
|
|
||||||
Host struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"host"`
|
|
||||||
} `json:"host" cfg:"host"`
|
|
||||||
Port struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value int `json:"value" cfg:"port"`
|
|
||||||
} `json:"port" cfg:"port"`
|
|
||||||
JellyfinLogin struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value bool `json:"value" cfg:"jellyfin_login"`
|
|
||||||
} `json:"jellyfin_login" cfg:"jellyfin_login"`
|
|
||||||
AdminOnly struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value bool `json:"value" cfg:"admin_only"`
|
|
||||||
} `json:"admin_only" cfg:"admin_only"`
|
|
||||||
Username struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"username"`
|
|
||||||
} `json:"username" cfg:"username"`
|
|
||||||
Password struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"password"`
|
|
||||||
} `json:"password" cfg:"password"`
|
|
||||||
Email struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"email"`
|
|
||||||
} `json:"email" cfg:"email"`
|
|
||||||
Debug struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value bool `json:"value" cfg:"debug"`
|
|
||||||
} `json:"debug" cfg:"debug"`
|
|
||||||
ContactMessage struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"contact_message"`
|
|
||||||
} `json:"contact_message" cfg:"contact_message"`
|
|
||||||
HelpMessage struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"help_message"`
|
|
||||||
} `json:"help_message" cfg:"help_message"`
|
|
||||||
SuccessMessage struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"success_message"`
|
|
||||||
} `json:"success_message" cfg:"success_message"`
|
|
||||||
Bs5 struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value bool `json:"value" cfg:"bs5"`
|
|
||||||
} `json:"bs5" cfg:"bs5"`
|
|
||||||
} `json:"ui"`
|
|
||||||
PasswordValidation struct{
|
|
||||||
Order []string `json:"order"`
|
|
||||||
Meta Metadata `json:"meta"`
|
|
||||||
Enabled struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value bool `json:"value" cfg:"enabled"`
|
|
||||||
} `json:"enabled" cfg:"enabled"`
|
|
||||||
MinLength struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"min_length"`
|
|
||||||
} `json:"min_length" cfg:"min_length"`
|
|
||||||
Upper struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"upper"`
|
|
||||||
} `json:"upper" cfg:"upper"`
|
|
||||||
Lower struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"lower"`
|
|
||||||
} `json:"lower" cfg:"lower"`
|
|
||||||
Number struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"number"`
|
|
||||||
} `json:"number" cfg:"number"`
|
|
||||||
Special struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"special"`
|
|
||||||
} `json:"special" cfg:"special"`
|
|
||||||
} `json:"password_validation"`
|
|
||||||
Email struct{
|
|
||||||
Order []string `json:"order"`
|
|
||||||
Meta Metadata `json:"meta"`
|
|
||||||
NoUsername struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value bool `json:"value" cfg:"no_username"`
|
|
||||||
} `json:"no_username" cfg:"no_username"`
|
|
||||||
Use24H struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value bool `json:"value" cfg:"use_24h"`
|
|
||||||
} `json:"use_24h" cfg:"use_24h"`
|
|
||||||
DateFormat struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"date_format"`
|
|
||||||
} `json:"date_format" cfg:"date_format"`
|
|
||||||
Message struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"message"`
|
|
||||||
} `json:"message" cfg:"message"`
|
|
||||||
Method struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Options []string `json:"options"`
|
|
||||||
Value string `json:"value" cfg:"method"`
|
|
||||||
} `json:"method" cfg:"method"`
|
|
||||||
Address struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"address"`
|
|
||||||
} `json:"address" cfg:"address"`
|
|
||||||
From struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"from"`
|
|
||||||
} `json:"from" cfg:"from"`
|
|
||||||
} `json:"email"`
|
|
||||||
PasswordResets struct{
|
|
||||||
Order []string `json:"order"`
|
|
||||||
Meta Metadata `json:"meta"`
|
|
||||||
Enabled struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value bool `json:"value" cfg:"enabled"`
|
|
||||||
} `json:"enabled" cfg:"enabled"`
|
|
||||||
WatchDirectory struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"watch_directory"`
|
|
||||||
} `json:"watch_directory" cfg:"watch_directory"`
|
|
||||||
EmailHtml struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"email_html"`
|
|
||||||
} `json:"email_html" cfg:"email_html"`
|
|
||||||
EmailText struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"email_text"`
|
|
||||||
} `json:"email_text" cfg:"email_text"`
|
|
||||||
Subject struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"subject"`
|
|
||||||
} `json:"subject" cfg:"subject"`
|
|
||||||
} `json:"password_resets"`
|
|
||||||
InviteEmails struct{
|
|
||||||
Order []string `json:"order"`
|
|
||||||
Meta Metadata `json:"meta"`
|
|
||||||
Enabled struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value bool `json:"value" cfg:"enabled"`
|
|
||||||
} `json:"enabled" cfg:"enabled"`
|
|
||||||
EmailHtml struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"email_html"`
|
|
||||||
} `json:"email_html" cfg:"email_html"`
|
|
||||||
EmailText struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"email_text"`
|
|
||||||
} `json:"email_text" cfg:"email_text"`
|
|
||||||
Subject struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"subject"`
|
|
||||||
} `json:"subject" cfg:"subject"`
|
|
||||||
UrlBase struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"url_base"`
|
|
||||||
} `json:"url_base" cfg:"url_base"`
|
|
||||||
} `json:"invite_emails"`
|
|
||||||
Notifications struct{
|
|
||||||
Order []string `json:"order"`
|
|
||||||
Meta Metadata `json:"meta"`
|
|
||||||
Enabled struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value bool `json:"value" cfg:"enabled"`
|
|
||||||
} `json:"enabled" cfg:"enabled"`
|
|
||||||
ExpiryHtml struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"expiry_html"`
|
|
||||||
} `json:"expiry_html" cfg:"expiry_html"`
|
|
||||||
ExpiryText struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"expiry_text"`
|
|
||||||
} `json:"expiry_text" cfg:"expiry_text"`
|
|
||||||
CreatedHtml struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"created_html"`
|
|
||||||
} `json:"created_html" cfg:"created_html"`
|
|
||||||
CreatedText struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"created_text"`
|
|
||||||
} `json:"created_text" cfg:"created_text"`
|
|
||||||
} `json:"notifications"`
|
|
||||||
Mailgun struct{
|
|
||||||
Order []string `json:"order"`
|
|
||||||
Meta Metadata `json:"meta"`
|
|
||||||
ApiUrl struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"api_url"`
|
|
||||||
} `json:"api_url" cfg:"api_url"`
|
|
||||||
ApiKey struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"api_key"`
|
|
||||||
} `json:"api_key" cfg:"api_key"`
|
|
||||||
} `json:"mailgun"`
|
|
||||||
Smtp struct{
|
|
||||||
Order []string `json:"order"`
|
|
||||||
Meta Metadata `json:"meta"`
|
|
||||||
Encryption struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Options []string `json:"options"`
|
|
||||||
Value string `json:"value" cfg:"encryption"`
|
|
||||||
} `json:"encryption" cfg:"encryption"`
|
|
||||||
Server struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"server"`
|
|
||||||
} `json:"server" cfg:"server"`
|
|
||||||
Port struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value int `json:"value" cfg:"port"`
|
|
||||||
} `json:"port" cfg:"port"`
|
|
||||||
Password struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"password"`
|
|
||||||
} `json:"password" cfg:"password"`
|
|
||||||
} `json:"smtp"`
|
|
||||||
Files struct{
|
|
||||||
Order []string `json:"order"`
|
|
||||||
Meta Metadata `json:"meta"`
|
|
||||||
Invites struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"invites"`
|
|
||||||
} `json:"invites" cfg:"invites"`
|
|
||||||
Emails struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"emails"`
|
|
||||||
} `json:"emails" cfg:"emails"`
|
|
||||||
UserTemplate struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"user_template"`
|
|
||||||
} `json:"user_template" cfg:"user_template"`
|
|
||||||
UserConfiguration struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"user_configuration"`
|
|
||||||
} `json:"user_configuration" cfg:"user_configuration"`
|
|
||||||
UserDisplayprefs struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"user_displayprefs"`
|
|
||||||
} `json:"user_displayprefs" cfg:"user_displayprefs"`
|
|
||||||
CustomCss struct{
|
|
||||||
Name string `json:"name"`
|
|
||||||
Required bool `json:"required"`
|
|
||||||
Restart bool `json:"requires_restart"`
|
|
||||||
Description string `json:"description"`
|
|
||||||
Type string `json:"type"`
|
|
||||||
Value string `json:"value" cfg:"custom_css"`
|
|
||||||
} `json:"custom_css" cfg:"custom_css"`
|
|
||||||
} `json:"files"`
|
|
||||||
}
|
|
2
email.go
2
email.go
@ -340,7 +340,7 @@ func (emailer *Emailer) inviteValues(code string, invite Invite, app *appContext
|
|||||||
|
|
||||||
func (emailer *Emailer) constructInvite(code string, invite Invite, app *appContext, noSub bool) (*Email, error) {
|
func (emailer *Emailer) constructInvite(code string, invite Invite, app *appContext, noSub bool) (*Email, error) {
|
||||||
email := &Email{
|
email := &Email{
|
||||||
Subject: app.config.Section("email_confirmation").Key("subject").MustString(emailer.lang.InviteEmail.get("title")),
|
Subject: app.config.Section("invite_emails").Key("subject").MustString(emailer.lang.InviteEmail.get("title")),
|
||||||
}
|
}
|
||||||
template := emailer.inviteValues(code, invite, app, noSub)
|
template := emailer.inviteValues(code, invite, app, noSub)
|
||||||
var err error
|
var err error
|
||||||
|
@ -22,7 +22,11 @@
|
|||||||
</span>
|
</span>
|
||||||
<p class="content mb-1">
|
<p class="content mb-1">
|
||||||
{{ if .success }}
|
{{ if .success }}
|
||||||
|
{{ if .ombiEnabled }}
|
||||||
|
{{ .strings.youCanLoginOmbi }}
|
||||||
|
{{ else }}
|
||||||
{{ .strings.youCanLogin }}
|
{{ .strings.youCanLogin }}
|
||||||
|
{{ end }}
|
||||||
{{ else }}
|
{{ else }}
|
||||||
{{ .strings.tryAgain }}
|
{{ .strings.tryAgain }}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
"resetFailed": "Password reset failed",
|
"resetFailed": "Password reset failed",
|
||||||
"tryAgain": "Please try again.",
|
"tryAgain": "Please try again.",
|
||||||
"youCanLogin": "You can now log in with the below code as your password.",
|
"youCanLogin": "You can now log in with the below code as your password.",
|
||||||
|
"youCanLoginOmbi": "You can now log in to Jellyfin & Ombi with the below code as your password.",
|
||||||
"changeYourPassword": "Make sure to change your password after you log in."
|
"changeYourPassword": "Make sure to change your password after you log in."
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -130,7 +130,7 @@ func (ombi *Ombi) ModifyUser(user map[string]interface{}) (status int, err error
|
|||||||
err = fmt.Errorf("No ID provided")
|
err = fmt.Errorf("No ID provided")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
_, status, err = ombi.put(ombi.server+"/api/v1/Identity", user, false)
|
_, status, err = ombi.put(ombi.server+"/api/v1/Identity/", user, false)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,11 +1,5 @@
|
|||||||
declare var window: Window;
|
declare var window: Window;
|
||||||
|
|
||||||
export function createEl(html: string): HTMLElement {
|
|
||||||
let div = document.createElement('div') as HTMLDivElement;
|
|
||||||
div.innerHTML = html;
|
|
||||||
return div.firstElementChild as HTMLElement;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function toDateString(date: Date): string {
|
export function toDateString(date: Date): string {
|
||||||
const locale = window.language || (window as any).navigator.userLanguage || window.navigator.language;
|
const locale = window.language || (window as any).navigator.userLanguage || window.navigator.language;
|
||||||
const t12 = document.getElementById("lang-12h") as HTMLInputElement;
|
const t12 = document.getElementById("lang-12h") as HTMLInputElement;
|
||||||
@ -27,49 +21,6 @@ export function toDateString(date: Date): string {
|
|||||||
return date.toLocaleDateString(locale, args1) + " " + date.toLocaleString(locale, args2);
|
return date.toLocaleDateString(locale, args1) + " " + date.toLocaleString(locale, args2);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function serializeForm(id: string): Object {
|
|
||||||
const form = document.getElementById(id) as HTMLFormElement;
|
|
||||||
let formData = {};
|
|
||||||
for (let i = 0; i < form.elements.length; i++) {
|
|
||||||
const el = form.elements[i];
|
|
||||||
if ((el as HTMLInputElement).type == "submit") {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
let name = (el as HTMLInputElement).name;
|
|
||||||
if (!name) {
|
|
||||||
name = el.id;
|
|
||||||
}
|
|
||||||
switch ((el as HTMLInputElement).type) {
|
|
||||||
case "checkbox":
|
|
||||||
formData[name] = (el as HTMLInputElement).checked;
|
|
||||||
break;
|
|
||||||
case "text":
|
|
||||||
case "password":
|
|
||||||
case "email":
|
|
||||||
case "number":
|
|
||||||
formData[name] = (el as HTMLInputElement).value;
|
|
||||||
break;
|
|
||||||
case "select-one":
|
|
||||||
case "select":
|
|
||||||
let val: string = (el as HTMLSelectElement).value.toString();
|
|
||||||
if (!isNaN(val as any)) {
|
|
||||||
formData[name] = +val;
|
|
||||||
} else {
|
|
||||||
formData[name] = val;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return formData;
|
|
||||||
}
|
|
||||||
|
|
||||||
export const rmAttr = (el: HTMLElement, attr: string): void => {
|
|
||||||
if (el.classList.contains(attr)) {
|
|
||||||
el.classList.remove(attr);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
export const addAttr = (el: HTMLElement, attr: string): void => el.classList.add(attr);
|
|
||||||
export const _get = (url: string, data: Object, onreadystatechange: (req: XMLHttpRequest) => void): void => {
|
export const _get = (url: string, data: Object, onreadystatechange: (req: XMLHttpRequest) => void): void => {
|
||||||
let req = new XMLHttpRequest();
|
let req = new XMLHttpRequest();
|
||||||
if (window.URLBase) { url = window.URLBase + url; }
|
if (window.URLBase) { url = window.URLBase + url; }
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import { _get, _post, _delete, toClipboard, toggleLoader, toDateString } from "../modules/common.js";
|
import { _get, _post, _delete, toClipboard, toggleLoader, toDateString } from "../modules/common.js";
|
||||||
|
|
||||||
export class DOMInvite implements Invite {
|
class DOMInvite implements Invite {
|
||||||
updateNotify = (checkbox: HTMLInputElement) => {
|
updateNotify = (checkbox: HTMLInputElement) => {
|
||||||
let state: { [code: string]: { [type: string]: boolean } } = {};
|
let state: { [code: string]: { [type: string]: boolean } } = {};
|
||||||
let revertChanges: () => void;
|
let revertChanges: () => void;
|
||||||
|
22
views.go
22
views.go
@ -144,6 +144,7 @@ func (app *appContext) ResetPassword(gc *gin.Context) {
|
|||||||
"contactMessage": app.config.Section("ui").Key("contact_message").String(),
|
"contactMessage": app.config.Section("ui").Key("contact_message").String(),
|
||||||
"strings": app.storage.lang.PasswordReset[lang].Strings,
|
"strings": app.storage.lang.PasswordReset[lang].Strings,
|
||||||
"success": false,
|
"success": false,
|
||||||
|
"ombiEnabled": app.config.Section("ombi").Key("enabled").MustBool(false),
|
||||||
}
|
}
|
||||||
resp, status, err := app.jf.ResetPassword(pin)
|
resp, status, err := app.jf.ResetPassword(pin)
|
||||||
if status == 200 && err == nil && resp.Success {
|
if status == 200 && err == nil && resp.Success {
|
||||||
@ -152,7 +153,26 @@ func (app *appContext) ResetPassword(gc *gin.Context) {
|
|||||||
} else {
|
} else {
|
||||||
app.err.Printf("Password Reset failed (%d): %v", status, err)
|
app.err.Printf("Password Reset failed (%d): %v", status, err)
|
||||||
}
|
}
|
||||||
gcHTML(gc, http.StatusOK, "password-reset.html", data)
|
defer gcHTML(gc, http.StatusOK, "password-reset.html", data)
|
||||||
|
if app.config.Section("ombi").Key("enabled").MustBool(false) {
|
||||||
|
jfUser, status, err := app.jf.UserByName(resp.UsersReset[0], false)
|
||||||
|
if status != 200 || err != nil {
|
||||||
|
app.err.Printf("Failed to get user \"%s\" from jellyfin/emby (%d): %v", resp.UsersReset[0], status, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
ombiUser, status, err := app.getOmbiUser(jfUser.ID)
|
||||||
|
if status != 200 || err != nil {
|
||||||
|
app.err.Printf("Failed to get user \"%s\" from ombi (%d): %v", resp.UsersReset[0], status, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
ombiUser["password"] = pin
|
||||||
|
status, err = app.ombi.ModifyUser(ombiUser)
|
||||||
|
if status != 200 || err != nil {
|
||||||
|
app.err.Printf("Failed to set password for ombi user \"%s\" (%d): %v", ombiUser["userName"], status, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
app.debug.Printf("Reset password for ombi user \"%s\"", ombiUser["userName"])
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (app *appContext) InviteProxy(gc *gin.Context) {
|
func (app *appContext) InviteProxy(gc *gin.Context) {
|
||||||
|
Loading…
Reference in New Issue
Block a user