Skip to content

Commit 88d47ab

Browse files
authored
プラグインの簡易的なログを表示する機能 (#13564)
* add plugin logging * change variable name * Update plugin.ts * Update CHANGELOG.md
1 parent 29f6ba6 commit 88d47ab

File tree

4 files changed

+37
-11
lines changed

4 files changed

+37
-11
lines changed

CHANGELOG.md

+2
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,8 @@
88
- Enhance: 広告がMisskeyと同一ドメインの場合はRouterで遷移するように
99
- Enhance: リアクション・いいねの総数を表示するように
1010
- Enhance: リアクション受け入れが「いいねのみ」の場合はリアクション絵文字一覧を表示しないように
11+
- Enhance: 設定>プラグインのページからプラグインの簡易的なログやエラーを見られるように
12+
- 実装の都合により、プラグインは1つエラーを起こした時に即時停止するようになりました
1113
- Fix: 一部のページ内リンクが正しく動作しない問題を修正
1214
- Fix: 周年の実績が閏年を考慮しない問題を修正
1315
- Fix: ローカルURLのプレビューポップアップが左上に表示される

locales/ja-JP.yml

+1
Original file line numberDiff line numberDiff line change
@@ -1772,6 +1772,7 @@ _plugin:
17721772
installWarn: "信頼できないプラグインはインストールしないでください。"
17731773
manage: "プラグインの管理"
17741774
viewSource: "ソースを表示"
1775+
viewLog: "ログを表示"
17751776

17761777
_preferencesBackups:
17771778
list: "作成したバックアップ"

packages/frontend/src/pages/settings/plugin.vue

+17-3
Original file line numberDiff line numberDiff line change
@@ -41,13 +41,26 @@ SPDX-License-Identifier: AGPL-3.0-only
4141
<MkButton inline danger @click="uninstall(plugin)"><i class="ti ti-trash"></i> {{ i18n.ts.uninstall }}</MkButton>
4242
</div>
4343

44+
<MkFolder>
45+
<template #icon><i class="ti ti-terminal-2"></i></template>
46+
<template #label>{{ i18n.ts._plugin.viewLog }}</template>
47+
48+
<div class="_gaps_s">
49+
<div class="_buttons">
50+
<MkButton inline @click="copy(pluginLogs.get(plugin.id)?.join('\n'))"><i class="ti ti-copy"></i> {{ i18n.ts.copy }}</MkButton>
51+
</div>
52+
53+
<MkCode :code="pluginLogs.get(plugin.id)?.join('\n') ?? ''"/>
54+
</div>
55+
</MkFolder>
56+
4457
<MkFolder>
4558
<template #icon><i class="ti ti-code"></i></template>
4659
<template #label>{{ i18n.ts._plugin.viewSource }}</template>
4760

4861
<div class="_gaps_s">
4962
<div class="_buttons">
50-
<MkButton inline @click="copy(plugin)"><i class="ti ti-copy"></i> {{ i18n.ts.copy }}</MkButton>
63+
<MkButton inline @click="copy(plugin.src)"><i class="ti ti-copy"></i> {{ i18n.ts.copy }}</MkButton>
5164
</div>
5265

5366
<MkCode :code="plugin.src ?? ''" lang="is"/>
@@ -74,6 +87,7 @@ import { ColdDeviceStorage } from '@/store.js';
7487
import { unisonReload } from '@/scripts/unison-reload.js';
7588
import { i18n } from '@/i18n.js';
7689
import { definePageMetadata } from '@/scripts/page-metadata.js';
90+
import { pluginLogs } from '@/plugin.js';
7791

7892
const plugins = ref(ColdDeviceStorage.get('plugins'));
7993

@@ -87,8 +101,8 @@ async function uninstall(plugin) {
87101
});
88102
}
89103

90-
function copy(plugin) {
91-
copyToClipboard(plugin.src ?? '');
104+
function copy(text) {
105+
copyToClipboard(text ?? '');
92106
os.success();
93107
}
94108

packages/frontend/src/plugin.ts

+17-8
Original file line numberDiff line numberDiff line change
@@ -3,13 +3,15 @@
33
* SPDX-License-Identifier: AGPL-3.0-only
44
*/
55

6+
import { ref } from 'vue';
67
import { Interpreter, Parser, utils, values } from '@syuilo/aiscript';
78
import { aiScriptReadline, createAiScriptEnv } from '@/scripts/aiscript/api.js';
89
import { inputText } from '@/os.js';
910
import { Plugin, noteActions, notePostInterruptors, noteViewInterruptors, postFormActions, userActions, pageViewInterruptors } from '@/store.js';
1011

1112
const parser = new Parser();
1213
const pluginContexts = new Map<string, Interpreter>();
14+
export const pluginLogs = ref(new Map<string, string[]>());
1315

1416
export async function install(plugin: Plugin): Promise<void> {
1517
// 後方互換性のため
@@ -22,21 +24,27 @@ export async function install(plugin: Plugin): Promise<void> {
2224
in: aiScriptReadline,
2325
out: (value): void => {
2426
console.log(value);
27+
pluginLogs.value.get(plugin.id).push(utils.reprValue(value));
2528
},
2629
log: (): void => {
2730
},
31+
err: (err): void => {
32+
pluginLogs.value.get(plugin.id).push(`${err}`);
33+
throw err; // install時のtry-catchに反応させる
34+
},
2835
});
2936

3037
initPlugin({ plugin, aiscript });
3138

32-
try {
33-
await aiscript.exec(parser.parse(plugin.src));
34-
} catch (err) {
35-
console.error('Plugin install failed:', plugin.name, 'v' + plugin.version);
36-
return;
37-
}
38-
39-
console.info('Plugin installed:', plugin.name, 'v' + plugin.version);
39+
aiscript.exec(parser.parse(plugin.src)).then(
40+
() => {
41+
console.info('Plugin installed:', plugin.name, 'v' + plugin.version);
42+
},
43+
(err) => {
44+
console.error('Plugin install failed:', plugin.name, 'v' + plugin.version);
45+
throw err;
46+
},
47+
);
4048
}
4149

4250
function createPluginEnv(opts: { plugin: Plugin; storageKey: string }): Record<string, values.Value> {
@@ -92,6 +100,7 @@ function createPluginEnv(opts: { plugin: Plugin; storageKey: string }): Record<s
92100

93101
function initPlugin({ plugin, aiscript }): void {
94102
pluginContexts.set(plugin.id, aiscript);
103+
pluginLogs.value.set(plugin.id, []);
95104
}
96105

97106
function registerPostFormAction({ pluginId, title, handler }): void {

0 commit comments

Comments
 (0)