Revert "chore: 開発モードでフロントエンドとバックエンドを独立して起動するようにする(再) (#12593)"
This reverts commit b0039f0946.
			
			
This commit is contained in:
		
							parent
							
								
									002e939003
								
							
						
					
					
						commit
						27f98ef549
					
				|  | @ -196,27 +196,6 @@ pnpm dev | |||
| ``` | ||||
| command. | ||||
| 
 | ||||
| - Server-side source files and automatically builds them if they are modified. Automatically start the server process(es). | ||||
| - Vite HMR (just the `vite` command) is available. The behavior may be different from production. | ||||
| - Service Worker is watched by esbuild. | ||||
| - The front end can be viewed by accessing `http://localhost:5173`. | ||||
| - The backend listens on the port configured with `port` in .config/default.yml. | ||||
| If you have not changed it from the default, it will be "http://localhost:3000". | ||||
| If "port" in .config/default.yml is set to something other than 3000, you need to change the proxy settings in packages/frontend/vite.config.local-dev.ts. | ||||
| 
 | ||||
| ### `MK_DEV_PREFER=backend pnpm dev` | ||||
| pnpm dev has another mode with `MK_DEV_PREFER=backend`. | ||||
| 
 | ||||
| ``` | ||||
| MK_DEV_PREFER=backend pnpm dev | ||||
| ``` | ||||
| 
 | ||||
| - This mode is closer to the production environment than the default mode. | ||||
| - Vite runs behind the backend (the backend will proxy Vite at /vite). | ||||
| - You can see Misskey by accessing `http://localhost:3000` (Replace `3000` with the port configured with `port` in .config/default.yml). | ||||
| - To change the port of Vite, specify with `VITE_PORT` environment variable. | ||||
| - HMR may not work in some environments such as Windows. | ||||
| 
 | ||||
| ## Testing | ||||
| You can run non-backend tests by executing following commands: | ||||
| ```sh | ||||
|  |  | |||
|  | @ -4,7 +4,6 @@ | |||
| 	"type": "module", | ||||
| 	"scripts": { | ||||
| 		"watch": "vite", | ||||
| 		"dev": "vite --config vite.config.local-dev.ts --debug hmr", | ||||
| 		"build": "vite build", | ||||
| 		"storybook-dev": "nodemon --verbose --watch src --ext \"mdx,ts,vue\" --ignore \"*.stories.ts\" --exec \"pnpm build-storybook-pre && pnpm exec storybook dev -p 6006 --ci\"", | ||||
| 		"build-storybook-pre": "(tsc -p .storybook || echo done.) && node .storybook/generate.js && node .storybook/preload-locale.js && node .storybook/preload-theme.js", | ||||
|  |  | |||
|  | @ -1,90 +0,0 @@ | |||
| /* | ||||
|  * SPDX-FileCopyrightText: syuilo and misskey-project | ||||
|  * SPDX-License-Identifier: AGPL-3.0-only | ||||
|  */ | ||||
| 
 | ||||
| await main(); | ||||
| 
 | ||||
| import('@/_boot_.js'); | ||||
| 
 | ||||
| /** | ||||
|  * backend/src/server/web/boot.jsで差し込まれている起動処理のうち、最低限必要なものを模倣するための処理 | ||||
|  */ | ||||
| async function main() { | ||||
| 	const forceError = localStorage.getItem('forceError'); | ||||
| 	if (forceError != null) { | ||||
| 		renderError('FORCED_ERROR', 'This error is forced by having forceError in local storage.'); | ||||
| 	} | ||||
| 
 | ||||
| 	//#region Detect language & fetch translations
 | ||||
| 
 | ||||
| 	// dev-modeの場合は常に取り直す
 | ||||
| 	const supportedLangs = _LANGS_.map(it => it[0]); | ||||
| 	let lang: string | null | undefined = localStorage.getItem('lang'); | ||||
| 	if (lang == null || !supportedLangs.includes(lang)) { | ||||
| 		if (supportedLangs.includes(navigator.language)) { | ||||
| 			lang = navigator.language; | ||||
| 		} else { | ||||
| 			lang = supportedLangs.find(x => x.split('-')[0] === navigator.language); | ||||
| 
 | ||||
| 			// Fallback
 | ||||
| 			if (lang == null) lang = 'en-US'; | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	// TODO:今のままだと言語ファイル変更後はpnpm devをリスタートする必要があるので、chokidarを使ったり等で対応できるようにする
 | ||||
| 	const locale = _LANGS_FULL_.find(it => it[0] === lang); | ||||
| 	localStorage.setItem('lang', lang); | ||||
| 	localStorage.setItem('locale', JSON.stringify(locale[1])); | ||||
| 	localStorage.setItem('localeVersion', _VERSION_); | ||||
| 	//#endregion
 | ||||
| 
 | ||||
| 	//#region Theme
 | ||||
| 	const theme = localStorage.getItem('theme'); | ||||
| 	if (theme) { | ||||
| 		for (const [k, v] of Object.entries(JSON.parse(theme))) { | ||||
| 			document.documentElement.style.setProperty(`--MI_THEME-${k}`, v.toString()); | ||||
| 
 | ||||
| 			// HTMLの theme-color 適用
 | ||||
| 			if (k === 'htmlThemeColor') { | ||||
| 				for (const tag of document.head.children) { | ||||
| 					if (tag.tagName === 'META' && tag.getAttribute('name') === 'theme-color') { | ||||
| 						tag.setAttribute('content', v); | ||||
| 						break; | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	const colorScheme = localStorage.getItem('colorScheme'); | ||||
| 	if (colorScheme) { | ||||
| 		document.documentElement.style.setProperty('color-scheme', colorScheme); | ||||
| 	} | ||||
| 	//#endregion
 | ||||
| 
 | ||||
| 	const fontSize = localStorage.getItem('fontSize'); | ||||
| 	if (fontSize) { | ||||
| 		document.documentElement.classList.add('f-' + fontSize); | ||||
| 	} | ||||
| 
 | ||||
| 	const useSystemFont = localStorage.getItem('useSystemFont'); | ||||
| 	if (useSystemFont) { | ||||
| 		document.documentElement.classList.add('useSystemFont'); | ||||
| 	} | ||||
| 
 | ||||
| 	const wallpaper = localStorage.getItem('wallpaper'); | ||||
| 	if (wallpaper) { | ||||
| 		document.documentElement.style.backgroundImage = `url(${wallpaper})`; | ||||
| 	} | ||||
| 
 | ||||
| 	const customCss = localStorage.getItem('customCss'); | ||||
| 	if (customCss && customCss.length > 0) { | ||||
| 		const style = document.createElement('style'); | ||||
| 		style.innerHTML = customCss; | ||||
| 		document.head.appendChild(style); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| function renderError(code: string, details?: string) { | ||||
| 	console.log(code, details); | ||||
| } | ||||
|  | @ -1,36 +0,0 @@ | |||
| <!-- | ||||
|   SPDX-FileCopyrightText: syuilo and misskey-project | ||||
|   SPDX-License-Identifier: AGPL-3.0-only | ||||
| --> | ||||
| 
 | ||||
| <!-- | ||||
|   開発モードのviteはこのファイルを起点にサーバーを起動します。 | ||||
|   このファイルに書かれた [t]js のリンクと (s)cssのリンクと、その依存関係にあるファイルはビルドされます | ||||
| --> | ||||
| 
 | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| <head> | ||||
| 	<meta charset="UTF-8" /> | ||||
| 	<title>[DEV] Loading...</title> | ||||
| 	<!-- https://developer.mozilla.org/en-US/docs/Web/HTTP/CSP --> | ||||
| 	<meta | ||||
| 		http-equiv="Content-Security-Policy" | ||||
| 		content="default-src 'self' https://newassets.hcaptcha.com/ https://challenges.cloudflare.com/ http://localhost:7493/; | ||||
| 			worker-src 'self'; | ||||
| 			script-src 'self' 'unsafe-eval' https://*.hcaptcha.com https://*.recaptcha.net https://*.gstatic.com https://challenges.cloudflare.com https://esm.sh; | ||||
| 			style-src 'self' 'unsafe-inline'; | ||||
| 			img-src 'self' data: blob: www.google.com xn--931a.moe localhost:3000 localhost:5173 127.0.0.1:5173 127.0.0.1:3000; | ||||
| 			media-src 'self' localhost:3000 localhost:5173 127.0.0.1:5173 127.0.0.1:3000; | ||||
| 			connect-src 'self' localhost:3000 localhost:5173 127.0.0.1:5173 127.0.0.1:3000 https://newassets.hcaptcha.com; | ||||
| 			frame-src *;" | ||||
| 	/> | ||||
| 	<meta property="og:site_name" content="[DEV BUILD] Misskey" /> | ||||
| 	<meta name="viewport" content="width=device-width, initial-scale=1"> | ||||
| </head> | ||||
| 
 | ||||
| <body> | ||||
| <div id="misskey_app"></div> | ||||
| <script type="module" src="./_dev_boot_.ts"></script> | ||||
| </body> | ||||
| </html> | ||||
|  | @ -53,6 +53,7 @@ function getInstanceIcon(instance: Misskey.entities.FederationInstance): string | |||
| 	if (!instance.iconUrl) { | ||||
| 		return ''; | ||||
| 	} | ||||
| 
 | ||||
| 	return getProxiedImageUrl(instance.iconUrl, 'preview'); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,101 +0,0 @@ | |||
| import dns from 'dns'; | ||||
| import { readFile } from 'node:fs/promises'; | ||||
| import type { IncomingMessage } from 'node:http'; | ||||
| import { defineConfig } from 'vite'; | ||||
| import type { UserConfig } from 'vite'; | ||||
| import * as yaml from 'js-yaml'; | ||||
| import locales from '../../locales/index.js'; | ||||
| import { getConfig } from './vite.config.js'; | ||||
| 
 | ||||
| dns.setDefaultResultOrder('ipv4first'); | ||||
| 
 | ||||
| const defaultConfig = getConfig(); | ||||
| 
 | ||||
| const { port } = yaml.load(await readFile('../../.config/default.yml', 'utf-8')); | ||||
| 
 | ||||
| const httpUrl = `http://localhost:${port}/`; | ||||
| const websocketUrl = `ws://localhost:${port}/`; | ||||
| const embedUrl = `http://localhost:5174/`; | ||||
| 
 | ||||
