重构UserAIModelConfigServiceImpl的setDefaultConfiguration逻辑,并为AdminModelConfig的enabled字段设置默认值
This commit is contained in:
@@ -381,7 +381,7 @@ public class AdminModelConfigController {
|
||||
.provider(requestDTO.getProvider())
|
||||
.modelId(requestDTO.getModelId())
|
||||
.displayName(requestDTO.getDisplayName())
|
||||
.enabled(requestDTO.getEnabled())
|
||||
.enabled(requestDTO.getEnabled() != null ? requestDTO.getEnabled() : true)
|
||||
.apiEndpoint(requestDTO.getApiEndpoint())
|
||||
.enabledForFeatures(requestDTO.getEnabledForFeatures())
|
||||
.creditRateMultiplier(requestDTO.getCreditRateMultiplier())
|
||||
|
||||
@@ -12,7 +12,6 @@ import reactor.core.publisher.Mono;
|
||||
public interface UserAIModelConfigRepository extends ReactiveMongoRepository<UserAIModelConfig, String> {
|
||||
|
||||
Flux<UserAIModelConfig> findByUserId(String userId);
|
||||
|
||||
Mono<UserAIModelConfig> findByUserIdAndId(String userId, String id);
|
||||
|
||||
Mono<UserAIModelConfig> findByUserIdAndProviderAndModelName(String userId, String provider, String modelName);
|
||||
|
||||
@@ -174,27 +174,22 @@ public class UserAIModelConfigServiceImpl implements UserAIModelConfigService {
|
||||
@Override
|
||||
@Transactional
|
||||
public Mono<UserAIModelConfig> setDefaultConfiguration(String userId, String configId) {
|
||||
return configRepository.findByUserIdAndId(userId, configId)
|
||||
// 查找要设为默认的配置,并确保它存在且已验证
|
||||
Mono<UserAIModelConfig> configToSetDefaultMono = configRepository.findByUserIdAndId(userId, configId)
|
||||
.switchIfEmpty(Mono.error(new RuntimeException("配置不存在或无权访问")))
|
||||
.flatMap(configToSetDefault -> {
|
||||
if (!configToSetDefault.getIsValidated()) {
|
||||
.flatMap(config -> {
|
||||
if (!config.getIsValidated()) {
|
||||
return Mono.error(new IllegalArgumentException("无法将未验证的配置设为默认"));
|
||||
}
|
||||
if (configToSetDefault.isDefault()) {
|
||||
return Mono.just(configToSetDefault);
|
||||
if (config.isDefault()) {
|
||||
return Mono.just(config); // 如果已经是默认,直接返回
|
||||
}
|
||||
return Mono.just(config);
|
||||
});
|
||||
|
||||
return configRepository.findByUserIdAndIsDefaultIsTrue(userId)
|
||||
.flatMap(currentDefault -> {
|
||||
if (!currentDefault.getId().equals(configId)) {
|
||||
currentDefault.setDefault(false);
|
||||
currentDefault.setUpdatedAt(LocalDateTime.now());
|
||||
return configRepository.save(currentDefault);
|
||||
}
|
||||
return Mono.empty();
|
||||
})
|
||||
.thenMany(configRepository.findByUserIdAndIsDefaultIsFalse(userId))
|
||||
.filter(config -> !config.getId().equals(configId))
|
||||
// 事务性操作:先将所有配置取消默认,再设置新的默认
|
||||
return configToSetDefaultMono.flatMap(configToSetDefault ->
|
||||
configRepository.findByUserId(userId)
|
||||
.flatMap(config -> {
|
||||
if (config.isDefault()) {
|
||||
config.setDefault(false);
|
||||
@@ -204,13 +199,12 @@ public class UserAIModelConfigServiceImpl implements UserAIModelConfigService {
|
||||
return Mono.empty();
|
||||
})
|
||||
.then()
|
||||
.then(Mono.fromCallable(() -> {
|
||||
.then(Mono.defer(() -> {
|
||||
configToSetDefault.setDefault(true);
|
||||
configToSetDefault.setUpdatedAt(LocalDateTime.now());
|
||||
return configToSetDefault;
|
||||
return configRepository.save(configToSetDefault);
|
||||
}))
|
||||
.flatMap(configRepository::save);
|
||||
});
|
||||
);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
||||
@@ -15,7 +15,7 @@ MANAGEMENT_HEALTH_RABBIT_ENABLED=false
|
||||
|
||||
# ==== 最小必填占位(避免 Bean 装配失败)====
|
||||
# ChatLanguageModelConfig 需要该键存在;开源默认给占位值,实际使用请改成真实 Key
|
||||
AI_OPENAI_API_KEY=dummy_openai_key
|
||||
AI_OPENAI_API_KEY=sk-QodfEMFLud0D6mtKQwtgcOUA6Vh2djaSPZSKuu9r4bopnKLF
|
||||
|
||||
# 可选:如你启用了 Gemini 相关功能,可填,否则保留占位即可
|
||||
AI_GEMINI_API_KEY=dummy_gemini_key
|
||||
@@ -43,9 +43,11 @@ CHROMA_URL=
|
||||
CHROMA_COLLECTION=ainovel
|
||||
|
||||
# ==== AI Key(按需)====
|
||||
OPENAI_API_KEY=
|
||||
OPENAI_API_KEY=sk-QodfEMFLud0D6mtKQwtgcOUA6Vh2djaSPZSKuu9r4bopnKLF
|
||||
GEMINI_API_KEY=
|
||||
ANTHROPIC_API_KEY=
|
||||
AI_DEFAULT_MODEL=gemini-2.5-pro
|
||||
DEFAULT_API_ENDPOINT=https://newapi.shizhuoran.top/v1
|
||||
|
||||
|
||||
AINOVEL_AI_FEATURES_SETTING_TREE_GENERATION_INIT_ON_STARTUP=true
|
||||
Reference in New Issue
Block a user