enhance: OAuth2 (IndieAuth) でロゴが提供されている場合は表示するように (#15578)
* enhance: OAuthでロゴが提供されている場合は表示するように * Update Changelog * refactor * fix * fix test
This commit is contained in:
		| @@ -95,6 +95,7 @@ interface ClientInformation { | ||||
| 	id: string; | ||||
| 	redirectUris: string[]; | ||||
| 	name: string; | ||||
| 	logo: string | null; | ||||
| } | ||||
|  | ||||
| // https://indieauth.spec.indieweb.org/#client-information-discovery | ||||
| @@ -124,11 +125,19 @@ async function discoverClientInformation(logger: Logger, httpRequestService: Htt | ||||
| 		redirectUris.push(...[...fragment.querySelectorAll<HTMLLinkElement>('link[rel=redirect_uri][href]')].map(el => el.href)); | ||||
|  | ||||
| 		let name = id; | ||||
| 		let logo: string | null = null; | ||||
| 		if (text) { | ||||
| 			const microformats = mf2(text, { baseUrl: res.url }); | ||||
| 			const nameProperty = microformats.items.find(item => item.type?.includes('h-app') && item.properties.url.includes(id))?.properties.name[0]; | ||||
| 			if (typeof nameProperty === 'string') { | ||||
| 				name = nameProperty; | ||||
| 			const correspondingProperties = microformats.items.find(item => item.type?.includes('h-app') && item.properties.url.includes(id)); | ||||
| 			if (correspondingProperties) { | ||||
| 				const nameProperty = correspondingProperties.properties.name?.[0]; | ||||
| 				if (typeof nameProperty === 'string') { | ||||
| 					name = nameProperty; | ||||
| 				} | ||||
| 				const logoProperty = correspondingProperties.properties.logo?.[0]; | ||||
| 				if (typeof logoProperty === 'string') { | ||||
| 					logo = logoProperty; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| @@ -136,6 +145,7 @@ async function discoverClientInformation(logger: Logger, httpRequestService: Htt | ||||
| 			id, | ||||
| 			redirectUris: redirectUris.map(uri => new URL(uri, res.url).toString()), | ||||
| 			name: typeof name === 'string' ? name : id, | ||||
| 			logo, | ||||
| 		}; | ||||
| 	} catch (err) { | ||||
| 		console.error(err); | ||||
| @@ -379,6 +389,7 @@ export class OAuth2ProviderService { | ||||
| 			return await reply.view('oauth', { | ||||
| 				transactionId: oauth2.transactionID, | ||||
| 				clientName: oauth2.client.name, | ||||
| 				clientLogo: oauth2.client.logo, | ||||
| 				scope: oauth2.req.scope.join(' '), | ||||
| 			}); | ||||
| 		}); | ||||
|   | ||||
| @@ -6,4 +6,6 @@ block meta | ||||
| 	//- XXX: Remove navigation bar in auth page? | ||||
| 	meta(name='misskey:oauth:transaction-id' content=transactionId) | ||||
| 	meta(name='misskey:oauth:client-name' content=clientName) | ||||
| 	if clientLogo | ||||
| 		meta(name='misskey:oauth:client-logo' content=clientLogo) | ||||
| 	meta(name='misskey:oauth:scope' content=scope) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 かっこかり
					かっこかり