cmdbox 0.6.3.2__py3-none-any.whl → 0.6.4.1__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of cmdbox might be problematic. Click here for more details.
- cmdbox/app/app.py +22 -7
- cmdbox/app/common.py +9 -6
- cmdbox/app/commons/loghandler.py +101 -20
- cmdbox/app/commons/redis_client.py +1 -1
- cmdbox/app/edge.py +2 -4
- cmdbox/app/feature.py +1 -1
- cmdbox/app/features/cli/cmdbox_agent_mcp_client.py +175 -0
- cmdbox/app/features/cli/cmdbox_agent_mcp_proxy.py +96 -0
- cmdbox/app/features/cli/cmdbox_audit_createdb.py +224 -224
- cmdbox/app/features/cli/cmdbox_audit_delete.py +4 -4
- cmdbox/app/features/cli/cmdbox_audit_search.py +4 -4
- cmdbox/app/features/cli/cmdbox_audit_write.py +6 -8
- cmdbox/app/features/cli/cmdbox_client_file_copy.py +3 -3
- cmdbox/app/features/cli/cmdbox_client_file_download.py +3 -3
- cmdbox/app/features/cli/cmdbox_client_file_list.py +3 -3
- cmdbox/app/features/cli/cmdbox_client_file_mkdir.py +3 -3
- cmdbox/app/features/cli/cmdbox_client_file_move.py +3 -3
- cmdbox/app/features/cli/cmdbox_client_file_remove.py +3 -3
- cmdbox/app/features/cli/cmdbox_client_file_rmdir.py +3 -3
- cmdbox/app/features/cli/cmdbox_client_file_upload.py +3 -3
- cmdbox/app/features/cli/cmdbox_client_http.py +7 -6
- cmdbox/app/features/cli/cmdbox_client_server_info.py +4 -4
- cmdbox/app/features/cli/cmdbox_cmd_list.py +4 -4
- cmdbox/app/features/cli/cmdbox_cmd_load.py +5 -5
- cmdbox/app/features/cli/cmdbox_edge_config.py +1 -1
- cmdbox/app/features/cli/cmdbox_edge_start.py +3 -3
- cmdbox/app/features/cli/cmdbox_mcp_client.py +174 -174
- cmdbox/app/features/cli/cmdbox_mcp_proxy.py +96 -96
- cmdbox/app/features/cli/cmdbox_server_list.py +3 -3
- cmdbox/app/features/cli/cmdbox_server_start.py +103 -103
- cmdbox/app/features/cli/cmdbox_server_stop.py +6 -6
- cmdbox/app/features/cli/cmdbox_tts_install.py +317 -0
- cmdbox/app/features/cli/cmdbox_tts_say.py +179 -0
- cmdbox/app/features/cli/cmdbox_tts_start.py +329 -0
- cmdbox/app/features/cli/cmdbox_tts_stop.py +108 -0
- cmdbox/app/features/cli/cmdbox_web_apikey_add.py +91 -91
- cmdbox/app/features/cli/cmdbox_web_apikey_del.py +91 -91
- cmdbox/app/features/cli/cmdbox_web_gencert.py +7 -7
- cmdbox/app/features/cli/cmdbox_web_genpass.py +168 -168
- cmdbox/app/features/cli/cmdbox_web_group_add.py +94 -94
- cmdbox/app/features/cli/cmdbox_web_group_del.py +87 -87
- cmdbox/app/features/cli/cmdbox_web_group_edit.py +94 -94
- cmdbox/app/features/cli/cmdbox_web_group_list.py +87 -87
- cmdbox/app/features/cli/cmdbox_web_start.py +236 -235
- cmdbox/app/features/cli/cmdbox_web_stop.py +72 -72
- cmdbox/app/features/cli/cmdbox_web_user_add.py +104 -104
- cmdbox/app/features/cli/cmdbox_web_user_del.py +87 -87
- cmdbox/app/features/cli/cmdbox_web_user_edit.py +104 -104
- cmdbox/app/features/cli/cmdbox_web_user_list.py +87 -87
- cmdbox/app/features/web/cmdbox_web_agent.py +16 -4
- cmdbox/app/features/web/cmdbox_web_get_cmd_choices.py +10 -2
- cmdbox/app/features/web/cmdbox_web_save_cmd.py +1 -0
- cmdbox/app/features/web/cmdbox_web_versions_used.py +4 -0
- cmdbox/app/filer.py +9 -9
- cmdbox/app/mcp.py +19 -8
- cmdbox/app/options.py +52 -47
- cmdbox/app/server.py +224 -224
- cmdbox/app/web.py +39 -17
- cmdbox/extensions/features.yml +7 -1
- cmdbox/extensions/sample_project/sample/app/features/cli/sample_client_time.py +2 -2
- cmdbox/extensions/sample_project/sample/app/features/cli/sample_server_time.py +3 -3
- cmdbox/licenses/LICENSE_APScheduler_3_11_0_MIT_License.txt +19 -0
- cmdbox/licenses/LICENSE_SQLAlchemy_2_0_43_MIT.txt +19 -0
- cmdbox/licenses/LICENSE_Werkzeug_3_1_1_BSD_License.txt +28 -0
- cmdbox/licenses/LICENSE_absolufy-imports_0_3_1_MIT_License.txt +21 -0
- cmdbox/licenses/LICENSE_anyio_4_10_0_UNKNOWN.txt +20 -0
- cmdbox/licenses/{LICENSE_typer_0_16_0_MIT_License.txt → LICENSE_backoff_2_2_1_MIT_License.txt} +1 -1
- cmdbox/licenses/LICENSE_certifi_2025_8_3_Mozilla_Public_License_2_0-MPL_2_0.txt +20 -0
- cmdbox/licenses/LICENSE_charset-normalizer_3_4_3_MIT.txt +21 -0
- cmdbox/licenses/LICENSE_cryptography_45_0_6_Apache-2_0_OR_BSD-3-Clause.txt +3 -0
- cmdbox/licenses/LICENSE_cyclopts_3_22_5_Apache_Software_License.txt +201 -0
- cmdbox/licenses/LICENSE_fastapi-sso_0_18_0_MIT_License.txt +21 -0
- cmdbox/licenses/LICENSE_fastmcp_2_11_3_Apache_Software_License.txt +201 -0
- cmdbox/licenses/LICENSE_google-adk_1_9_0_Apache_Software_License.txt +202 -0
- cmdbox/licenses/LICENSE_google-genai_1_28_0_Apache_Software_License.txt +202 -0
- cmdbox/licenses/LICENSE_google-genai_1_29_0_Apache_Software_License.txt +202 -0
- cmdbox/licenses/LICENSE_greenlet_3_2_4_MIT_AND_Python-2_0.txt +30 -0
- cmdbox/licenses/LICENSE_isodate_0_7_2_BSD_License.txt +26 -0
- cmdbox/licenses/LICENSE_lazy-object-proxy_1_11_0_BSD_License.txt +20 -0
- cmdbox/licenses/LICENSE_litellm-enterprise_0_1_19_UNKNOWN.txt +37 -0
- cmdbox/licenses/LICENSE_litellm_1_75_5_post1_MIT_License.txt +26 -0
- cmdbox/licenses/LICENSE_markdown-it-py_4_0_0_MIT_License.txt +21 -0
- cmdbox/licenses/LICENSE_mcp_1_12_4_MIT_License.txt +21 -0
- cmdbox/licenses/LICENSE_multidict_6_6_4_Apache_License_2_0.txt +13 -0
- cmdbox/licenses/LICENSE_oauthlib_3_3_1_BSD-3-Clause.txt +27 -0
- cmdbox/licenses/LICENSE_openai_1_99_9_Apache_Software_License.txt +201 -0
- cmdbox/licenses/LICENSE_openapi-core_0_19_5_BSD_License.txt +29 -0
- cmdbox/licenses/LICENSE_openapi-schema-validator_0_6_3_BSD_License.txt +29 -0
- cmdbox/licenses/LICENSE_openapi-spec-validator_0_7_2_Apache_Software_License.txt +201 -0
- cmdbox/licenses/LICENSE_opentelemetry-api_1_36_0_UNKNOWN.txt +201 -0
- cmdbox/licenses/LICENSE_opentelemetry-sdk_1_36_0_UNKNOWN.txt +201 -0
- cmdbox/licenses/LICENSE_opentelemetry-semantic-conventions_0_57b0_UNKNOWN.txt +201 -0
- cmdbox/licenses/LICENSE_orjson_3_11_1_Apache_Software_License-MIT_License.txt +201 -0
- cmdbox/licenses/LICENSE_parse_1_20_2_MIT_License.txt +19 -0
- cmdbox/licenses/LICENSE_pathable_0_4_4_Apache_Software_License.txt +201 -0
- cmdbox/licenses/{LICENSE_pillow_11_2_1_UNKNOWN.txt → LICENSE_pillow_11_3_0_UNKNOWN.txt} +393 -3
- cmdbox/licenses/LICENSE_pyperclip_1_9_0_BSD_License.txt +27 -0
- cmdbox/licenses/LICENSE_redis_6_4_0_MIT_License.txt +21 -0
- cmdbox/licenses/LICENSE_rfc3339-validator_0_1_4_MIT_License.txt +22 -0
- cmdbox/licenses/LICENSE_rich-rst_1_3_1_MIT_License.txt +7 -0
- cmdbox/licenses/LICENSE_rpds-py_0_27_0_UNKNOWN.txt +19 -0
- cmdbox/licenses/{LICENSE_setuptools_65_5_0_MIT_License.txt → LICENSE_setuptools_80_9_0_UNKNOWN.txt} +0 -2
- cmdbox/licenses/LICENSE_sphinx-intl_2_3_2_UNKNOWN.txt +25 -0
- cmdbox/licenses/LICENSE_tenacity_9_1_2_Apache_Software_License.txt +202 -0
- cmdbox/licenses/LICENSE_tiktoken_0_11_0_MIT_License-Copyright-c-2022_OpenAI-Shantanu_Jain-Permission_is_hereby_granted-free_of_charge-to_any_per.txt +21 -0
- cmdbox/licenses/LICENSE_tokenizers_0_21_4_Apache_Software_License.txt +1 -0
- cmdbox/licenses/LICENSE_voicevox_core_0_16_0_MIT.txt +20 -0
- cmdbox/licenses/LICENSE_watchdog_6_0_0_Apache_Software_License.txt +16 -0
- cmdbox/licenses/{LICENSE_httptools_0_6_4_MIT_License.txt → LICENSE_wsproto_1_2_0_MIT_License.txt} +3 -3
- cmdbox/licenses/files.txt +69 -50
- cmdbox/logconf_cmdbox.yml +136 -0
- cmdbox/version.py +2 -2
- cmdbox/web/agent.html +16 -2
- cmdbox/web/assets/cmdbox/agent.js +226 -1
- cmdbox/web/assets/cmdbox/common.js +20 -25
- cmdbox/web/assets/cmdbox/svgicon.js +18 -0
- {cmdbox-0.6.3.2.dist-info → cmdbox-0.6.4.1.dist-info}/METADATA +29 -20
- {cmdbox-0.6.3.2.dist-info → cmdbox-0.6.4.1.dist-info}/RECORD +158 -118
- {cmdbox-0.6.3.2.dist-info → cmdbox-0.6.4.1.dist-info}/WHEEL +1 -1
- cmdbox/config.yml +0 -3
- cmdbox/licenses/LICENSE_shellingham_1_5_4_ISC_License-ISCL.txt +0 -13
- cmdbox/licenses/LICENSE_watchfiles_1_1_0_MIT_License.txt +0 -21
- cmdbox/logconf_audit.yml +0 -43
- cmdbox/logconf_client.yml +0 -43
- cmdbox/logconf_edge.yml +0 -43
- cmdbox/logconf_gui.yml +0 -43
- cmdbox/logconf_mcp.yml +0 -43
- cmdbox/logconf_server.yml +0 -43
- cmdbox/logconf_web.yml +0 -43
- /cmdbox/licenses/{LICENSE_Authlib_1_6_0_BSD_License.txt → LICENSE_Authlib_1_6_1_BSD_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_SQLAlchemy_2_0_41_MIT.txt → LICENSE_SQLAlchemy_2_0_42_MIT.txt} +0 -0
- /cmdbox/licenses/{LICENSE_aiohttp_3_12_13_Apache-2_0.txt → LICENSE_aiohttp_3_12_15_Apache-2_0_AND_MIT.txt} +0 -0
- /cmdbox/licenses/{LICENSE_aiosignal_1_3_2_Apache_Software_License.txt → LICENSE_aiosignal_1_4_0_Apache_Software_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_certifi_2025_6_15_Mozilla_Public_License_2_0-MPL_2_0.txt → LICENSE_certifi_2025_7_14_Mozilla_Public_License_2_0-MPL_2_0.txt} +0 -0
- /cmdbox/licenses/{LICENSE_cryptography_45_0_4_Apache-2_0_OR_BSD-3-Clause.txt → LICENSE_cryptography_45_0_5_Apache-2_0_OR_BSD-3-Clause.txt} +0 -0
- /cmdbox/licenses/{LICENSE_docstring_parser_0_16_MIT_License.txt → LICENSE_docstring_parser_0_17_0_MIT_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_fastapi_0_115_14_MIT_License.txt → LICENSE_fastapi_0_116_1_MIT_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_fastmcp_2_10_1_Apache_Software_License.txt → LICENSE_fastmcp_2_11_0_Apache_Software_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_fsspec_2025_5_1_BSD_License.txt → LICENSE_fsspec_2025_7_0_BSD_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_google-adk_1_5_0_Apache_Software_License.txt → LICENSE_google-adk_1_10_0_Apache_Software_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_google-api-python-client_2_174_0_Apache_Software_License.txt → LICENSE_google-api-python-client_2_177_0_Apache_Software_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_huggingface-hub_0_33_1_Apache_Software_License.txt → LICENSE_google-api-python-client_2_178_0_Apache_Software_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_google-cloud-aiplatform_1_100_0_Apache_2_0.txt → LICENSE_google-cloud-aiplatform_1_106_0_Apache_2_0.txt} +0 -0
- /cmdbox/licenses/{LICENSE_google-cloud-bigquery_3_34_0_Apache_Software_License.txt → LICENSE_google-cloud-aiplatform_1_108_0_Apache_2_0.txt} +0 -0
- /cmdbox/licenses/{LICENSE_google-genai_1_23_0_Apache_Software_License.txt → LICENSE_google-cloud-bigquery_3_35_1_Apache_Software_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_grpcio-status_1_73_1_Apache_Software_License.txt → LICENSE_grpcio-status_1_74_0_Apache_Software_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_grpcio_1_73_1_Apache_Software_License.txt → LICENSE_grpcio_1_74_0_Apache_Software_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_opentelemetry-api_1_34_1_Apache_Software_License.txt → LICENSE_huggingface-hub_0_34_3_Apache_Software_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_opentelemetry-sdk_1_34_1_Apache_Software_License.txt → LICENSE_huggingface-hub_0_34_4_Apache_Software_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_opentelemetry-semantic-conventions_0_55b1_Apache_Software_License.txt → LICENSE_jsonschema-path_0_3_4_Apache_Software_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_jsonschema_4_24_0_UNKNOWN.txt → LICENSE_jsonschema_4_25_0_UNKNOWN.txt} +0 -0
- /cmdbox/licenses/{LICENSE_litellm_1_73_6_MIT_License.txt → LICENSE_litellm_1_74_12_MIT_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_mcp_1_10_1_MIT_License.txt → LICENSE_mcp_1_12_3_MIT_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_multidict_6_6_2_Apache_License_2_0.txt → LICENSE_multidict_6_6_3_Apache_License_2_0.txt} +0 -0
- /cmdbox/licenses/{LICENSE_nh3_0_2_21_MIT.txt → LICENSE_nh3_0_3_0_MIT.txt} +0 -0
- /cmdbox/licenses/{LICENSE_numpy_2_3_1_BSD_License.txt → LICENSE_numpy_2_3_2_BSD_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_openai_1_93_0_Apache_Software_License.txt → LICENSE_openai_1_98_0_Apache_Software_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_tokenizers_0_21_2_Apache_Software_License.txt → LICENSE_pywin32_311_Python_Software_Foundation_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_regex_2024_11_6_Apache_Software_License.txt → LICENSE_regex_2025_7_34_UNKNOWN.txt} +0 -0
- /cmdbox/licenses/{LICENSE_rich_14_0_0_MIT_License.txt → LICENSE_rich_14_1_0_MIT_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_rpds-py_0_25_1_MIT.txt → LICENSE_rpds-py_0_26_0_MIT.txt} +0 -0
- /cmdbox/licenses/{LICENSE_sse-starlette_2_3_6_BSD_License.txt → LICENSE_sse-starlette_3_0_2_UNKNOWN.txt} +0 -0
- /cmdbox/licenses/{LICENSE_starlette_0_46_2_BSD_License.txt → LICENSE_starlette_0_47_2_BSD_License.txt} +0 -0
- /cmdbox/licenses/{LICENSE_typing_extensions_4_14_0_UNKNOWN.txt → LICENSE_typing_extensions_4_14_1_UNKNOWN.txt} +0 -0
- /cmdbox/licenses/{LICENSE_zope_event_5_1_Zope_Public_License.txt → LICENSE_zope_event_5_1_1_Zope_Public_License.txt} +0 -0
- {cmdbox-0.6.3.2.dist-info → cmdbox-0.6.4.1.dist-info}/entry_points.txt +0 -0
- {cmdbox-0.6.3.2.dist-info → cmdbox-0.6.4.1.dist-info/licenses}/LICENSE +0 -0
- {cmdbox-0.6.3.2.dist-info → cmdbox-0.6.4.1.dist-info}/top_level.txt +0 -0
|
@@ -1,104 +1,104 @@
|
|
|
1
|
-
from cmdbox.app import common, feature, web
|
|
2
|
-
from cmdbox.app.options import Options
|
|
3
|
-
from pathlib import Path
|
|
4
|
-
from typing import Dict, Any, Tuple, List, Union
|
|
5
|
-
import argparse
|
|
6
|
-
import logging
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
class WebUserEdit(feature.UnsupportEdgeFeature):
|
|
10
|
-
def get_mode(self) -> Union[str, List[str]]:
|
|
11
|
-
"""
|
|
12
|
-
この機能のモードを返します
|
|
13
|
-
|
|
14
|
-
Returns:
|
|
15
|
-
Union[str, List[str]]: モード
|
|
16
|
-
"""
|
|
17
|
-
return 'web'
|
|
18
|
-
|
|
19
|
-
def get_cmd(self):
|
|
20
|
-
"""
|
|
21
|
-
この機能のコマンドを返します
|
|
22
|
-
|
|
23
|
-
Returns:
|
|
24
|
-
str: コマンド
|
|
25
|
-
"""
|
|
26
|
-
return 'user_edit'
|
|
27
|
-
|
|
28
|
-
def get_option(self):
|
|
29
|
-
"""
|
|
30
|
-
この機能のオプションを返します
|
|
31
|
-
|
|
32
|
-
Returns:
|
|
33
|
-
Dict[str, Any]: オプション
|
|
34
|
-
"""
|
|
35
|
-
return dict(
|
|
36
|
-
use_redis=self.USE_REDIS_MEIGHT, nouse_webmode=False,
|
|
37
|
-
description_ja="Webモードのユーザーを編集します。",
|
|
38
|
-
description_en="Edit users in Web mode.",
|
|
39
|
-
choice=[
|
|
40
|
-
dict(opt="user_id", type=Options.T_INT, default=None, required=True, multi=False, hide=False, choice=None,
|
|
41
|
-
description_ja="ユーザーIDを指定します。",
|
|
42
|
-
description_en="Specify the user ID."),
|
|
43
|
-
dict(opt="user_name", type=Options.T_STR, default=None, required=True, multi=False, hide=False, choice=None,
|
|
44
|
-
description_ja="ユーザー名を指定します。他のユーザーと重複しないようにしてください。",
|
|
45
|
-
description_en="Specify a user name. Do not duplicate other users."),
|
|
46
|
-
dict(opt="user_pass", type=Options.T_STR, default=None, required=False, multi=False, hide=False, choice=None,
|
|
47
|
-
description_ja="ユーザーパスワードを指定します。",
|
|
48
|
-
description_en="Specify the user password."),
|
|
49
|
-
dict(opt="user_pass_hash", type=Options.T_STR, default='sha1', required=False, multi=False, hide=False, choice=['oauth2', 'saml', 'plain', 'md5', 'sha1', 'sha256'],
|
|
50
|
-
description_ja="ユーザーパスワードのハッシュアルゴリズムを指定します。",
|
|
51
|
-
description_en="Specifies the hash algorithm for user passwords."),
|
|
52
|
-
dict(opt="user_email", type=Options.T_STR, default=None, required=False, multi=False, hide=False, choice=None,
|
|
53
|
-
description_ja="ユーザーメールアドレスを指定します。 `user_pass_hash` が `oauth2` 又は `saml` の時は必須です。",
|
|
54
|
-
description_en="Specify the user email. Required when `user_pass_hash` is `oauth2` or `saml`."),
|
|
55
|
-
dict(opt="user_group", type=Options.T_STR, default=None, required=True, multi=True, hide=False, choice=None,
|
|
56
|
-
description_ja="ユーザーが所属するグループを指定します。",
|
|
57
|
-
description_en="Specifies the groups to which the user belongs."),
|
|
58
|
-
dict(opt="signin_file", type=Options.T_FILE, default=f".{self.ver.__appid__}/user_list.yml", required=True, multi=False, hide=False, choice=None, fileio="in",
|
|
59
|
-
description_ja="サインイン可能なユーザーとパスワードを記載したファイルを指定します。省略した時は認証を要求しません。",
|
|
60
|
-
description_en="Specify a file containing users and passwords with which they can signin. If omitted, no authentication is required."),
|
|
61
|
-
dict(opt="stdout_log", type=Options.T_BOOL, default=True, required=False, multi=False, hide=True, choice=[True, False],
|
|
62
|
-
description_ja="GUIモードでのみ使用可能です。コマンド実行時の標準出力をConsole logに出力します。",
|
|
63
|
-
description_en="Available only in GUI mode. Outputs standard output during command execution to Console log."),
|
|
64
|
-
dict(opt="capture_stdout", type=Options.T_BOOL, default=True, required=False, multi=False, hide=True, choice=[True, False],
|
|
65
|
-
description_ja="GUIモードでのみ使用可能です。コマンド実行時の標準出力をキャプチャーし、実行結果画面に表示します。",
|
|
66
|
-
description_en="Available only in GUI mode. Captures standard output during command execution and displays it on the execution result screen."),
|
|
67
|
-
dict(opt="capture_maxsize", type=Options.T_INT, default=self.DEFAULT_CAPTURE_MAXSIZE, required=False, multi=False, hide=True, choice=None,
|
|
68
|
-
description_ja="GUIモードでのみ使用可能です。コマンド実行時の標準出力の最大キャプチャーサイズを指定します。",
|
|
69
|
-
description_en="Available only in GUI mode. Specifies the maximum capture size of standard output when executing commands."),
|
|
70
|
-
]
|
|
71
|
-
)
|
|
72
|
-
|
|
73
|
-
def apprun(self, logger:logging.Logger, args:argparse.Namespace, tm:float, pf:List[Dict[str, float]]=[]) -> Tuple[int, Dict[str, Any], Any]:
|
|
74
|
-
"""
|
|
75
|
-
この機能の実行を行います
|
|
76
|
-
|
|
77
|
-
Args:
|
|
78
|
-
logger (logging.Logger): ロガー
|
|
79
|
-
args (argparse.Namespace): 引数
|
|
80
|
-
tm (float): 実行開始時間
|
|
81
|
-
pf (List[Dict[str, float]]): 呼出元のパフォーマンス情報
|
|
82
|
-
|
|
83
|
-
Returns:
|
|
84
|
-
Tuple[int, Dict[str, Any], Any]: 終了コード, 結果, オブジェクト
|
|
85
|
-
"""
|
|
86
|
-
if args.data is None:
|
|
87
|
-
msg = dict(warn=f"Please specify the --data option.")
|
|
88
|
-
common.print_format(msg, args.format, tm, args.output_json, args.output_json_append, pf=pf)
|
|
89
|
-
return
|
|
90
|
-
w = None
|
|
91
|
-
try:
|
|
92
|
-
w = web.Web(logger, self.default_data, appcls=self.appcls, ver=self.ver,
|
|
93
|
-
redis_host=self.default_host, redis_port=self.default_port, redis_password=self.default_pass, svname=self.default_svname,
|
|
94
|
-
signin_file=args.signin_file)
|
|
95
|
-
user = dict(uid=args.user_id, name=args.user_name, password=args.user_pass, hash=args.user_pass_hash,
|
|
96
|
-
email=args.user_email, groups=args.user_group)
|
|
97
|
-
w.user_edit(user)
|
|
98
|
-
msg = dict(success=f"User ID {args.user_id} has been edited.")
|
|
99
|
-
common.print_format(msg, args.format, tm, args.output_json, args.output_json_append, pf=pf)
|
|
100
|
-
return
|
|
101
|
-
except Exception as e:
|
|
102
|
-
msg = dict(warn=f"{e}")
|
|
103
|
-
common.print_format(msg, args.format, tm, args.output_json, args.output_json_append, pf=pf)
|
|
104
|
-
return
|
|
1
|
+
from cmdbox.app import common, feature, web
|
|
2
|
+
from cmdbox.app.options import Options
|
|
3
|
+
from pathlib import Path
|
|
4
|
+
from typing import Dict, Any, Tuple, List, Union
|
|
5
|
+
import argparse
|
|
6
|
+
import logging
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
class WebUserEdit(feature.UnsupportEdgeFeature):
|
|
10
|
+
def get_mode(self) -> Union[str, List[str]]:
|
|
11
|
+
"""
|
|
12
|
+
この機能のモードを返します
|
|
13
|
+
|
|
14
|
+
Returns:
|
|
15
|
+
Union[str, List[str]]: モード
|
|
16
|
+
"""
|
|
17
|
+
return 'web'
|
|
18
|
+
|
|
19
|
+
def get_cmd(self):
|
|
20
|
+
"""
|
|
21
|
+
この機能のコマンドを返します
|
|
22
|
+
|
|
23
|
+
Returns:
|
|
24
|
+
str: コマンド
|
|
25
|
+
"""
|
|
26
|
+
return 'user_edit'
|
|
27
|
+
|
|
28
|
+
def get_option(self):
|
|
29
|
+
"""
|
|
30
|
+
この機能のオプションを返します
|
|
31
|
+
|
|
32
|
+
Returns:
|
|
33
|
+
Dict[str, Any]: オプション
|
|
34
|
+
"""
|
|
35
|
+
return dict(
|
|
36
|
+
use_redis=self.USE_REDIS_MEIGHT, nouse_webmode=False, use_agent=False,
|
|
37
|
+
description_ja="Webモードのユーザーを編集します。",
|
|
38
|
+
description_en="Edit users in Web mode.",
|
|
39
|
+
choice=[
|
|
40
|
+
dict(opt="user_id", type=Options.T_INT, default=None, required=True, multi=False, hide=False, choice=None,
|
|
41
|
+
description_ja="ユーザーIDを指定します。",
|
|
42
|
+
description_en="Specify the user ID."),
|
|
43
|
+
dict(opt="user_name", type=Options.T_STR, default=None, required=True, multi=False, hide=False, choice=None,
|
|
44
|
+
description_ja="ユーザー名を指定します。他のユーザーと重複しないようにしてください。",
|
|
45
|
+
description_en="Specify a user name. Do not duplicate other users."),
|
|
46
|
+
dict(opt="user_pass", type=Options.T_STR, default=None, required=False, multi=False, hide=False, choice=None,
|
|
47
|
+
description_ja="ユーザーパスワードを指定します。",
|
|
48
|
+
description_en="Specify the user password."),
|
|
49
|
+
dict(opt="user_pass_hash", type=Options.T_STR, default='sha1', required=False, multi=False, hide=False, choice=['oauth2', 'saml', 'plain', 'md5', 'sha1', 'sha256'],
|
|
50
|
+
description_ja="ユーザーパスワードのハッシュアルゴリズムを指定します。",
|
|
51
|
+
description_en="Specifies the hash algorithm for user passwords."),
|
|
52
|
+
dict(opt="user_email", type=Options.T_STR, default=None, required=False, multi=False, hide=False, choice=None,
|
|
53
|
+
description_ja="ユーザーメールアドレスを指定します。 `user_pass_hash` が `oauth2` 又は `saml` の時は必須です。",
|
|
54
|
+
description_en="Specify the user email. Required when `user_pass_hash` is `oauth2` or `saml`."),
|
|
55
|
+
dict(opt="user_group", type=Options.T_STR, default=None, required=True, multi=True, hide=False, choice=None,
|
|
56
|
+
description_ja="ユーザーが所属するグループを指定します。",
|
|
57
|
+
description_en="Specifies the groups to which the user belongs."),
|
|
58
|
+
dict(opt="signin_file", type=Options.T_FILE, default=f".{self.ver.__appid__}/user_list.yml", required=True, multi=False, hide=False, choice=None, fileio="in",
|
|
59
|
+
description_ja="サインイン可能なユーザーとパスワードを記載したファイルを指定します。省略した時は認証を要求しません。",
|
|
60
|
+
description_en="Specify a file containing users and passwords with which they can signin. If omitted, no authentication is required."),
|
|
61
|
+
dict(opt="stdout_log", type=Options.T_BOOL, default=True, required=False, multi=False, hide=True, choice=[True, False],
|
|
62
|
+
description_ja="GUIモードでのみ使用可能です。コマンド実行時の標準出力をConsole logに出力します。",
|
|
63
|
+
description_en="Available only in GUI mode. Outputs standard output during command execution to Console log."),
|
|
64
|
+
dict(opt="capture_stdout", type=Options.T_BOOL, default=True, required=False, multi=False, hide=True, choice=[True, False],
|
|
65
|
+
description_ja="GUIモードでのみ使用可能です。コマンド実行時の標準出力をキャプチャーし、実行結果画面に表示します。",
|
|
66
|
+
description_en="Available only in GUI mode. Captures standard output during command execution and displays it on the execution result screen."),
|
|
67
|
+
dict(opt="capture_maxsize", type=Options.T_INT, default=self.DEFAULT_CAPTURE_MAXSIZE, required=False, multi=False, hide=True, choice=None,
|
|
68
|
+
description_ja="GUIモードでのみ使用可能です。コマンド実行時の標準出力の最大キャプチャーサイズを指定します。",
|
|
69
|
+
description_en="Available only in GUI mode. Specifies the maximum capture size of standard output when executing commands."),
|
|
70
|
+
]
|
|
71
|
+
)
|
|
72
|
+
|
|
73
|
+
def apprun(self, logger:logging.Logger, args:argparse.Namespace, tm:float, pf:List[Dict[str, float]]=[]) -> Tuple[int, Dict[str, Any], Any]:
|
|
74
|
+
"""
|
|
75
|
+
この機能の実行を行います
|
|
76
|
+
|
|
77
|
+
Args:
|
|
78
|
+
logger (logging.Logger): ロガー
|
|
79
|
+
args (argparse.Namespace): 引数
|
|
80
|
+
tm (float): 実行開始時間
|
|
81
|
+
pf (List[Dict[str, float]]): 呼出元のパフォーマンス情報
|
|
82
|
+
|
|
83
|
+
Returns:
|
|
84
|
+
Tuple[int, Dict[str, Any], Any]: 終了コード, 結果, オブジェクト
|
|
85
|
+
"""
|
|
86
|
+
if args.data is None:
|
|
87
|
+
msg = dict(warn=f"Please specify the --data option.")
|
|
88
|
+
common.print_format(msg, args.format, tm, args.output_json, args.output_json_append, pf=pf)
|
|
89
|
+
return self.RESP_WARN, msg, None
|
|
90
|
+
w = None
|
|
91
|
+
try:
|
|
92
|
+
w = web.Web(logger, self.default_data, appcls=self.appcls, ver=self.ver,
|
|
93
|
+
redis_host=self.default_host, redis_port=self.default_port, redis_password=self.default_pass, svname=self.default_svname,
|
|
94
|
+
signin_file=args.signin_file)
|
|
95
|
+
user = dict(uid=args.user_id, name=args.user_name, password=args.user_pass, hash=args.user_pass_hash,
|
|
96
|
+
email=args.user_email, groups=args.user_group)
|
|
97
|
+
w.user_edit(user)
|
|
98
|
+
msg = dict(success=f"User ID {args.user_id} has been edited.")
|
|
99
|
+
common.print_format(msg, args.format, tm, args.output_json, args.output_json_append, pf=pf)
|
|
100
|
+
return self.RESP_SUCCESS, msg, w
|
|
101
|
+
except Exception as e:
|
|
102
|
+
msg = dict(warn=f"{e}")
|
|
103
|
+
common.print_format(msg, args.format, tm, args.output_json, args.output_json_append, pf=pf)
|
|
104
|
+
return self.RESP_WARN, msg, w
|
|
@@ -1,87 +1,87 @@
|
|
|
1
|
-
from cmdbox.app import common, feature, web
|
|
2
|
-
from cmdbox.app.options import Options
|
|
3
|
-
from pathlib import Path
|
|
4
|
-
from typing import Dict, Any, Tuple, List, Union
|
|
5
|
-
import argparse
|
|
6
|
-
import logging
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
class WebUserList(feature.
|
|
10
|
-
def get_mode(self) -> Union[str, List[str]]:
|
|
11
|
-
"""
|
|
12
|
-
この機能のモードを返します
|
|
13
|
-
|
|
14
|
-
Returns:
|
|
15
|
-
Union[str, List[str]]: モード
|
|
16
|
-
"""
|
|
17
|
-
return 'web'
|
|
18
|
-
|
|
19
|
-
def get_cmd(self):
|
|
20
|
-
"""
|
|
21
|
-
この機能のコマンドを返します
|
|
22
|
-
|
|
23
|
-
Returns:
|
|
24
|
-
str: コマンド
|
|
25
|
-
"""
|
|
26
|
-
return 'user_list'
|
|
27
|
-
|
|
28
|
-
def get_option(self):
|
|
29
|
-
"""
|
|
30
|
-
この機能のオプションを返します
|
|
31
|
-
|
|
32
|
-
Returns:
|
|
33
|
-
Dict[str, Any]: オプション
|
|
34
|
-
"""
|
|
35
|
-
return dict(
|
|
36
|
-
use_redis=self.USE_REDIS_MEIGHT, nouse_webmode=False,
|
|
37
|
-
description_ja="Webモードのユーザー一覧を取得します。",
|
|
38
|
-
description_en="Get a list of users in Web mode.",
|
|
39
|
-
choice=[
|
|
40
|
-
dict(opt="user_name", type=Options.T_STR, default=None, required=False, multi=False, hide=False, choice=None,
|
|
41
|
-
description_ja="ユーザー名を指定して取得します。省略した時は全てのユーザーを取得します。",
|
|
42
|
-
description_en="Retrieved by specifying a user name. If omitted, all users are retrieved."),
|
|
43
|
-
dict(opt="signin_file", type=Options.T_FILE, default=f".{self.ver.__appid__}/user_list.yml", required=True, multi=False, hide=False, choice=None, fileio="in",
|
|
44
|
-
description_ja="サインイン可能なユーザーとパスワードを記載したファイルを指定します。省略した時は認証を要求しません。",
|
|
45
|
-
description_en="Specify a file containing users and passwords with which they can signin. If omitted, no authentication is required."),
|
|
46
|
-
dict(opt="stdout_log", type=Options.T_BOOL, default=True, required=False, multi=False, hide=True, choice=[True, False],
|
|
47
|
-
description_ja="GUIモードでのみ使用可能です。コマンド実行時の標準出力をConsole logに出力します。",
|
|
48
|
-
description_en="Available only in GUI mode. Outputs standard output during command execution to Console log."),
|
|
49
|
-
dict(opt="capture_stdout", type=Options.T_BOOL, default=True, required=False, multi=False, hide=True, choice=[True, False],
|
|
50
|
-
description_ja="GUIモードでのみ使用可能です。コマンド実行時の標準出力をキャプチャーし、実行結果画面に表示します。",
|
|
51
|
-
description_en="Available only in GUI mode. Captures standard output during command execution and displays it on the execution result screen."),
|
|
52
|
-
dict(opt="capture_maxsize", type=Options.T_INT, default=self.DEFAULT_CAPTURE_MAXSIZE, required=False, multi=False, hide=True, choice=None,
|
|
53
|
-
description_ja="GUIモードでのみ使用可能です。コマンド実行時の標準出力の最大キャプチャーサイズを指定します。",
|
|
54
|
-
description_en="Available only in GUI mode. Specifies the maximum capture size of standard output when executing commands."),
|
|
55
|
-
]
|
|
56
|
-
)
|
|
57
|
-
|
|
58
|
-
def apprun(self, logger:logging.Logger, args:argparse.Namespace, tm:float, pf:List[Dict[str, float]]=[]) -> Tuple[int, Dict[str, Any], Any]:
|
|
59
|
-
"""
|
|
60
|
-
この機能の実行を行います
|
|
61
|
-
|
|
62
|
-
Args:
|
|
63
|
-
logger (logging.Logger): ロガー
|
|
64
|
-
args (argparse.Namespace): 引数
|
|
65
|
-
tm (float): 実行開始時間
|
|
66
|
-
pf (List[Dict[str, float]]): 呼出元のパフォーマンス情報
|
|
67
|
-
|
|
68
|
-
Returns:
|
|
69
|
-
Tuple[int, Dict[str, Any], Any]: 終了コード, 結果, オブジェクト
|
|
70
|
-
"""
|
|
71
|
-
if args.data is None:
|
|
72
|
-
msg = dict(warn=f"Please specify the --data option.")
|
|
73
|
-
common.print_format(msg, args.format, tm, args.output_json, args.output_json_append, pf=pf)
|
|
74
|
-
return
|
|
75
|
-
w = None
|
|
76
|
-
try:
|
|
77
|
-
w = web.Web(logger, self.default_data, appcls=self.appcls, ver=self.ver,
|
|
78
|
-
redis_host=self.default_host, redis_port=self.default_port, redis_password=self.default_pass, svname=self.default_svname,
|
|
79
|
-
signin_file=args.signin_file)
|
|
80
|
-
users = w.user_list(args.user_name)
|
|
81
|
-
msg = dict(success=users)
|
|
82
|
-
common.print_format(msg, args.format, tm, args.output_json, args.output_json_append, pf=pf)
|
|
83
|
-
return
|
|
84
|
-
except Exception as e:
|
|
85
|
-
msg = dict(warn=f"{e}")
|
|
86
|
-
common.print_format(msg, args.format, tm, args.output_json, args.output_json_append, pf=pf)
|
|
87
|
-
return
|
|
1
|
+
from cmdbox.app import common, feature, web
|
|
2
|
+
from cmdbox.app.options import Options
|
|
3
|
+
from pathlib import Path
|
|
4
|
+
from typing import Dict, Any, Tuple, List, Union
|
|
5
|
+
import argparse
|
|
6
|
+
import logging
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
class WebUserList(feature.UnsupportEdgeFeature):
|
|
10
|
+
def get_mode(self) -> Union[str, List[str]]:
|
|
11
|
+
"""
|
|
12
|
+
この機能のモードを返します
|
|
13
|
+
|
|
14
|
+
Returns:
|
|
15
|
+
Union[str, List[str]]: モード
|
|
16
|
+
"""
|
|
17
|
+
return 'web'
|
|
18
|
+
|
|
19
|
+
def get_cmd(self):
|
|
20
|
+
"""
|
|
21
|
+
この機能のコマンドを返します
|
|
22
|
+
|
|
23
|
+
Returns:
|
|
24
|
+
str: コマンド
|
|
25
|
+
"""
|
|
26
|
+
return 'user_list'
|
|
27
|
+
|
|
28
|
+
def get_option(self):
|
|
29
|
+
"""
|
|
30
|
+
この機能のオプションを返します
|
|
31
|
+
|
|
32
|
+
Returns:
|
|
33
|
+
Dict[str, Any]: オプション
|
|
34
|
+
"""
|
|
35
|
+
return dict(
|
|
36
|
+
use_redis=self.USE_REDIS_MEIGHT, nouse_webmode=False, use_agent=False,
|
|
37
|
+
description_ja="Webモードのユーザー一覧を取得します。",
|
|
38
|
+
description_en="Get a list of users in Web mode.",
|
|
39
|
+
choice=[
|
|
40
|
+
dict(opt="user_name", type=Options.T_STR, default=None, required=False, multi=False, hide=False, choice=None,
|
|
41
|
+
description_ja="ユーザー名を指定して取得します。省略した時は全てのユーザーを取得します。",
|
|
42
|
+
description_en="Retrieved by specifying a user name. If omitted, all users are retrieved."),
|
|
43
|
+
dict(opt="signin_file", type=Options.T_FILE, default=f".{self.ver.__appid__}/user_list.yml", required=True, multi=False, hide=False, choice=None, fileio="in",
|
|
44
|
+
description_ja="サインイン可能なユーザーとパスワードを記載したファイルを指定します。省略した時は認証を要求しません。",
|
|
45
|
+
description_en="Specify a file containing users and passwords with which they can signin. If omitted, no authentication is required."),
|
|
46
|
+
dict(opt="stdout_log", type=Options.T_BOOL, default=True, required=False, multi=False, hide=True, choice=[True, False],
|
|
47
|
+
description_ja="GUIモードでのみ使用可能です。コマンド実行時の標準出力をConsole logに出力します。",
|
|
48
|
+
description_en="Available only in GUI mode. Outputs standard output during command execution to Console log."),
|
|
49
|
+
dict(opt="capture_stdout", type=Options.T_BOOL, default=True, required=False, multi=False, hide=True, choice=[True, False],
|
|
50
|
+
description_ja="GUIモードでのみ使用可能です。コマンド実行時の標準出力をキャプチャーし、実行結果画面に表示します。",
|
|
51
|
+
description_en="Available only in GUI mode. Captures standard output during command execution and displays it on the execution result screen."),
|
|
52
|
+
dict(opt="capture_maxsize", type=Options.T_INT, default=self.DEFAULT_CAPTURE_MAXSIZE, required=False, multi=False, hide=True, choice=None,
|
|
53
|
+
description_ja="GUIモードでのみ使用可能です。コマンド実行時の標準出力の最大キャプチャーサイズを指定します。",
|
|
54
|
+
description_en="Available only in GUI mode. Specifies the maximum capture size of standard output when executing commands."),
|
|
55
|
+
]
|
|
56
|
+
)
|
|
57
|
+
|
|
58
|
+
def apprun(self, logger:logging.Logger, args:argparse.Namespace, tm:float, pf:List[Dict[str, float]]=[]) -> Tuple[int, Dict[str, Any], Any]:
|
|
59
|
+
"""
|
|
60
|
+
この機能の実行を行います
|
|
61
|
+
|
|
62
|
+
Args:
|
|
63
|
+
logger (logging.Logger): ロガー
|
|
64
|
+
args (argparse.Namespace): 引数
|
|
65
|
+
tm (float): 実行開始時間
|
|
66
|
+
pf (List[Dict[str, float]]): 呼出元のパフォーマンス情報
|
|
67
|
+
|
|
68
|
+
Returns:
|
|
69
|
+
Tuple[int, Dict[str, Any], Any]: 終了コード, 結果, オブジェクト
|
|
70
|
+
"""
|
|
71
|
+
if args.data is None:
|
|
72
|
+
msg = dict(warn=f"Please specify the --data option.")
|
|
73
|
+
common.print_format(msg, args.format, tm, args.output_json, args.output_json_append, pf=pf)
|
|
74
|
+
return self.RESP_WARN, msg, None
|
|
75
|
+
w = None
|
|
76
|
+
try:
|
|
77
|
+
w = web.Web(logger, self.default_data, appcls=self.appcls, ver=self.ver,
|
|
78
|
+
redis_host=self.default_host, redis_port=self.default_port, redis_password=self.default_pass, svname=self.default_svname,
|
|
79
|
+
signin_file=args.signin_file)
|
|
80
|
+
users = w.user_list(args.user_name)
|
|
81
|
+
msg = dict(success=users)
|
|
82
|
+
common.print_format(msg, args.format, tm, args.output_json, args.output_json_append, pf=pf)
|
|
83
|
+
return self.RESP_SUCCESS, msg, w
|
|
84
|
+
except Exception as e:
|
|
85
|
+
msg = dict(warn=f"{e}")
|
|
86
|
+
common.print_format(msg, args.format, tm, args.output_json, args.output_json_append, pf=pf)
|
|
87
|
+
return self.RESP_WARN, msg, w
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
from cmdbox.app import common, feature
|
|
2
2
|
from cmdbox.app.auth import signin
|
|
3
|
+
from cmdbox.app.features.cli import agent_base
|
|
3
4
|
from cmdbox.app.web import Web
|
|
4
5
|
from fastapi import FastAPI, Depends, HTTPException, Request, Response, WebSocket
|
|
5
6
|
from fastapi.responses import HTMLResponse, StreamingResponse
|
|
@@ -38,6 +39,16 @@ class Agent(feature.WebFeature):
|
|
|
38
39
|
web.options.audit_exec(req, res, web)
|
|
39
40
|
return web.agent_html_data
|
|
40
41
|
|
|
42
|
+
@app.get('/agent/llmsetting')
|
|
43
|
+
async def agent(req:Request, res:Response):
|
|
44
|
+
signin = web.signin.check_signin(req, res)
|
|
45
|
+
if signin is not None:
|
|
46
|
+
return signin
|
|
47
|
+
res.headers['Access-Control-Allow-Origin'] = '*'
|
|
48
|
+
web.options.audit_exec(req, res, web)
|
|
49
|
+
cmd = agent_base.AgentBase(web.appcls, web.ver)
|
|
50
|
+
return cmd.get_option().get('choice')
|
|
51
|
+
|
|
41
52
|
@app.post('/agent/session/list')
|
|
42
53
|
async def agent_session_list(req:Request, res:Response):
|
|
43
54
|
signin = web.signin.check_signin(req, res)
|
|
@@ -150,12 +161,9 @@ class Agent(feature.WebFeature):
|
|
|
150
161
|
if 'signin' in session:
|
|
151
162
|
user_id = session['signin']['name']
|
|
152
163
|
groups = session['signin']['groups']
|
|
153
|
-
# 言語認識
|
|
154
|
-
language, _ = locale.getlocale()
|
|
155
|
-
is_japan = language.find('Japan') >= 0 or language.find('ja_JP') >= 0
|
|
156
164
|
# セッションを作成する
|
|
157
165
|
agent_session = await web.create_agent_session(web.agent_runner.session_service, user_id, session_id=session_id)
|
|
158
|
-
startmsg = "こんにちは!何かお手伝いできることはありますか?" if is_japan else "Hello! Is there anything I can help you with?"
|
|
166
|
+
startmsg = "こんにちは!何かお手伝いできることはありますか?" if common.is_japan() else "Hello! Is there anything I can help you with?"
|
|
159
167
|
yield json.dumps(dict(message=startmsg), default=common.default_json_enc)
|
|
160
168
|
def _replace_match(match_obj):
|
|
161
169
|
json_str = match_obj.group(0)
|
|
@@ -229,6 +237,10 @@ class Agent(feature.WebFeature):
|
|
|
229
237
|
break
|
|
230
238
|
except self.SSEDisconnect as e:
|
|
231
239
|
break
|
|
240
|
+
except NotImplementedError as e:
|
|
241
|
+
web.logger.warning(f'The session table needs to be reloaded.{e}', exc_info=True)
|
|
242
|
+
yield json.dumps(dict(message=f'The session table needs to be reloaded. Please reload your browser.'), default=common.default_json_enc)
|
|
243
|
+
break
|
|
232
244
|
except Exception as e:
|
|
233
245
|
web.logger.warning(f'chat error.', exc_info=True)
|
|
234
246
|
yield json.dumps(dict(message=f'<pre>{traceback.format_exc()}</pre>'), default=common.default_json_enc)
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
from cmdbox.app import feature
|
|
1
|
+
from cmdbox.app import common, feature
|
|
2
2
|
from cmdbox.app.web import Web
|
|
3
3
|
from fastapi import FastAPI, Request, Response, HTTPException
|
|
4
4
|
|
|
@@ -20,5 +20,13 @@ class GetCmdChoices(feature.WebFeature):
|
|
|
20
20
|
form = await req.form()
|
|
21
21
|
mode = form.get('mode')
|
|
22
22
|
cmd = form.get('cmd')
|
|
23
|
-
ret = web.options.get_cmd_choices(mode, cmd, True)
|
|
23
|
+
ret = web.options.get_cmd_choices(mode, cmd, True).copy()
|
|
24
|
+
fobj = web.options.get_cmd_attr(mode, cmd, 'feature')
|
|
25
|
+
desc = web.options.get_cmd_attr(mode, cmd, 'description_en' if not common.is_japan() else 'description_ja')
|
|
26
|
+
desc_nouse_webmode = '\U00002B55 Web' if not web.options.get_cmd_attr(mode, cmd, 'nouse_webmode') else '\U0000274C Web'
|
|
27
|
+
desc_use_agent = '\U00002B55 Agent' if web.options.get_cmd_attr(mode, cmd, 'use_agent') else '\U0000274C Agent'
|
|
28
|
+
desc_edge = '\U00002B55 Edge' if not isinstance(fobj, feature.UnsupportEdgeFeature) else '\U0000274C Edge'
|
|
29
|
+
help = dict(opt="help", type=web.options.T_TEXT, default=f"\U00002B55 CLI, {desc_nouse_webmode}, {desc_use_agent}, {desc_edge}, {desc}",
|
|
30
|
+
required=False, multi=False, hide=False, choice=None, description_ja="-", description_en="-")
|
|
31
|
+
ret.insert(0, help)
|
|
24
32
|
return ret
|
|
@@ -50,5 +50,6 @@ class SaveCmd(feature.WebFeature):
|
|
|
50
50
|
if 'cmd_disabled' in opt: del opt['cmd_disabled']
|
|
51
51
|
if 'name_disabled' in opt: del opt['name_disabled']
|
|
52
52
|
if 'modal_mode' in opt: del opt['modal_mode']
|
|
53
|
+
if 'help' in opt: del opt['help']
|
|
53
54
|
common.saveopt(opt, opt_path, True)
|
|
54
55
|
return dict(success=f'Command "{title}" saved in "{opt_path}".')
|
|
@@ -25,6 +25,10 @@ class VersionsUsed(feature.WebFeature):
|
|
|
25
25
|
for i, line in enumerate(f.readlines()):
|
|
26
26
|
parts = line.strip().split('\t')
|
|
27
27
|
ret.append(parts)
|
|
28
|
+
with open(Path(cmdbox.__file__).parent / 'app' / 'lib_license_list.txt', 'r', encoding='utf-8') as f:
|
|
29
|
+
for i, line in enumerate(f.readlines()):
|
|
30
|
+
parts = line.strip().split('\t')
|
|
31
|
+
ret.append(parts)
|
|
28
32
|
with open(Path(cmdbox.__file__).parent / 'web' / 'assets_license_list.txt', 'r', encoding='utf-8') as f:
|
|
29
33
|
for i, line in enumerate(f.readlines()):
|
|
30
34
|
parts = line.strip().split('\t')
|
cmdbox/app/filer.py
CHANGED
|
@@ -8,7 +8,7 @@ import mimetypes
|
|
|
8
8
|
import shutil
|
|
9
9
|
|
|
10
10
|
class Filer(object):
|
|
11
|
-
|
|
11
|
+
RESP_SUCCESS:int = 0
|
|
12
12
|
RESP_WARN:int = 1
|
|
13
13
|
RESP_ERROR:int = 2
|
|
14
14
|
def __init__(self, data_dir: Path, logger: logging.Logger,):
|
|
@@ -132,7 +132,7 @@ class Filer(object):
|
|
|
132
132
|
file_list:Path = self.data_dir / cpath
|
|
133
133
|
tpath_key, pt = _path_tree(file_list, cpart, i, recursive if i+1==len(current_path_parts) else False)
|
|
134
134
|
path_tree[tpath_key] = pt
|
|
135
|
-
return self.
|
|
135
|
+
return self.RESP_SUCCESS, dict(success=path_tree)
|
|
136
136
|
|
|
137
137
|
def file_mkdir(self, current_path:str) -> Tuple[int, Dict[str, Any]]:
|
|
138
138
|
"""
|
|
@@ -152,7 +152,7 @@ class Filer(object):
|
|
|
152
152
|
try:
|
|
153
153
|
abspath.mkdir(parents=True)
|
|
154
154
|
ret_path = str(Path(current_path).parent).replace("\\","/")
|
|
155
|
-
return self.
|
|
155
|
+
return self.RESP_SUCCESS, dict(success=dict(path=f"{ret_path}",msg=f"Created {abspath}"))
|
|
156
156
|
except Exception as e:
|
|
157
157
|
self.logger.warning(f"Failed to create {abspath}. {e}")
|
|
158
158
|
return self.RESP_WARN, dict(warn=f"Failed to create {abspath}. {e}")
|
|
@@ -178,7 +178,7 @@ class Filer(object):
|
|
|
178
178
|
try:
|
|
179
179
|
common.rmdirs(abspath, ignore_errors=False)
|
|
180
180
|
ret_path = str(Path(current_path).parent).replace("\\","/")
|
|
181
|
-
return self.
|
|
181
|
+
return self.RESP_SUCCESS, dict(success=dict(path=f"{ret_path}",msg=f"Removed {abspath}"))
|
|
182
182
|
except Exception as e:
|
|
183
183
|
self.logger.warning(f"Failed to remove {abspath}. {e}")
|
|
184
184
|
return self.RESP_WARN, dict(warn=f"Failed to remove {abspath}. {e}")
|
|
@@ -213,7 +213,7 @@ class Filer(object):
|
|
|
213
213
|
fd = convert.img2byte(img, "jpeg")
|
|
214
214
|
fname = f"{fname}.thumbnail.jpg"
|
|
215
215
|
data = convert.bytes2b64str(fd)
|
|
216
|
-
return self.
|
|
216
|
+
return self.RESP_SUCCESS, dict(success=dict(name=fname, data=data, mime_type=mime_type))
|
|
217
217
|
except Exception as e:
|
|
218
218
|
self.logger.warning(f"Failed to download {abspath}. {e}")
|
|
219
219
|
return self.RESP_WARN, dict(warn=f"Failed to download {abspath}. {e}")
|
|
@@ -254,7 +254,7 @@ class Filer(object):
|
|
|
254
254
|
save_path.parent.mkdir(parents=True, exist_ok=True)
|
|
255
255
|
with open(save_path, "wb") as f:
|
|
256
256
|
f.write(file_data)
|
|
257
|
-
return self.
|
|
257
|
+
return self.RESP_SUCCESS, dict(success=f"Uploaded {save_path}")
|
|
258
258
|
except Exception as e:
|
|
259
259
|
self.logger.warning(f"Failed to upload {save_path}. {e}")
|
|
260
260
|
return self.RESP_WARN, dict(warn=f"Failed to upload {save_path}. {e}")
|
|
@@ -280,7 +280,7 @@ class Filer(object):
|
|
|
280
280
|
try:
|
|
281
281
|
abspath.unlink()
|
|
282
282
|
ret_path = str(Path(current_path).parent).replace("\\","/")
|
|
283
|
-
return self.
|
|
283
|
+
return self.RESP_SUCCESS, dict(success=dict(path=ret_path, msg=f"Removed {abspath}"))
|
|
284
284
|
except Exception as e:
|
|
285
285
|
self.logger.warning(f"Failed to remove {abspath}. {e}")
|
|
286
286
|
return self.RESP_WARN, dict(warn=f"Failed to remove {abspath}. {e}")
|
|
@@ -316,7 +316,7 @@ class Filer(object):
|
|
|
316
316
|
self.logger.warning(f"Path {from_abspath} is not file or directory.")
|
|
317
317
|
return self.RESP_WARN, dict(warn=f"Path {from_abspath} is not file or directory.")
|
|
318
318
|
|
|
319
|
-
return self.
|
|
319
|
+
return self.RESP_SUCCESS, dict(success=dict(path=Path(to_path).parent,
|
|
320
320
|
to_path=to_path,
|
|
321
321
|
from_path=from_path,
|
|
322
322
|
ret_path=ret_path,
|
|
@@ -344,7 +344,7 @@ class Filer(object):
|
|
|
344
344
|
|
|
345
345
|
ret_path = shutil.move(from_abspath, to_abspath)
|
|
346
346
|
|
|
347
|
-
return self.
|
|
347
|
+
return self.RESP_SUCCESS, dict(success=dict(path=Path(to_path).parent,
|
|
348
348
|
to_path=to_path,
|
|
349
349
|
from_path=from_path,
|
|
350
350
|
ret_path=ret_path,
|