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.

Files changed (168) hide show
  1. cmdbox/app/app.py +22 -7
  2. cmdbox/app/common.py +9 -6
  3. cmdbox/app/commons/loghandler.py +101 -20
  4. cmdbox/app/commons/redis_client.py +1 -1
  5. cmdbox/app/edge.py +2 -4
  6. cmdbox/app/feature.py +1 -1
  7. cmdbox/app/features/cli/cmdbox_agent_mcp_client.py +175 -0
  8. cmdbox/app/features/cli/cmdbox_agent_mcp_proxy.py +96 -0
  9. cmdbox/app/features/cli/cmdbox_audit_createdb.py +224 -224
  10. cmdbox/app/features/cli/cmdbox_audit_delete.py +4 -4
  11. cmdbox/app/features/cli/cmdbox_audit_search.py +4 -4
  12. cmdbox/app/features/cli/cmdbox_audit_write.py +6 -8
  13. cmdbox/app/features/cli/cmdbox_client_file_copy.py +3 -3
  14. cmdbox/app/features/cli/cmdbox_client_file_download.py +3 -3
  15. cmdbox/app/features/cli/cmdbox_client_file_list.py +3 -3
  16. cmdbox/app/features/cli/cmdbox_client_file_mkdir.py +3 -3
  17. cmdbox/app/features/cli/cmdbox_client_file_move.py +3 -3
  18. cmdbox/app/features/cli/cmdbox_client_file_remove.py +3 -3
  19. cmdbox/app/features/cli/cmdbox_client_file_rmdir.py +3 -3
  20. cmdbox/app/features/cli/cmdbox_client_file_upload.py +3 -3
  21. cmdbox/app/features/cli/cmdbox_client_http.py +7 -6
  22. cmdbox/app/features/cli/cmdbox_client_server_info.py +4 -4
  23. cmdbox/app/features/cli/cmdbox_cmd_list.py +4 -4
  24. cmdbox/app/features/cli/cmdbox_cmd_load.py +5 -5
  25. cmdbox/app/features/cli/cmdbox_edge_config.py +1 -1
  26. cmdbox/app/features/cli/cmdbox_edge_start.py +3 -3
  27. cmdbox/app/features/cli/cmdbox_mcp_client.py +174 -174
  28. cmdbox/app/features/cli/cmdbox_mcp_proxy.py +96 -96
  29. cmdbox/app/features/cli/cmdbox_server_list.py +3 -3
  30. cmdbox/app/features/cli/cmdbox_server_start.py +103 -103
  31. cmdbox/app/features/cli/cmdbox_server_stop.py +6 -6
  32. cmdbox/app/features/cli/cmdbox_tts_install.py +317 -0
  33. cmdbox/app/features/cli/cmdbox_tts_say.py +179 -0
  34. cmdbox/app/features/cli/cmdbox_tts_start.py +329 -0
  35. cmdbox/app/features/cli/cmdbox_tts_stop.py +108 -0
  36. cmdbox/app/features/cli/cmdbox_web_apikey_add.py +91 -91
  37. cmdbox/app/features/cli/cmdbox_web_apikey_del.py +91 -91
  38. cmdbox/app/features/cli/cmdbox_web_gencert.py +7 -7
  39. cmdbox/app/features/cli/cmdbox_web_genpass.py +168 -168
  40. cmdbox/app/features/cli/cmdbox_web_group_add.py +94 -94
  41. cmdbox/app/features/cli/cmdbox_web_group_del.py +87 -87
  42. cmdbox/app/features/cli/cmdbox_web_group_edit.py +94 -94
  43. cmdbox/app/features/cli/cmdbox_web_group_list.py +87 -87
  44. cmdbox/app/features/cli/cmdbox_web_start.py +236 -235
  45. cmdbox/app/features/cli/cmdbox_web_stop.py +72 -72
  46. cmdbox/app/features/cli/cmdbox_web_user_add.py +104 -104
  47. cmdbox/app/features/cli/cmdbox_web_user_del.py +87 -87
  48. cmdbox/app/features/cli/cmdbox_web_user_edit.py +104 -104
  49. cmdbox/app/features/cli/cmdbox_web_user_list.py +87 -87
  50. cmdbox/app/features/web/cmdbox_web_agent.py +16 -4
  51. cmdbox/app/features/web/cmdbox_web_get_cmd_choices.py +10 -2
  52. cmdbox/app/features/web/cmdbox_web_save_cmd.py +1 -0
  53. cmdbox/app/features/web/cmdbox_web_versions_used.py +4 -0
  54. cmdbox/app/filer.py +9 -9
  55. cmdbox/app/mcp.py +19 -8
  56. cmdbox/app/options.py +52 -47
  57. cmdbox/app/server.py +224 -224
  58. cmdbox/app/web.py +39 -17
  59. cmdbox/extensions/features.yml +7 -1
  60. cmdbox/extensions/sample_project/sample/app/features/cli/sample_client_time.py +2 -2
  61. cmdbox/extensions/sample_project/sample/app/features/cli/sample_server_time.py +3 -3
  62. cmdbox/licenses/LICENSE_APScheduler_3_11_0_MIT_License.txt +19 -0
  63. cmdbox/licenses/LICENSE_SQLAlchemy_2_0_43_MIT.txt +19 -0
  64. cmdbox/licenses/LICENSE_Werkzeug_3_1_1_BSD_License.txt +28 -0
  65. cmdbox/licenses/LICENSE_absolufy-imports_0_3_1_MIT_License.txt +21 -0
  66. cmdbox/licenses/LICENSE_anyio_4_10_0_UNKNOWN.txt +20 -0
  67. cmdbox/licenses/{LICENSE_typer_0_16_0_MIT_License.txt → LICENSE_backoff_2_2_1_MIT_License.txt} +1 -1
  68. cmdbox/licenses/LICENSE_certifi_2025_8_3_Mozilla_Public_License_2_0-MPL_2_0.txt +20 -0
  69. cmdbox/licenses/LICENSE_charset-normalizer_3_4_3_MIT.txt +21 -0
  70. cmdbox/licenses/LICENSE_cryptography_45_0_6_Apache-2_0_OR_BSD-3-Clause.txt +3 -0
  71. cmdbox/licenses/LICENSE_cyclopts_3_22_5_Apache_Software_License.txt +201 -0
  72. cmdbox/licenses/LICENSE_fastapi-sso_0_18_0_MIT_License.txt +21 -0
  73. cmdbox/licenses/LICENSE_fastmcp_2_11_3_Apache_Software_License.txt +201 -0
  74. cmdbox/licenses/LICENSE_google-adk_1_9_0_Apache_Software_License.txt +202 -0
  75. cmdbox/licenses/LICENSE_google-genai_1_28_0_Apache_Software_License.txt +202 -0
  76. cmdbox/licenses/LICENSE_google-genai_1_29_0_Apache_Software_License.txt +202 -0
  77. cmdbox/licenses/LICENSE_greenlet_3_2_4_MIT_AND_Python-2_0.txt +30 -0
  78. cmdbox/licenses/LICENSE_isodate_0_7_2_BSD_License.txt +26 -0
  79. cmdbox/licenses/LICENSE_lazy-object-proxy_1_11_0_BSD_License.txt +20 -0
  80. cmdbox/licenses/LICENSE_litellm-enterprise_0_1_19_UNKNOWN.txt +37 -0
  81. cmdbox/licenses/LICENSE_litellm_1_75_5_post1_MIT_License.txt +26 -0
  82. cmdbox/licenses/LICENSE_markdown-it-py_4_0_0_MIT_License.txt +21 -0
  83. cmdbox/licenses/LICENSE_mcp_1_12_4_MIT_License.txt +21 -0
  84. cmdbox/licenses/LICENSE_multidict_6_6_4_Apache_License_2_0.txt +13 -0
  85. cmdbox/licenses/LICENSE_oauthlib_3_3_1_BSD-3-Clause.txt +27 -0
  86. cmdbox/licenses/LICENSE_openai_1_99_9_Apache_Software_License.txt +201 -0
  87. cmdbox/licenses/LICENSE_openapi-core_0_19_5_BSD_License.txt +29 -0
  88. cmdbox/licenses/LICENSE_openapi-schema-validator_0_6_3_BSD_License.txt +29 -0
  89. cmdbox/licenses/LICENSE_openapi-spec-validator_0_7_2_Apache_Software_License.txt +201 -0
  90. cmdbox/licenses/LICENSE_opentelemetry-api_1_36_0_UNKNOWN.txt +201 -0
  91. cmdbox/licenses/LICENSE_opentelemetry-sdk_1_36_0_UNKNOWN.txt +201 -0
  92. cmdbox/licenses/LICENSE_opentelemetry-semantic-conventions_0_57b0_UNKNOWN.txt +201 -0
  93. cmdbox/licenses/LICENSE_orjson_3_11_1_Apache_Software_License-MIT_License.txt +201 -0
  94. cmdbox/licenses/LICENSE_parse_1_20_2_MIT_License.txt +19 -0
  95. cmdbox/licenses/LICENSE_pathable_0_4_4_Apache_Software_License.txt +201 -0
  96. cmdbox/licenses/{LICENSE_pillow_11_2_1_UNKNOWN.txt → LICENSE_pillow_11_3_0_UNKNOWN.txt} +393 -3
  97. cmdbox/licenses/LICENSE_pyperclip_1_9_0_BSD_License.txt +27 -0
  98. cmdbox/licenses/LICENSE_redis_6_4_0_MIT_License.txt +21 -0
  99. cmdbox/licenses/LICENSE_rfc3339-validator_0_1_4_MIT_License.txt +22 -0
  100. cmdbox/licenses/LICENSE_rich-rst_1_3_1_MIT_License.txt +7 -0
  101. cmdbox/licenses/LICENSE_rpds-py_0_27_0_UNKNOWN.txt +19 -0
  102. cmdbox/licenses/{LICENSE_setuptools_65_5_0_MIT_License.txt → LICENSE_setuptools_80_9_0_UNKNOWN.txt} +0 -2
  103. cmdbox/licenses/LICENSE_sphinx-intl_2_3_2_UNKNOWN.txt +25 -0
  104. cmdbox/licenses/LICENSE_tenacity_9_1_2_Apache_Software_License.txt +202 -0
  105. 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
  106. cmdbox/licenses/LICENSE_tokenizers_0_21_4_Apache_Software_License.txt +1 -0
  107. cmdbox/licenses/LICENSE_voicevox_core_0_16_0_MIT.txt +20 -0
  108. cmdbox/licenses/LICENSE_watchdog_6_0_0_Apache_Software_License.txt +16 -0
  109. cmdbox/licenses/{LICENSE_httptools_0_6_4_MIT_License.txt → LICENSE_wsproto_1_2_0_MIT_License.txt} +3 -3
  110. cmdbox/licenses/files.txt +69 -50
  111. cmdbox/logconf_cmdbox.yml +136 -0
  112. cmdbox/version.py +2 -2
  113. cmdbox/web/agent.html +16 -2
  114. cmdbox/web/assets/cmdbox/agent.js +226 -1
  115. cmdbox/web/assets/cmdbox/common.js +20 -25
  116. cmdbox/web/assets/cmdbox/svgicon.js +18 -0
  117. {cmdbox-0.6.3.2.dist-info → cmdbox-0.6.4.1.dist-info}/METADATA +29 -20
  118. {cmdbox-0.6.3.2.dist-info → cmdbox-0.6.4.1.dist-info}/RECORD +158 -118
  119. {cmdbox-0.6.3.2.dist-info → cmdbox-0.6.4.1.dist-info}/WHEEL +1 -1
  120. cmdbox/config.yml +0 -3
  121. cmdbox/licenses/LICENSE_shellingham_1_5_4_ISC_License-ISCL.txt +0 -13
  122. cmdbox/licenses/LICENSE_watchfiles_1_1_0_MIT_License.txt +0 -21
  123. cmdbox/logconf_audit.yml +0 -43
  124. cmdbox/logconf_client.yml +0 -43
  125. cmdbox/logconf_edge.yml +0 -43
  126. cmdbox/logconf_gui.yml +0 -43
  127. cmdbox/logconf_mcp.yml +0 -43
  128. cmdbox/logconf_server.yml +0 -43
  129. cmdbox/logconf_web.yml +0 -43
  130. /cmdbox/licenses/{LICENSE_Authlib_1_6_0_BSD_License.txt → LICENSE_Authlib_1_6_1_BSD_License.txt} +0 -0
  131. /cmdbox/licenses/{LICENSE_SQLAlchemy_2_0_41_MIT.txt → LICENSE_SQLAlchemy_2_0_42_MIT.txt} +0 -0
  132. /cmdbox/licenses/{LICENSE_aiohttp_3_12_13_Apache-2_0.txt → LICENSE_aiohttp_3_12_15_Apache-2_0_AND_MIT.txt} +0 -0
  133. /cmdbox/licenses/{LICENSE_aiosignal_1_3_2_Apache_Software_License.txt → LICENSE_aiosignal_1_4_0_Apache_Software_License.txt} +0 -0
  134. /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
  135. /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
  136. /cmdbox/licenses/{LICENSE_docstring_parser_0_16_MIT_License.txt → LICENSE_docstring_parser_0_17_0_MIT_License.txt} +0 -0
  137. /cmdbox/licenses/{LICENSE_fastapi_0_115_14_MIT_License.txt → LICENSE_fastapi_0_116_1_MIT_License.txt} +0 -0
  138. /cmdbox/licenses/{LICENSE_fastmcp_2_10_1_Apache_Software_License.txt → LICENSE_fastmcp_2_11_0_Apache_Software_License.txt} +0 -0
  139. /cmdbox/licenses/{LICENSE_fsspec_2025_5_1_BSD_License.txt → LICENSE_fsspec_2025_7_0_BSD_License.txt} +0 -0
  140. /cmdbox/licenses/{LICENSE_google-adk_1_5_0_Apache_Software_License.txt → LICENSE_google-adk_1_10_0_Apache_Software_License.txt} +0 -0
  141. /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
  142. /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
  143. /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
  144. /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
  145. /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
  146. /cmdbox/licenses/{LICENSE_grpcio-status_1_73_1_Apache_Software_License.txt → LICENSE_grpcio-status_1_74_0_Apache_Software_License.txt} +0 -0
  147. /cmdbox/licenses/{LICENSE_grpcio_1_73_1_Apache_Software_License.txt → LICENSE_grpcio_1_74_0_Apache_Software_License.txt} +0 -0
  148. /cmdbox/licenses/{LICENSE_opentelemetry-api_1_34_1_Apache_Software_License.txt → LICENSE_huggingface-hub_0_34_3_Apache_Software_License.txt} +0 -0
  149. /cmdbox/licenses/{LICENSE_opentelemetry-sdk_1_34_1_Apache_Software_License.txt → LICENSE_huggingface-hub_0_34_4_Apache_Software_License.txt} +0 -0
  150. /cmdbox/licenses/{LICENSE_opentelemetry-semantic-conventions_0_55b1_Apache_Software_License.txt → LICENSE_jsonschema-path_0_3_4_Apache_Software_License.txt} +0 -0
  151. /cmdbox/licenses/{LICENSE_jsonschema_4_24_0_UNKNOWN.txt → LICENSE_jsonschema_4_25_0_UNKNOWN.txt} +0 -0
  152. /cmdbox/licenses/{LICENSE_litellm_1_73_6_MIT_License.txt → LICENSE_litellm_1_74_12_MIT_License.txt} +0 -0
  153. /cmdbox/licenses/{LICENSE_mcp_1_10_1_MIT_License.txt → LICENSE_mcp_1_12_3_MIT_License.txt} +0 -0
  154. /cmdbox/licenses/{LICENSE_multidict_6_6_2_Apache_License_2_0.txt → LICENSE_multidict_6_6_3_Apache_License_2_0.txt} +0 -0
  155. /cmdbox/licenses/{LICENSE_nh3_0_2_21_MIT.txt → LICENSE_nh3_0_3_0_MIT.txt} +0 -0
  156. /cmdbox/licenses/{LICENSE_numpy_2_3_1_BSD_License.txt → LICENSE_numpy_2_3_2_BSD_License.txt} +0 -0
  157. /cmdbox/licenses/{LICENSE_openai_1_93_0_Apache_Software_License.txt → LICENSE_openai_1_98_0_Apache_Software_License.txt} +0 -0
  158. /cmdbox/licenses/{LICENSE_tokenizers_0_21_2_Apache_Software_License.txt → LICENSE_pywin32_311_Python_Software_Foundation_License.txt} +0 -0
  159. /cmdbox/licenses/{LICENSE_regex_2024_11_6_Apache_Software_License.txt → LICENSE_regex_2025_7_34_UNKNOWN.txt} +0 -0
  160. /cmdbox/licenses/{LICENSE_rich_14_0_0_MIT_License.txt → LICENSE_rich_14_1_0_MIT_License.txt} +0 -0
  161. /cmdbox/licenses/{LICENSE_rpds-py_0_25_1_MIT.txt → LICENSE_rpds-py_0_26_0_MIT.txt} +0 -0
  162. /cmdbox/licenses/{LICENSE_sse-starlette_2_3_6_BSD_License.txt → LICENSE_sse-starlette_3_0_2_UNKNOWN.txt} +0 -0
  163. /cmdbox/licenses/{LICENSE_starlette_0_46_2_BSD_License.txt → LICENSE_starlette_0_47_2_BSD_License.txt} +0 -0
  164. /cmdbox/licenses/{LICENSE_typing_extensions_4_14_0_UNKNOWN.txt → LICENSE_typing_extensions_4_14_1_UNKNOWN.txt} +0 -0
  165. /cmdbox/licenses/{LICENSE_zope_event_5_1_Zope_Public_License.txt → LICENSE_zope_event_5_1_1_Zope_Public_License.txt} +0 -0
  166. {cmdbox-0.6.3.2.dist-info → cmdbox-0.6.4.1.dist-info}/entry_points.txt +0 -0
  167. {cmdbox-0.6.3.2.dist-info → cmdbox-0.6.4.1.dist-info/licenses}/LICENSE +0 -0
  168. {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 1, 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 0, 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 1, msg, w
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.OneshotResultEdgeFeature):
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 1, 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 0, 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 1, msg, w
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
- RESP_SCCESS:int = 0
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.RESP_SCCESS, dict(success=path_tree)
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.RESP_SCCESS, dict(success=dict(path=f"{ret_path}",msg=f"Created {abspath}"))
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.RESP_SCCESS, dict(success=dict(path=f"{ret_path}",msg=f"Removed {abspath}"))
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.RESP_SCCESS, dict(success=dict(name=fname, data=data, mime_type=mime_type))
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.RESP_SCCESS, dict(success=f"Uploaded {save_path}")
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.RESP_SCCESS, dict(success=dict(path=ret_path, msg=f"Removed {abspath}"))
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.RESP_SCCESS, dict(success=dict(path=Path(to_path).parent,
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.RESP_SCCESS, dict(success=dict(path=Path(to_path).parent,
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,