mirror of
https://github.com/TheAnachronism/docspell.git
synced 2025-04-05 10:59:33 +00:00
Merge pull request #915 from eikek/generate-preview-admin
Replace generating preview images with an admin endpoint
This commit is contained in:
commit
8c9732c761
12
Changelog.md
12
Changelog.md
@ -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*
|
||||||
|
@ -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 =>
|
||||||
|
@ -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"
|
||||||
|
@ -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] = {
|
||||||
|
@ -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
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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)
|
||||||
|
@ -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
|
|
||||||
|
@ -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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user