プラグインの簡易的なログを表示する機能 (#13564)
* add plugin logging * change variable name * Update plugin.ts * Update CHANGELOG.md
This commit is contained in:
		
							parent
							
								
									29f6ba6310
								
							
						
					
					
						commit
						88d47ab024
					
				
					 4 changed files with 37 additions and 11 deletions
				
			
		| 
						 | 
					@ -8,6 +8,8 @@
 | 
				
			||||||
- Enhance: 広告がMisskeyと同一ドメインの場合はRouterで遷移するように
 | 
					- Enhance: 広告がMisskeyと同一ドメインの場合はRouterで遷移するように
 | 
				
			||||||
- Enhance: リアクション・いいねの総数を表示するように
 | 
					- Enhance: リアクション・いいねの総数を表示するように
 | 
				
			||||||
- Enhance: リアクション受け入れが「いいねのみ」の場合はリアクション絵文字一覧を表示しないように
 | 
					- Enhance: リアクション受け入れが「いいねのみ」の場合はリアクション絵文字一覧を表示しないように
 | 
				
			||||||
 | 
					- Enhance: 設定>プラグインのページからプラグインの簡易的なログやエラーを見られるように
 | 
				
			||||||
 | 
					  - 実装の都合により、プラグインは1つエラーを起こした時に即時停止するようになりました
 | 
				
			||||||
- Fix: 一部のページ内リンクが正しく動作しない問題を修正
 | 
					- Fix: 一部のページ内リンクが正しく動作しない問題を修正
 | 
				
			||||||
- Fix: 周年の実績が閏年を考慮しない問題を修正
 | 
					- Fix: 周年の実績が閏年を考慮しない問題を修正
 | 
				
			||||||
- Fix: ローカルURLのプレビューポップアップが左上に表示される
 | 
					- Fix: ローカルURLのプレビューポップアップが左上に表示される
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1772,6 +1772,7 @@ _plugin:
 | 
				
			||||||
  installWarn: "信頼できないプラグインはインストールしないでください。"
 | 
					  installWarn: "信頼できないプラグインはインストールしないでください。"
 | 
				
			||||||
  manage: "プラグインの管理"
 | 
					  manage: "プラグインの管理"
 | 
				
			||||||
  viewSource: "ソースを表示"
 | 
					  viewSource: "ソースを表示"
 | 
				
			||||||
 | 
					  viewLog: "ログを表示"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
_preferencesBackups:
 | 
					_preferencesBackups:
 | 
				
			||||||
  list: "作成したバックアップ"
 | 
					  list: "作成したバックアップ"
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -41,13 +41,26 @@ SPDX-License-Identifier: AGPL-3.0-only
 | 
				
			||||||
					<MkButton inline danger @click="uninstall(plugin)"><i class="ti ti-trash"></i> {{ i18n.ts.uninstall }}</MkButton>
 | 
										<MkButton inline danger @click="uninstall(plugin)"><i class="ti ti-trash"></i> {{ i18n.ts.uninstall }}</MkButton>
 | 
				
			||||||
				</div>
 | 
									</div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									<MkFolder>
 | 
				
			||||||
 | 
										<template #icon><i class="ti ti-terminal-2"></i></template>
 | 
				
			||||||
 | 
										<template #label>{{ i18n.ts._plugin.viewLog }}</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
										<div class="_gaps_s">
 | 
				
			||||||
 | 
											<div class="_buttons">
 | 
				
			||||||
 | 
												<MkButton inline @click="copy(pluginLogs.get(plugin.id)?.join('\n'))"><i class="ti ti-copy"></i> {{ i18n.ts.copy }}</MkButton>
 | 
				
			||||||
 | 
											</div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
											<MkCode :code="pluginLogs.get(plugin.id)?.join('\n') ?? ''"/>
 | 
				
			||||||
 | 
										</div>
 | 
				
			||||||
 | 
									</MkFolder>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				<MkFolder>
 | 
									<MkFolder>
 | 
				
			||||||
					<template #icon><i class="ti ti-code"></i></template>
 | 
										<template #icon><i class="ti ti-code"></i></template>
 | 
				
			||||||
					<template #label>{{ i18n.ts._plugin.viewSource }}</template>
 | 
										<template #label>{{ i18n.ts._plugin.viewSource }}</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
					<div class="_gaps_s">
 | 
										<div class="_gaps_s">
 | 
				
			||||||
						<div class="_buttons">
 | 
											<div class="_buttons">
 | 
				
			||||||
							<MkButton inline @click="copy(plugin)"><i class="ti ti-copy"></i> {{ i18n.ts.copy }}</MkButton>
 | 
												<MkButton inline @click="copy(plugin.src)"><i class="ti ti-copy"></i> {{ i18n.ts.copy }}</MkButton>
 | 
				
			||||||
						</div>
 | 
											</div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
						<MkCode :code="plugin.src ?? ''" lang="is"/>
 | 
											<MkCode :code="plugin.src ?? ''" lang="is"/>
 | 
				
			||||||
| 
						 | 
					@ -74,6 +87,7 @@ import { ColdDeviceStorage } from '@/store.js';
 | 
				
			||||||
import { unisonReload } from '@/scripts/unison-reload.js';
 | 
					import { unisonReload } from '@/scripts/unison-reload.js';
 | 
				
			||||||
import { i18n } from '@/i18n.js';
 | 
					import { i18n } from '@/i18n.js';
 | 
				
			||||||
import { definePageMetadata } from '@/scripts/page-metadata.js';
 | 
					import { definePageMetadata } from '@/scripts/page-metadata.js';
 | 
				
			||||||
 | 
					import { pluginLogs } from '@/plugin.js';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const plugins = ref(ColdDeviceStorage.get('plugins'));
 | 
					const plugins = ref(ColdDeviceStorage.get('plugins'));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -87,8 +101,8 @@ async function uninstall(plugin) {
 | 
				
			||||||
	});
 | 
						});
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function copy(plugin) {
 | 
					function copy(text) {
 | 
				
			||||||
	copyToClipboard(plugin.src ?? '');
 | 
						copyToClipboard(text ?? '');
 | 
				
			||||||
	os.success();
 | 
						os.success();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -3,6 +3,7 @@
 | 
				
			||||||
 * SPDX-License-Identifier: AGPL-3.0-only
 | 
					 * SPDX-License-Identifier: AGPL-3.0-only
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import { ref } from 'vue';
 | 
				
			||||||
import { Interpreter, Parser, utils, values } from '@syuilo/aiscript';
 | 
					import { Interpreter, Parser, utils, values } from '@syuilo/aiscript';
 | 
				
			||||||
import { aiScriptReadline, createAiScriptEnv } from '@/scripts/aiscript/api.js';
 | 
					import { aiScriptReadline, createAiScriptEnv } from '@/scripts/aiscript/api.js';
 | 
				
			||||||
import { inputText } from '@/os.js';
 | 
					import { inputText } from '@/os.js';
 | 
				
			||||||
| 
						 | 
					@ -10,6 +11,7 @@ import { Plugin, noteActions, notePostInterruptors, noteViewInterruptors, postFo
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const parser = new Parser();
 | 
					const parser = new Parser();
 | 
				
			||||||
const pluginContexts = new Map<string, Interpreter>();
 | 
					const pluginContexts = new Map<string, Interpreter>();
 | 
				
			||||||
 | 
					export const pluginLogs = ref(new Map<string, string[]>());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export async function install(plugin: Plugin): Promise<void> {
 | 
					export async function install(plugin: Plugin): Promise<void> {
 | 
				
			||||||
	// 後方互換性のため
 | 
						// 後方互換性のため
 | 
				
			||||||
| 
						 | 
					@ -22,21 +24,27 @@ export async function install(plugin: Plugin): Promise<void> {
 | 
				
			||||||
		in: aiScriptReadline,
 | 
							in: aiScriptReadline,
 | 
				
			||||||
		out: (value): void => {
 | 
							out: (value): void => {
 | 
				
			||||||
			console.log(value);
 | 
								console.log(value);
 | 
				
			||||||
 | 
								pluginLogs.value.get(plugin.id).push(utils.reprValue(value));
 | 
				
			||||||
		},
 | 
							},
 | 
				
			||||||
		log: (): void => {
 | 
							log: (): void => {
 | 
				
			||||||
		},
 | 
							},
 | 
				
			||||||
 | 
							err: (err): void => {
 | 
				
			||||||
 | 
								pluginLogs.value.get(plugin.id).push(`${err}`);
 | 
				
			||||||
 | 
								throw err; // install時のtry-catchに反応させる
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
	});
 | 
						});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	initPlugin({ plugin, aiscript });
 | 
						initPlugin({ plugin, aiscript });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	try {
 | 
						aiscript.exec(parser.parse(plugin.src)).then(
 | 
				
			||||||
		await aiscript.exec(parser.parse(plugin.src));
 | 
							() => {
 | 
				
			||||||
	} catch (err) {
 | 
								console.info('Plugin installed:', plugin.name, 'v' + plugin.version);
 | 
				
			||||||
		console.error('Plugin install failed:', plugin.name, 'v' + plugin.version);
 | 
							},
 | 
				
			||||||
		return;
 | 
							(err) => {
 | 
				
			||||||
	}
 | 
								console.error('Plugin install failed:', plugin.name, 'v' + plugin.version);
 | 
				
			||||||
 | 
								throw err;
 | 
				
			||||||
	console.info('Plugin installed:', plugin.name, 'v' + plugin.version);
 | 
							},
 | 
				
			||||||
 | 
						);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function createPluginEnv(opts: { plugin: Plugin; storageKey: string }): Record<string, values.Value> {
 | 
					function createPluginEnv(opts: { plugin: Plugin; storageKey: string }): Record<string, values.Value> {
 | 
				
			||||||
| 
						 | 
					@ -92,6 +100,7 @@ function createPluginEnv(opts: { plugin: Plugin; storageKey: string }): Record<s
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function initPlugin({ plugin, aiscript }): void {
 | 
					function initPlugin({ plugin, aiscript }): void {
 | 
				
			||||||
	pluginContexts.set(plugin.id, aiscript);
 | 
						pluginContexts.set(plugin.id, aiscript);
 | 
				
			||||||
 | 
						pluginLogs.value.set(plugin.id, []);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function registerPostFormAction({ pluginId, title, handler }): void {
 | 
					function registerPostFormAction({ pluginId, title, handler }): void {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue