Merge pull request #915 from eikek/generate-preview-admin

Replace generating preview images with an admin endpoint
This commit is contained in:
mergify[bot] 2021-07-04 19:50:09 +00:00 committed by GitHub
commit 8c9732c761
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 85 additions and 60 deletions

View File

@ -1,5 +1,17 @@
# Changelog # Changelog
## v0.25.0
*Unreleased*
### Rest API Changes
- Removed `sec/collective/previews` endpoint, in favor for new
`admin/attachments/generatePreviews` endpoint which is now an admin
task to generate previews for all files. The now removed enpoint did
this only for one collective.
## v0.24.0 ## v0.24.0
*Jun 18, 2021* *Jun 18, 2021*

View File

@ -193,6 +193,14 @@ trait OItem[F[_]] {
account: AccountId, account: AccountId,
notifyJoex: Boolean notifyJoex: Boolean
): F[UpdateResult] ): F[UpdateResult]
/** Submits a task that (re)generates the preview images for all
* attachments.
*/
def generateAllPreviews(
storeMode: MakePreviewArgs.StoreMode,
notifyJoex: Boolean
): F[UpdateResult]
} }
object OItem { object OItem {
@ -699,6 +707,16 @@ object OItem {
_ <- if (notifyJoex) joex.notifyAllNodes else ().pure[F] _ <- if (notifyJoex) joex.notifyAllNodes else ().pure[F]
} yield UpdateResult.success } yield UpdateResult.success
def generateAllPreviews(
storeMode: MakePreviewArgs.StoreMode,
notifyJoex: Boolean
): F[UpdateResult] =
for {
job <- JobFactory.allPreviews[F](AllPreviewsArgs(None, storeMode), None)
_ <- queue.insertIfNew(job)
_ <- if (notifyJoex) joex.notifyAllNodes else ().pure[F]
} yield UpdateResult.success
private def onSuccessIgnoreError(update: F[Unit])(ar: UpdateResult): F[Unit] = private def onSuccessIgnoreError(update: F[Unit])(ar: UpdateResult): F[Unit] =
ar match { ar match {
case UpdateResult.Success => case UpdateResult.Success =>

View File

@ -1136,30 +1136,6 @@ paths:
schema: schema:
$ref: "#/components/schemas/BasicResult" $ref: "#/components/schemas/BasicResult"
/sec/collective/previews:
post:
operationId: "sec-collective-previews-start-generate"
tags: [ Collective ]
summary: Starts the generate previews task
description: |
Submits a task that re-generates preview images of all
attachments of the current collective. Each existing preview
image will be replaced.
This can be used after changing the `preview` settings.
If only preview images of selected attachments should be
regenerated, see the `/sec/attachment/{id}/preview` endpoint.
security:
- authTokenHeader: []
responses:
200:
description: Ok
content:
application/json:
schema:
$ref: "#/components/schemas/BasicResult"
/sec/user: /sec/user:
get: get:
operationId: "sec-user-get-all" operationId: "sec-user-get-all"
@ -1348,6 +1324,32 @@ paths:
schema: schema:
$ref: "#/components/schemas/ResetPasswordResult" $ref: "#/components/schemas/ResetPasswordResult"
/admin/attachments/generatePreviews:
post:
operationId: "admin-attachments-generate-previews"
tags: [Attachment, Admin]
summary: (Re)generate all preview images
description: |
Submits a task that re-generates preview images of all
attachments. Each existing preview image will be replaced.
This can be used after changing the `preview` settings.
If only preview images of selected attachments should be
regenerated, see the `/sec/attachment/{id}/preview` endpoint.
This is an admin route, you need to specify the secret from
the config file via a http header `Docspell-Admin-Secret`.
security:
- adminHeader: []
responses:
200:
description: Ok
content:
application/json:
schema:
$ref: "#/components/schemas/BasicResult"
/sec/source: /sec/source:
get: get:
operationId: "sec-source-get-all" operationId: "sec-source-get-all"

View File

@ -108,9 +108,10 @@ object RestServer {
def adminRoutes[F[_]: Async](cfg: Config, restApp: RestApp[F]): HttpRoutes[F] = def adminRoutes[F[_]: Async](cfg: Config, restApp: RestApp[F]): HttpRoutes[F] =
Router( Router(
"fts" -> FullTextIndexRoutes.admin(cfg, restApp.backend), "fts" -> FullTextIndexRoutes.admin(cfg, restApp.backend),
"user" -> UserRoutes.admin(restApp.backend), "user" -> UserRoutes.admin(restApp.backend),
"info" -> InfoRoutes.admin(cfg) "info" -> InfoRoutes.admin(cfg),
"attachments" -> AttachmentRoutes.admin(restApp.backend)
) )
def redirectTo[F[_]: Async](path: String): HttpRoutes[F] = { def redirectTo[F[_]: Async](path: String): HttpRoutes[F] = {

View File

@ -189,4 +189,19 @@ object AttachmentRoutes {
} yield resp } yield resp
} }
} }
def admin[F[_]: Async](backend: BackendApp[F]): HttpRoutes[F] = {
val dsl = Http4sDsl[F]
import dsl._
HttpRoutes.of { case POST -> Root / "generatePreviews" =>
for {
res <- backend.item.generateAllPreviews(MakePreviewArgs.StoreMode.Replace, true)
resp <- Ok(
Conversions.basicResult(res, "Generate all previews task submitted.")
)
} yield resp
}
}
} }