| // activitypubリクエストはProxyを通し、それ以外はViteの開発サーバーを返す
 | ||||
| function varyHandler(req: IncomingMessage) { | ||||
| 	if (req.headers.accept?.includes('application/activity+json')) { | ||||
| 		return null; | ||||
| 	} | ||||
| 	return '/index.html'; | ||||
| } | ||||
| 
 | ||||
| const devConfig: UserConfig = { | ||||
| 	// 基本の設定は vite.config.js から引き継ぐ
 | ||||
| 	...defaultConfig, | ||||
| 	root: 'src', | ||||
| 	publicDir: '../assets', | ||||
| 	base: './', | ||||
| 	server: { | ||||
| 		host: 'localhost', | ||||
| 		port: 5173, | ||||
| 		proxy: { | ||||
| 			'/api': { | ||||
| 				changeOrigin: true, | ||||
| 				target: httpUrl, | ||||
| 			}, | ||||
| 			'/assets': httpUrl, | ||||
| 			'/static-assets': httpUrl, | ||||
| 			'/client-assets': httpUrl, | ||||
| 			'/files': httpUrl, | ||||
| 			'/twemoji': httpUrl, | ||||
| 			'/fluent-emoji': httpUrl, | ||||
| 			'/sw.js': httpUrl, | ||||
| 			'/streaming': { | ||||
| 				target: websocketUrl, | ||||
| 				ws: true, | ||||
| 			}, | ||||
| 			'/favicon.ico': httpUrl, | ||||
| 			'/robots.txt': httpUrl, | ||||
| 			'/embed.js': httpUrl, | ||||
| 			'/embed': { | ||||
| 				target: embedUrl, | ||||
| 				ws: true, | ||||
| 			}, | ||||
| 			'/identicon': { | ||||
| 				target: httpUrl, | ||||
| 				rewrite(path) { | ||||
| 					return path.replace('@localhost:5173', ''); | ||||
| 				}, | ||||
| 			}, | ||||
| 			'/url': httpUrl, | ||||
| 			'/proxy': httpUrl, | ||||
| 			'/_info_card_': httpUrl, | ||||
| 			'/bios': httpUrl, | ||||
| 			'/cli': httpUrl, | ||||
| 			'/inbox': httpUrl, | ||||
| 			'/emoji/': httpUrl, | ||||
| 			'/notes': { | ||||
| 				target: httpUrl, | ||||
| 				bypass: varyHandler, | ||||
| 			}, | ||||
| 			'/users': { | ||||
| 				target: httpUrl, | ||||
| 				bypass: varyHandler, | ||||
| 			}, | ||||
| 			'/.well-known': { | ||||
| 				target: httpUrl, | ||||
| 			}, | ||||
| 		}, | ||||
| 	}, | ||||
| 	build: { | ||||
| 		...defaultConfig.build, | ||||
| 		rollupOptions: { | ||||
| 			...defaultConfig.build?.rollupOptions, | ||||
| 			input: 'index.html', | ||||
| 		}, | ||||
| 	}, | ||||
| 
 | ||||
| 	define: { | ||||
| 		...defaultConfig.define, | ||||
| 		_LANGS_FULL_: JSON.stringify(Object.entries(locales)), | ||||
| 	}, | ||||
| }; | ||||
| 
 | ||||
| export default defineConfig(({ command, mode }) => devConfig); | ||||
| 
 | ||||
		Loading…
	
		Reference in New Issue