61 lines
1.8 KiB
TypeScript
61 lines
1.8 KiB
TypeScript
import uploadFromUrl from '../../../services/drive/upload-from-url';
|
|
import { IRemoteUser } from '../../../models/entities/user';
|
|
import Resolver from '../resolver';
|
|
import { fetchMeta } from '../../../misc/fetch-meta';
|
|
import { apLogger } from '../logger';
|
|
import { DriveFile } from '../../../models/entities/drive-file';
|
|
import { DriveFiles } from '../../../models';
|
|
import { ensure } from '../../../prelude/ensure';
|
|
|
|
const logger = apLogger;
|
|
|
|
/**
|
|
* Imageを作成します。
|
|
*/
|
|
export async function createImage(actor: IRemoteUser, value: any): Promise<DriveFile> {
|
|
// 投稿者が凍結されていたらスキップ
|
|
if (actor.isSuspended) {
|
|
throw new Error('actor has been suspended');
|
|
}
|
|
|
|
const image = await new Resolver().resolve(value) as any;
|
|
|
|
if (image.url == null) {
|
|
throw new Error('invalid image: url not privided');
|
|
}
|
|
|
|
logger.info(`Creating the Image: ${image.url}`);
|
|
|
|
const instance = await fetchMeta();
|
|
const cache = instance.cacheRemoteFiles;
|
|
|
|
let file = await uploadFromUrl(image.url, actor, null, image.url, image.sensitive, false, !cache);
|
|
|
|
if (file.isLink) {
|
|
// URLが異なっている場合、同じ画像が以前に異なるURLで登録されていたということなので、
|
|
// URLを更新する
|
|
if (file.url !== image.url) {
|
|
await DriveFiles.update({ id: file.id }, {
|
|
url: image.url,
|
|
uri: image.url
|
|
});
|
|
|
|
file = await DriveFiles.findOne(file.id).then(ensure);
|
|
}
|
|
}
|
|
|
|
return file;
|
|
}
|
|
|
|
/**
|
|
* Imageを解決します。
|
|
*
|
|
* Misskeyに対象のImageが登録されていればそれを返し、そうでなければ
|
|
* リモートサーバーからフェッチしてMisskeyに登録しそれを返します。
|
|
*/
|
|
export async function resolveImage(actor: IRemoteUser, value: any): Promise<DriveFile> {
|
|
// TODO
|
|
|
|
// リモートサーバーからフェッチしてきて登録
|
|
return await createImage(actor, value);
|
|
}
|