keep cached avatar&banner when refresh fails to get new values (#13145)
* keep cached avatar&banner when refresh fails to get new values when the remote explicitly tells us a user image is gone, we remove our cached value, but if we fail to get the image, we keep whatever value we already have this should minimise the problem of avatars randomly disappearing * autogen bits * pnpm run build-misskey-js-with-types --------- Co-authored-by: tamaina <tamaina@hotmail.co.jp>
This commit is contained in:
		 Gianni Ceccarelli
					Gianni Ceccarelli
				
			
				
					committed by
					
						 GitHub
						GitHub
					
				
			
			
				
	
			
			
			 GitHub
						GitHub
					
				
			
						parent
						
							bafef1f8b4
						
					
				
				
					commit
					dabf1867fd
				
			| @@ -225,20 +225,37 @@ export class ApPersonService implements OnModuleInit { | ||||
| 		return null; | ||||
| 	} | ||||
|  | ||||
| 	private async resolveAvatarAndBanner(user: MiRemoteUser, icon: any, image: any): Promise<Pick<MiRemoteUser, 'avatarId' | 'bannerId' | 'avatarUrl' | 'bannerUrl' | 'avatarBlurhash' | 'bannerBlurhash'>> { | ||||
| 	private async resolveAvatarAndBanner(user: MiRemoteUser, icon: any, image: any): Promise<Partial<Pick<MiRemoteUser, 'avatarId' | 'bannerId' | 'avatarUrl' | 'bannerUrl' | 'avatarBlurhash' | 'bannerBlurhash'>>> { | ||||
| 		if (user == null) throw new Error('failed to create user: user is null'); | ||||
|  | ||||
| 		const [avatar, banner] = await Promise.all([icon, image].map(img => { | ||||
| 			if (img == null) return null; | ||||
| 			if (user == null) throw new Error('failed to create user: user is null'); | ||||
| 			// if we have an explicitly missing image, return an | ||||
| 			// explicitly-null set of values | ||||
| 			if ((img == null) || (typeof img === 'object' && img.url == null)) { | ||||
| 				return { id: null, url: null, blurhash: null }; | ||||
| 			} | ||||
|  | ||||
| 			return this.apImageService.resolveImage(user, img).catch(() => null); | ||||
| 		})); | ||||
|  | ||||
| 		/* | ||||
| 			we don't want to return nulls on errors! if the database fields | ||||
| 			are already null, nothing changes; if the database has old | ||||
| 			values, we should keep those. The exception is if the remote has | ||||
| 			actually removed the images: in that case, the block above | ||||
| 			returns the special {id:null}&c value, and we return those | ||||
| 		*/ | ||||
| 		return { | ||||
| 			avatarId: avatar?.id ?? null, | ||||
| 			bannerId: banner?.id ?? null, | ||||
| 			avatarUrl: avatar ? this.driveFileEntityService.getPublicUrl(avatar, 'avatar') : null, | ||||
| 			bannerUrl: banner ? this.driveFileEntityService.getPublicUrl(banner) : null, | ||||
| 			avatarBlurhash: avatar?.blurhash ?? null, | ||||
| 			bannerBlurhash: banner?.blurhash ?? null, | ||||
| 			...( avatar ? { | ||||
| 				avatarId: avatar.id, | ||||
| 				avatarUrl: avatar.url ? this.driveFileEntityService.getPublicUrl(avatar, 'avatar') : null, | ||||
| 				avatarBlurhash: avatar.blurhash, | ||||
| 			} : {}), | ||||
| 			...( banner ? { | ||||
| 				bannerId: banner.id, | ||||
| 				bannerUrl: banner.url ? this.driveFileEntityService.getPublicUrl(banner) : null, | ||||
| 				bannerBlurhash: banner.blurhash, | ||||
| 			} : {}), | ||||
| 		}; | ||||
| 	} | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user