From ba3dffb3c49104215edd9cf5ff1de292601f1859 Mon Sep 17 00:00:00 2001 From: ronger Date: Tue, 28 May 2024 17:47:00 +0800 Subject: [PATCH] =?UTF-8?q?:art:=20=E8=B0=83=E6=95=B4=20openai=20=E6=8E=A5?= =?UTF-8?q?=E5=8F=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/com/rymcu/forest/config/RedisListenerConfig.java | 6 ++++++ src/main/java/com/rymcu/forest/openai/OpenAiController.java | 4 ++-- src/main/java/com/rymcu/forest/util/UserUtils.java | 4 ++++ 3 files changed, 12 insertions(+), 2 deletions(-) diff --git a/src/main/java/com/rymcu/forest/config/RedisListenerConfig.java b/src/main/java/com/rymcu/forest/config/RedisListenerConfig.java index 676ee27..ec7ee36 100644 --- a/src/main/java/com/rymcu/forest/config/RedisListenerConfig.java +++ b/src/main/java/com/rymcu/forest/config/RedisListenerConfig.java @@ -3,6 +3,7 @@ package com.rymcu.forest.config; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.data.redis.connection.RedisConnectionFactory; +import org.springframework.data.redis.core.StringRedisTemplate; import org.springframework.data.redis.listener.RedisMessageListenerContainer; /** @@ -21,4 +22,9 @@ public class RedisListenerConfig { container.setConnectionFactory(connectionFactory); return container; } + + @Bean + public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory redisConnectionFactory) { + return new StringRedisTemplate(redisConnectionFactory); + } } diff --git a/src/main/java/com/rymcu/forest/openai/OpenAiController.java b/src/main/java/com/rymcu/forest/openai/OpenAiController.java index 4375c81..19644e5 100644 --- a/src/main/java/com/rymcu/forest/openai/OpenAiController.java +++ b/src/main/java/com/rymcu/forest/openai/OpenAiController.java @@ -60,7 +60,6 @@ public class OpenAiController { throw new IllegalArgumentException("参数异常!"); } User user = UserUtils.getCurrentUserByToken(); - Collections.reverse(messages); List list = new ArrayList<>(messages.size()); if (messages.size() > 4) { messages = messages.subList(messages.size() - 4, messages.size()); @@ -78,9 +77,10 @@ public class OpenAiController { @NotNull private GlobalResult sendMessage(User user, List list) { + boolean isAdmin = UserUtils.isAdmin(user.getEmail()); OpenAiService service = new OpenAiService(token, Duration.ofSeconds(180)); ChatCompletionRequest completionRequest = ChatCompletionRequest.builder() - .model("gpt-3.5-turbo-16k-0613") + .model(isAdmin ? "gpt-4o" : "gpt-3.5-turbo-16k-0613") .stream(true) .messages(list) .build(); diff --git a/src/main/java/com/rymcu/forest/util/UserUtils.java b/src/main/java/com/rymcu/forest/util/UserUtils.java index 78fe61d..277dccf 100644 --- a/src/main/java/com/rymcu/forest/util/UserUtils.java +++ b/src/main/java/com/rymcu/forest/util/UserUtils.java @@ -78,4 +78,8 @@ public class UserUtils { } throw new UnauthenticatedException(); } + + public static boolean isAdmin(String email) { + return userMapper.hasAdminPermission(email); + } }