import { minBy } from 'lodash'
import { join } from 'path'
-import { processImage } from '@server/helpers/image-utils'
+import { getImageSize, processImage } from '@server/helpers/image-utils'
import { CONFIG } from '@server/initializers/config'
import { ACTOR_IMAGES_SIZE } from '@server/initializers/constants'
import { updateActorImages } from '@server/lib/activitypub/actors'
console.log('Generate avatar miniatures from existing avatars.')
await initDatabaseModels(true)
- JobQueue.Instance.init(true)
+ JobQueue.Instance.init()
const accounts: AccountModel[] = await AccountModel.findAll({
include: [
for (const account of accounts) {
try {
+ await fillAvatarSizeIfNeeded(account)
await generateSmallerAvatarIfNeeded(account)
} catch (err) {
console.error(`Cannot process account avatar ${account.name}`, err)
for (const videoChannel of account.VideoChannels) {
try {
+ await fillAvatarSizeIfNeeded(videoChannel)
await generateSmallerAvatarIfNeeded(videoChannel)
} catch (err) {
console.error(`Cannot process channel avatar ${videoChannel.name}`, err)
console.log('Generation finished!')
}
+async function fillAvatarSizeIfNeeded (accountOrChannel: MAccountDefault | MChannelDefault) {
+ const avatars = accountOrChannel.Actor.Avatars
+
+ for (const avatar of avatars) {
+ if (avatar.width && avatar.height) continue
+
+ console.log('Filling size of avatars of %s.', accountOrChannel.name)
+
+ const { width, height } = await getImageSize(join(CONFIG.STORAGE.ACTOR_IMAGES, avatar.filename))
+ avatar.width = width
+ avatar.height = height
+
+ await avatar.save()
+ }
+}
+
async function generateSmallerAvatarIfNeeded (accountOrChannel: MAccountDefault | MChannelDefault) {
const avatars = accountOrChannel.Actor.Avatars
if (avatars.length !== 1) {
const source = join(CONFIG.STORAGE.ACTOR_IMAGES, sourceFilename)
const destination = join(CONFIG.STORAGE.ACTOR_IMAGES, newImageName)
- await processImage(source, destination, imageSize, true)
+ await processImage({ path: source, destination, newSize: imageSize, keepOriginal: true })
const actorImageInfo = {
name: newImageName,