View File

@ -12,7 +12,7 @@ import cats.implicits._
import docspell.backend.BackendApp import docspell.backend.BackendApp
import docspell.backend.auth.AuthToken import docspell.backend.auth.AuthToken
import docspell.backend.ops.OCollective import docspell.backend.ops.OCollective
import docspell.common.{ListType, MakePreviewArgs} import docspell.common.ListType
import docspell.restapi.model._ import docspell.restapi.model._
import docspell.restserver.conv.Conversions import docspell.restserver.conv.Conversions
import docspell.restserver.http4s._ import docspell.restserver.http4s._
@ -101,18 +101,6 @@ object CollectiveRoutes {
resp <- Ok(BasicResult(true, "Task submitted")) resp <- Ok(BasicResult(true, "Task submitted"))
} yield resp } yield resp
case POST -> Root / "previews" =>
for {
res <- backend.collective.generatePreviews(
MakePreviewArgs.StoreMode.Replace,
user.account,
true
)
resp <- Ok(
Conversions.basicResult(res, "Generate all previews task submitted.")
)
} yield resp
case GET -> Root => case GET -> Root =>
for { for {
collDb <- backend.collective.find(user.account.collective) collDb <- backend.collective.find(user.account.collective)

View File

@ -11,23 +11,12 @@ JQ_CMD="jq"
BASE_URL="${1:-http://localhost:7880}" BASE_URL="${1:-http://localhost:7880}"
LOGIN_URL="$BASE_URL/api/v1/open/auth/login" TRIGGER_URL="$BASE_URL/api/v1/admin/attachments/generatePreviews"
TRIGGER_URL="$BASE_URL/api/v1/sec/collective/previews"
echo "Login to trigger regenerating preview images." echo "Login to trigger regenerating preview images."
echo "Using url: $BASE_URL" echo "Using url: $BASE_URL"
echo -n "Account: " echo -n "Admin Secret: "
read USER read -s ADMIN_SECRET
echo -n "Password: "
read -s PASS
echo echo
auth=$("$CURL_CMD" --fail -XPOST --silent --data-binary "{\"account\":\"$USER\", \"password\":\"$PASS\"}" "$LOGIN_URL") curl --fail -XPOST -H "Docspell-Admin-Secret: $ADMIN_SECRET" "$TRIGGER_URL"
if [ "$(echo $auth | $JQ_CMD .success)" == "true" ]; then
echo "Login successful"
auth_token=$(echo $auth | "$JQ_CMD" -r .token)
curl --fail -XPOST -H "X-Docspell-Auth: $auth_token" "$TRIGGER_URL"
else
echo "Login failed."
fi

View File

@ -20,18 +20,18 @@ It is a bash script that additionally needs
# Usage # Usage
``` ```
./regenerate-previews.sh [docspell-base-url] ./regenerate-previews.sh [docspell-base-url] [admin-secret]
``` ```
For example, if docspell is at `http://localhost:7880`: For example, if docspell is at `http://localhost:7880`:
``` ```
./convert-all-pdfs.sh http://localhost:7880 ./convert-all-pdfs.sh http://localhost:7880 test123
``` ```
The script asks for your account name and password. It then logs in The script asks for the admin secret if not given to the command. It
and triggers the said endpoint. After this you should see a few tasks then logs in and triggers the said endpoint. After this you should see
running. a few tasks running.
There will be one task per file to convert. All these tasks are There will be one task per file to convert. All these tasks are
submitted with a low priority. So files uploaded through the webapp or submitted with a low priority. So files uploaded through the webapp or