1 package org
.asamk
.signal
.manager
.jobs
;
3 import org
.asamk
.signal
.manager
.JsonStickerPack
;
4 import org
.asamk
.signal
.manager
.helper
.Context
;
5 import org
.asamk
.signal
.manager
.storage
.stickers
.StickerPackId
;
6 import org
.asamk
.signal
.manager
.util
.IOUtils
;
7 import org
.slf4j
.Logger
;
8 import org
.slf4j
.LoggerFactory
;
9 import org
.whispersystems
.libsignal
.InvalidMessageException
;
10 import org
.whispersystems
.signalservice
.internal
.util
.Hex
;
12 import java
.io
.IOException
;
13 import java
.util
.HashSet
;
15 public class RetrieveStickerPackJob
implements Job
{
17 private final static Logger logger
= LoggerFactory
.getLogger(RetrieveStickerPackJob
.class);
19 private final StickerPackId packId
;
20 private final byte[] packKey
;
22 public RetrieveStickerPackJob(final StickerPackId packId
, final byte[] packKey
) {
24 this.packKey
= packKey
;
28 public void run(Context context
) {
29 if (context
.getStickerPackStore().existsStickerPack(packId
)) {
30 logger
.debug("Sticker pack {} already downloaded.", Hex
.toStringCondensed(packId
.serialize()));
33 logger
.debug("Retrieving sticker pack {}.", Hex
.toStringCondensed(packId
.serialize()));
35 final var manifest
= context
.getDependencies()
37 .retrieveStickerManifest(packId
.serialize(), packKey
);
39 final var stickerIds
= new HashSet
<Integer
>();
40 if (manifest
.getCover().isPresent()) {
41 stickerIds
.add(manifest
.getCover().get().getId());
43 for (var sticker
: manifest
.getStickers()) {
44 stickerIds
.add(sticker
.getId());
47 for (var id
: stickerIds
) {
48 final var inputStream
= context
.getDependencies()
50 .retrieveSticker(packId
.serialize(), packKey
, id
);
51 context
.getStickerPackStore().storeSticker(packId
, id
, o
-> IOUtils
.copyStream(inputStream
, o
));
54 final var jsonManifest
= new JsonStickerPack(manifest
.getTitle().orNull(),
55 manifest
.getAuthor().orNull(),
57 .transform(c
-> new JsonStickerPack
.JsonSticker(c
.getEmoji(),
58 String
.valueOf(c
.getId()),
61 manifest
.getStickers()
63 .map(c
-> new JsonStickerPack
.JsonSticker(c
.getEmoji(),
64 String
.valueOf(c
.getId()),
67 context
.getStickerPackStore().storeManifest(packId
, jsonManifest
);
68 } catch (IOException e
) {
69 logger
.warn("Failed to retrieve sticker pack {}: {}",
70 Hex
.toStringCondensed(packId
.serialize()),
72 } catch (InvalidMessageException e
) {
73 logger
.warn("Failed to retrieve sticker pack {}, invalid pack data: {}",
74 Hex
.toStringCondensed(packId
.serialize()),