mirror of
https://github.com/infiniflow/ragflow.git
synced 2026-05-23 09:28:06 +08:00
## What Fixes #12409. Implements admin CLI support for: - `list vars;` - `show var <name-or-prefix>;` - `set var <name> <value>;` ## Changes - Wire Go CLI variable commands to the admin API. - Support integer and quoted string values in `SET VAR`. - Return variable rows as `data_type`, `name`, `setting_type`, and `value`. - Add exact-name lookup with prefix fallback for `SHOW VAR`. - Validate values by stored data type: `string`, `integer`, `bool`, and `json`. - Keep the legacy Python admin CLI/server behavior aligned. - Update admin CLI docs and add focused tests. ## Verification - `go test -count=1 ./internal/cli` - `python3.12 -m py_compile admin/server/services.py admin/server/routes.py api/db/services/system_settings_service.py admin/client/parser.py admin/client/ragflow_client.py` - Python admin CLI parser smoke test for `SET VAR`, quoted values, `SHOW VAR`, and `LIST VARS`. - Attempted `./run_go_tests.sh`; local environment is missing native tokenizer/linker artifacts: - `internal/cpp/cmake-build-release/librag_tokenizer_c_api.a` - `-lstdc++` Co-authored-by: Jin Hai <haijin.chn@gmail.com>
51 lines
1.7 KiB
Python
51 lines
1.7 KiB
Python
#
|
|
# Copyright 2026 The InfiniFlow Authors. All Rights Reserved.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
#
|
|
from datetime import datetime
|
|
from common.time_utils import current_timestamp, datetime_format
|
|
from api.db.db_models import DB
|
|
from api.db.db_models import SystemSettings
|
|
from api.db.services.common_service import CommonService
|
|
|
|
|
|
class SystemSettingsService(CommonService):
|
|
model = SystemSettings
|
|
|
|
@classmethod
|
|
@DB.connection_context()
|
|
def get_by_name(cls, name):
|
|
objs = cls.model.select().where(cls.model.name == name).order_by(cls.model.name.asc())
|
|
return objs
|
|
|
|
@classmethod
|
|
@DB.connection_context()
|
|
def get_by_name_prefix(cls, name_prefix):
|
|
objs = cls.model.select().where(cls.model.name.startswith(name_prefix)).order_by(cls.model.name.asc())
|
|
return objs
|
|
|
|
@classmethod
|
|
@DB.connection_context()
|
|
def update_by_name(cls, name, obj):
|
|
obj["update_time"] = current_timestamp()
|
|
obj["update_date"] = datetime_format(datetime.now())
|
|
cls.model.update(obj).where(cls.model.name == name).execute()
|
|
return SystemSettings(**obj)
|
|
|
|
@classmethod
|
|
@DB.connection_context()
|
|
def get_record_count(cls):
|
|
count = cls.model.select().count()
|
|
return count
|