Compare commits
No commits in common. "5f1de4ec676723592e2dfdc95b179ea55f53a5f8" and "0f271ac2fbe3b04f4e7fca15354008e1b75ae1e6" have entirely different histories.
5f1de4ec67
...
0f271ac2fb
85
api/api.go
85
api/api.go
@ -78,57 +78,47 @@ func (api *API) registerWebAppRoutes() {
|
|||||||
"NiceSeconds": niceSeconds,
|
"NiceSeconds": niceSeconds,
|
||||||
}
|
}
|
||||||
|
|
||||||
// Templates
|
|
||||||
render.AddFromFiles("error", "templates/error.html")
|
render.AddFromFiles("error", "templates/error.html")
|
||||||
render.AddFromFilesFuncs("activity", helperFuncs, "templates/base.html", "templates/activity.html")
|
|
||||||
render.AddFromFilesFuncs("document", helperFuncs, "templates/base.html", "templates/document.html")
|
|
||||||
render.AddFromFilesFuncs("documents", helperFuncs, "templates/base.html", "templates/documents.html")
|
|
||||||
render.AddFromFilesFuncs("home", helperFuncs, "templates/base.html", "templates/home.html")
|
|
||||||
render.AddFromFilesFuncs("login", helperFuncs, "templates/login.html")
|
render.AddFromFilesFuncs("login", helperFuncs, "templates/login.html")
|
||||||
|
render.AddFromFilesFuncs("home", helperFuncs, "templates/base.html", "templates/home.html")
|
||||||
render.AddFromFilesFuncs("search", helperFuncs, "templates/base.html", "templates/search.html")
|
render.AddFromFilesFuncs("search", helperFuncs, "templates/base.html", "templates/search.html")
|
||||||
render.AddFromFilesFuncs("settings", helperFuncs, "templates/base.html", "templates/settings.html")
|
render.AddFromFilesFuncs("settings", helperFuncs, "templates/base.html", "templates/settings.html")
|
||||||
|
render.AddFromFilesFuncs("activity", helperFuncs, "templates/base.html", "templates/activity.html")
|
||||||
|
render.AddFromFilesFuncs("documents", helperFuncs, "templates/base.html", "templates/documents.html")
|
||||||
|
render.AddFromFilesFuncs("document", helperFuncs, "templates/base.html", "templates/document.html")
|
||||||
|
|
||||||
api.Router.HTMLRender = render
|
api.Router.HTMLRender = render
|
||||||
|
|
||||||
// Static Assets (Required @ Root)
|
// Static Assets (Require @ Root)
|
||||||
api.Router.GET("/manifest.json", api.webManifest)
|
api.Router.GET("/manifest.json", api.webManifest)
|
||||||
api.Router.GET("/sw.js", api.serviceWorker)
|
api.Router.GET("/sw.js", api.serviceWorker)
|
||||||
|
|
||||||
// Local / Offline Static Pages (No Template, No Auth)
|
// Local / Offline Static Pages (No Template)
|
||||||
api.Router.GET("/local", api.localDocuments)
|
api.Router.GET("/local", api.localDocuments)
|
||||||
api.Router.GET("/reader", api.documentReader)
|
api.Router.GET("/reader", api.documentReader)
|
||||||
|
|
||||||
// Web App
|
// Template App
|
||||||
api.Router.GET("/", api.authWebAppMiddleware, api.createAppResourcesRoute("home"))
|
|
||||||
api.Router.GET("/activity", api.authWebAppMiddleware, api.createAppResourcesRoute("activity"))
|
|
||||||
api.Router.GET("/documents", api.authWebAppMiddleware, api.createAppResourcesRoute("documents"))
|
|
||||||
api.Router.GET("/documents/:document", api.authWebAppMiddleware, api.createAppResourcesRoute("document"))
|
|
||||||
api.Router.GET("/documents/:document/cover", api.authWebAppMiddleware, api.getDocumentCover)
|
|
||||||
api.Router.GET("/documents/:document/file", api.authWebAppMiddleware, api.downloadDocument)
|
|
||||||
api.Router.GET("/documents/:document/progress", api.authWebAppMiddleware, api.getDocumentProgress)
|
|
||||||
api.Router.GET("/login", api.createAppResourcesRoute("login"))
|
api.Router.GET("/login", api.createAppResourcesRoute("login"))
|
||||||
api.Router.GET("/logout", api.authWebAppMiddleware, api.authLogout)
|
|
||||||
api.Router.GET("/register", api.createAppResourcesRoute("login", gin.H{"Register": true}))
|
api.Router.GET("/register", api.createAppResourcesRoute("login", gin.H{"Register": true}))
|
||||||
api.Router.GET("/settings", api.authWebAppMiddleware, api.createAppResourcesRoute("settings"))
|
api.Router.GET("/logout", api.authWebAppMiddleware, api.authLogout)
|
||||||
api.Router.POST("/login", api.authFormLogin)
|
api.Router.POST("/login", api.authFormLogin)
|
||||||
api.Router.POST("/register", api.authFormRegister)
|
api.Router.POST("/register", api.authFormRegister)
|
||||||
|
|
||||||
// Demo Mode Enabled Configuration
|
api.Router.GET("/", api.authWebAppMiddleware, api.createAppResourcesRoute("home"))
|
||||||
if api.Config.DemoMode {
|
api.Router.GET("/settings", api.authWebAppMiddleware, api.createAppResourcesRoute("settings"))
|
||||||
api.Router.POST("/documents", api.authWebAppMiddleware, api.demoModeAppError)
|
api.Router.POST("/settings", api.authWebAppMiddleware, api.editSettings)
|
||||||
api.Router.POST("/documents/:document/delete", api.authWebAppMiddleware, api.demoModeAppError)
|
api.Router.GET("/activity", api.authWebAppMiddleware, api.createAppResourcesRoute("activity"))
|
||||||
api.Router.POST("/documents/:document/edit", api.authWebAppMiddleware, api.demoModeAppError)
|
api.Router.GET("/documents", api.authWebAppMiddleware, api.createAppResourcesRoute("documents"))
|
||||||
api.Router.POST("/documents/:document/identify", api.authWebAppMiddleware, api.demoModeAppError)
|
api.Router.POST("/documents", api.authWebAppMiddleware, api.uploadNewDocument)
|
||||||
api.Router.POST("/settings", api.authWebAppMiddleware, api.demoModeAppError)
|
api.Router.GET("/documents/:document", api.authWebAppMiddleware, api.createAppResourcesRoute("document"))
|
||||||
} else {
|
api.Router.GET("/documents/:document/file", api.authWebAppMiddleware, api.downloadDocument)
|
||||||
api.Router.POST("/documents", api.authWebAppMiddleware, api.uploadNewDocument)
|
api.Router.GET("/documents/:document/cover", api.authWebAppMiddleware, api.getDocumentCover)
|
||||||
api.Router.POST("/documents/:document/delete", api.authWebAppMiddleware, api.deleteDocument)
|
api.Router.POST("/documents/:document/edit", api.authWebAppMiddleware, api.editDocument)
|
||||||
api.Router.POST("/documents/:document/edit", api.authWebAppMiddleware, api.editDocument)
|
api.Router.POST("/documents/:document/identify", api.authWebAppMiddleware, api.identifyDocument)
|
||||||
api.Router.POST("/documents/:document/identify", api.authWebAppMiddleware, api.identifyDocument)
|
api.Router.POST("/documents/:document/delete", api.authWebAppMiddleware, api.deleteDocument)
|
||||||
api.Router.POST("/settings", api.authWebAppMiddleware, api.editSettings)
|
api.Router.GET("/documents/:document/progress", api.authWebAppMiddleware, api.getDocumentProgress)
|
||||||
}
|
|
||||||
|
|
||||||
// Search Enabled Configuration
|
// Behind Configuration Flag
|
||||||
if api.Config.SearchEnabled {
|
if api.Config.SearchEnabled {
|
||||||
api.Router.GET("/search", api.authWebAppMiddleware, api.createAppResourcesRoute("search"))
|
api.Router.GET("/search", api.authWebAppMiddleware, api.createAppResourcesRoute("search"))
|
||||||
api.Router.POST("/search", api.authWebAppMiddleware, api.saveNewDocument)
|
api.Router.POST("/search", api.authWebAppMiddleware, api.saveNewDocument)
|
||||||
@ -138,35 +128,28 @@ func (api *API) registerWebAppRoutes() {
|
|||||||
func (api *API) registerKOAPIRoutes(apiGroup *gin.RouterGroup) {
|
func (api *API) registerKOAPIRoutes(apiGroup *gin.RouterGroup) {
|
||||||
koGroup := apiGroup.Group("/ko")
|
koGroup := apiGroup.Group("/ko")
|
||||||
|
|
||||||
// KO Sync Routes (WebApp Uses - Progress & Activity)
|
koGroup.POST("/users/create", api.createUser)
|
||||||
koGroup.GET("/documents/:document/file", api.authKOMiddleware, api.downloadDocument)
|
|
||||||
koGroup.GET("/syncs/progress/:document", api.authKOMiddleware, api.getProgress)
|
|
||||||
koGroup.GET("/users/auth", api.authKOMiddleware, api.authorizeUser)
|
koGroup.GET("/users/auth", api.authKOMiddleware, api.authorizeUser)
|
||||||
|
|
||||||
|
koGroup.PUT("/syncs/progress", api.authKOMiddleware, api.setProgress)
|
||||||
|
koGroup.GET("/syncs/progress/:document", api.authKOMiddleware, api.getProgress)
|
||||||
|
|
||||||
|
koGroup.POST("/documents", api.authKOMiddleware, api.addDocuments)
|
||||||
|
koGroup.POST("/syncs/documents", api.authKOMiddleware, api.checkDocumentsSync)
|
||||||
|
koGroup.PUT("/documents/:document/file", api.authKOMiddleware, api.uploadExistingDocument)
|
||||||
|
koGroup.GET("/documents/:document/file", api.authKOMiddleware, api.downloadDocument)
|
||||||
|
|
||||||
koGroup.POST("/activity", api.authKOMiddleware, api.addActivities)
|
koGroup.POST("/activity", api.authKOMiddleware, api.addActivities)
|
||||||
koGroup.POST("/syncs/activity", api.authKOMiddleware, api.checkActivitySync)
|
koGroup.POST("/syncs/activity", api.authKOMiddleware, api.checkActivitySync)
|
||||||
koGroup.POST("/users/create", api.createUser)
|
|
||||||
koGroup.PUT("/syncs/progress", api.authKOMiddleware, api.setProgress)
|
|
||||||
|
|
||||||
// Demo Mode Enabled Configuration
|
|
||||||
if api.Config.DemoMode {
|
|
||||||
koGroup.POST("/documents", api.authKOMiddleware, api.demoModeJSONError)
|
|
||||||
koGroup.POST("/syncs/documents", api.authKOMiddleware, api.demoModeJSONError)
|
|
||||||
koGroup.PUT("/documents/:document/file", api.authKOMiddleware, api.demoModeJSONError)
|
|
||||||
} else {
|
|
||||||
koGroup.POST("/documents", api.authKOMiddleware, api.addDocuments)
|
|
||||||
koGroup.POST("/syncs/documents", api.authKOMiddleware, api.checkDocumentsSync)
|
|
||||||
koGroup.PUT("/documents/:document/file", api.authKOMiddleware, api.uploadExistingDocument)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (api *API) registerOPDSRoutes(apiGroup *gin.RouterGroup) {
|
func (api *API) registerOPDSRoutes(apiGroup *gin.RouterGroup) {
|
||||||
opdsGroup := apiGroup.Group("/opds")
|
opdsGroup := apiGroup.Group("/opds")
|
||||||
|
|
||||||
// OPDS Routes
|
|
||||||
opdsGroup.GET("/", api.authOPDSMiddleware, api.opdsDocuments)
|
opdsGroup.GET("/", api.authOPDSMiddleware, api.opdsDocuments)
|
||||||
opdsGroup.GET("/documents/:document/cover", api.authOPDSMiddleware, api.getDocumentCover)
|
|
||||||
opdsGroup.GET("/documents/:document/file", api.authOPDSMiddleware, api.downloadDocument)
|
|
||||||
opdsGroup.GET("/search.xml", api.authOPDSMiddleware, api.opdsSearchDescription)
|
opdsGroup.GET("/search.xml", api.authOPDSMiddleware, api.opdsSearchDescription)
|
||||||
|
opdsGroup.GET("/documents/:document/file", api.authOPDSMiddleware, api.downloadDocument)
|
||||||
|
opdsGroup.GET("/documents/:document/cover", api.authOPDSMiddleware, api.getDocumentCover)
|
||||||
}
|
}
|
||||||
|
|
||||||
func generateToken(n int) ([]byte, error) {
|
func generateToken(n int) ([]byte, error) {
|
||||||
|
@ -219,14 +219,6 @@ func (api *API) authLogout(c *gin.Context) {
|
|||||||
c.Redirect(http.StatusFound, "/login")
|
c.Redirect(http.StatusFound, "/login")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (api *API) demoModeAppError(c *gin.Context) {
|
|
||||||
errorPage(c, http.StatusUnauthorized, "Not Allowed in Demo Mode")
|
|
||||||
}
|
|
||||||
|
|
||||||
func (api *API) demoModeJSONError(c *gin.Context) {
|
|
||||||
c.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"error": "Not Allowed in Demo Mode"})
|
|
||||||
}
|
|
||||||
|
|
||||||
func getSession(session sessions.Session) (user string, ok bool) {
|
func getSession(session sessions.Session) (user string, ok bool) {
|
||||||
// Check Session
|
// Check Session
|
||||||
authorizedUser := session.Get("authorizedUser")
|
authorizedUser := session.Get("authorizedUser")
|
||||||
|
@ -724,24 +724,15 @@ class EBookReader {
|
|||||||
this.bookState.currentWord += pageWords;
|
this.bookState.currentWord += pageWords;
|
||||||
|
|
||||||
let pageWPM = pageWords / (elapsedTime / 60000);
|
let pageWPM = pageWords / (elapsedTime / 60000);
|
||||||
console.log("[createActivity] Page WPM:", pageWPM);
|
|
||||||
|
|
||||||
// Exclude Ridiculous WPM
|
// Exclude Ridiculous WPM
|
||||||
if (pageWPM >= WPM_MAX)
|
// if (pageWPM >= WPM_MAX) return;
|
||||||
return console.log(
|
|
||||||
"[createActivity] Page WPM Exceeds Max (2000):",
|
|
||||||
pageWPM
|
|
||||||
);
|
|
||||||
|
|
||||||
// Ensure WPM Minimum
|
// Ensure WPM Minimum
|
||||||
if (pageWPM < WPM_MIN) elapsedTime = (pageWords / WPM_MIN) * 60000;
|
if (pageWPM < WPM_MIN) elapsedTime = (pageWords / WPM_MIN) * 60000;
|
||||||
|
|
||||||
let totalPages = Math.round(1 / percentRead);
|
let totalPages = Math.round(1 / percentRead);
|
||||||
|
|
||||||
// Exclude 0 Pages
|
|
||||||
if (totalPages == 0)
|
|
||||||
return console.log("[createActivity] Invalid Total Pages (0)");
|
|
||||||
|
|
||||||
let currentPage = Math.round(
|
let currentPage = Math.round(
|
||||||
(startingWord * totalPages) / this.bookState.words
|
(startingWord * totalPages) / this.bookState.words
|
||||||
);
|
);
|
||||||
|
@ -21,7 +21,6 @@ type Config struct {
|
|||||||
// Miscellaneous Settings
|
// Miscellaneous Settings
|
||||||
RegistrationEnabled bool
|
RegistrationEnabled bool
|
||||||
SearchEnabled bool
|
SearchEnabled bool
|
||||||
DemoMode bool
|
|
||||||
|
|
||||||
// Cookie Settings
|
// Cookie Settings
|
||||||
CookieSessionKey string
|
CookieSessionKey string
|
||||||
@ -38,7 +37,6 @@ func Load() *Config {
|
|||||||
DataPath: getEnv("DATA_PATH", "/data"),
|
DataPath: getEnv("DATA_PATH", "/data"),
|
||||||
ListenPort: getEnv("LISTEN_PORT", "8585"),
|
ListenPort: getEnv("LISTEN_PORT", "8585"),
|
||||||
RegistrationEnabled: trimLowerString(getEnv("REGISTRATION_ENABLED", "false")) == "true",
|
RegistrationEnabled: trimLowerString(getEnv("REGISTRATION_ENABLED", "false")) == "true",
|
||||||
DemoMode: trimLowerString(getEnv("DEMO_MODE", "false")) == "true",
|
|
||||||
SearchEnabled: trimLowerString(getEnv("SEARCH_ENABLED", "false")) == "true",
|
SearchEnabled: trimLowerString(getEnv("SEARCH_ENABLED", "false")) == "true",
|
||||||
CookieSessionKey: trimLowerString(getEnv("COOKIE_SESSION_KEY", "")),
|
CookieSessionKey: trimLowerString(getEnv("COOKIE_SESSION_KEY", "")),
|
||||||
CookieSecure: trimLowerString(getEnv("COOKIE_SECURE", "true")) == "true",
|
CookieSecure: trimLowerString(getEnv("COOKIE_SECURE", "true")) == "true",
|
||||||
|
Loading…
Reference in New Issue
Block a user