@ -129,11 +129,19 @@ func (app *appContext) checkInvites() {
msg , err := app . email . constructExpiry ( code , data , app , false )
msg , err := app . email . constructExpiry ( code , data , app , false )
if err != nil {
if err != nil {
app . err . Printf ( "%s: Failed to construct expiry notification: %v" , code , err )
app . err . Printf ( "%s: Failed to construct expiry notification: %v" , code , err )
} else if err := app . email . send ( msg , addr ) ; err != nil {
} else {
// Check whether notify "address" is an email address of Jellyfin ID
if strings . Contains ( addr , "@" ) {
err = app . email . send ( msg , addr )
} else {
err = app . sendByID ( msg , addr )
}
if err != nil {
app . err . Printf ( "%s: Failed to send expiry notification: %v" , code , err )
app . err . Printf ( "%s: Failed to send expiry notification: %v" , code , err )
} else {
} else {
app . info . Printf ( "Sent expiry notification to %s" , addr )
app . info . Printf ( "Sent expiry notification to %s" , addr )
}
}
}
} ( address )
} ( address )
}
}
wait . Wait ( )
wait . Wait ( )
@ -171,11 +179,19 @@ func (app *appContext) checkInvite(code string, used bool, username string) bool
msg , err := app . email . constructExpiry ( code , inv , app , false )
msg , err := app . email . constructExpiry ( code , inv , app , false )
if err != nil {
if err != nil {
app . err . Printf ( "%s: Failed to construct expiry notification: %v" , code , err )
app . err . Printf ( "%s: Failed to construct expiry notification: %v" , code , err )
} else if err := app . email . send ( msg , addr ) ; err != nil {
} else {
// Check whether notify "address" is an email address of Jellyfin ID
if strings . Contains ( addr , "@" ) {
err = app . email . send ( msg , addr )
} else {
err = app . sendByID ( msg , addr )
}
if err != nil {
app . err . Printf ( "%s: Failed to send expiry notification: %v" , code , err )
app . err . Printf ( "%s: Failed to send expiry notification: %v" , code , err )
} else {
} else {
app . info . Printf ( "Sent expiry notification to %s" , addr )
app . info . Printf ( "Sent expiry notification to %s" , addr )
}
}
}
} ( address )
} ( address )
}
}
wait . Wait ( )
wait . Wait ( )
@ -470,10 +486,18 @@ func (app *appContext) newUser(req newUserDTO, confirmed bool) (f errorFunc, suc
msg , err := app . email . constructCreated ( req . Code , req . Username , req . Email , invite , app , false )
msg , err := app . email . constructCreated ( req . Code , req . Username , req . Email , invite , app , false )
if err != nil {
if err != nil {
app . err . Printf ( "%s: Failed to construct user creation notification: %v" , req . Code , err )
app . err . Printf ( "%s: Failed to construct user creation notification: %v" , req . Code , err )
} else if err := app . email . send ( msg , address ) ; err != nil {
} else {
// Check whether notify "address" is an email address of Jellyfin ID
if strings . Contains ( address , "@" ) {
err = app . email . send ( msg , address )
} else {
err = app . sendByID ( msg , address )
}
if err != nil {
app . err . Printf ( "%s: Failed to send user creation notification: %v" , req . Code , err )
app . err . Printf ( "%s: Failed to send user creation notification: %v" , req . Code , err )
} else {
} else {
app . info . Printf ( "%s: Sent user creation notification to %v" , req . Code , address )
app . info . Printf ( "Sent user creation notification to %s" , address )
}
}
}
} ( )
} ( )
}
}
@ -1340,15 +1364,16 @@ func (app *appContext) SetNotify(gc *gin.Context) {
return
return
}
}
var address string
var address string
if app . config . Section ( "ui" ) . Key ( "jellyfin_login" ) . MustBool ( false ) {
jellyfinLogin := app . config . Section ( "ui" ) . Key ( "jellyfin_login" ) . MustBool ( false )
addr , ok := app . storage . emails [ gc . GetString ( "jfId" ) ]
if jellyfinLogin {
if ! ok {
var addressAvailable bool = app . getAddressOrName ( gc . GetString ( "jfId" ) ) != ""
app . err . Printf ( "%s: Couldn't find email address. Make sure it's set" , code )
if ! addressAvailable {
app . err . Printf ( "%s: Couldn't find contact method for admin. Make sure one is set." , code )
app . debug . Printf ( "%s: User ID \"%s\"" , code , gc . GetString ( "jfId" ) )
app . debug . Printf ( "%s: User ID \"%s\"" , code , gc . GetString ( "jfId" ) )
respond ( 500 , "Missing user email ", gc )
respond ( 500 , "Missing user contact method ", gc )
return
return
}
}
address = addr. Addr
address = gc. GetString ( "jfId" )
} else {
} else {
address = app . config . Section ( "ui" ) . Key ( "email" ) . String ( )
address = app . config . Section ( "ui" ) . Key ( "email" ) . String ( )
}
}