Compare commits
33 Commits
8c9cb6f21d
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
eea6307c87 | ||
|
|
c5366e006b | ||
|
|
f0f295bfc9 | ||
|
|
e34c5d2e3e | ||
|
|
86d6fcaec7 | ||
|
|
2c09d97cec | ||
|
|
37ac0cd311 | ||
|
|
9fa38a3065 | ||
|
|
d908f99fbd | ||
|
|
5b0b23336c | ||
|
|
263b91c42a | ||
|
|
a53c90a348 | ||
|
|
e3583dad0c | ||
|
|
514a65a5e6 | ||
|
|
57a57ace77 | ||
|
|
1338e6458c | ||
|
|
9fd46b3a20 | ||
|
|
8e8b1a7684 | ||
|
|
4d8238dd7f | ||
|
|
73f7d3085a | ||
|
|
3f8652395c | ||
|
|
8c6e0aa353 | ||
|
|
e15dd6289d | ||
|
|
7d33227d70 | ||
|
|
8fda8f7669 | ||
|
|
57a828c5b4 | ||
|
|
b9f6aa0cc2 | ||
|
|
dcb9028d86 | ||
|
|
57a2787bf8 | ||
|
|
813ddfaeac | ||
|
|
0cbf6b28ef | ||
|
|
7efb2527d0 | ||
|
|
f085c9d506 |
2
.gitignore
vendored
2
.gitignore
vendored
@@ -32,7 +32,7 @@ buildNumber.properties
|
|||||||
!.vscode/*.code-snippets
|
!.vscode/*.code-snippets
|
||||||
.history/
|
.history/
|
||||||
*.vsix
|
*.vsix
|
||||||
**/.idea/**
|
.idea/**
|
||||||
cmake-build-*/
|
cmake-build-*/
|
||||||
.idea/**/mongoSettings.xml
|
.idea/**/mongoSettings.xml
|
||||||
*.iws
|
*.iws
|
||||||
|
|||||||
102
bin/.gitignore
vendored
102
bin/.gitignore
vendored
@@ -1,102 +0,0 @@
|
|||||||
.vscode/*
|
|
||||||
!.vscode/settings.json
|
|
||||||
!.vscode/tasks.json
|
|
||||||
!.vscode/launch.json
|
|
||||||
!.vscode/extensions.json
|
|
||||||
!.vscode/*.code-snippets
|
|
||||||
.history/
|
|
||||||
*.vsix
|
|
||||||
*~
|
|
||||||
.fuse_hidden*
|
|
||||||
.directory
|
|
||||||
.Trash-*
|
|
||||||
.nfs*
|
|
||||||
logs
|
|
||||||
*.log
|
|
||||||
npm-debug.log*
|
|
||||||
yarn-debug.log*
|
|
||||||
yarn-error.log*
|
|
||||||
lerna-debug.log*
|
|
||||||
.pnpm-debug.log*
|
|
||||||
report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json
|
|
||||||
pids
|
|
||||||
*.pid
|
|
||||||
*.seed
|
|
||||||
*.pid.lock
|
|
||||||
lib-cov
|
|
||||||
coverage
|
|
||||||
*.lcov
|
|
||||||
.nyc_output
|
|
||||||
.grunt
|
|
||||||
bower_components
|
|
||||||
.lock-wscript
|
|
||||||
build/Release
|
|
||||||
node_modules/
|
|
||||||
jspm_packages/
|
|
||||||
web_modules/
|
|
||||||
*.tsbuildinfo
|
|
||||||
.npm
|
|
||||||
.eslintcache
|
|
||||||
.stylelintcache
|
|
||||||
.rpt2_cache/
|
|
||||||
.rts2_cache_cjs/
|
|
||||||
.rts2_cache_es/
|
|
||||||
.rts2_cache_umd/
|
|
||||||
.node_repl_history
|
|
||||||
*.tgz
|
|
||||||
.yarn-integrity
|
|
||||||
.env
|
|
||||||
.env.development.local
|
|
||||||
.env.test.local
|
|
||||||
.env.production.local
|
|
||||||
.env.local
|
|
||||||
.cache
|
|
||||||
.parcel-cache
|
|
||||||
.next
|
|
||||||
out
|
|
||||||
.nuxt
|
|
||||||
dist
|
|
||||||
.cache/
|
|
||||||
.vuepress/dist
|
|
||||||
.temp
|
|
||||||
.docusaurus
|
|
||||||
.serverless/
|
|
||||||
.fusebox/
|
|
||||||
.dynamodb/
|
|
||||||
.tern-port
|
|
||||||
.vscode-test
|
|
||||||
.yarn/cache
|
|
||||||
.yarn/unplugged
|
|
||||||
.yarn/build-state.yml
|
|
||||||
.yarn/install-state.gz
|
|
||||||
.pnp.*
|
|
||||||
Thumbs.db
|
|
||||||
Thumbs.db:encryptable
|
|
||||||
ehthumbs.db
|
|
||||||
ehthumbs_vista.db
|
|
||||||
*.stackdump
|
|
||||||
[Dd]esktop.ini
|
|
||||||
$RECYCLE.BIN/
|
|
||||||
*.cab
|
|
||||||
*.msi
|
|
||||||
*.msix
|
|
||||||
*.msm
|
|
||||||
*.msp
|
|
||||||
*.lnk
|
|
||||||
.DS_Store
|
|
||||||
.AppleDouble
|
|
||||||
.LSOverride
|
|
||||||
Icon
|
|
||||||
._*
|
|
||||||
.DocumentRevisions-V100
|
|
||||||
.fseventsd
|
|
||||||
.Spotlight-V100
|
|
||||||
.TemporaryItems
|
|
||||||
.Trashes
|
|
||||||
.VolumeIcon.icns
|
|
||||||
.com.apple.timemachine.donotpresent
|
|
||||||
.AppleDB
|
|
||||||
.AppleDesktop
|
|
||||||
Network Trash Folder
|
|
||||||
Temporary Items
|
|
||||||
.apdisk
|
|
||||||
@@ -1,54 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_package_batch, run_upload} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch([
|
|
||||||
'service-common',
|
|
||||||
'service-dependencies',
|
|
||||||
'service-configuration',
|
|
||||||
'service-forest',
|
|
||||||
'service-cli',
|
|
||||||
'service-cli/service-cli-core',
|
|
||||||
'service-executor',
|
|
||||||
'service-executor/service-executor-core',
|
|
||||||
'utils/executor',
|
|
||||||
])
|
|
||||||
await run_package_batch([
|
|
||||||
'service-api',
|
|
||||||
'service-check',
|
|
||||||
'service-cli/service-cli-runner',
|
|
||||||
'service-cloud-query',
|
|
||||||
'service-executor/service-executor-manager',
|
|
||||||
'service-executor/service-executor-task',
|
|
||||||
'service-command',
|
|
||||||
'service-command-pro',
|
|
||||||
'service-exporter',
|
|
||||||
'service-flink-query',
|
|
||||||
'service-gateway',
|
|
||||||
'service-hudi-query',
|
|
||||||
'service-info-query',
|
|
||||||
'service-monitor',
|
|
||||||
'service-loki-query',
|
|
||||||
'service-pulsar-query',
|
|
||||||
'service-queue',
|
|
||||||
'service-scheduler',
|
|
||||||
'service-uploader',
|
|
||||||
'service-web',
|
|
||||||
'service-yarn-query',
|
|
||||||
'service-zookeeper-query',
|
|
||||||
'utils/patch',
|
|
||||||
'utils/sync',
|
|
||||||
])
|
|
||||||
for (const profile of ['b2a4', 'b2b1', 'b2b12']) {
|
|
||||||
await run_package('service-launcher', profile)
|
|
||||||
await run_upload(`**/service-launcher-${profile}-1.0.0-SNAPSHOT.jar`)
|
|
||||||
}
|
|
||||||
await run_upload('**/target/*-1.0.0-SNAPSHOT.jar')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
38
bin/build-all.sh
Executable file
38
bin/build-all.sh
Executable file
@@ -0,0 +1,38 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
mvn install -N -D skipTests
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest service-cli service-cli/service-cli-core service-executor service-executor/service-executor-core utils/executor
|
||||||
|
package service-api service-check service-cli/service-cli-runner service-cloud-query service-executor/service-executor-manager service-executor/service-executor-task service-command service-command-pro service-exporter service-flink-query service-gateway service-hudi-query service-info-query service-monitor service-loki-query service-pulsar-query service-queue service-scheduler service-uploader service-web service-yarn-query service-zookeeper-query utils/patch utils/sync
|
||||||
|
|
||||||
|
configs=(b2a4 b2b1 b2b12)
|
||||||
|
for config in ${configs[*]};
|
||||||
|
do
|
||||||
|
mvn -pl service-launcher clean package -D skipTests -P $config
|
||||||
|
upload $root_path/service-launcher/target/service-launcher-$config-1.0.0-SNAPSHOT.jar
|
||||||
|
done
|
||||||
|
|
||||||
|
upload $root_path/service-api/target/service-api-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-check/target/service-check-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-cloud-query/target/service-cloud-query-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-command/target/service-command-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-command-pro/target/service-command-pro-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-executor/service-executor-manager/target/service-executor-manager-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-executor/service-executor-task/target/service-executor-task-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-exporter/target/service-exporter-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-flink-query/target/service-flink-query-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-gateway/target/service-gateway-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-hudi-query/target/service-hudi-query-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-info-query/target/service-info-query-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-loki-query/target/service-loki-query-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-monitor/target/service-monitor-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-pulsar-query/target/service-pulsar-query-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-queue/target/service-queue-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-scheduler/target/service-scheduler-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-web/target/service-web-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-yarn-query/target/service-yarn-query-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-zookeeper-query/target/service-zookeeper-query-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/utils/sync/target/sync-1.0.0-SNAPSHOT.jar
|
||||||
|
|
||||||
|
upload $root_path/service-cli/service-cli-runner/target/service-cli-runner-1.0.0-SNAPSHOT.jar
|
||||||
|
upload $root_path/service-uploader/target/service-uploader-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-api')
|
|
||||||
await run_upload_normal('service-api')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-api.sh
Executable file
6
bin/build-api.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-api
|
||||||
|
upload $root_path/service-api/target/service-api-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-check')
|
|
||||||
await run_upload_normal('service-check')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-check.sh
Executable file
6
bin/build-check.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-check
|
||||||
|
upload $root_path/service-check/target/service-check-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-cli', 'service-cli/service-cli-core'])
|
|
||||||
await run_package('service-cli/service-cli-runner')
|
|
||||||
await run_upload_normal('service-cli-runner', 'service-cli')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-cli.sh
Executable file
6
bin/build-cli.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-cli service-cli/service-cli-core
|
||||||
|
package service-cli/service-cli-runner
|
||||||
|
upload $root_path/service-cli/service-cli-runner/target/service-cli-runner-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-cloud-query')
|
|
||||||
await run_upload_normal('service-cloud-query')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-cloud-query.sh
Executable file
6
bin/build-cloud-query.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-cloud-query
|
||||||
|
upload $root_path/service-cloud-query/target/service-cloud-query-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-command-pro')
|
|
||||||
await run_upload_normal('service-command-pro')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-command-pro.sh
Executable file
6
bin/build-command-pro.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-command-pro
|
||||||
|
upload $root_path/service-command-pro/target/service-command-pro-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-command')
|
|
||||||
await run_upload_normal('service-command')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-command.sh
Executable file
6
bin/build-command.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-command
|
||||||
|
upload $root_path/service-command/target/service-command-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest', 'service-executor', 'service-executor/service-executor-core'])
|
|
||||||
await run_package('service-executor/service-executor-manager')
|
|
||||||
await run_upload_normal('service-executor-manager', 'service-executor')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-executor-manager.sh
Executable file
6
bin/build-executor-manager.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest service-executor service-executor/service-executor-core
|
||||||
|
package service-executor/service-executor-manager
|
||||||
|
upload $root_path/service-executor/service-executor-manager/target/service-executor-manager-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest', 'service-executor', 'service-executor/service-executor-core'])
|
|
||||||
await run_package('service-executor/service-executor-task')
|
|
||||||
await run_upload_normal('service-executor-task', 'service-executor')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-executor-task.sh
Executable file
6
bin/build-executor-task.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest service-executor service-executor/service-executor-core
|
||||||
|
package service-executor/service-executor-task
|
||||||
|
upload $root_path/service-executor/service-executor-task/target/service-executor-task-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-exporter')
|
|
||||||
await run_upload_normal('service-exporter')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-exporter.sh
Executable file
6
bin/build-exporter.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-exporter
|
||||||
|
upload $root_path/service-exporter/target/service-exporter-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-flink-query')
|
|
||||||
await run_upload_normal('service-flink-query')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-flink-query.sh
Executable file
6
bin/build-flink-query.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-flink-query
|
||||||
|
upload $root_path/service-flink-query/target/service-flink-query-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-gateway')
|
|
||||||
await run_upload_normal('service-gateway')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-gateway.sh
Executable file
6
bin/build-gateway.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-gateway
|
||||||
|
upload $root_path/service-gateway/target/service-gateway-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-hudi-query')
|
|
||||||
await run_upload_normal('service-hudi-query')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-hudi-query.sh
Executable file
6
bin/build-hudi-query.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-hudi-query
|
||||||
|
upload $root_path/service-hudi-query/target/service-hudi-query-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-info-query')
|
|
||||||
await run_upload_normal('service-info-query')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-info-query.sh
Executable file
6
bin/build-info-query.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-info-query
|
||||||
|
upload $root_path/service-info-query/target/service-info-query-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,17 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
for (const profile of ['b2a4', 'b2b1', 'b2b12']) {
|
|
||||||
await run_package('service-launcher', profile)
|
|
||||||
await run_upload(`**/service-launcher-${profile}-1.0.0-SNAPSHOT.jar`)
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
11
bin/build-launcher.sh
Executable file
11
bin/build-launcher.sh
Executable file
@@ -0,0 +1,11 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
|
||||||
|
configs=(b2a4 b2b1 b2b12)
|
||||||
|
for config in ${configs[*]};
|
||||||
|
do
|
||||||
|
mvn -pl service-launcher clean package -D skipTests -P $config
|
||||||
|
upload $root_path/service-launcher/target/service-launcher-$config-1.0.0-SNAPSHOT.jar
|
||||||
|
done
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-loki-query')
|
|
||||||
await run_upload_normal('service-loki-query')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-loki-query.sh
Executable file
6
bin/build-loki-query.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-loki-query
|
||||||
|
upload $root_path/service-loki-query/target/service-loki-query-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-monitor')
|
|
||||||
await run_upload_normal('service-monitor')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-monitor.sh
Executable file
6
bin/build-monitor.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-monitor
|
||||||
|
upload $root_path/service-monitor/target/service-monitor-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common'])
|
|
||||||
await run_package('utils/patch')
|
|
||||||
await run_upload_normal('**/patch-1.0.0-SNAPSHOT.jar')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-patch.sh
Executable file
6
bin/build-patch.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package utils/patch
|
||||||
|
upload $root_path/utils/patch/target/patch-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-pulsar-query')
|
|
||||||
await run_upload_normal('service-pulsar-query')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-pulsar-query.sh
Executable file
6
bin/build-pulsar-query.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-pulsar-query
|
||||||
|
upload $root_path/service-pulsar-query/target/service-pulsar-query-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-queue')
|
|
||||||
await run_upload_normal('service-queue')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-queue.sh
Executable file
6
bin/build-queue.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-queue
|
||||||
|
upload $root_path/service-queue/target/service-queue-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-scheduler')
|
|
||||||
await run_upload_normal('service-scheduler')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-scheduler.sh
Executable file
6
bin/build-scheduler.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-scheduler
|
||||||
|
upload $root_path/service-scheduler/target/service-scheduler-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'utils/patch'])
|
|
||||||
await run_package('utils/sync')
|
|
||||||
await run_upload('**/sync-1.0.0-SNAPSHOT.jar')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-sync.sh
Executable file
6
bin/build-sync.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest utils/patch
|
||||||
|
package utils/sync
|
||||||
|
upload $root_path/utils/sync/target/sync-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-uploader')
|
|
||||||
await run_upload_normal('service-uploader')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-uploader.sh
Executable file
6
bin/build-uploader.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-uploader
|
||||||
|
ytp-transfer2 $root_path/service-uploader/target/service-uploader-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-web')
|
|
||||||
await run_upload_normal('service-web')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-web.sh
Executable file
6
bin/build-web.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-web
|
||||||
|
upload $root_path/service-web/target/service-web-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-yarn-query')
|
|
||||||
await run_upload_normal('service-yarn-query')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-yarn-query.sh
Executable file
6
bin/build-yarn-query.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-yarn-query
|
||||||
|
upload $root_path/service-yarn-query/target/service-yarn-query-1.0.0-SNAPSHOT.jar
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy_batch, run_deploy_root, run_package, run_upload_normal} from "./library.js";
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy_root()
|
|
||||||
await run_deploy_batch(['service-common', 'service-dependencies', 'service-configuration', 'service-forest'])
|
|
||||||
await run_package('service-zookeeper-query')
|
|
||||||
await run_upload_normal('service-zookeeper-query')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
6
bin/build-zookeeper-query.sh
Executable file
6
bin/build-zookeeper-query.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
root_path=$(dirname $(cd $(dirname $0);pwd))
|
||||||
|
source $root_path/bin/library.sh
|
||||||
|
deploy service-common service-dependencies service-configuration service-forest
|
||||||
|
package service-zookeeper-query
|
||||||
|
upload $root_path/service-zookeeper-query/target/service-zookeeper-query-1.0.0-SNAPSHOT.jar
|
||||||
102
bin/library.js
102
bin/library.js
@@ -1,102 +0,0 @@
|
|||||||
import {$, fetch, fs, glob, os, path, spinner, syncProcessCwd, usePowerShell} from 'zx'
|
|
||||||
import {isEqual, trim} from "licia";
|
|
||||||
|
|
||||||
syncProcessCwd(true)
|
|
||||||
if (isEqual(os.platform(), 'win32')) {
|
|
||||||
usePowerShell()
|
|
||||||
}
|
|
||||||
|
|
||||||
const maven_setting = '/Users/lanyuanxiaoyao/.m2/settings-nas.xml'
|
|
||||||
|
|
||||||
const upload_url = 'http://132.126.207.124:36800'
|
|
||||||
const upload_username = 'AxhEbscwsJDbYMH2'
|
|
||||||
const upload_password = 'cYxg3b4PtWoVD5SjFayWxtnSVsjzRsg4'
|
|
||||||
|
|
||||||
const millisecondToString = (timestamp) => {
|
|
||||||
const totalSeconds = Math.floor(parseFloat(timestamp) / 1000)
|
|
||||||
if (isNaN(totalSeconds) || totalSeconds < 0) {
|
|
||||||
return "0秒";
|
|
||||||
}
|
|
||||||
|
|
||||||
const days = Math.floor(totalSeconds / 86400)
|
|
||||||
let remaining = totalSeconds % 86400
|
|
||||||
const hours = Math.floor(remaining / 3600)
|
|
||||||
remaining %= 3600
|
|
||||||
const minutes = Math.floor(remaining / 60)
|
|
||||||
const seconds = remaining % 60
|
|
||||||
|
|
||||||
const parts = []
|
|
||||||
if (days > 0) parts.push(`${days}天`)
|
|
||||||
if (days > 0 || hours > 0) parts.push(`${hours}小时`)
|
|
||||||
if (days > 0 || hours > 0 || minutes > 0) parts.push(`${minutes}分钟`)
|
|
||||||
parts.push(`${seconds}秒`)
|
|
||||||
|
|
||||||
return parts.join('')
|
|
||||||
}
|
|
||||||
|
|
||||||
export const run_deploy = async (project) => {
|
|
||||||
let output = await spinner(
|
|
||||||
`Deploying project ${project}`,
|
|
||||||
() => $`mvn -pl ${project} clean deploy -D skipTests -s ${maven_setting}`
|
|
||||||
)
|
|
||||||
console.log(`✅ Finish deploy ${project} (${millisecondToString(output['duration'])})`)
|
|
||||||
}
|
|
||||||
|
|
||||||
export const run_deploy_root = async () => {
|
|
||||||
let output = await spinner(
|
|
||||||
`Deploying root`,
|
|
||||||
() => $`mvn clean deploy -N -D skipTests -s ${maven_setting}`
|
|
||||||
)
|
|
||||||
console.log(`✅ Finish deploy root (${millisecondToString(output['duration'])})`)
|
|
||||||
}
|
|
||||||
|
|
||||||
export const run_deploy_batch = async (projects) => {
|
|
||||||
for (const project of projects) {
|
|
||||||
await run_deploy(project)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export const run_package = async (project, profile = 'b2b12') => {
|
|
||||||
let output = await spinner(
|
|
||||||
`Packaging project ${project}${isEqual(profile, 'b2b12') ? '' : ` ${profile}`}`,
|
|
||||||
() => $`mvn -pl ${project} clean package -D skipTests -P ${profile} -s ${maven_setting}`
|
|
||||||
)
|
|
||||||
console.log(`✅ Finish package ${project}${isEqual(profile, 'b2b12') ? '' : ` ${profile}`} (${millisecondToString(output['duration'])})`)
|
|
||||||
}
|
|
||||||
|
|
||||||
export const run_package_batch = async (projects) => {
|
|
||||||
for (const project of projects) {
|
|
||||||
await run_package(project)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const upload = async (file_path) => {
|
|
||||||
let response = await spinner(
|
|
||||||
`Uploading project ${file_path}`,
|
|
||||||
() => fetch(`${upload_url}/file/upload/${path.basename(file_path)}`, {
|
|
||||||
method: 'POST',
|
|
||||||
headers: {
|
|
||||||
'Content-Type': 'application/octet-stream',
|
|
||||||
'Authorization': `Basic ${Buffer.from(`${upload_username}:${upload_password}`).toString('base64')}`,
|
|
||||||
},
|
|
||||||
body: fs.createReadStream(file_path),
|
|
||||||
duplex: 'half',
|
|
||||||
})
|
|
||||||
)
|
|
||||||
|
|
||||||
if (!isEqual(response.status, 200)) {
|
|
||||||
throw response
|
|
||||||
}
|
|
||||||
console.log(`✅ Finish upload ${file_path}`)
|
|
||||||
fs.rmSync(file_path)
|
|
||||||
}
|
|
||||||
|
|
||||||
export const run_upload = async (pattern) => {
|
|
||||||
for (let p of glob.sync(pattern)) {
|
|
||||||
await upload(path.join(trim($.sync`pwd`.text()), p))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export const run_upload_normal = async (project) => {
|
|
||||||
await run_upload(`${project}/target/${project}-1.0.0-SNAPSHOT.jar`)
|
|
||||||
}
|
|
||||||
@@ -1,7 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
maven_setting=/Users/lanyuanxiaoyao/.m2/settings-nas.xml
|
|
||||||
|
|
||||||
build_profile=b2b12
|
build_profile=b2b12
|
||||||
|
|
||||||
upload_username=AxhEbscwsJDbYMH2
|
upload_username=AxhEbscwsJDbYMH2
|
||||||
@@ -29,14 +27,10 @@ function joining {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
function deploy_root() {
|
|
||||||
mvn deploy -N -D skipTests -s $maven_setting
|
|
||||||
}
|
|
||||||
|
|
||||||
function deploy() {
|
function deploy() {
|
||||||
mvn -pl $(joining , $@) clean deploy -D skipTests -s $maven_setting
|
mvn -pl $(joining , $@) clean install -D skipTests
|
||||||
}
|
}
|
||||||
|
|
||||||
function package() {
|
function package() {
|
||||||
mvn -pl $(joining , $@) clean package -D skipTests -P $build_profile -s $maven_setting
|
mvn -pl $(joining , $@) clean package -D skipTests -P $build_profile
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,18 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "bin",
|
|
||||||
"version": "1.0.0",
|
|
||||||
"type": "module",
|
|
||||||
"dependencies": {
|
|
||||||
"@webpod/ps": "^0.1.1",
|
|
||||||
"chalk": "^5.4.1",
|
|
||||||
"envapi": "^0.2.3",
|
|
||||||
"fs-extra": "^11.3.0",
|
|
||||||
"globby": "^14.1.0",
|
|
||||||
"licia": "^1.48.0",
|
|
||||||
"minimist": "^1.2.8",
|
|
||||||
"node-fetch-native": "^1.6.6",
|
|
||||||
"which": "^5.0.0",
|
|
||||||
"yaml": "^2.8.0",
|
|
||||||
"zx": "^8.5.4"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
327
bin/pnpm-lock.yaml
generated
327
bin/pnpm-lock.yaml
generated
@@ -1,327 +0,0 @@
|
|||||||
lockfileVersion: '9.0'
|
|
||||||
|
|
||||||
settings:
|
|
||||||
autoInstallPeers: true
|
|
||||||
excludeLinksFromLockfile: false
|
|
||||||
|
|
||||||
importers:
|
|
||||||
|
|
||||||
.:
|
|
||||||
dependencies:
|
|
||||||
'@webpod/ps':
|
|
||||||
specifier: ^0.1.1
|
|
||||||
version: 0.1.1
|
|
||||||
chalk:
|
|
||||||
specifier: ^5.4.1
|
|
||||||
version: 5.4.1
|
|
||||||
envapi:
|
|
||||||
specifier: ^0.2.3
|
|
||||||
version: 0.2.3
|
|
||||||
fs-extra:
|
|
||||||
specifier: ^11.3.0
|
|
||||||
version: 11.3.0
|
|
||||||
globby:
|
|
||||||
specifier: ^14.1.0
|
|
||||||
version: 14.1.0
|
|
||||||
licia:
|
|
||||||
specifier: ^1.48.0
|
|
||||||
version: 1.48.0
|
|
||||||
minimist:
|
|
||||||
specifier: ^1.2.8
|
|
||||||
version: 1.2.8
|
|
||||||
node-fetch-native:
|
|
||||||
specifier: ^1.6.6
|
|
||||||
version: 1.6.6
|
|
||||||
which:
|
|
||||||
specifier: ^5.0.0
|
|
||||||
version: 5.0.0
|
|
||||||
yaml:
|
|
||||||
specifier: ^2.8.0
|
|
||||||
version: 2.8.0
|
|
||||||
zx:
|
|
||||||
specifier: ^8.5.4
|
|
||||||
version: 8.5.4
|
|
||||||
|
|
||||||
packages:
|
|
||||||
|
|
||||||
'@nodelib/fs.scandir@2.1.5':
|
|
||||||
resolution: {integrity: sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==}
|
|
||||||
engines: {node: '>= 8'}
|
|
||||||
|
|
||||||
'@nodelib/fs.stat@2.0.5':
|
|
||||||
resolution: {integrity: sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==}
|
|
||||||
engines: {node: '>= 8'}
|
|
||||||
|
|
||||||
'@nodelib/fs.walk@1.2.8':
|
|
||||||
resolution: {integrity: sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==}
|
|
||||||
engines: {node: '>= 8'}
|
|
||||||
|
|
||||||
'@sindresorhus/merge-streams@2.3.0':
|
|
||||||
resolution: {integrity: sha512-LtoMMhxAlorcGhmFYI+LhPgbPZCkgP6ra1YL604EeF6U98pLlQ3iWIGMdWSC+vWmPBWBNgmDBAhnAobLROJmwg==}
|
|
||||||
engines: {node: '>=18'}
|
|
||||||
|
|
||||||
'@webpod/ingrid@0.0.0-beta.3':
|
|
||||||
resolution: {integrity: sha512-PkorwT+q/MiIF+It47ORX0wCYHumOeMKwp5KX5WbUvbCeOtSB6b5UUC5FvzlijdwK/YPR+sOitQzyVSsRrMmJA==}
|
|
||||||
|
|
||||||
'@webpod/ps@0.1.1':
|
|
||||||
resolution: {integrity: sha512-SIgb4wWEVlKgdRByMMz9c3y1hpKfNm2sbretCPD49O9LG6itibULMkiRISdkpMdGRiUpbGHp8tiN3ZLYRDHj1g==}
|
|
||||||
|
|
||||||
braces@3.0.3:
|
|
||||||
resolution: {integrity: sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==}
|
|
||||||
engines: {node: '>=8'}
|
|
||||||
|
|
||||||
chalk@5.4.1:
|
|
||||||
resolution: {integrity: sha512-zgVZuo2WcZgfUEmsn6eO3kINexW8RAE4maiQ8QNs8CtpPCSyMiYsULR3HQYkm3w8FIA3SberyMJMSldGsW+U3w==}
|
|
||||||
engines: {node: ^12.17.0 || ^14.13 || >=16.0.0}
|
|
||||||
|
|
||||||
envapi@0.2.3:
|
|
||||||
resolution: {integrity: sha512-kSPSecU+/eH0IajEYZ/LndeBjzSBmLyp/SZFgx8Zgyeu0SoGioHkICOOVJgJLaX/rqZrCrQ+eDxiaYNVcyCsbQ==}
|
|
||||||
|
|
||||||
fast-glob@3.3.3:
|
|
||||||
resolution: {integrity: sha512-7MptL8U0cqcFdzIzwOTHoilX9x5BrNqye7Z/LuC7kCMRio1EMSyqRK3BEAUD7sXRq4iT4AzTVuZdhgQ2TCvYLg==}
|
|
||||||
engines: {node: '>=8.6.0'}
|
|
||||||
|
|
||||||
fastq@1.19.1:
|
|
||||||
resolution: {integrity: sha512-GwLTyxkCXjXbxqIhTsMI2Nui8huMPtnxg7krajPJAjnEG/iiOS7i+zCtWGZR9G0NBKbXKh6X9m9UIsYX/N6vvQ==}
|
|
||||||
|
|
||||||
fill-range@7.1.1:
|
|
||||||
resolution: {integrity: sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==}
|
|
||||||
engines: {node: '>=8'}
|
|
||||||
|
|
||||||
fs-extra@11.3.0:
|
|
||||||
resolution: {integrity: sha512-Z4XaCL6dUDHfP/jT25jJKMmtxvuwbkrD1vNSMFlo9lNLY2c5FHYSQgHPRZUjAB26TpDEoW9HCOgplrdbaPV/ew==}
|
|
||||||
engines: {node: '>=14.14'}
|
|
||||||
|
|
||||||
glob-parent@5.1.2:
|
|
||||||
resolution: {integrity: sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==}
|
|
||||||
engines: {node: '>= 6'}
|
|
||||||
|
|
||||||
globby@14.1.0:
|
|
||||||
resolution: {integrity: sha512-0Ia46fDOaT7k4og1PDW4YbodWWr3scS2vAr2lTbsplOt2WkKp0vQbkI9wKis/T5LV/dqPjO3bpS/z6GTJB82LA==}
|
|
||||||
engines: {node: '>=18'}
|
|
||||||
|
|
||||||
graceful-fs@4.2.11:
|
|
||||||
resolution: {integrity: sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==}
|
|
||||||
|
|
||||||
ignore@7.0.4:
|
|
||||||
resolution: {integrity: sha512-gJzzk+PQNznz8ysRrC0aOkBNVRBDtE1n53IqyqEf3PXrYwomFs5q4pGMizBMJF+ykh03insJ27hB8gSrD2Hn8A==}
|
|
||||||
engines: {node: '>= 4'}
|
|
||||||
|
|
||||||
is-extglob@2.1.1:
|
|
||||||
resolution: {integrity: sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==}
|
|
||||||
engines: {node: '>=0.10.0'}
|
|
||||||
|
|
||||||
is-glob@4.0.3:
|
|
||||||
resolution: {integrity: sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==}
|
|
||||||
engines: {node: '>=0.10.0'}
|
|
||||||
|
|
||||||
is-number@7.0.0:
|
|
||||||
resolution: {integrity: sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==}
|
|
||||||
engines: {node: '>=0.12.0'}
|
|
||||||
|
|
||||||
isexe@3.1.1:
|
|
||||||
resolution: {integrity: sha512-LpB/54B+/2J5hqQ7imZHfdU31OlgQqx7ZicVlkm9kzg9/w8GKLEcFfJl/t7DCEDueOyBAD6zCCwTO6Fzs0NoEQ==}
|
|
||||||
engines: {node: '>=16'}
|
|
||||||
|
|
||||||
jsonfile@6.1.0:
|
|
||||||
resolution: {integrity: sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==}
|
|
||||||
|
|
||||||
licia@1.48.0:
|
|
||||||
resolution: {integrity: sha512-bBWiT5CSdEtwuAHiYTJ74yItCjIFdHi4xiFk6BRDfKa+sdCpkUHp69YKb5udNOJlHDzFjNjcMgNZ/+wQIHrB8A==}
|
|
||||||
|
|
||||||
merge2@1.4.1:
|
|
||||||
resolution: {integrity: sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==}
|
|
||||||
engines: {node: '>= 8'}
|
|
||||||
|
|
||||||
micromatch@4.0.8:
|
|
||||||
resolution: {integrity: sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA==}
|
|
||||||
engines: {node: '>=8.6'}
|
|
||||||
|
|
||||||
minimist@1.2.8:
|
|
||||||
resolution: {integrity: sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==}
|
|
||||||
|
|
||||||
node-fetch-native@1.6.6:
|
|
||||||
resolution: {integrity: sha512-8Mc2HhqPdlIfedsuZoc3yioPuzp6b+L5jRCRY1QzuWZh2EGJVQrGppC6V6cF0bLdbW0+O2YpqCA25aF/1lvipQ==}
|
|
||||||
|
|
||||||
path-type@6.0.0:
|
|
||||||
resolution: {integrity: sha512-Vj7sf++t5pBD637NSfkxpHSMfWaeig5+DKWLhcqIYx6mWQz5hdJTGDVMQiJcw1ZYkhs7AazKDGpRVji1LJCZUQ==}
|
|
||||||
engines: {node: '>=18'}
|
|
||||||
|
|
||||||
picomatch@2.3.1:
|
|
||||||
resolution: {integrity: sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==}
|
|
||||||
engines: {node: '>=8.6'}
|
|
||||||
|
|
||||||
queue-microtask@1.2.3:
|
|
||||||
resolution: {integrity: sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==}
|
|
||||||
|
|
||||||
reusify@1.1.0:
|
|
||||||
resolution: {integrity: sha512-g6QUff04oZpHs0eG5p83rFLhHeV00ug/Yf9nZM6fLeUrPguBTkTQOdpAWWspMh55TZfVQDPaN3NQJfbVRAxdIw==}
|
|
||||||
engines: {iojs: '>=1.0.0', node: '>=0.10.0'}
|
|
||||||
|
|
||||||
run-parallel@1.2.0:
|
|
||||||
resolution: {integrity: sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==}
|
|
||||||
|
|
||||||
slash@5.1.0:
|
|
||||||
resolution: {integrity: sha512-ZA6oR3T/pEyuqwMgAKT0/hAv8oAXckzbkmR0UkUosQ+Mc4RxGoJkRmwHgHufaenlyAgE1Mxgpdcrf75y6XcnDg==}
|
|
||||||
engines: {node: '>=14.16'}
|
|
||||||
|
|
||||||
to-regex-range@5.0.1:
|
|
||||||
resolution: {integrity: sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==}
|
|
||||||
engines: {node: '>=8.0'}
|
|
||||||
|
|
||||||
unicorn-magic@0.3.0:
|
|
||||||
resolution: {integrity: sha512-+QBBXBCvifc56fsbuxZQ6Sic3wqqc3WWaqxs58gvJrcOuN83HGTCwz3oS5phzU9LthRNE9VrJCFCLUgHeeFnfA==}
|
|
||||||
engines: {node: '>=18'}
|
|
||||||
|
|
||||||
universalify@2.0.1:
|
|
||||||
resolution: {integrity: sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==}
|
|
||||||
engines: {node: '>= 10.0.0'}
|
|
||||||
|
|
||||||
which@5.0.0:
|
|
||||||
resolution: {integrity: sha512-JEdGzHwwkrbWoGOlIHqQ5gtprKGOenpDHpxE9zVR1bWbOtYRyPPHMe9FaP6x61CmNaTThSkb0DAJte5jD+DmzQ==}
|
|
||||||
engines: {node: ^18.17.0 || >=20.5.0}
|
|
||||||
hasBin: true
|
|
||||||
|
|
||||||
yaml@2.8.0:
|
|
||||||
resolution: {integrity: sha512-4lLa/EcQCB0cJkyts+FpIRx5G/llPxfP6VQU5KByHEhLxY3IJCH0f0Hy1MHI8sClTvsIb8qwRJ6R/ZdlDJ/leQ==}
|
|
||||||
engines: {node: '>= 14.6'}
|
|
||||||
hasBin: true
|
|
||||||
|
|
||||||
zurk@0.11.2:
|
|
||||||
resolution: {integrity: sha512-OKUQsmG588B18hzO4ThzOU0NUwr4C8aKl9NjGQfXUv5fskLfS6Sj3XGNbTzKj3d2+jWvmnqS2cgrwYX6bIkDyA==}
|
|
||||||
|
|
||||||
zx@8.5.4:
|
|
||||||
resolution: {integrity: sha512-44oKea9Sa8ZnOkTnS6fRJpg3quzgnbB43nLrVfYnqE86J4sxgZMUDLezzKET/FdOAVkF4X+Alm9Bume+W+RW9Q==}
|
|
||||||
engines: {node: '>= 12.17.0'}
|
|
||||||
hasBin: true
|
|
||||||
|
|
||||||
snapshots:
|
|
||||||
|
|
||||||
'@nodelib/fs.scandir@2.1.5':
|
|
||||||
dependencies:
|
|
||||||
'@nodelib/fs.stat': 2.0.5
|
|
||||||
run-parallel: 1.2.0
|
|
||||||
|
|
||||||
'@nodelib/fs.stat@2.0.5': {}
|
|
||||||
|
|
||||||
'@nodelib/fs.walk@1.2.8':
|
|
||||||
dependencies:
|
|
||||||
'@nodelib/fs.scandir': 2.1.5
|
|
||||||
fastq: 1.19.1
|
|
||||||
|
|
||||||
'@sindresorhus/merge-streams@2.3.0': {}
|
|
||||||
|
|
||||||
'@webpod/ingrid@0.0.0-beta.3': {}
|
|
||||||
|
|
||||||
'@webpod/ps@0.1.1':
|
|
||||||
dependencies:
|
|
||||||
'@webpod/ingrid': 0.0.0-beta.3
|
|
||||||
zurk: 0.11.2
|
|
||||||
|
|
||||||
braces@3.0.3:
|
|
||||||
dependencies:
|
|
||||||
fill-range: 7.1.1
|
|
||||||
|
|
||||||
chalk@5.4.1: {}
|
|
||||||
|
|
||||||
envapi@0.2.3: {}
|
|
||||||
|
|
||||||
fast-glob@3.3.3:
|
|
||||||
dependencies:
|
|
||||||
'@nodelib/fs.stat': 2.0.5
|
|
||||||
'@nodelib/fs.walk': 1.2.8
|
|
||||||
glob-parent: 5.1.2
|
|
||||||
merge2: 1.4.1
|
|
||||||
micromatch: 4.0.8
|
|
||||||
|
|
||||||
fastq@1.19.1:
|
|
||||||
dependencies:
|
|
||||||
reusify: 1.1.0
|
|
||||||
|
|
||||||
fill-range@7.1.1:
|
|
||||||
dependencies:
|
|
||||||
to-regex-range: 5.0.1
|
|
||||||
|
|
||||||
fs-extra@11.3.0:
|
|
||||||
dependencies:
|
|
||||||
graceful-fs: 4.2.11
|
|
||||||
jsonfile: 6.1.0
|
|
||||||
universalify: 2.0.1
|
|
||||||
|
|
||||||
glob-parent@5.1.2:
|
|
||||||
dependencies:
|
|
||||||
is-glob: 4.0.3
|
|
||||||
|
|
||||||
globby@14.1.0:
|
|
||||||
dependencies:
|
|
||||||
'@sindresorhus/merge-streams': 2.3.0
|
|
||||||
fast-glob: 3.3.3
|
|
||||||
ignore: 7.0.4
|
|
||||||
path-type: 6.0.0
|
|
||||||
slash: 5.1.0
|
|
||||||
unicorn-magic: 0.3.0
|
|
||||||
|
|
||||||
graceful-fs@4.2.11: {}
|
|
||||||
|
|
||||||
ignore@7.0.4: {}
|
|
||||||
|
|
||||||
is-extglob@2.1.1: {}
|
|
||||||
|
|
||||||
is-glob@4.0.3:
|
|
||||||
dependencies:
|
|
||||||
is-extglob: 2.1.1
|
|
||||||
|
|
||||||
is-number@7.0.0: {}
|
|
||||||
|
|
||||||
isexe@3.1.1: {}
|
|
||||||
|
|
||||||
jsonfile@6.1.0:
|
|
||||||
dependencies:
|
|
||||||
universalify: 2.0.1
|
|
||||||
optionalDependencies:
|
|
||||||
graceful-fs: 4.2.11
|
|
||||||
|
|
||||||
licia@1.48.0: {}
|
|
||||||
|
|
||||||
merge2@1.4.1: {}
|
|
||||||
|
|
||||||
micromatch@4.0.8:
|
|
||||||
dependencies:
|
|
||||||
braces: 3.0.3
|
|
||||||
picomatch: 2.3.1
|
|
||||||
|
|
||||||
minimist@1.2.8: {}
|
|
||||||
|
|
||||||
node-fetch-native@1.6.6: {}
|
|
||||||
|
|
||||||
path-type@6.0.0: {}
|
|
||||||
|
|
||||||
picomatch@2.3.1: {}
|
|
||||||
|
|
||||||
queue-microtask@1.2.3: {}
|
|
||||||
|
|
||||||
reusify@1.1.0: {}
|
|
||||||
|
|
||||||
run-parallel@1.2.0:
|
|
||||||
dependencies:
|
|
||||||
queue-microtask: 1.2.3
|
|
||||||
|
|
||||||
slash@5.1.0: {}
|
|
||||||
|
|
||||||
to-regex-range@5.0.1:
|
|
||||||
dependencies:
|
|
||||||
is-number: 7.0.0
|
|
||||||
|
|
||||||
unicorn-magic@0.3.0: {}
|
|
||||||
|
|
||||||
universalify@2.0.1: {}
|
|
||||||
|
|
||||||
which@5.0.0:
|
|
||||||
dependencies:
|
|
||||||
isexe: 3.1.1
|
|
||||||
|
|
||||||
yaml@2.8.0: {}
|
|
||||||
|
|
||||||
zurk@0.11.2: {}
|
|
||||||
|
|
||||||
zx@8.5.4: {}
|
|
||||||
2
pom.xml
2
pom.xml
@@ -8,7 +8,7 @@
|
|||||||
<artifactId>hudi-service</artifactId>
|
<artifactId>hudi-service</artifactId>
|
||||||
<version>1.0.0-SNAPSHOT</version>
|
<version>1.0.0-SNAPSHOT</version>
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
<description>Hudi服务应用集合</description>
|
<description>Hudi服务模块系列应用</description>
|
||||||
<modules>
|
<modules>
|
||||||
<module>service-common</module>
|
<module>service-common</module>
|
||||||
<module>service-dependencies</module>
|
<module>service-dependencies</module>
|
||||||
|
|||||||
102
service-ai/bin/.gitignore
vendored
102
service-ai/bin/.gitignore
vendored
@@ -1,102 +0,0 @@
|
|||||||
.vscode/*
|
|
||||||
!.vscode/settings.json
|
|
||||||
!.vscode/tasks.json
|
|
||||||
!.vscode/launch.json
|
|
||||||
!.vscode/extensions.json
|
|
||||||
!.vscode/*.code-snippets
|
|
||||||
.history/
|
|
||||||
*.vsix
|
|
||||||
*~
|
|
||||||
.fuse_hidden*
|
|
||||||
.directory
|
|
||||||
.Trash-*
|
|
||||||
.nfs*
|
|
||||||
logs
|
|
||||||
*.log
|
|
||||||
npm-debug.log*
|
|
||||||
yarn-debug.log*
|
|
||||||
yarn-error.log*
|
|
||||||
lerna-debug.log*
|
|
||||||
.pnpm-debug.log*
|
|
||||||
report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json
|
|
||||||
pids
|
|
||||||
*.pid
|
|
||||||
*.seed
|
|
||||||
*.pid.lock
|
|
||||||
lib-cov
|
|
||||||
coverage
|
|
||||||
*.lcov
|
|
||||||
.nyc_output
|
|
||||||
.grunt
|
|
||||||
bower_components
|
|
||||||
.lock-wscript
|
|
||||||
build/Release
|
|
||||||
node_modules/
|
|
||||||
jspm_packages/
|
|
||||||
web_modules/
|
|
||||||
*.tsbuildinfo
|
|
||||||
.npm
|
|
||||||
.eslintcache
|
|
||||||
.stylelintcache
|
|
||||||
.rpt2_cache/
|
|
||||||
.rts2_cache_cjs/
|
|
||||||
.rts2_cache_es/
|
|
||||||
.rts2_cache_umd/
|
|
||||||
.node_repl_history
|
|
||||||
*.tgz
|
|
||||||
.yarn-integrity
|
|
||||||
.env
|
|
||||||
.env.development.local
|
|
||||||
.env.test.local
|
|
||||||
.env.production.local
|
|
||||||
.env.local
|
|
||||||
.cache
|
|
||||||
.parcel-cache
|
|
||||||
.next
|
|
||||||
out
|
|
||||||
.nuxt
|
|
||||||
dist
|
|
||||||
.cache/
|
|
||||||
.vuepress/dist
|
|
||||||
.temp
|
|
||||||
.docusaurus
|
|
||||||
.serverless/
|
|
||||||
.fusebox/
|
|
||||||
.dynamodb/
|
|
||||||
.tern-port
|
|
||||||
.vscode-test
|
|
||||||
.yarn/cache
|
|
||||||
.yarn/unplugged
|
|
||||||
.yarn/build-state.yml
|
|
||||||
.yarn/install-state.gz
|
|
||||||
.pnp.*
|
|
||||||
Thumbs.db
|
|
||||||
Thumbs.db:encryptable
|
|
||||||
ehthumbs.db
|
|
||||||
ehthumbs_vista.db
|
|
||||||
*.stackdump
|
|
||||||
[Dd]esktop.ini
|
|
||||||
$RECYCLE.BIN/
|
|
||||||
*.cab
|
|
||||||
*.msi
|
|
||||||
*.msix
|
|
||||||
*.msm
|
|
||||||
*.msp
|
|
||||||
*.lnk
|
|
||||||
.DS_Store
|
|
||||||
.AppleDouble
|
|
||||||
.LSOverride
|
|
||||||
Icon
|
|
||||||
._*
|
|
||||||
.DocumentRevisions-V100
|
|
||||||
.fseventsd
|
|
||||||
.Spotlight-V100
|
|
||||||
.TemporaryItems
|
|
||||||
.Trashes
|
|
||||||
.VolumeIcon.icns
|
|
||||||
.com.apple.timemachine.donotpresent
|
|
||||||
.AppleDB
|
|
||||||
.AppleDesktop
|
|
||||||
Network Trash Folder
|
|
||||||
Temporary Items
|
|
||||||
.apdisk
|
|
||||||
@@ -1,14 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy, run_package, run_upload} from '../../bin/library.js'
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy('service-ai-core')
|
|
||||||
await run_package('service-ai-chat')
|
|
||||||
await run_upload('service-ai-chat')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
@@ -1,14 +0,0 @@
|
|||||||
import {cd, path} from 'zx'
|
|
||||||
import {trim} from "licia";
|
|
||||||
import {run_deploy, run_package, run_upload_normal} from '../../bin/library.js'
|
|
||||||
|
|
||||||
// 切换目录
|
|
||||||
cd(trim(path.dirname(import.meta.dirname)))
|
|
||||||
// 执行流程
|
|
||||||
try {
|
|
||||||
await run_deploy('service-ai-core')
|
|
||||||
await run_package('service-ai-knowledge')
|
|
||||||
await run_upload_normal('service-ai-knowledge')
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e)
|
|
||||||
}
|
|
||||||
@@ -1,18 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "bin",
|
|
||||||
"version": "1.0.0",
|
|
||||||
"type": "module",
|
|
||||||
"dependencies": {
|
|
||||||
"@webpod/ps": "^0.1.1",
|
|
||||||
"chalk": "^5.4.1",
|
|
||||||
"envapi": "^0.2.3",
|
|
||||||
"fs-extra": "^11.3.0",
|
|
||||||
"globby": "^14.1.0",
|
|
||||||
"licia": "^1.48.0",
|
|
||||||
"minimist": "^1.2.8",
|
|
||||||
"node-fetch-native": "^1.6.6",
|
|
||||||
"which": "^5.0.0",
|
|
||||||
"yaml": "^2.8.0",
|
|
||||||
"zx": "^8.5.4"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
327
service-ai/bin/pnpm-lock.yaml
generated
327
service-ai/bin/pnpm-lock.yaml
generated
@@ -1,327 +0,0 @@
|
|||||||
lockfileVersion: '9.0'
|
|
||||||
|
|
||||||
settings:
|
|
||||||
autoInstallPeers: true
|
|
||||||
excludeLinksFromLockfile: false
|
|
||||||
|
|
||||||
importers:
|
|
||||||
|
|
||||||
.:
|
|
||||||
dependencies:
|
|
||||||
'@webpod/ps':
|
|
||||||
specifier: ^0.1.1
|
|
||||||
version: 0.1.1
|
|
||||||
chalk:
|
|
||||||
specifier: ^5.4.1
|
|
||||||
version: 5.4.1
|
|
||||||
envapi:
|
|
||||||
specifier: ^0.2.3
|
|
||||||
version: 0.2.3
|
|
||||||
fs-extra:
|
|
||||||
specifier: ^11.3.0
|
|
||||||
version: 11.3.0
|
|
||||||
globby:
|
|
||||||
specifier: ^14.1.0
|
|
||||||
version: 14.1.0
|
|
||||||
licia:
|
|
||||||
specifier: ^1.48.0
|
|
||||||
version: 1.48.0
|
|
||||||
minimist:
|
|
||||||
specifier: ^1.2.8
|
|
||||||
version: 1.2.8
|
|
||||||
node-fetch-native:
|
|
||||||
specifier: ^1.6.6
|
|
||||||
version: 1.6.6
|
|
||||||
which:
|
|
||||||
specifier: ^5.0.0
|
|
||||||
version: 5.0.0
|
|
||||||
yaml:
|
|
||||||
specifier: ^2.8.0
|
|
||||||
version: 2.8.0
|
|
||||||
zx:
|
|
||||||
specifier: ^8.5.4
|
|
||||||
version: 8.5.4
|
|
||||||
|
|
||||||
packages:
|
|
||||||
|
|
||||||
'@nodelib/fs.scandir@2.1.5':
|
|
||||||
resolution: {integrity: sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==}
|
|
||||||
engines: {node: '>= 8'}
|
|
||||||
|
|
||||||
'@nodelib/fs.stat@2.0.5':
|
|
||||||
resolution: {integrity: sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==}
|
|
||||||
engines: {node: '>= 8'}
|
|
||||||
|
|
||||||
'@nodelib/fs.walk@1.2.8':
|
|
||||||
resolution: {integrity: sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==}
|
|
||||||
engines: {node: '>= 8'}
|
|
||||||
|
|
||||||
'@sindresorhus/merge-streams@2.3.0':
|
|
||||||
resolution: {integrity: sha512-LtoMMhxAlorcGhmFYI+LhPgbPZCkgP6ra1YL604EeF6U98pLlQ3iWIGMdWSC+vWmPBWBNgmDBAhnAobLROJmwg==}
|
|
||||||
engines: {node: '>=18'}
|
|
||||||
|
|
||||||
'@webpod/ingrid@0.0.0-beta.3':
|
|
||||||
resolution: {integrity: sha512-PkorwT+q/MiIF+It47ORX0wCYHumOeMKwp5KX5WbUvbCeOtSB6b5UUC5FvzlijdwK/YPR+sOitQzyVSsRrMmJA==}
|
|
||||||
|
|
||||||
'@webpod/ps@0.1.1':
|
|
||||||
resolution: {integrity: sha512-SIgb4wWEVlKgdRByMMz9c3y1hpKfNm2sbretCPD49O9LG6itibULMkiRISdkpMdGRiUpbGHp8tiN3ZLYRDHj1g==}
|
|
||||||
|
|
||||||
braces@3.0.3:
|
|
||||||
resolution: {integrity: sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==}
|
|
||||||
engines: {node: '>=8'}
|
|
||||||
|
|
||||||
chalk@5.4.1:
|
|
||||||
resolution: {integrity: sha512-zgVZuo2WcZgfUEmsn6eO3kINexW8RAE4maiQ8QNs8CtpPCSyMiYsULR3HQYkm3w8FIA3SberyMJMSldGsW+U3w==}
|
|
||||||
engines: {node: ^12.17.0 || ^14.13 || >=16.0.0}
|
|
||||||
|
|
||||||
envapi@0.2.3:
|
|
||||||
resolution: {integrity: sha512-kSPSecU+/eH0IajEYZ/LndeBjzSBmLyp/SZFgx8Zgyeu0SoGioHkICOOVJgJLaX/rqZrCrQ+eDxiaYNVcyCsbQ==}
|
|
||||||
|
|
||||||
fast-glob@3.3.3:
|
|
||||||
resolution: {integrity: sha512-7MptL8U0cqcFdzIzwOTHoilX9x5BrNqye7Z/LuC7kCMRio1EMSyqRK3BEAUD7sXRq4iT4AzTVuZdhgQ2TCvYLg==}
|
|
||||||
engines: {node: '>=8.6.0'}
|
|
||||||
|
|
||||||
fastq@1.19.1:
|
|
||||||
resolution: {integrity: sha512-GwLTyxkCXjXbxqIhTsMI2Nui8huMPtnxg7krajPJAjnEG/iiOS7i+zCtWGZR9G0NBKbXKh6X9m9UIsYX/N6vvQ==}
|
|
||||||
|
|
||||||
fill-range@7.1.1:
|
|
||||||
resolution: {integrity: sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==}
|
|
||||||
engines: {node: '>=8'}
|
|
||||||
|
|
||||||
fs-extra@11.3.0:
|
|
||||||
resolution: {integrity: sha512-Z4XaCL6dUDHfP/jT25jJKMmtxvuwbkrD1vNSMFlo9lNLY2c5FHYSQgHPRZUjAB26TpDEoW9HCOgplrdbaPV/ew==}
|
|
||||||
engines: {node: '>=14.14'}
|
|
||||||
|
|
||||||
glob-parent@5.1.2:
|
|
||||||
resolution: {integrity: sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==}
|
|
||||||
engines: {node: '>= 6'}
|
|
||||||
|
|
||||||
globby@14.1.0:
|
|
||||||
resolution: {integrity: sha512-0Ia46fDOaT7k4og1PDW4YbodWWr3scS2vAr2lTbsplOt2WkKp0vQbkI9wKis/T5LV/dqPjO3bpS/z6GTJB82LA==}
|
|
||||||
engines: {node: '>=18'}
|
|
||||||
|
|
||||||
graceful-fs@4.2.11:
|
|
||||||
resolution: {integrity: sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==}
|
|
||||||
|
|
||||||
ignore@7.0.4:
|
|
||||||
resolution: {integrity: sha512-gJzzk+PQNznz8ysRrC0aOkBNVRBDtE1n53IqyqEf3PXrYwomFs5q4pGMizBMJF+ykh03insJ27hB8gSrD2Hn8A==}
|
|
||||||
engines: {node: '>= 4'}
|
|
||||||
|
|
||||||
is-extglob@2.1.1:
|
|
||||||
resolution: {integrity: sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==}
|
|
||||||
engines: {node: '>=0.10.0'}
|
|
||||||
|
|
||||||
is-glob@4.0.3:
|
|
||||||
resolution: {integrity: sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==}
|
|
||||||
engines: {node: '>=0.10.0'}
|
|
||||||
|
|
||||||
is-number@7.0.0:
|
|
||||||
resolution: {integrity: sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==}
|
|
||||||
engines: {node: '>=0.12.0'}
|
|
||||||
|
|
||||||
isexe@3.1.1:
|
|
||||||
resolution: {integrity: sha512-LpB/54B+/2J5hqQ7imZHfdU31OlgQqx7ZicVlkm9kzg9/w8GKLEcFfJl/t7DCEDueOyBAD6zCCwTO6Fzs0NoEQ==}
|
|
||||||
engines: {node: '>=16'}
|
|
||||||
|
|
||||||
jsonfile@6.1.0:
|
|
||||||
resolution: {integrity: sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==}
|
|
||||||
|
|
||||||
licia@1.48.0:
|
|
||||||
resolution: {integrity: sha512-bBWiT5CSdEtwuAHiYTJ74yItCjIFdHi4xiFk6BRDfKa+sdCpkUHp69YKb5udNOJlHDzFjNjcMgNZ/+wQIHrB8A==}
|
|
||||||
|
|
||||||
merge2@1.4.1:
|
|
||||||
resolution: {integrity: sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==}
|
|
||||||
engines: {node: '>= 8'}
|
|
||||||
|
|
||||||
micromatch@4.0.8:
|
|
||||||
resolution: {integrity: sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA==}
|
|
||||||
engines: {node: '>=8.6'}
|
|
||||||
|
|
||||||
minimist@1.2.8:
|
|
||||||
resolution: {integrity: sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==}
|
|
||||||
|
|
||||||
node-fetch-native@1.6.6:
|
|
||||||
resolution: {integrity: sha512-8Mc2HhqPdlIfedsuZoc3yioPuzp6b+L5jRCRY1QzuWZh2EGJVQrGppC6V6cF0bLdbW0+O2YpqCA25aF/1lvipQ==}
|
|
||||||
|
|
||||||
path-type@6.0.0:
|
|
||||||
resolution: {integrity: sha512-Vj7sf++t5pBD637NSfkxpHSMfWaeig5+DKWLhcqIYx6mWQz5hdJTGDVMQiJcw1ZYkhs7AazKDGpRVji1LJCZUQ==}
|
|
||||||
engines: {node: '>=18'}
|
|
||||||
|
|
||||||
picomatch@2.3.1:
|
|
||||||
resolution: {integrity: sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==}
|
|
||||||
engines: {node: '>=8.6'}
|
|
||||||
|
|
||||||
queue-microtask@1.2.3:
|
|
||||||
resolution: {integrity: sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==}
|
|
||||||
|
|
||||||
reusify@1.1.0:
|
|
||||||
resolution: {integrity: sha512-g6QUff04oZpHs0eG5p83rFLhHeV00ug/Yf9nZM6fLeUrPguBTkTQOdpAWWspMh55TZfVQDPaN3NQJfbVRAxdIw==}
|
|
||||||
engines: {iojs: '>=1.0.0', node: '>=0.10.0'}
|
|
||||||
|
|
||||||
run-parallel@1.2.0:
|
|
||||||
resolution: {integrity: sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==}
|
|
||||||
|
|
||||||
slash@5.1.0:
|
|
||||||
resolution: {integrity: sha512-ZA6oR3T/pEyuqwMgAKT0/hAv8oAXckzbkmR0UkUosQ+Mc4RxGoJkRmwHgHufaenlyAgE1Mxgpdcrf75y6XcnDg==}
|
|
||||||
engines: {node: '>=14.16'}
|
|
||||||
|
|
||||||
to-regex-range@5.0.1:
|
|
||||||
resolution: {integrity: sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==}
|
|
||||||
engines: {node: '>=8.0'}
|
|
||||||
|
|
||||||
unicorn-magic@0.3.0:
|
|
||||||
resolution: {integrity: sha512-+QBBXBCvifc56fsbuxZQ6Sic3wqqc3WWaqxs58gvJrcOuN83HGTCwz3oS5phzU9LthRNE9VrJCFCLUgHeeFnfA==}
|
|
||||||
engines: {node: '>=18'}
|
|
||||||
|
|
||||||
universalify@2.0.1:
|
|
||||||
resolution: {integrity: sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==}
|
|
||||||
engines: {node: '>= 10.0.0'}
|
|
||||||
|
|
||||||
which@5.0.0:
|
|
||||||
resolution: {integrity: sha512-JEdGzHwwkrbWoGOlIHqQ5gtprKGOenpDHpxE9zVR1bWbOtYRyPPHMe9FaP6x61CmNaTThSkb0DAJte5jD+DmzQ==}
|
|
||||||
engines: {node: ^18.17.0 || >=20.5.0}
|
|
||||||
hasBin: true
|
|
||||||
|
|
||||||
yaml@2.8.0:
|
|
||||||
resolution: {integrity: sha512-4lLa/EcQCB0cJkyts+FpIRx5G/llPxfP6VQU5KByHEhLxY3IJCH0f0Hy1MHI8sClTvsIb8qwRJ6R/ZdlDJ/leQ==}
|
|
||||||
engines: {node: '>= 14.6'}
|
|
||||||
hasBin: true
|
|
||||||
|
|
||||||
zurk@0.11.2:
|
|
||||||
resolution: {integrity: sha512-OKUQsmG588B18hzO4ThzOU0NUwr4C8aKl9NjGQfXUv5fskLfS6Sj3XGNbTzKj3d2+jWvmnqS2cgrwYX6bIkDyA==}
|
|
||||||
|
|
||||||
zx@8.5.4:
|
|
||||||
resolution: {integrity: sha512-44oKea9Sa8ZnOkTnS6fRJpg3quzgnbB43nLrVfYnqE86J4sxgZMUDLezzKET/FdOAVkF4X+Alm9Bume+W+RW9Q==}
|
|
||||||
engines: {node: '>= 12.17.0'}
|
|
||||||
hasBin: true
|
|
||||||
|
|
||||||
snapshots:
|
|
||||||
|
|
||||||
'@nodelib/fs.scandir@2.1.5':
|
|
||||||
dependencies:
|
|
||||||
'@nodelib/fs.stat': 2.0.5
|
|
||||||
run-parallel: 1.2.0
|
|
||||||
|
|
||||||
'@nodelib/fs.stat@2.0.5': {}
|
|
||||||
|
|
||||||
'@nodelib/fs.walk@1.2.8':
|
|
||||||
dependencies:
|
|
||||||
'@nodelib/fs.scandir': 2.1.5
|
|
||||||
fastq: 1.19.1
|
|
||||||
|
|
||||||
'@sindresorhus/merge-streams@2.3.0': {}
|
|
||||||
|
|
||||||
'@webpod/ingrid@0.0.0-beta.3': {}
|
|
||||||
|
|
||||||
'@webpod/ps@0.1.1':
|
|
||||||
dependencies:
|
|
||||||
'@webpod/ingrid': 0.0.0-beta.3
|
|
||||||
zurk: 0.11.2
|
|
||||||
|
|
||||||
braces@3.0.3:
|
|
||||||
dependencies:
|
|
||||||
fill-range: 7.1.1
|
|
||||||
|
|
||||||
chalk@5.4.1: {}
|
|
||||||
|
|
||||||
envapi@0.2.3: {}
|
|
||||||
|
|
||||||
fast-glob@3.3.3:
|
|
||||||
dependencies:
|
|
||||||
'@nodelib/fs.stat': 2.0.5
|
|
||||||
'@nodelib/fs.walk': 1.2.8
|
|
||||||
glob-parent: 5.1.2
|
|
||||||
merge2: 1.4.1
|
|
||||||
micromatch: 4.0.8
|
|
||||||
|
|
||||||
fastq@1.19.1:
|
|
||||||
dependencies:
|
|
||||||
reusify: 1.1.0
|
|
||||||
|
|
||||||
fill-range@7.1.1:
|
|
||||||
dependencies:
|
|
||||||
to-regex-range: 5.0.1
|
|
||||||
|
|
||||||
fs-extra@11.3.0:
|
|
||||||
dependencies:
|
|
||||||
graceful-fs: 4.2.11
|
|
||||||
jsonfile: 6.1.0
|
|
||||||
universalify: 2.0.1
|
|
||||||
|
|
||||||
glob-parent@5.1.2:
|
|
||||||
dependencies:
|
|
||||||
is-glob: 4.0.3
|
|
||||||
|
|
||||||
globby@14.1.0:
|
|
||||||
dependencies:
|
|
||||||
'@sindresorhus/merge-streams': 2.3.0
|
|
||||||
fast-glob: 3.3.3
|
|
||||||
ignore: 7.0.4
|
|
||||||
path-type: 6.0.0
|
|
||||||
slash: 5.1.0
|
|
||||||
unicorn-magic: 0.3.0
|
|
||||||
|
|
||||||
graceful-fs@4.2.11: {}
|
|
||||||
|
|
||||||
ignore@7.0.4: {}
|
|
||||||
|
|
||||||
is-extglob@2.1.1: {}
|
|
||||||
|
|
||||||
is-glob@4.0.3:
|
|
||||||
dependencies:
|
|
||||||
is-extglob: 2.1.1
|
|
||||||
|
|
||||||
is-number@7.0.0: {}
|
|
||||||
|
|
||||||
isexe@3.1.1: {}
|
|
||||||
|
|
||||||
jsonfile@6.1.0:
|
|
||||||
dependencies:
|
|
||||||
universalify: 2.0.1
|
|
||||||
optionalDependencies:
|
|
||||||
graceful-fs: 4.2.11
|
|
||||||
|
|
||||||
licia@1.48.0: {}
|
|
||||||
|
|
||||||
merge2@1.4.1: {}
|
|
||||||
|
|
||||||
micromatch@4.0.8:
|
|
||||||
dependencies:
|
|
||||||
braces: 3.0.3
|
|
||||||
picomatch: 2.3.1
|
|
||||||
|
|
||||||
minimist@1.2.8: {}
|
|
||||||
|
|
||||||
node-fetch-native@1.6.6: {}
|
|
||||||
|
|
||||||
path-type@6.0.0: {}
|
|
||||||
|
|
||||||
picomatch@2.3.1: {}
|
|
||||||
|
|
||||||
queue-microtask@1.2.3: {}
|
|
||||||
|
|
||||||
reusify@1.1.0: {}
|
|
||||||
|
|
||||||
run-parallel@1.2.0:
|
|
||||||
dependencies:
|
|
||||||
queue-microtask: 1.2.3
|
|
||||||
|
|
||||||
slash@5.1.0: {}
|
|
||||||
|
|
||||||
to-regex-range@5.0.1:
|
|
||||||
dependencies:
|
|
||||||
is-number: 7.0.0
|
|
||||||
|
|
||||||
unicorn-magic@0.3.0: {}
|
|
||||||
|
|
||||||
universalify@2.0.1: {}
|
|
||||||
|
|
||||||
which@5.0.0:
|
|
||||||
dependencies:
|
|
||||||
isexe: 3.1.1
|
|
||||||
|
|
||||||
yaml@2.8.0: {}
|
|
||||||
|
|
||||||
zurk@0.11.2: {}
|
|
||||||
|
|
||||||
zx@8.5.4: {}
|
|
||||||
@@ -1,11 +0,0 @@
|
|||||||
CREATE TABLE `service_ai_file`
|
|
||||||
(
|
|
||||||
`id` bigint NOT NULL,
|
|
||||||
`filename` varchar(500) DEFAULT NULL,
|
|
||||||
`size` bigint DEFAULT NULL,
|
|
||||||
`md5` varchar(100) DEFAULT NULL,
|
|
||||||
`path` varchar(500) DEFAULT NULL,
|
|
||||||
`type` varchar(50) DEFAULT NULL,
|
|
||||||
`created_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
||||||
PRIMARY KEY (`id`)
|
|
||||||
) DEFAULT CHARSET = utf8mb4;
|
|
||||||
@@ -1,9 +0,0 @@
|
|||||||
CREATE TABLE `service_ai_group`
|
|
||||||
(
|
|
||||||
`id` bigint NOT NULL,
|
|
||||||
`knowledge_id` bigint NOT NULL,
|
|
||||||
`name` varchar(100) NOT NULL,
|
|
||||||
`status` varchar(10) NOT NULL DEFAULT 'RUNNING',
|
|
||||||
`created_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
||||||
`modified_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
|
|
||||||
) DEFAULT CHARSET = utf8mb4;
|
|
||||||
@@ -1,10 +0,0 @@
|
|||||||
CREATE TABLE `service_ai_knowledge`
|
|
||||||
(
|
|
||||||
`id` bigint NOT NULL,
|
|
||||||
`vector_source_id` varchar(100) NOT NULL,
|
|
||||||
`name` varchar(100) NOT NULL,
|
|
||||||
`strategy` varchar(10) NOT NULL,
|
|
||||||
`created_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
||||||
`modified_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
|
|
||||||
PRIMARY KEY (`id`)
|
|
||||||
) DEFAULT CHARSET = utf8mb4;
|
|
||||||
@@ -1,177 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
|
||||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
|
||||||
<modelVersion>4.0.0</modelVersion>
|
|
||||||
|
|
||||||
<groupId>com.lanyuanxiaoyao</groupId>
|
|
||||||
<artifactId>service-ai</artifactId>
|
|
||||||
<version>1.0.0-SNAPSHOT</version>
|
|
||||||
<packaging>pom</packaging>
|
|
||||||
<description>Hudi AI服务集合</description>
|
|
||||||
<modules>
|
|
||||||
<module>service-ai-core</module>
|
|
||||||
<module>service-ai-chat</module>
|
|
||||||
<module>service-ai-knowledge</module>
|
|
||||||
</modules>
|
|
||||||
|
|
||||||
<properties>
|
|
||||||
<maven.compiler.source>17</maven.compiler.source>
|
|
||||||
<maven.compiler.target>17</maven.compiler.target>
|
|
||||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
|
||||||
|
|
||||||
<build-tag>b2b12</build-tag>
|
|
||||||
|
|
||||||
<spring-boot.version>3.4.3</spring-boot.version>
|
|
||||||
<spring-cloud.version>2024.0.1</spring-cloud.version>
|
|
||||||
<spring-ai.version>1.0.0</spring-ai.version>
|
|
||||||
<eclipse-collections.version>11.1.0</eclipse-collections.version>
|
|
||||||
<curator.version>5.1.0</curator.version>
|
|
||||||
<hutool.version>5.8.27</hutool.version>
|
|
||||||
</properties>
|
|
||||||
|
|
||||||
<dependencyManagement>
|
|
||||||
<dependencies>
|
|
||||||
<!-- 当前项目依赖 -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.lanyuanxiaoyao</groupId>
|
|
||||||
<artifactId>service-common</artifactId>
|
|
||||||
<version>${project.version}</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.lanyuanxiaoyao</groupId>
|
|
||||||
<artifactId>service-configuration</artifactId>
|
|
||||||
<version>${project.version}</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.lanyuanxiaoyao</groupId>
|
|
||||||
<artifactId>service-dependencies</artifactId>
|
|
||||||
<version>${project.version}</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.lanyuanxiaoyao</groupId>
|
|
||||||
<artifactId>service-forest</artifactId>
|
|
||||||
<version>${project.version}</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.lanyuanxiaoyao</groupId>
|
|
||||||
<artifactId>service-ai-core</artifactId>
|
|
||||||
<version>${project.version}</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- spring boot 相关依赖 -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.boot</groupId>
|
|
||||||
<artifactId>spring-boot-dependencies</artifactId>
|
|
||||||
<version>${spring-boot.version}</version>
|
|
||||||
<type>pom</type>
|
|
||||||
<scope>import</scope>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.cloud</groupId>
|
|
||||||
<artifactId>spring-cloud-dependencies</artifactId>
|
|
||||||
<version>${spring-cloud.version}</version>
|
|
||||||
<type>pom</type>
|
|
||||||
<scope>import</scope>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.ai</groupId>
|
|
||||||
<artifactId>spring-ai-bom</artifactId>
|
|
||||||
<version>${spring-ai.version}</version>
|
|
||||||
<type>pom</type>
|
|
||||||
<scope>import</scope>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.dtflys.forest</groupId>
|
|
||||||
<artifactId>forest-spring-boot3-starter</artifactId>
|
|
||||||
<version>1.5.36</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.fasterxml.jackson.datatype</groupId>
|
|
||||||
<artifactId>jackson-datatype-eclipse-collections</artifactId>
|
|
||||||
<version>2.17.1</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.github.ulisesbocchio</groupId>
|
|
||||||
<artifactId>jasypt-spring-boot-starter</artifactId>
|
|
||||||
<version>3.0.5</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- 日志相关 -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>pl.tkowalcz.tjahzi</groupId>
|
|
||||||
<artifactId>logback-appender</artifactId>
|
|
||||||
<version>0.9.23</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.github.loki4j</groupId>
|
|
||||||
<artifactId>loki-logback-appender-jdk8</artifactId>
|
|
||||||
<version>1.4.2</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- 其他 -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>dev.failsafe</groupId>
|
|
||||||
<artifactId>failsafe</artifactId>
|
|
||||||
<version>3.3.1</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.eclipse.collections</groupId>
|
|
||||||
<artifactId>eclipse-collections</artifactId>
|
|
||||||
<version>${eclipse-collections.version}</version>
|
|
||||||
<scope>runtime</scope>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.eclipse.collections</groupId>
|
|
||||||
<artifactId>eclipse-collections-api</artifactId>
|
|
||||||
<version>${eclipse-collections.version}</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>cn.hutool</groupId>
|
|
||||||
<artifactId>hutool-all</artifactId>
|
|
||||||
<version>${hutool.version}</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.yomahub</groupId>
|
|
||||||
<artifactId>liteflow-spring-boot-starter</artifactId>
|
|
||||||
<version>2.13.2</version>
|
|
||||||
</dependency>
|
|
||||||
</dependencies>
|
|
||||||
</dependencyManagement>
|
|
||||||
|
|
||||||
<build>
|
|
||||||
<pluginManagement>
|
|
||||||
<plugins>
|
|
||||||
<plugin>
|
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
|
||||||
<artifactId>maven-source-plugin</artifactId>
|
|
||||||
<version>3.3.0</version>
|
|
||||||
</plugin>
|
|
||||||
<plugin>
|
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
|
||||||
<artifactId>maven-shade-plugin</artifactId>
|
|
||||||
<version>3.3.0</version>
|
|
||||||
</plugin>
|
|
||||||
<plugin>
|
|
||||||
<groupId>org.springframework.boot</groupId>
|
|
||||||
<artifactId>spring-boot-maven-plugin</artifactId>
|
|
||||||
<version>${spring-boot.version}</version>
|
|
||||||
</plugin>
|
|
||||||
</plugins>
|
|
||||||
</pluginManagement>
|
|
||||||
</build>
|
|
||||||
|
|
||||||
<distributionManagement>
|
|
||||||
<repository>
|
|
||||||
<id>${releases.id}</id>
|
|
||||||
<name>${releases.name}</name>
|
|
||||||
<url>${releases.url}</url>
|
|
||||||
</repository>
|
|
||||||
<snapshotRepository>
|
|
||||||
<id>${snapshots.id}</id>
|
|
||||||
<name>${snapshots.name}</name>
|
|
||||||
<url>${snapshots.url}</url>
|
|
||||||
</snapshotRepository>
|
|
||||||
</distributionManagement>
|
|
||||||
|
|
||||||
</project>
|
|
||||||
@@ -1,41 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
|
||||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
|
||||||
<modelVersion>4.0.0</modelVersion>
|
|
||||||
<parent>
|
|
||||||
<groupId>com.lanyuanxiaoyao</groupId>
|
|
||||||
<artifactId>service-ai</artifactId>
|
|
||||||
<version>1.0.0-SNAPSHOT</version>
|
|
||||||
</parent>
|
|
||||||
|
|
||||||
<artifactId>service-ai-chat</artifactId>
|
|
||||||
|
|
||||||
<dependencies>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.lanyuanxiaoyao</groupId>
|
|
||||||
<artifactId>service-ai-core</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.ai</groupId>
|
|
||||||
<artifactId>spring-ai-starter-model-openai</artifactId>
|
|
||||||
</dependency>
|
|
||||||
</dependencies>
|
|
||||||
|
|
||||||
<build>
|
|
||||||
<plugins>
|
|
||||||
<plugin>
|
|
||||||
<groupId>org.springframework.boot</groupId>
|
|
||||||
<artifactId>spring-boot-maven-plugin</artifactId>
|
|
||||||
<executions>
|
|
||||||
<execution>
|
|
||||||
<phase>package</phase>
|
|
||||||
<goals>
|
|
||||||
<goal>repackage</goal>
|
|
||||||
</goals>
|
|
||||||
</execution>
|
|
||||||
</executions>
|
|
||||||
</plugin>
|
|
||||||
</plugins>
|
|
||||||
</build>
|
|
||||||
</project>
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.chat;
|
|
||||||
|
|
||||||
import com.ulisesbocchio.jasyptspringboot.annotation.EnableEncryptableProperties;
|
|
||||||
import org.springframework.boot.SpringApplication;
|
|
||||||
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
|
||||||
import org.springframework.boot.context.properties.EnableConfigurationProperties;
|
|
||||||
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
|
|
||||||
import org.springframework.retry.annotation.EnableRetry;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250514
|
|
||||||
*/
|
|
||||||
@SpringBootApplication(scanBasePackages = "com.lanyuanxiaoyao.service")
|
|
||||||
@EnableDiscoveryClient
|
|
||||||
@EnableConfigurationProperties
|
|
||||||
@EnableEncryptableProperties
|
|
||||||
@EnableRetry
|
|
||||||
public class AiChatApplication {
|
|
||||||
public static void main(String[] args) {
|
|
||||||
SpringApplication.run(AiChatApplication.class, args);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,87 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.chat.controller;
|
|
||||||
|
|
||||||
import cn.hutool.core.util.StrUtil;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.chat.entity.MessageVO;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.chat.tools.DatetimeTools;
|
|
||||||
import java.io.IOException;
|
|
||||||
import org.eclipse.collections.api.list.ImmutableList;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.ai.chat.client.ChatClient;
|
|
||||||
import org.springframework.ai.chat.messages.AssistantMessage;
|
|
||||||
import org.springframework.ai.chat.messages.Message;
|
|
||||||
import org.springframework.ai.chat.messages.UserMessage;
|
|
||||||
import org.springframework.stereotype.Controller;
|
|
||||||
import org.springframework.web.bind.annotation.PostMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestBody;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.ResponseBody;
|
|
||||||
import org.springframework.web.servlet.mvc.method.annotation.SseEmitter;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 聊天
|
|
||||||
*
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250514
|
|
||||||
*/
|
|
||||||
@Controller
|
|
||||||
@RequestMapping("chat")
|
|
||||||
public class ChatController {
|
|
||||||
private static final Logger logger = LoggerFactory.getLogger(ChatController.class);
|
|
||||||
|
|
||||||
private final ChatClient chatClient;
|
|
||||||
|
|
||||||
public ChatController(ChatClient.Builder builder) {
|
|
||||||
this.chatClient = builder.build();
|
|
||||||
}
|
|
||||||
|
|
||||||
private ChatClient.ChatClientRequestSpec buildRequest(ImmutableList<MessageVO> messages) {
|
|
||||||
return chatClient.prompt()
|
|
||||||
.system("""
|
|
||||||
你是一名专业的AI运维助手,负责“Hudi数据同步服务平台”的运维工作;
|
|
||||||
你将会友好地帮助用户解答关于该平台运维工作的问题,你会尽可能通过各种方式获取知识和数据来解答;
|
|
||||||
对于无法通过已有知识回答的问题,你会提示用户你无法解答该问题,而不是虚构不存在的数据或答案;
|
|
||||||
对于与该平台无关的问题,你会委婉地拒绝用户,并提示无法回答;
|
|
||||||
你将始终在中文语境下进行对话。
|
|
||||||
""")
|
|
||||||
.tools(new DatetimeTools())
|
|
||||||
.messages(
|
|
||||||
messages
|
|
||||||
.collect(message -> StrUtil.equals(message.getRole(), "assistant")
|
|
||||||
? new AssistantMessage(message.getContent())
|
|
||||||
: new UserMessage(message.getContent()))
|
|
||||||
.collect(message -> (Message) message)
|
|
||||||
.toList()
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
@PostMapping("sync")
|
|
||||||
@ResponseBody
|
|
||||||
public String chatSync(@RequestBody ImmutableList<MessageVO> messages) {
|
|
||||||
String content = buildRequest(messages)
|
|
||||||
.call()
|
|
||||||
.content();
|
|
||||||
return StrUtil.trimToEmpty(content);
|
|
||||||
}
|
|
||||||
|
|
||||||
@PostMapping("async")
|
|
||||||
public SseEmitter chatAsync(@RequestBody ImmutableList<MessageVO> messages) {
|
|
||||||
SseEmitter emitter = new SseEmitter();
|
|
||||||
buildRequest(messages)
|
|
||||||
.stream()
|
|
||||||
.content()
|
|
||||||
.subscribe(
|
|
||||||
content -> {
|
|
||||||
try {
|
|
||||||
emitter.send(content);
|
|
||||||
} catch (IOException e) {
|
|
||||||
emitter.completeWithError(e);
|
|
||||||
throw new RuntimeException(e);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
emitter::completeWithError,
|
|
||||||
emitter::complete
|
|
||||||
);
|
|
||||||
return emitter;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,34 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.chat.entity;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250516
|
|
||||||
*/
|
|
||||||
public class MessageVO {
|
|
||||||
private String role;
|
|
||||||
private String content;
|
|
||||||
|
|
||||||
public String getRole() {
|
|
||||||
return role;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setRole(String role) {
|
|
||||||
this.role = role;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getContent() {
|
|
||||||
return content;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setContent(String content) {
|
|
||||||
this.content = content;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "MessageVO{" +
|
|
||||||
"role='" + role + '\'' +
|
|
||||||
", content='" + content + '\'' +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,18 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.chat.tools;
|
|
||||||
|
|
||||||
import java.time.LocalDateTime;
|
|
||||||
import java.time.format.DateTimeFormatter;
|
|
||||||
import org.springframework.ai.tool.annotation.Tool;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250516
|
|
||||||
*/
|
|
||||||
public class DatetimeTools {
|
|
||||||
private final static DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
|
|
||||||
|
|
||||||
@Tool(description = "获取当前日期和时间")
|
|
||||||
public String getCurrentDateTime() {
|
|
||||||
return LocalDateTime.now().format(formatter);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
spring:
|
|
||||||
application:
|
|
||||||
name: service-ai-chat
|
|
||||||
profiles:
|
|
||||||
include: random-port,common,discovery,metrics,forest
|
|
||||||
ai:
|
|
||||||
openai:
|
|
||||||
base-url: http://132.121.206.65:10086
|
|
||||||
api-key: ENC(K+Hff9QGC+fcyi510VIDd9CaeK/IN5WBJ9rlkUsHEdDgIidW+stHHJlsK0lLPUXXREha+ToQZqqDXJrqSE+GUKCXklFhelD8bRHFXBIeP/ZzT2cxhzgKUXgjw3S0Qw2R)
|
|
||||||
chat:
|
|
||||||
options:
|
|
||||||
model: 'Qwen3-1.7-vllm'
|
|
||||||
mvc:
|
|
||||||
async:
|
|
||||||
request-timeout: 300000
|
|
||||||
@@ -1,34 +0,0 @@
|
|||||||
<configuration>
|
|
||||||
<conversionRule conversionWord="clr" converterClass="org.springframework.boot.logging.logback.ColorConverter" />
|
|
||||||
<conversionRule conversionWord="wex" converterClass="org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter" />
|
|
||||||
<conversionRule conversionWord="wEx" converterClass="org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter" />
|
|
||||||
|
|
||||||
<springProperty scope="context" name="LOKI_PUSH_URL" source="loki.url"/>
|
|
||||||
<springProperty scope="context" name="LOGGING_PARENT" source="logging.parent"/>
|
|
||||||
<springProperty scope="context" name="APP_NAME" source="spring.application.name"/>
|
|
||||||
|
|
||||||
<appender name="Console" class="ch.qos.logback.core.ConsoleAppender">
|
|
||||||
<encoder>
|
|
||||||
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %clr(%5p) %clr([${HOSTNAME}]){yellow} %clr([%t]){magenta} %clr(%logger{40}){cyan} #@# %m%n%wEx</pattern>
|
|
||||||
</encoder>
|
|
||||||
</appender>
|
|
||||||
|
|
||||||
<appender name="RollingFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
||||||
<file>${LOGGING_PARENT:-.}/${APP_NAME:-run}.log</file>
|
|
||||||
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
|
|
||||||
<fileNamePattern>${LOGGING_PARENT:-.}/archive/${APP_NAME:-run}-%d{yyyy-MM-dd}.gz</fileNamePattern>
|
|
||||||
<MaxHistory>7</MaxHistory>
|
|
||||||
</rollingPolicy>
|
|
||||||
<encoder>
|
|
||||||
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %p [${HOSTNAME}] [%t] %logger #@# %m%n%wEx</pattern>
|
|
||||||
</encoder>
|
|
||||||
</appender>
|
|
||||||
|
|
||||||
<logger name="com.zaxxer.hikari" level="ERROR"/>
|
|
||||||
<logger name="com.netflix.discovery.shared.resolver.aws.ConfigClusterResolver" level="WARN"/>
|
|
||||||
|
|
||||||
<root level="INFO">
|
|
||||||
<appender-ref ref="Console"/>
|
|
||||||
<appender-ref ref="RollingFile"/>
|
|
||||||
</root>
|
|
||||||
</configuration>
|
|
||||||
@@ -1,37 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.chat;
|
|
||||||
|
|
||||||
import org.springframework.ai.chat.client.ChatClient;
|
|
||||||
import org.springframework.ai.openai.OpenAiChatModel;
|
|
||||||
import org.springframework.ai.openai.OpenAiChatOptions;
|
|
||||||
import org.springframework.ai.openai.api.OpenAiApi;
|
|
||||||
import reactor.core.Disposable;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250514
|
|
||||||
*/
|
|
||||||
public class TestChat {
|
|
||||||
public static void main(String[] args) {
|
|
||||||
ChatClient client = ChatClient.builder(
|
|
||||||
OpenAiChatModel.builder()
|
|
||||||
.openAiApi(
|
|
||||||
OpenAiApi.builder()
|
|
||||||
.baseUrl("http://132.121.206.65:10086")
|
|
||||||
.apiKey("*XMySqV%>hR&v>>g*NwCs3tpQ5FVMFEF2VHVTj<MYQd$&@$sY7CgqNyea4giJi4")
|
|
||||||
.build()
|
|
||||||
)
|
|
||||||
.defaultOptions(
|
|
||||||
OpenAiChatOptions.builder()
|
|
||||||
.model("Qwen3-1.7")
|
|
||||||
.build()
|
|
||||||
)
|
|
||||||
.build()
|
|
||||||
)
|
|
||||||
.build();
|
|
||||||
String content = client.prompt()
|
|
||||||
.user("你好")
|
|
||||||
.call()
|
|
||||||
.content();
|
|
||||||
System.out.println(content);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,54 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
|
||||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
|
||||||
<modelVersion>4.0.0</modelVersion>
|
|
||||||
<parent>
|
|
||||||
<groupId>com.lanyuanxiaoyao</groupId>
|
|
||||||
<artifactId>service-ai</artifactId>
|
|
||||||
<version>1.0.0-SNAPSHOT</version>
|
|
||||||
</parent>
|
|
||||||
|
|
||||||
<artifactId>service-ai-core</artifactId>
|
|
||||||
|
|
||||||
<dependencies>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.lanyuanxiaoyao</groupId>
|
|
||||||
<artifactId>service-forest</artifactId>
|
|
||||||
<exclusions>
|
|
||||||
<exclusion>
|
|
||||||
<groupId>com.dtflys.forest</groupId>
|
|
||||||
<artifactId>forest-spring-boot-starter</artifactId>
|
|
||||||
</exclusion>
|
|
||||||
<exclusion>
|
|
||||||
<groupId>org.springframework.cloud</groupId>
|
|
||||||
<artifactId>spring-cloud-starter-sleuth</artifactId>
|
|
||||||
</exclusion>
|
|
||||||
<exclusion>
|
|
||||||
<groupId>commons-logging</groupId>
|
|
||||||
<artifactId>commons-logging</artifactId>
|
|
||||||
</exclusion>
|
|
||||||
</exclusions>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.boot</groupId>
|
|
||||||
<artifactId>spring-boot-starter-aop</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.dtflys.forest</groupId>
|
|
||||||
<artifactId>forest-spring-boot3-starter</artifactId>
|
|
||||||
<exclusions>
|
|
||||||
<exclusion>
|
|
||||||
<groupId>commons-logging</groupId>
|
|
||||||
<artifactId>commons-logging</artifactId>
|
|
||||||
</exclusion>
|
|
||||||
</exclusions>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.boot</groupId>
|
|
||||||
<artifactId>spring-boot-starter-webflux</artifactId>
|
|
||||||
<scope>provided</scope>
|
|
||||||
</dependency>
|
|
||||||
</dependencies>
|
|
||||||
</project>
|
|
||||||
@@ -1,39 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.core.configuration;
|
|
||||||
|
|
||||||
import java.net.http.HttpClient;
|
|
||||||
import org.springframework.context.annotation.Bean;
|
|
||||||
import org.springframework.context.annotation.Configuration;
|
|
||||||
import org.springframework.context.annotation.Primary;
|
|
||||||
import org.springframework.http.client.JdkClientHttpRequestFactory;
|
|
||||||
import org.springframework.http.client.reactive.JdkClientHttpConnector;
|
|
||||||
import org.springframework.web.client.RestClient;
|
|
||||||
import org.springframework.web.reactive.function.client.WebClient;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* vLLM只能使用http1.0
|
|
||||||
*
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250519
|
|
||||||
*/
|
|
||||||
@Configuration
|
|
||||||
public class WebClientConfiguration {
|
|
||||||
private HttpClient httpClient() {
|
|
||||||
return HttpClient.newBuilder()
|
|
||||||
.version(HttpClient.Version.HTTP_1_1)
|
|
||||||
.build();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
@Primary
|
|
||||||
public RestClient.Builder restClientBuilder() {
|
|
||||||
return RestClient.builder()
|
|
||||||
.requestFactory(new JdkClientHttpRequestFactory(httpClient()));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
@Primary
|
|
||||||
public WebClient.Builder webClientBuilder() {
|
|
||||||
return WebClient.builder()
|
|
||||||
.clientConnector(new JdkClientHttpConnector(httpClient()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,24 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.core.configuration;
|
|
||||||
|
|
||||||
import org.springframework.context.annotation.Configuration;
|
|
||||||
import org.springframework.web.servlet.config.annotation.CorsRegistry;
|
|
||||||
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* web 配置
|
|
||||||
*
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @date 2023-04-21
|
|
||||||
*/
|
|
||||||
@Configuration
|
|
||||||
public class WebConfiguration implements WebMvcConfigurer {
|
|
||||||
@Override
|
|
||||||
public void addCorsMappings(CorsRegistry registry) {
|
|
||||||
// 避免跨域影响调试
|
|
||||||
registry.addMapping("/**")
|
|
||||||
.allowedOriginPatterns("*")
|
|
||||||
.allowCredentials(true)
|
|
||||||
.allowedMethods("*")
|
|
||||||
.maxAge(3600);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,30 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.core.entity.amis;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Crud 响应
|
|
||||||
*
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @date 2023-07-06
|
|
||||||
*/
|
|
||||||
public class AmisCrudResponse extends AmisMapResponse {
|
|
||||||
public void setData(Iterable<?> list) {
|
|
||||||
getData().put("items", list);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setTotal(Long total) {
|
|
||||||
getData().put("total", total);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setTotal(Integer total) {
|
|
||||||
setTotal(total.longValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setData(Iterable<?> list, Long total) {
|
|
||||||
setData(list);
|
|
||||||
setTotal(total);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setData(Iterable<?> list, Integer total) {
|
|
||||||
setData(list, total.longValue());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,13 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.core.entity.amis;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Crud 响应
|
|
||||||
*
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @date 2023-07-06
|
|
||||||
*/
|
|
||||||
public class AmisDetailResponse extends AmisMapResponse {
|
|
||||||
public void setDetail(Object detail) {
|
|
||||||
getData().put("detail", detail);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,21 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.core.entity.amis;
|
|
||||||
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Map 响应
|
|
||||||
*
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @date 2023-07-06
|
|
||||||
*/
|
|
||||||
public class AmisMapResponse extends AmisResponse<Map<String, Object>> {
|
|
||||||
public AmisMapResponse() {
|
|
||||||
setData(new HashMap<>());
|
|
||||||
}
|
|
||||||
|
|
||||||
public AmisMapResponse setData(String key, Object value) {
|
|
||||||
getData().put(key, value);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,138 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.core.entity.amis;
|
|
||||||
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Amis 组件结构化返回值
|
|
||||||
*
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @date 2022-09-21
|
|
||||||
*/
|
|
||||||
public class AmisResponse<T> {
|
|
||||||
private static final int SUCCESS_STATUS = 0;
|
|
||||||
private static final int ERROR_STATUS = 500;
|
|
||||||
private static final String SUCCESS_MESSAGE = "OK";
|
|
||||||
private static final String ERROR_MESSAGE = "ERROR";
|
|
||||||
private Integer status;
|
|
||||||
private String message;
|
|
||||||
private T data;
|
|
||||||
|
|
||||||
public static AmisResponse<Object> responseError() {
|
|
||||||
return responseError(ERROR_MESSAGE);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static AmisResponse<Object> responseError(String message) {
|
|
||||||
AmisResponse<Object> response = new AmisResponse<>();
|
|
||||||
response.setStatus(ERROR_STATUS);
|
|
||||||
response.setMessage(message);
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static AmisResponse<Object> responseSuccess() {
|
|
||||||
AmisResponse<Object> response = new AmisResponse<>();
|
|
||||||
response.setStatus(SUCCESS_STATUS);
|
|
||||||
response.setMessage(SUCCESS_MESSAGE);
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static AmisResponse<Object> responseSuccess(String message) {
|
|
||||||
AmisResponse<Object> response = new AmisResponse<>();
|
|
||||||
response.setStatus(SUCCESS_STATUS);
|
|
||||||
response.setMessage(message);
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static <E> AmisResponse<E> responseSuccess(String message, E data) {
|
|
||||||
AmisResponse<E> response = new AmisResponse<>();
|
|
||||||
response.setStatus(SUCCESS_STATUS);
|
|
||||||
response.setMessage(message);
|
|
||||||
response.setData(data);
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static <E> AmisResponse<E> responseSuccess(E data) {
|
|
||||||
AmisResponse<E> response = new AmisResponse<>();
|
|
||||||
response.setStatus(SUCCESS_STATUS);
|
|
||||||
response.setMessage(SUCCESS_MESSAGE);
|
|
||||||
response.setData(data);
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static AmisMapResponse responseMapData() {
|
|
||||||
AmisMapResponse response = new AmisMapResponse();
|
|
||||||
response.setStatus(SUCCESS_STATUS);
|
|
||||||
response.setMessage(SUCCESS_MESSAGE);
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static AmisMapResponse responseMapData(Map<String, Object> data) {
|
|
||||||
AmisMapResponse response = responseMapData();
|
|
||||||
response.setData(data);
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static AmisMapResponse responseMapData(String key, Object value) {
|
|
||||||
AmisMapResponse response = responseMapData();
|
|
||||||
response.setData(key, value);
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static AmisCrudResponse responseCrudData(Iterable<?> data) {
|
|
||||||
AmisCrudResponse response = new AmisCrudResponse();
|
|
||||||
response.setStatus(SUCCESS_STATUS);
|
|
||||||
response.setMessage(SUCCESS_MESSAGE);
|
|
||||||
response.setData(data);
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static AmisCrudResponse responseCrudData(Iterable<?> data, Integer total) {
|
|
||||||
AmisCrudResponse response = responseCrudData(data);
|
|
||||||
response.setTotal(total);
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static AmisCrudResponse responseCrudData(Iterable<?> data, Long total) {
|
|
||||||
AmisCrudResponse response = responseCrudData(data);
|
|
||||||
response.setTotal(total);
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static AmisDetailResponse responseDetailData(Object detail) {
|
|
||||||
AmisDetailResponse response = new AmisDetailResponse();
|
|
||||||
response.setDetail(detail);
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Integer getStatus() {
|
|
||||||
return status;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setStatus(Integer status) {
|
|
||||||
this.status = status;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getMessage() {
|
|
||||||
return message;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setMessage(String message) {
|
|
||||||
this.message = message;
|
|
||||||
}
|
|
||||||
|
|
||||||
public T getData() {
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setData(T data) {
|
|
||||||
this.data = data;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "AmisResponse{" +
|
|
||||||
"status=" + status +
|
|
||||||
", message='" + message + '\'' +
|
|
||||||
", data=" + data +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,58 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.configuration;
|
|
||||||
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.context.annotation.Bean;
|
|
||||||
import org.springframework.context.annotation.Configuration;
|
|
||||||
import org.springframework.security.config.Customizer;
|
|
||||||
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
|
|
||||||
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
|
|
||||||
import org.springframework.security.config.annotation.web.configurers.AbstractHttpConfigurer;
|
|
||||||
import org.springframework.security.core.userdetails.User;
|
|
||||||
import org.springframework.security.core.userdetails.UserDetails;
|
|
||||||
import org.springframework.security.provisioning.InMemoryUserDetailsManager;
|
|
||||||
import org.springframework.security.web.SecurityFilterChain;
|
|
||||||
import org.springframework.web.cors.CorsConfiguration;
|
|
||||||
import org.springframework.web.cors.CorsConfigurationSource;
|
|
||||||
import org.springframework.web.cors.UrlBasedCorsConfigurationSource;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250514
|
|
||||||
*/
|
|
||||||
@Configuration
|
|
||||||
@EnableWebSecurity
|
|
||||||
public class SecurityConfig {
|
|
||||||
private static final Logger logger = LoggerFactory.getLogger(SecurityConfig.class);
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception {
|
|
||||||
return http.authorizeHttpRequests(registry -> registry.anyRequest().authenticated())
|
|
||||||
.httpBasic(Customizer.withDefaults())
|
|
||||||
.csrf(AbstractHttpConfigurer::disable)
|
|
||||||
.cors(configurer -> configurer.configurationSource(corsConfigurationSource()))
|
|
||||||
.formLogin(AbstractHttpConfigurer::disable)
|
|
||||||
.build();
|
|
||||||
}
|
|
||||||
|
|
||||||
private CorsConfigurationSource corsConfigurationSource() {
|
|
||||||
CorsConfiguration configuration = new CorsConfiguration();
|
|
||||||
configuration.setAllowCredentials(true);
|
|
||||||
configuration.addAllowedHeader("*");
|
|
||||||
configuration.addAllowedMethod("*");
|
|
||||||
configuration.addAllowedOriginPattern("*");
|
|
||||||
UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
|
|
||||||
source.registerCorsConfiguration("/**", configuration);
|
|
||||||
return source;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public InMemoryUserDetailsManager userDetailsService(SecurityProperties securityProperties) {
|
|
||||||
UserDetails user = User.builder()
|
|
||||||
.username(securityProperties.getUsername())
|
|
||||||
.password("{noop}" + securityProperties.getDarkcode())
|
|
||||||
.authorities(securityProperties.getAuthority())
|
|
||||||
.build();
|
|
||||||
return new InMemoryUserDetailsManager(user);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,75 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
|
||||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
|
||||||
<modelVersion>4.0.0</modelVersion>
|
|
||||||
<parent>
|
|
||||||
<groupId>com.lanyuanxiaoyao</groupId>
|
|
||||||
<artifactId>service-ai</artifactId>
|
|
||||||
<version>1.0.0-SNAPSHOT</version>
|
|
||||||
</parent>
|
|
||||||
|
|
||||||
<artifactId>service-ai-knowledge</artifactId>
|
|
||||||
|
|
||||||
<dependencies>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.lanyuanxiaoyao</groupId>
|
|
||||||
<artifactId>service-ai-core</artifactId>
|
|
||||||
<exclusions>
|
|
||||||
<exclusion>
|
|
||||||
<groupId>com.google.protobuf</groupId>
|
|
||||||
<artifactId>protobuf-java</artifactId>
|
|
||||||
</exclusion>
|
|
||||||
</exclusions>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.ai</groupId>
|
|
||||||
<artifactId>spring-ai-starter-model-openai</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.ai</groupId>
|
|
||||||
<artifactId>spring-ai-starter-vector-store-qdrant</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.ai</groupId>
|
|
||||||
<artifactId>spring-ai-markdown-document-reader</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.boot</groupId>
|
|
||||||
<artifactId>spring-boot-starter-jdbc</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.mysql</groupId>
|
|
||||||
<artifactId>mysql-connector-j</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.yomahub</groupId>
|
|
||||||
<artifactId>liteflow-spring-boot-starter</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.ai</groupId>
|
|
||||||
<artifactId>spring-ai-tika-document-reader</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.ai</groupId>
|
|
||||||
<artifactId>spring-ai-pdf-document-reader</artifactId>
|
|
||||||
</dependency>
|
|
||||||
</dependencies>
|
|
||||||
|
|
||||||
<build>
|
|
||||||
<plugins>
|
|
||||||
<plugin>
|
|
||||||
<groupId>org.springframework.boot</groupId>
|
|
||||||
<artifactId>spring-boot-maven-plugin</artifactId>
|
|
||||||
<executions>
|
|
||||||
<execution>
|
|
||||||
<phase>package</phase>
|
|
||||||
<goals>
|
|
||||||
<goal>repackage</goal>
|
|
||||||
</goals>
|
|
||||||
</execution>
|
|
||||||
</executions>
|
|
||||||
</plugin>
|
|
||||||
</plugins>
|
|
||||||
</build>
|
|
||||||
</project>
|
|
||||||
@@ -1,31 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.knowledge;
|
|
||||||
|
|
||||||
import com.ulisesbocchio.jasyptspringboot.annotation.EnableEncryptableProperties;
|
|
||||||
import org.springframework.boot.ApplicationArguments;
|
|
||||||
import org.springframework.boot.ApplicationRunner;
|
|
||||||
import org.springframework.boot.SpringApplication;
|
|
||||||
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
|
||||||
import org.springframework.boot.context.properties.EnableConfigurationProperties;
|
|
||||||
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
|
|
||||||
import org.springframework.retry.annotation.EnableRetry;
|
|
||||||
import org.springframework.scheduling.annotation.EnableScheduling;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250515
|
|
||||||
*/
|
|
||||||
@SpringBootApplication(scanBasePackages = "com.lanyuanxiaoyao.service")
|
|
||||||
@EnableDiscoveryClient
|
|
||||||
@EnableConfigurationProperties
|
|
||||||
@EnableEncryptableProperties
|
|
||||||
@EnableRetry
|
|
||||||
@EnableScheduling
|
|
||||||
public class KnowledgeApplication implements ApplicationRunner {
|
|
||||||
public static void main(String[] args) {
|
|
||||||
SpringApplication.run(KnowledgeApplication.class, args);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void run(ApplicationArguments args) {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,39 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.knowledge.configuration;
|
|
||||||
|
|
||||||
import org.springframework.boot.context.properties.ConfigurationProperties;
|
|
||||||
import org.springframework.context.annotation.Configuration;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250527
|
|
||||||
*/
|
|
||||||
@Configuration
|
|
||||||
@ConfigurationProperties(prefix = "knowledge")
|
|
||||||
public class KnowledgeConfiguration {
|
|
||||||
private String downloadPrefix;
|
|
||||||
private String uploadPath;
|
|
||||||
|
|
||||||
public String getDownloadPrefix() {
|
|
||||||
return downloadPrefix;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setDownloadPrefix(String downloadPrefix) {
|
|
||||||
this.downloadPrefix = downloadPrefix;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getUploadPath() {
|
|
||||||
return uploadPath;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setUploadPath(String uploadPath) {
|
|
||||||
this.uploadPath = uploadPath;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "KnowledgeConfiguration{" +
|
|
||||||
"downloadPrefix='" + downloadPrefix + '\'' +
|
|
||||||
", uploadPath='" + uploadPath + '\'' +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,381 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.knowledge.controller;
|
|
||||||
|
|
||||||
import cn.hutool.core.io.FileUtil;
|
|
||||||
import cn.hutool.core.io.IoUtil;
|
|
||||||
import cn.hutool.core.util.StrUtil;
|
|
||||||
import cn.hutool.core.util.URLUtil;
|
|
||||||
import cn.hutool.crypto.SecureUtil;
|
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.core.entity.amis.AmisResponse;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.knowledge.configuration.KnowledgeConfiguration;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.knowledge.entity.vo.DataFileVO;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.knowledge.service.DataFileService;
|
|
||||||
import jakarta.servlet.http.HttpServletResponse;
|
|
||||||
import java.io.ByteArrayInputStream;
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.FileInputStream;
|
|
||||||
import java.io.FileOutputStream;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.nio.channels.FileChannel;
|
|
||||||
import org.eclipse.collections.api.list.ImmutableList;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
|
||||||
import org.springframework.web.bind.annotation.PathVariable;
|
|
||||||
import org.springframework.web.bind.annotation.PostMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestBody;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestParam;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
import org.springframework.web.multipart.MultipartFile;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 文件上传接口
|
|
||||||
*
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @date 2024-11-21
|
|
||||||
*/
|
|
||||||
@RestController
|
|
||||||
@RequestMapping("/upload")
|
|
||||||
public class DataFileController {
|
|
||||||
private static final Logger log = LoggerFactory.getLogger(DataFileController.class);
|
|
||||||
|
|
||||||
private final KnowledgeConfiguration knowledgeConfiguration;
|
|
||||||
private final DataFileService dataFileService;
|
|
||||||
private final String uploadFolderPath;
|
|
||||||
private final String cacheFolderPath;
|
|
||||||
private final String sliceFolderPath;
|
|
||||||
|
|
||||||
public DataFileController(KnowledgeConfiguration knowledgeConfiguration, DataFileService dataFileService) {
|
|
||||||
this.knowledgeConfiguration = knowledgeConfiguration;
|
|
||||||
this.dataFileService = dataFileService;
|
|
||||||
|
|
||||||
this.uploadFolderPath = knowledgeConfiguration.getUploadPath();
|
|
||||||
this.cacheFolderPath = StrUtil.format("{}/cache", uploadFolderPath);
|
|
||||||
this.sliceFolderPath = StrUtil.format("{}/slice", uploadFolderPath);
|
|
||||||
}
|
|
||||||
|
|
||||||
@PostMapping("")
|
|
||||||
public AmisResponse<FinishResponse> upload(@RequestParam("file") MultipartFile file) throws IOException {
|
|
||||||
String filename = file.getOriginalFilename();
|
|
||||||
Long id = dataFileService.initialDataFile(filename);
|
|
||||||
String url = StrUtil.format("{}/upload/download/{}", knowledgeConfiguration.getDownloadPrefix(), id);
|
|
||||||
byte[] bytes = file.getBytes();
|
|
||||||
String originMd5 = SecureUtil.md5(new ByteArrayInputStream(bytes));
|
|
||||||
File targetFile = new File(StrUtil.format("{}/{}", uploadFolderPath, originMd5));
|
|
||||||
if (targetFile.exists()) {
|
|
||||||
dataFileService.updateDataFile(id, FileUtil.getAbsolutePath(targetFile), FileUtil.size(targetFile), originMd5, file.getContentType());
|
|
||||||
return AmisResponse.responseSuccess(new FinishResponse(id, filename, url, url));
|
|
||||||
}
|
|
||||||
File cacheFile = new File(StrUtil.format("{}/{}", cacheFolderPath, id));
|
|
||||||
cacheFile = FileUtil.writeBytes(bytes, cacheFile);
|
|
||||||
String targetMd5 = SecureUtil.md5(cacheFile);
|
|
||||||
if (!StrUtil.equals(originMd5, targetMd5)) {
|
|
||||||
throw new RuntimeException("文件上传失败,校验不匹配");
|
|
||||||
}
|
|
||||||
FileUtil.move(cacheFile, targetFile, true);
|
|
||||||
dataFileService.updateDataFile(id, FileUtil.getAbsolutePath(targetFile), FileUtil.size(targetFile), targetMd5, file.getContentType());
|
|
||||||
return AmisResponse.responseSuccess(new FinishResponse(id, filename, url, url));
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("/download/{id}")
|
|
||||||
public void download(@PathVariable Long id, HttpServletResponse response) throws IOException {
|
|
||||||
DataFileVO dataFile = dataFileService.downloadFile(id);
|
|
||||||
File targetFile = new File(dataFile.getPath());
|
|
||||||
response.setHeader("Content-Type", dataFile.getType());
|
|
||||||
response.setHeader("Access-Control-Expose-Headers", "Content-Disposition");
|
|
||||||
response.setHeader("Content-Disposition", StrUtil.format("attachment; filename={}", URLUtil.encodeAll(dataFile.getFilename())));
|
|
||||||
IoUtil.copy(new FileInputStream(targetFile), response.getOutputStream());
|
|
||||||
}
|
|
||||||
|
|
||||||
@PostMapping("/start")
|
|
||||||
public AmisResponse<StartResponse> start(@RequestBody StartRequest request) {
|
|
||||||
Long id = dataFileService.initialDataFile(request.filename);
|
|
||||||
return AmisResponse.responseSuccess(new StartResponse(id.toString()));
|
|
||||||
}
|
|
||||||
|
|
||||||
@PostMapping("/slice")
|
|
||||||
public AmisResponse<SliceResponse> slice(
|
|
||||||
@RequestParam("uploadId")
|
|
||||||
Long uploadId,
|
|
||||||
@RequestParam("partNumber")
|
|
||||||
Integer sequence,
|
|
||||||
@RequestParam("partSize")
|
|
||||||
Long size,
|
|
||||||
@RequestParam("file")
|
|
||||||
MultipartFile file
|
|
||||||
) throws IOException {
|
|
||||||
byte[] bytes = file.getBytes();
|
|
||||||
String md5 = SecureUtil.md5(new ByteArrayInputStream(bytes));
|
|
||||||
String targetFilename = StrUtil.format("{}-{}", sequence, md5);
|
|
||||||
String targetFilePath = sliceFilePath(uploadId, targetFilename);
|
|
||||||
FileUtil.mkParentDirs(targetFilePath);
|
|
||||||
FileUtil.writeBytes(bytes, targetFilePath);
|
|
||||||
return AmisResponse.responseSuccess(new SliceResponse(targetFilename));
|
|
||||||
}
|
|
||||||
|
|
||||||
private String sliceFilePath(Long uploadId, String sliceFilename) {
|
|
||||||
return StrUtil.format("{}/{}/{}", sliceFolderPath, uploadId, sliceFilename);
|
|
||||||
}
|
|
||||||
|
|
||||||
@PostMapping("finish")
|
|
||||||
public AmisResponse<FinishResponse> finish(@RequestBody FinishRequest request) {
|
|
||||||
if (request.partList.anySatisfy(part -> !FileUtil.exist(sliceFilePath(request.uploadId, part.eTag)))) {
|
|
||||||
throw new RuntimeException("文件校验失败,请重新上传");
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
File cacheFile = new File(StrUtil.format("{}/{}", cacheFolderPath, request.uploadId));
|
|
||||||
FileUtil.mkParentDirs(cacheFile);
|
|
||||||
if (cacheFile.createNewFile()) {
|
|
||||||
try (FileOutputStream fos = new FileOutputStream(cacheFile)) {
|
|
||||||
try (FileChannel fosChannel = fos.getChannel()) {
|
|
||||||
for (FinishRequest.Part part : request.partList) {
|
|
||||||
File sliceFile = new File(sliceFilePath(request.uploadId, part.eTag));
|
|
||||||
try (FileInputStream fis = new FileInputStream(sliceFile)) {
|
|
||||||
try (FileChannel fisChannel = fis.getChannel()) {
|
|
||||||
fisChannel.transferTo(0, fisChannel.size(), fosChannel);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
String md5 = SecureUtil.md5(cacheFile);
|
|
||||||
File targetFile = new File(StrUtil.format("{}/{}", uploadFolderPath, md5));
|
|
||||||
if (!targetFile.exists()) {
|
|
||||||
FileUtil.move(cacheFile, targetFile, true);
|
|
||||||
}
|
|
||||||
String absolutePath = FileUtil.getAbsolutePath(targetFile);
|
|
||||||
dataFileService.updateDataFile(
|
|
||||||
request.uploadId,
|
|
||||||
absolutePath,
|
|
||||||
FileUtil.size(targetFile),
|
|
||||||
SecureUtil.md5(targetFile),
|
|
||||||
FileUtil.getMimeType(absolutePath)
|
|
||||||
);
|
|
||||||
return AmisResponse.responseSuccess(new FinishResponse(
|
|
||||||
request.uploadId,
|
|
||||||
request.filename,
|
|
||||||
request.uploadId.toString(),
|
|
||||||
StrUtil.format("{}/upload/download/{}", knowledgeConfiguration.getDownloadPrefix(), request.uploadId)
|
|
||||||
));
|
|
||||||
} else {
|
|
||||||
throw new RuntimeException("合并文件失败");
|
|
||||||
}
|
|
||||||
} catch (Throwable throwable) {
|
|
||||||
throw new RuntimeException(throwable);
|
|
||||||
} finally {
|
|
||||||
FileUtil.del(StrUtil.format("{}/{}", cacheFolderPath, request.uploadId));
|
|
||||||
FileUtil.del(StrUtil.format("{}/{}", sliceFolderPath, request.uploadId));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static final class StartRequest {
|
|
||||||
private String name;
|
|
||||||
private String filename;
|
|
||||||
|
|
||||||
public String getName() {
|
|
||||||
return name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setName(String name) {
|
|
||||||
this.name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getFilename() {
|
|
||||||
return filename;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setFilename(String filename) {
|
|
||||||
this.filename = filename;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "StartRequest{" +
|
|
||||||
"name='" + name + '\'' +
|
|
||||||
", filename='" + filename + '\'' +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static final class StartResponse {
|
|
||||||
private String uploadId;
|
|
||||||
|
|
||||||
public StartResponse() {
|
|
||||||
}
|
|
||||||
|
|
||||||
public StartResponse(String uploadId) {
|
|
||||||
this.uploadId = uploadId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getUploadId() {
|
|
||||||
return uploadId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setUploadId(String uploadId) {
|
|
||||||
this.uploadId = uploadId;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "StartResponse{" +
|
|
||||||
"uploadId='" + uploadId + '\'' +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static final class SliceResponse {
|
|
||||||
@JsonProperty("eTag")
|
|
||||||
private String eTag;
|
|
||||||
|
|
||||||
public SliceResponse() {
|
|
||||||
}
|
|
||||||
|
|
||||||
public SliceResponse(String eTag) {
|
|
||||||
this.eTag = eTag;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String geteTag() {
|
|
||||||
return eTag;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void seteTag(String eTag) {
|
|
||||||
this.eTag = eTag;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "SliceResponse{" +
|
|
||||||
"eTag='" + eTag + '\'' +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static final class FinishRequest {
|
|
||||||
private String filename;
|
|
||||||
private Long uploadId;
|
|
||||||
private ImmutableList<Part> partList;
|
|
||||||
|
|
||||||
public String getFilename() {
|
|
||||||
return filename;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setFilename(String filename) {
|
|
||||||
this.filename = filename;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getUploadId() {
|
|
||||||
return uploadId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setUploadId(Long uploadId) {
|
|
||||||
this.uploadId = uploadId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public ImmutableList<Part> getPartList() {
|
|
||||||
return partList;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setPartList(ImmutableList<Part> partList) {
|
|
||||||
this.partList = partList;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "FinishRequest{" +
|
|
||||||
"filename='" + filename + '\'' +
|
|
||||||
", uploadId=" + uploadId +
|
|
||||||
", partList=" + partList +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
|
|
||||||
public static final class Part {
|
|
||||||
private Integer partNumber;
|
|
||||||
@JsonProperty("eTag")
|
|
||||||
private String eTag;
|
|
||||||
|
|
||||||
public Integer getPartNumber() {
|
|
||||||
return partNumber;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setPartNumber(Integer partNumber) {
|
|
||||||
this.partNumber = partNumber;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String geteTag() {
|
|
||||||
return eTag;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void seteTag(String eTag) {
|
|
||||||
this.eTag = eTag;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "Part{" +
|
|
||||||
"partNumber=" + partNumber +
|
|
||||||
", eTag='" + eTag + '\'' +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static final class FinishResponse {
|
|
||||||
private Long id;
|
|
||||||
private String filename;
|
|
||||||
private String value;
|
|
||||||
private String url;
|
|
||||||
|
|
||||||
public FinishResponse() {
|
|
||||||
}
|
|
||||||
|
|
||||||
public FinishResponse(Long id, String filename, String value, String url) {
|
|
||||||
this.id = id;
|
|
||||||
this.filename = filename;
|
|
||||||
this.value = value;
|
|
||||||
this.url = url;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId(Long id) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getFilename() {
|
|
||||||
return filename;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setFilename(String filename) {
|
|
||||||
this.filename = filename;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setValue(String value) {
|
|
||||||
this.value = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getUrl() {
|
|
||||||
return url;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setUrl(String url) {
|
|
||||||
this.url = url;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "FinishResponse{" +
|
|
||||||
"id=" + id +
|
|
||||||
", filename='" + filename + '\'' +
|
|
||||||
", value='" + value + '\'' +
|
|
||||||
", url='" + url + '\'' +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,38 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.knowledge.controller;
|
|
||||||
|
|
||||||
import com.lanyuanxiaoyao.service.ai.core.entity.amis.AmisResponse;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.knowledge.service.GroupService;
|
|
||||||
import java.util.concurrent.ExecutionException;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestParam;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250528
|
|
||||||
*/
|
|
||||||
@RestController
|
|
||||||
@RequestMapping("group")
|
|
||||||
public class GroupController {
|
|
||||||
private static final Logger logger = LoggerFactory.getLogger(GroupController.class);
|
|
||||||
|
|
||||||
private final GroupService groupService;
|
|
||||||
|
|
||||||
public GroupController(GroupService groupService) {
|
|
||||||
this.groupService = groupService;
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("list")
|
|
||||||
public AmisResponse<?> list(@RequestParam("knowledge_id") Long knowledgeId) {
|
|
||||||
return AmisResponse.responseCrudData(groupService.list(knowledgeId));
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("delete")
|
|
||||||
public AmisResponse<?> delete(@RequestParam("id") Long id) throws ExecutionException, InterruptedException {
|
|
||||||
groupService.remove(id);
|
|
||||||
return AmisResponse.responseSuccess();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,108 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.knowledge.controller;
|
|
||||||
|
|
||||||
import cn.hutool.core.util.StrUtil;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.core.entity.amis.AmisMapResponse;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.core.entity.amis.AmisResponse;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.knowledge.entity.vo.SegmentVO;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.knowledge.service.EmbeddingService;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.knowledge.service.KnowledgeService;
|
|
||||||
import java.util.concurrent.ExecutionException;
|
|
||||||
import org.eclipse.collections.api.factory.Lists;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
|
||||||
import org.springframework.web.bind.annotation.PostMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestParam;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250515
|
|
||||||
*/
|
|
||||||
@RestController
|
|
||||||
@RequestMapping("knowledge")
|
|
||||||
public class KnowledgeController {
|
|
||||||
private static final Logger logger = LoggerFactory.getLogger(KnowledgeController.class);
|
|
||||||
|
|
||||||
private final KnowledgeService knowledgeService;
|
|
||||||
private final EmbeddingService embeddingService;
|
|
||||||
|
|
||||||
public KnowledgeController(KnowledgeService knowledgeService, EmbeddingService embeddingService) {
|
|
||||||
this.knowledgeService = knowledgeService;
|
|
||||||
this.embeddingService = embeddingService;
|
|
||||||
}
|
|
||||||
|
|
||||||
@PostMapping("add")
|
|
||||||
public void add(
|
|
||||||
@RequestParam("name") String name,
|
|
||||||
@RequestParam("strategy") String strategy
|
|
||||||
) throws ExecutionException, InterruptedException {
|
|
||||||
knowledgeService.add(name, strategy);
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("name")
|
|
||||||
public AmisMapResponse name(@RequestParam("id") Long id) {
|
|
||||||
return AmisResponse.responseMapData()
|
|
||||||
.setData("name", knowledgeService.getName(id));
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("list")
|
|
||||||
public AmisResponse<?> list() {
|
|
||||||
return AmisResponse.responseCrudData(knowledgeService.list());
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("delete")
|
|
||||||
public void delete(@RequestParam("id") Long id) throws ExecutionException, InterruptedException {
|
|
||||||
knowledgeService.remove(id);
|
|
||||||
}
|
|
||||||
|
|
||||||
@PostMapping("preview_text")
|
|
||||||
public AmisResponse<?> previewText(
|
|
||||||
@RequestParam(value = "mode", defaultValue = "NORMAL") String mode,
|
|
||||||
@RequestParam(value = "type", defaultValue = "text") String type,
|
|
||||||
@RequestParam(value = "content", required = false) String content,
|
|
||||||
@RequestParam(value = "files", required = false) String files
|
|
||||||
) {
|
|
||||||
if (StrUtil.equals("text", type)) {
|
|
||||||
return AmisResponse.responseCrudData(
|
|
||||||
embeddingService.preview(mode, content)
|
|
||||||
.collect(doc -> {
|
|
||||||
SegmentVO vo = new SegmentVO();
|
|
||||||
vo.setId(doc.getId());
|
|
||||||
vo.setText(doc.getText());
|
|
||||||
return vo;
|
|
||||||
})
|
|
||||||
);
|
|
||||||
} else if (StrUtil.equals("file", type)) {
|
|
||||||
return AmisResponse.responseCrudData(
|
|
||||||
embeddingService.preview(mode, Lists.immutable.of(files.split(",")))
|
|
||||||
.collect(doc -> {
|
|
||||||
SegmentVO vo = new SegmentVO();
|
|
||||||
vo.setId(doc.getId());
|
|
||||||
vo.setText(doc.getText());
|
|
||||||
return vo;
|
|
||||||
})
|
|
||||||
);
|
|
||||||
} else {
|
|
||||||
throw new IllegalArgumentException("Unsupported type: " + type);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@PostMapping("submit_text")
|
|
||||||
public void submitText(
|
|
||||||
@RequestParam(value = "id") Long id,
|
|
||||||
@RequestParam(value = "mode", defaultValue = "NORMAL") String mode,
|
|
||||||
@RequestParam(value = "type", defaultValue = "text") String type,
|
|
||||||
@RequestParam(value = "content", required = false) String content,
|
|
||||||
@RequestParam(value = "files", required = false) String files
|
|
||||||
) {
|
|
||||||
if (StrUtil.equals("text", type)) {
|
|
||||||
embeddingService.submit(id, mode, content);
|
|
||||||
} else if (StrUtil.equals("file", type)) {
|
|
||||||
embeddingService.submit(id, mode, Lists.immutable.of(files.split(",")));
|
|
||||||
} else {
|
|
||||||
throw new IllegalArgumentException("Unsupported type: " + type);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,38 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.knowledge.controller;
|
|
||||||
|
|
||||||
import com.lanyuanxiaoyao.service.ai.core.entity.amis.AmisResponse;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.knowledge.service.SegmentService;
|
|
||||||
import java.util.concurrent.ExecutionException;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestParam;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250528
|
|
||||||
*/
|
|
||||||
@RestController
|
|
||||||
@RequestMapping("segment")
|
|
||||||
public class SegmentController {
|
|
||||||
private static final Logger logger = LoggerFactory.getLogger(SegmentController.class);
|
|
||||||
|
|
||||||
private final SegmentService segmentService;
|
|
||||||
|
|
||||||
public SegmentController(SegmentService segmentService) {
|
|
||||||
this.segmentService = segmentService;
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("list")
|
|
||||||
public AmisResponse<?> list(@RequestParam("knowledge_id") Long knowledgeId, @RequestParam("group_id") Long groupId) throws ExecutionException, InterruptedException {
|
|
||||||
return AmisResponse.responseCrudData(segmentService.list(knowledgeId, groupId));
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("delete")
|
|
||||||
public AmisResponse<?> delete(@RequestParam("knowledge_id") Long knowledgeId, @RequestParam("segment_id") Long segmentId) throws ExecutionException, InterruptedException {
|
|
||||||
segmentService.remove(knowledgeId, segmentId);
|
|
||||||
return AmisResponse.responseSuccess();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,202 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.knowledge.entity;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import org.eclipse.collections.api.factory.Lists;
|
|
||||||
import org.eclipse.collections.api.factory.Maps;
|
|
||||||
import org.springframework.ai.document.Document;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250523
|
|
||||||
*/
|
|
||||||
public class EmbeddingContext {
|
|
||||||
private Long vectorSourceId;
|
|
||||||
private Long groupId;
|
|
||||||
private Config config;
|
|
||||||
private String content;
|
|
||||||
private String file;
|
|
||||||
private String fileFormat;
|
|
||||||
private List<Document> documents = Lists.mutable.empty();
|
|
||||||
private Map<String, Object> metadata = Maps.mutable.empty();
|
|
||||||
|
|
||||||
private EmbeddingContext(Builder builder) {
|
|
||||||
setVectorSourceId(builder.vectorSourceId);
|
|
||||||
setGroupId(builder.groupId);
|
|
||||||
setConfig(builder.config);
|
|
||||||
setContent(builder.content);
|
|
||||||
setFile(builder.file);
|
|
||||||
setFileFormat(builder.fileFormat);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Builder builder() {
|
|
||||||
return new Builder();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getGroupId() {
|
|
||||||
return groupId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setGroupId(Long groupId) {
|
|
||||||
this.groupId = groupId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getVectorSourceId() {
|
|
||||||
return vectorSourceId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setVectorSourceId(Long vectorSourceId) {
|
|
||||||
this.vectorSourceId = vectorSourceId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Config getConfig() {
|
|
||||||
return config;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setConfig(Config config) {
|
|
||||||
this.config = config;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getContent() {
|
|
||||||
return content;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setContent(String content) {
|
|
||||||
this.content = content;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getFile() {
|
|
||||||
return file;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setFile(String file) {
|
|
||||||
this.file = file;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getFileFormat() {
|
|
||||||
return fileFormat;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setFileFormat(String fileFormat) {
|
|
||||||
this.fileFormat = fileFormat;
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<Document> getDocuments() {
|
|
||||||
return documents;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setDocuments(List<Document> documents) {
|
|
||||||
this.documents = documents;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Map<String, Object> getMetadata() {
|
|
||||||
return metadata;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setMetadata(Map<String, Object> metadata) {
|
|
||||||
this.metadata = metadata;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "EmbeddingContext{" +
|
|
||||||
"vectorSourceId=" + vectorSourceId +
|
|
||||||
", groupId=" + groupId +
|
|
||||||
", config=" + config +
|
|
||||||
", content='" + content + '\'' +
|
|
||||||
", file='" + file + '\'' +
|
|
||||||
", fileFormat='" + fileFormat + '\'' +
|
|
||||||
", documents=" + documents +
|
|
||||||
", metadata=" + metadata +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
|
|
||||||
public static final class Config {
|
|
||||||
private SplitStrategy splitStrategy = SplitStrategy.NORMAL;
|
|
||||||
|
|
||||||
private Config(Builder builder) {setSplitStrategy(builder.splitStrategy);}
|
|
||||||
|
|
||||||
public static Builder builder() {
|
|
||||||
return new Builder();
|
|
||||||
}
|
|
||||||
|
|
||||||
public SplitStrategy getSplitStrategy() {
|
|
||||||
return splitStrategy;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSplitStrategy(SplitStrategy splitStrategy) {
|
|
||||||
this.splitStrategy = splitStrategy;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "Config{" +
|
|
||||||
"splitStrategy=" + splitStrategy +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
|
|
||||||
public enum SplitStrategy {
|
|
||||||
NORMAL, LLM, QA
|
|
||||||
}
|
|
||||||
|
|
||||||
public static final class Builder {
|
|
||||||
private SplitStrategy splitStrategy;
|
|
||||||
|
|
||||||
private Builder() {}
|
|
||||||
|
|
||||||
public Builder splitStrategy(SplitStrategy val) {
|
|
||||||
splitStrategy = val;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Config build() {
|
|
||||||
return new Config(this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static final class Builder {
|
|
||||||
private Long vectorSourceId;
|
|
||||||
private Long groupId;
|
|
||||||
private Config config;
|
|
||||||
private String content;
|
|
||||||
private String file;
|
|
||||||
private String fileFormat;
|
|
||||||
|
|
||||||
private Builder() {}
|
|
||||||
|
|
||||||
public Builder vectorSourceId(Long val) {
|
|
||||||
vectorSourceId = val;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Builder groupId(Long val) {
|
|
||||||
groupId = val;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Builder config(Config val) {
|
|
||||||
config = val;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Builder content(String val) {
|
|
||||||
content = val;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Builder file(String val) {
|
|
||||||
file = val;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Builder fileFormat(String val) {
|
|
||||||
fileFormat = val;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public EmbeddingContext build() {
|
|
||||||
return new EmbeddingContext(this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,64 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.knowledge.entity;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250527
|
|
||||||
*/
|
|
||||||
public class Group {
|
|
||||||
private String id;
|
|
||||||
private String name;
|
|
||||||
private String status;
|
|
||||||
private Long createdTime;
|
|
||||||
private Long modifiedTime;
|
|
||||||
|
|
||||||
public String getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId(String id) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getName() {
|
|
||||||
return name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setName(String name) {
|
|
||||||
this.name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getStatus() {
|
|
||||||
return status;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setStatus(String status) {
|
|
||||||
this.status = status;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getCreatedTime() {
|
|
||||||
return createdTime;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setCreatedTime(Long createdTime) {
|
|
||||||
this.createdTime = createdTime;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getModifiedTime() {
|
|
||||||
return modifiedTime;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setModifiedTime(Long modifiedTime) {
|
|
||||||
this.modifiedTime = modifiedTime;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "GroupVO{" +
|
|
||||||
"id='" + id + '\'' +
|
|
||||||
", name='" + name + '\'' +
|
|
||||||
", status='" + status + '\'' +
|
|
||||||
", createdTime=" + createdTime +
|
|
||||||
", modifiedTime=" + modifiedTime +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,74 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.knowledge.entity;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250522
|
|
||||||
*/
|
|
||||||
public class Knowledge {
|
|
||||||
private Long id;
|
|
||||||
private Long vectorSourceId;
|
|
||||||
private String name;
|
|
||||||
private String strategy;
|
|
||||||
private Long createdTime;
|
|
||||||
private Long modifiedTime;
|
|
||||||
|
|
||||||
public Long getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId(Long id) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getVectorSourceId() {
|
|
||||||
return vectorSourceId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setVectorSourceId(Long vectorSourceId) {
|
|
||||||
this.vectorSourceId = vectorSourceId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getName() {
|
|
||||||
return name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setName(String name) {
|
|
||||||
this.name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getStrategy() {
|
|
||||||
return strategy;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setStrategy(String strategy) {
|
|
||||||
this.strategy = strategy;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getCreatedTime() {
|
|
||||||
return createdTime;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setCreatedTime(Long createdTime) {
|
|
||||||
this.createdTime = createdTime;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getModifiedTime() {
|
|
||||||
return modifiedTime;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setModifiedTime(Long modifiedTime) {
|
|
||||||
this.modifiedTime = modifiedTime;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "Knowledge{" +
|
|
||||||
"id=" + id +
|
|
||||||
", vectorSourceId=" + vectorSourceId +
|
|
||||||
", name='" + name + '\'' +
|
|
||||||
", strategy='" + strategy + '\'' +
|
|
||||||
", createdTime=" + createdTime +
|
|
||||||
", modifiedTime=" + modifiedTime +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,74 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.knowledge.entity.vo;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250527
|
|
||||||
*/
|
|
||||||
public class DataFileVO {
|
|
||||||
private String id;
|
|
||||||
private String filename;
|
|
||||||
private Long size;
|
|
||||||
private String md5;
|
|
||||||
private String path;
|
|
||||||
private String type;
|
|
||||||
|
|
||||||
public String getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId(String id) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getFilename() {
|
|
||||||
return filename;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setFilename(String filename) {
|
|
||||||
this.filename = filename;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getSize() {
|
|
||||||
return size;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSize(Long size) {
|
|
||||||
this.size = size;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getMd5() {
|
|
||||||
return md5;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setMd5(String md5) {
|
|
||||||
this.md5 = md5;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getPath() {
|
|
||||||
return path;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setPath(String path) {
|
|
||||||
this.path = path;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getType() {
|
|
||||||
return type;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setType(String type) {
|
|
||||||
this.type = type;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "DataFile{" +
|
|
||||||
"id='" + id + '\'' +
|
|
||||||
", filename='" + filename + '\'' +
|
|
||||||
", size=" + size +
|
|
||||||
", md5='" + md5 + '\'' +
|
|
||||||
", path='" + path + '\'' +
|
|
||||||
", type='" + type + '\'' +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,104 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.knowledge.entity.vo;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250516
|
|
||||||
*/
|
|
||||||
public class KnowledgeVO {
|
|
||||||
private String id;
|
|
||||||
private String name;
|
|
||||||
private String strategy;
|
|
||||||
private Long size;
|
|
||||||
private Long points;
|
|
||||||
private Long segments;
|
|
||||||
private String status;
|
|
||||||
private Long createdTime;
|
|
||||||
private Long modifiedTime;
|
|
||||||
|
|
||||||
public String getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId(String id) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getName() {
|
|
||||||
return name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setName(String name) {
|
|
||||||
this.name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getStrategy() {
|
|
||||||
return strategy;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setStrategy(String strategy) {
|
|
||||||
this.strategy = strategy;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getSize() {
|
|
||||||
return size;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSize(Long size) {
|
|
||||||
this.size = size;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getPoints() {
|
|
||||||
return points;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setPoints(Long points) {
|
|
||||||
this.points = points;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getSegments() {
|
|
||||||
return segments;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSegments(Long segments) {
|
|
||||||
this.segments = segments;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getStatus() {
|
|
||||||
return status;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setStatus(String status) {
|
|
||||||
this.status = status;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getCreatedTime() {
|
|
||||||
return createdTime;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setCreatedTime(Long createdTime) {
|
|
||||||
this.createdTime = createdTime;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getModifiedTime() {
|
|
||||||
return modifiedTime;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setModifiedTime(Long modifiedTime) {
|
|
||||||
this.modifiedTime = modifiedTime;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "KnowledgeVO{" +
|
|
||||||
"id='" + id + '\'' +
|
|
||||||
", name='" + name + '\'' +
|
|
||||||
", strategy='" + strategy + '\'' +
|
|
||||||
", size=" + size +
|
|
||||||
", points=" + points +
|
|
||||||
", segments=" + segments +
|
|
||||||
", status='" + status + '\'' +
|
|
||||||
", createdTime=" + createdTime +
|
|
||||||
", modifiedTime=" + modifiedTime +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,34 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.knowledge.entity.vo;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250516
|
|
||||||
*/
|
|
||||||
public class SegmentVO {
|
|
||||||
private String id;
|
|
||||||
private String text;
|
|
||||||
|
|
||||||
public String getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId(String id) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getText() {
|
|
||||||
return text;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setText(String text) {
|
|
||||||
this.text = text;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "PointVO{" +
|
|
||||||
"id='" + id + '\'' +
|
|
||||||
", text='" + text + '\'' +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,91 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.knowledge.service;
|
|
||||||
|
|
||||||
import club.kingon.sql.builder.SqlBuilder;
|
|
||||||
import cn.hutool.core.util.IdUtil;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.knowledge.entity.vo.DataFileVO;
|
|
||||||
import com.lanyuanxiaoyao.service.common.Constants;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.jdbc.core.JdbcTemplate;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250527
|
|
||||||
*/
|
|
||||||
@Service
|
|
||||||
public class DataFileService {
|
|
||||||
private static final Logger log = LoggerFactory.getLogger(DataFileService.class);
|
|
||||||
private static final String DATA_FILE_TABLE_NAME = Constants.DATABASE_NAME + ".service_ai_file";
|
|
||||||
|
|
||||||
private final JdbcTemplate template;
|
|
||||||
|
|
||||||
public DataFileService(JdbcTemplate template) {
|
|
||||||
this.template = template;
|
|
||||||
}
|
|
||||||
|
|
||||||
public DataFileVO downloadFile(Long id) {
|
|
||||||
return template.queryForObject(
|
|
||||||
SqlBuilder.select("id", "filename", "size", "md5", "path", "type")
|
|
||||||
.from(DATA_FILE_TABLE_NAME)
|
|
||||||
.whereEq("id", "?")
|
|
||||||
.precompileSql(),
|
|
||||||
(rs, row) -> {
|
|
||||||
DataFileVO vo = new DataFileVO();
|
|
||||||
vo.setId(String.valueOf(rs.getLong(1)));
|
|
||||||
vo.setFilename(rs.getString(2));
|
|
||||||
vo.setSize(rs.getLong(3));
|
|
||||||
vo.setMd5(rs.getString(4));
|
|
||||||
vo.setPath(rs.getString(5));
|
|
||||||
vo.setType(rs.getString(6));
|
|
||||||
return vo;
|
|
||||||
},
|
|
||||||
id
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Transactional(rollbackFor = Exception.class)
|
|
||||||
public Long initialDataFile(String filename) {
|
|
||||||
long id = IdUtil.getSnowflakeNextId();
|
|
||||||
template.update(
|
|
||||||
SqlBuilder.insertInto(DATA_FILE_TABLE_NAME, "id", "filename")
|
|
||||||
.values()
|
|
||||||
.addValue("?", "?")
|
|
||||||
.precompileSql(),
|
|
||||||
id,
|
|
||||||
filename
|
|
||||||
);
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Transactional(rollbackFor = Exception.class)
|
|
||||||
public void updateDataFile(Long id, String path, Long size, String md5, String type) {
|
|
||||||
template.update(
|
|
||||||
SqlBuilder.update(DATA_FILE_TABLE_NAME)
|
|
||||||
.set("size", "?")
|
|
||||||
.addSet("md5", "?")
|
|
||||||
.addSet("path", "?")
|
|
||||||
.addSet("type", "?")
|
|
||||||
.whereEq("id", "?")
|
|
||||||
.precompileSql(),
|
|
||||||
size,
|
|
||||||
md5,
|
|
||||||
path,
|
|
||||||
type,
|
|
||||||
id
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static final class DataFileNotFoundException extends RuntimeException {
|
|
||||||
public DataFileNotFoundException() {
|
|
||||||
super("文件未找到,请重新上传");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static final class UpdateDataFileFailedException extends RuntimeException {
|
|
||||||
public UpdateDataFileFailedException() {
|
|
||||||
super("更新文件信息失败,请重新上传");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,107 +0,0 @@
|
|||||||
package com.lanyuanxiaoyao.service.ai.knowledge.service;
|
|
||||||
|
|
||||||
import cn.hutool.core.io.FileUtil;
|
|
||||||
import cn.hutool.core.lang.Pair;
|
|
||||||
import cn.hutool.core.util.IdUtil;
|
|
||||||
import cn.hutool.core.util.StrUtil;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.knowledge.entity.EmbeddingContext;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.knowledge.entity.Knowledge;
|
|
||||||
import com.lanyuanxiaoyao.service.ai.knowledge.entity.vo.DataFileVO;
|
|
||||||
import com.yomahub.liteflow.core.FlowExecutor;
|
|
||||||
import java.nio.charset.StandardCharsets;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.concurrent.ExecutorService;
|
|
||||||
import java.util.concurrent.Executors;
|
|
||||||
import org.eclipse.collections.api.factory.Lists;
|
|
||||||
import org.eclipse.collections.api.list.ImmutableList;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.ai.document.Document;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author lanyuanxiaoyao
|
|
||||||
* @version 20250522
|
|
||||||
*/
|
|
||||||
@Service
|
|
||||||
public class EmbeddingService {
|
|
||||||
private static final Logger logger = LoggerFactory.getLogger(EmbeddingService.class);
|
|
||||||
|
|
||||||
private final DataFileService dataFileService;
|
|
||||||
private final FlowExecutor executor;
|
|
||||||
private final KnowledgeService knowledgeService;
|
|
||||||
private final GroupService groupService;
|
|
||||||
private final ExecutorService executors = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors());
|
|
||||||
|
|
||||||
@SuppressWarnings("SpringJavaInjectionPointsAutowiringInspection")
|
|
||||||
public EmbeddingService(DataFileService dataFileService, FlowExecutor executor, KnowledgeService knowledgeService, GroupService groupService) {
|
|
||||||
this.dataFileService = dataFileService;
|
|
||||||
this.executor = executor;
|
|
||||||
this.knowledgeService = knowledgeService;
|
|
||||||
this.groupService = groupService;
|
|
||||||
}
|
|
||||||
|
|
||||||
public ImmutableList<Document> preview(String mode, String content) {
|
|
||||||
if (content.length() > 2000) {
|
|
||||||
content = content.substring(0, 2000);
|
|
||||||
}
|
|
||||||
EmbeddingContext context = EmbeddingContext.builder()
|
|
||||||
.content(content)
|
|
||||||
.config(EmbeddingContext.Config.builder()
|
|
||||||
.splitStrategy(EmbeddingContext.Config.SplitStrategy.valueOf(mode))
|
|
||||||
.build())
|
|
||||||
.build();
|
|
||||||
executor.execute2Resp("embedding_preview", null, context);
|
|
||||||
return Lists.immutable.ofAll(context.getDocuments());
|
|
||||||
}
|
|
||||||
|
|
||||||
public ImmutableList<Document> preview(String mode, ImmutableList<String> ids) {
|
|
||||||
DataFileVO vo = dataFileService.downloadFile(Long.parseLong(ids.get(0)));
|
|
||||||
String content = FileUtil.readString(vo.getPath(), StandardCharsets.UTF_8);
|
|
||||||
return preview(mode, content);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void submit(Long id, String mode, String content) {
|
|
||||||
executors.submit(() -> {
|
|
||||||
Knowledge knowledge = knowledgeService.get(id);
|
|
||||||
Long groupId = groupService.add(knowledge.getId(), StrUtil.format("文本-{}", IdUtil.nanoId(10)));
|
|
||||||
EmbeddingContext context = EmbeddingContext.builder()
|
|
||||||
.vectorSourceId(knowledge.getVectorSourceId())
|
|
||||||
.groupId(groupId)
|
|
||||||
.content(content)
|
|
||||||
.config(EmbeddingContext.Config.builder()
|
|
||||||
.splitStrategy(EmbeddingContext.Config.SplitStrategy.valueOf(mode))
|
|
||||||
.build())
|
|
||||||
.build();
|
|
||||||
executor.execute2Resp("embedding_submit", null, context);
|
|
||||||
groupService.finish(groupId);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public void submit(Long id, String mode, ImmutableList<String> ids) {
|
|
||||||
executors.submit(() -> {
|
|
||||||
Knowledge knowledge = knowledgeService.get(id);
|
|
||||||
List<Pair<Long, DataFileVO>> vos = Lists.mutable.empty();
|
|
||||||
for (String fileId : ids) {
|
|
||||||
DataFileVO vo = dataFileService.downloadFile(Long.parseLong(fileId));
|
|
||||||
Long groupId = groupService.add(id, vo.getFilename());
|
|
||||||
vos.add(Pair.of(groupId, vo));
|
|
||||||
}
|
|
||||||
for (Pair<Long, DataFileVO> pair : vos) {
|
|
||||||
Long groupId = pair.getKey();
|
|
||||||
DataFileVO vo = pair.getValue();
|
|
||||||
EmbeddingContext context = EmbeddingContext.builder()
|
|
||||||
.vectorSourceId(knowledge.getVectorSourceId())
|
|
||||||
.groupId(groupId)
|
|
||||||
.file(vo.getPath())
|
|
||||||
.fileFormat(vo.getFilename())
|
|
||||||
.config(EmbeddingContext.Config.builder()
|
|
||||||
.splitStrategy(EmbeddingContext.Config.SplitStrategy.valueOf(mode))
|
|
||||||
.build())
|
|
||||||
.build();
|
|
||||||
executor.execute2Resp("embedding_submit", null, context);
|
|
||||||
groupService.finish(groupId);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user