mirror of
https://github.com/openimsdk/open-im-server.git
synced 2026-05-08 11:05:59 +08:00
Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 13b929444a |
@@ -15,33 +15,12 @@ jobs:
|
|||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
# submodules: "recursive"
|
|
||||||
|
|
||||||
- name: Safe submodule initialization
|
|
||||||
run: |
|
|
||||||
echo "Checking for submodules..."
|
|
||||||
if [ -f .gitmodules ]; then
|
|
||||||
if [ -s .gitmodules ]; then
|
|
||||||
echo "Initializing submodules..."
|
|
||||||
if git submodule sync --recursive 2>/dev/null; then
|
|
||||||
git submodule update --init --force --recursive || {
|
|
||||||
echo "Warning: Some submodules failed to initialize, continuing anyway..."
|
|
||||||
}
|
|
||||||
else
|
|
||||||
echo "Warning: Submodule sync failed, continuing without submodules..."
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo ".gitmodules exists but is empty, skipping submodule initialization"
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "No .gitmodules file found, no submodules to initialize"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Step 2: Set up Git with official account
|
# Step 2: Set up Git with official account
|
||||||
- name: Set up Git
|
- name: Set up Git
|
||||||
run: |
|
run: |
|
||||||
git config --global user.name "github-actions[bot]"
|
git config user.name "github-actions[bot]"
|
||||||
git config --global user.email "github-actions[bot]@users.noreply.github.com"
|
git config user.email "github-actions[bot]@users.noreply.github.com"
|
||||||
|
|
||||||
# Step 3: Check and delete existing tag
|
# Step 3: Check and delete existing tag
|
||||||
- name: Check and delete existing tag
|
- name: Check and delete existing tag
|
||||||
@@ -54,8 +33,7 @@ jobs:
|
|||||||
# Step 4: Update version file
|
# Step 4: Update version file
|
||||||
- name: Update version file
|
- name: Update version file
|
||||||
run: |
|
run: |
|
||||||
mkdir -p version
|
echo "${{ env.TAG_VERSION }}" > version/version
|
||||||
echo -n "${{ env.TAG_VERSION }}" > version/version
|
|
||||||
|
|
||||||
# Step 5: Commit and push changes
|
# Step 5: Commit and push changes
|
||||||
- name: Commit and push changes
|
- name: Commit and push changes
|
||||||
@@ -64,56 +42,43 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
git add version/version
|
git add version/version
|
||||||
git commit -m "Update version to ${{ env.TAG_VERSION }}"
|
git commit -m "Update version to ${{ env.TAG_VERSION }}"
|
||||||
|
git push origin HEAD:${{ github.ref }}
|
||||||
|
|
||||||
# Step 6: Update tag
|
# Step 6: Create and push tag
|
||||||
- name: Update tag
|
- name: Create and push tag
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
run: |
|
run: |
|
||||||
git tag -fa ${{ env.TAG_VERSION }} -m "Update version to ${{ env.TAG_VERSION }}"
|
git tag ${{ env.TAG_VERSION }}
|
||||||
git push origin ${{ env.TAG_VERSION }} --force
|
git push origin ${{ env.TAG_VERSION }}
|
||||||
|
|
||||||
# Step 7: Find and Publish Draft Release
|
# Step 7: Find and Publish Draft Release
|
||||||
- name: Find and Publish Draft Release
|
- name: Find and Publish Draft Release
|
||||||
uses: actions/github-script@v7
|
uses: actions/github-script@v6
|
||||||
with:
|
with:
|
||||||
github-token: ${{ secrets.GITHUB_TOKEN }}
|
github-token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
script: |
|
script: |
|
||||||
const { owner, repo } = context.repo;
|
// Get the list of releases
|
||||||
const tagName = process.env.TAG_VERSION;
|
const releases = await github.rest.repos.listReleases({
|
||||||
|
owner: context.repo.owner,
|
||||||
|
repo: context.repo.repo
|
||||||
|
});
|
||||||
|
|
||||||
try {
|
// Find the draft release where the title and tag_name are the same
|
||||||
let release;
|
const draftRelease = releases.data.find(release =>
|
||||||
try {
|
release.draft && release.name === release.tag_name
|
||||||
const response = await github.rest.repos.getReleaseByTag({
|
);
|
||||||
owner,
|
|
||||||
repo,
|
|
||||||
tag: tagName
|
|
||||||
});
|
|
||||||
release = response.data;
|
|
||||||
} catch (tagError) {
|
|
||||||
core.info(`Release not found by tag, searching all releases...`);
|
|
||||||
const releases = await github.rest.repos.listReleases({
|
|
||||||
owner,
|
|
||||||
repo,
|
|
||||||
per_page: 100
|
|
||||||
});
|
|
||||||
|
|
||||||
release = releases.data.find(r => r.draft && r.tag_name === tagName);
|
|
||||||
if (!release) {
|
|
||||||
throw new Error(`No release found with tag ${tagName}`);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
if (draftRelease) {
|
||||||
|
// Publish the draft release using the release_id
|
||||||
await github.rest.repos.updateRelease({
|
await github.rest.repos.updateRelease({
|
||||||
owner,
|
owner: context.repo.owner,
|
||||||
repo,
|
repo: context.repo.repo,
|
||||||
release_id: release.id,
|
release_id: draftRelease.id, // Use release_id
|
||||||
draft: false,
|
draft: false
|
||||||
prerelease: release.prerelease
|
|
||||||
});
|
});
|
||||||
|
|
||||||
const status = release.draft ? "was draft" : "was already published";
|
core.info(`Draft Release ${draftRelease.tag_name} published successfully.`);
|
||||||
core.info(`Release ${tagName} ensured to be published (${status}).`);
|
} else {
|
||||||
|
core.info("No matching draft release found.");
|
||||||
} catch (error) {
|
|
||||||
core.warning(`Could not find or update release for tag ${tagName}: ${error.message}`);
|
|
||||||
}
|
}
|
||||||
@@ -103,24 +103,22 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg
|
|||||||
}
|
}
|
||||||
userClient := rpcli.NewUserClient(userConn)
|
userClient := rpcli.NewUserClient(userConn)
|
||||||
|
|
||||||
database := controller.NewFriendDatabase(
|
|
||||||
friendMongoDB,
|
|
||||||
friendRequestMongoDB,
|
|
||||||
redis.NewFriendCacheRedis(rdb, &config.LocalCacheConfig, friendMongoDB, redis.GetRocksCacheOptions()),
|
|
||||||
mgocli.GetTx(),
|
|
||||||
)
|
|
||||||
// Initialize notification sender
|
// Initialize notification sender
|
||||||
notificationSender := NewFriendNotificationSender(
|
notificationSender := NewFriendNotificationSender(
|
||||||
&config.NotificationConfig,
|
&config.NotificationConfig,
|
||||||
rpcli.NewMsgClient(msgConn),
|
rpcli.NewMsgClient(msgConn),
|
||||||
WithRpcFunc(userClient.GetUsersInfo),
|
WithRpcFunc(userClient.GetUsersInfo),
|
||||||
WithFriendDB(database),
|
|
||||||
)
|
)
|
||||||
localcache.InitLocalCache(&config.LocalCacheConfig)
|
localcache.InitLocalCache(&config.LocalCacheConfig)
|
||||||
|
|
||||||
// Register Friend server with refactored MongoDB and Redis integrations
|
// Register Friend server with refactored MongoDB and Redis integrations
|
||||||
relation.RegisterFriendServer(server, &friendServer{
|
relation.RegisterFriendServer(server, &friendServer{
|
||||||
db: database,
|
db: controller.NewFriendDatabase(
|
||||||
|
friendMongoDB,
|
||||||
|
friendRequestMongoDB,
|
||||||
|
redis.NewFriendCacheRedis(rdb, &config.LocalCacheConfig, friendMongoDB, redis.GetRocksCacheOptions()),
|
||||||
|
mgocli.GetTx(),
|
||||||
|
),
|
||||||
blackDatabase: controller.NewBlackDatabase(
|
blackDatabase: controller.NewBlackDatabase(
|
||||||
blackMongoDB,
|
blackMongoDB,
|
||||||
redis.NewBlackCacheRedis(rdb, &config.LocalCacheConfig, blackMongoDB, redis.GetRocksCacheOptions()),
|
redis.NewBlackCacheRedis(rdb, &config.LocalCacheConfig, blackMongoDB, redis.GetRocksCacheOptions()),
|
||||||
|
|||||||
@@ -17,11 +17,8 @@ package third
|
|||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
"time"
|
|
||||||
|
|
||||||
"github.com/openimsdk/open-im-server/v3/pkg/rpcli"
|
"github.com/openimsdk/open-im-server/v3/pkg/rpcli"
|
||||||
"github.com/openimsdk/tools/s3/aws"
|
"time"
|
||||||
"github.com/openimsdk/tools/s3/disable"
|
|
||||||
|
|
||||||
"github.com/openimsdk/open-im-server/v3/pkg/common/config"
|
"github.com/openimsdk/open-im-server/v3/pkg/common/config"
|
||||||
"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache/redis"
|
"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache/redis"
|
||||||
@@ -93,10 +90,6 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg
|
|||||||
o, err = oss.NewOSS(*config.RpcConfig.Object.Oss.Build())
|
o, err = oss.NewOSS(*config.RpcConfig.Object.Oss.Build())
|
||||||
case "kodo":
|
case "kodo":
|
||||||
o, err = kodo.NewKodo(*config.RpcConfig.Object.Kodo.Build())
|
o, err = kodo.NewKodo(*config.RpcConfig.Object.Kodo.Build())
|
||||||
case "aws":
|
|
||||||
o, err = aws.NewAws(*config.RpcConfig.Object.Aws.Build())
|
|
||||||
case "":
|
|
||||||
o = disable.NewDisable()
|
|
||||||
default:
|
default:
|
||||||
err = fmt.Errorf("invalid object enable: %s", enable)
|
err = fmt.Errorf("invalid object enable: %s", enable)
|
||||||
}
|
}
|
||||||
|
|||||||
+1
-1
@@ -1 +1 @@
|
|||||||
v3.8.3-patch.6
|
v3.8.3-patch.5
|
||||||
|
|||||||
+1
-9
@@ -1,14 +1,6 @@
|
|||||||
package version
|
package version
|
||||||
|
|
||||||
import (
|
import _ "embed"
|
||||||
_ "embed"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
//go:embed version
|
//go:embed version
|
||||||
var Version string
|
var Version string
|
||||||
|
|
||||||
func init() {
|
|
||||||
Version = strings.Trim(Version, "\n")
|
|
||||||
Version = strings.TrimSpace(Version)
|
|
||||||
}
|
|
||||||
|
|||||||
Reference in New Issue
Block a user