mirror of
				https://github.com/bartvdbraak/hellob.art.git
				synced 2025-10-25 17:29:11 +00:00 
			
		
		
		
	refactor: restructure code and errorhandling
This commit is contained in:
		
							parent
							
								
									d063a4dc00
								
							
						
					
					
						commit
						c37a4efef3
					
				
					 1 changed files with 57 additions and 36 deletions
				
			
		|  | @ -4,19 +4,31 @@ import { html as toReactNode } from 'satori-html'; | ||||||
| import { OgImage } from '$lib/components/site'; | import { OgImage } from '$lib/components/site'; | ||||||
| import GeistRegular from '$lib/assets/og/Geist-Regular.woff'; | import GeistRegular from '$lib/assets/og/Geist-Regular.woff'; | ||||||
| import GeistBold from '$lib/assets/og/Geist-Bold.woff'; | import GeistBold from '$lib/assets/og/Geist-Bold.woff'; | ||||||
| import { readFileSync } from 'fs'; | import { readFile } from 'fs/promises'; | ||||||
|  | import path from 'path'; | ||||||
| 
 | 
 | ||||||
| const height = 630; | const height = 630; | ||||||
| const width = 1200; | const width = 1200; | ||||||
| 
 | 
 | ||||||
| const meImage = readFileSync(`${process.cwd()}/src/lib/assets/og/me.jpg`); | const getImageData = async () => { | ||||||
| const imageData = Buffer.from(meImage).toString('base64'); | 	try { | ||||||
|  | 		const imagePath = path.join(process.cwd(), 'src', 'lib', 'assets', 'og', 'me.jpg'); | ||||||
|  | 		const meImage = await readFile(imagePath); | ||||||
|  | 		return Buffer.from(meImage).toString('base64'); | ||||||
|  | 	} catch (error) { | ||||||
|  | 		console.error('Error reading image:', error); | ||||||
|  | 		throw error; | ||||||
|  | 	} | ||||||
|  | }; | ||||||
| 
 | 
 | ||||||
| /** @type {import('./$types').RequestHandler} */ | /** @type {import('./$types').RequestHandler} */ | ||||||
| export const GET = async ({ url }) => { | export const GET = async ({ url }) => { | ||||||
|  | 	try { | ||||||
| 		const title = url.searchParams.get('title') ?? undefined; | 		const title = url.searchParams.get('title') ?? undefined; | ||||||
| 		const subTitle = url.searchParams.get('subTitle') ?? undefined; | 		const subTitle = url.searchParams.get('subTitle') ?? undefined; | ||||||
| 
 | 
 | ||||||
|  | 		const imageData = await getImageData(); | ||||||
|  | 
 | ||||||
| 		// eslint-disable-next-line @typescript-eslint/no-explicit-any
 | 		// eslint-disable-next-line @typescript-eslint/no-explicit-any
 | ||||||
| 		const result = (OgImage as any).render({ title, subTitle, imageData }); | 		const result = (OgImage as any).render({ title, subTitle, imageData }); | ||||||
| 		const element = toReactNode(`${result.html}<style>${result.css.code}</style>`); | 		const element = toReactNode(`${result.html}<style>${result.css.code}</style>`); | ||||||
|  | @ -52,4 +64,13 @@ export const GET = async ({ url }) => { | ||||||
| 				'content-type': 'image/png' | 				'content-type': 'image/png' | ||||||
| 			} | 			} | ||||||
| 		}); | 		}); | ||||||
|  | 	} catch (error) { | ||||||
|  | 		console.error('Error generating image:', error); | ||||||
|  | 		return new Response('Internal Server Error', { | ||||||
|  | 			status: 500, | ||||||
|  | 			headers: { | ||||||
|  | 				'content-type': 'text/plain' | ||||||
|  | 			} | ||||||
|  | 		}); | ||||||
|  | 	} | ||||||
| }; | }; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue