mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-25 20:52:11 +08:00 
			
		
		
		
	Merge pull request #3494 from withchao/pre-release-v3.8.4
feat: merge main branch
This commit is contained in:
		
						commit
						4f6d5ebfc9
					
				
							
								
								
									
										3
									
								
								.env
									
									
									
									
									
								
							
							
						
						
									
										3
									
								
								.env
									
									
									
									
									
								
							| @ -2,7 +2,7 @@ MONGO_IMAGE=mongo:7.0 | |||||||
| REDIS_IMAGE=redis:7.0.0 | REDIS_IMAGE=redis:7.0.0 | ||||||
| KAFKA_IMAGE=bitnami/kafka:3.5.1 | KAFKA_IMAGE=bitnami/kafka:3.5.1 | ||||||
| MINIO_IMAGE=minio/minio:RELEASE.2024-01-11T07-46-16Z | MINIO_IMAGE=minio/minio:RELEASE.2024-01-11T07-46-16Z | ||||||
| ETCD_IMAGE=quay.io/coreos/etcd:v3.5.13 | ETCD_IMAGE=bitnami/etcd:3.5.13 | ||||||
| PROMETHEUS_IMAGE=prom/prometheus:v2.45.6 | PROMETHEUS_IMAGE=prom/prometheus:v2.45.6 | ||||||
| ALERTMANAGER_IMAGE=prom/alertmanager:v0.27.0 | ALERTMANAGER_IMAGE=prom/alertmanager:v0.27.0 | ||||||
| GRAFANA_IMAGE=grafana/grafana:11.0.1 | GRAFANA_IMAGE=grafana/grafana:11.0.1 | ||||||
| @ -22,4 +22,3 @@ MONGO_BACKUP_DIR=${DATA_DIR}components/backup/mongo/ | |||||||
| PROMETHEUS_PORT=19091 | PROMETHEUS_PORT=19091 | ||||||
| ALERTMANAGER_PORT=19093 | ALERTMANAGER_PORT=19093 | ||||||
| GRAFANA_PORT=13000 | GRAFANA_PORT=13000 | ||||||
| NODE_EXPORTER_PORT=19100 |  | ||||||
							
								
								
									
										2
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
								
							| @ -4,7 +4,7 @@ contact_links: | |||||||
|   #   description: "Report a bug in the project" |   #   description: "Report a bug in the project" | ||||||
|   #   file: "bug-report.yml" |   #   file: "bug-report.yml" | ||||||
|   - name: 📢 Connect on slack |   - name: 📢 Connect on slack | ||||||
|     url: https://join.slack.com/t/openimsdk/shared_invite/zt-1tmoj26uf-_FDy3dowVHBiGvLk9e5Xkg |     url: https://join.slack.com/t/openimsdk/shared_invite/zt-2ijy1ys1f-O0aEDCr7ExRZ7mwsHAVg9A | ||||||
|     about: Support OpenIM-related requests or issues, get in touch with developers and help on slack |     about: Support OpenIM-related requests or issues, get in touch with developers and help on slack | ||||||
|   - name: 🌐 OpenIM Blog |   - name: 🌐 OpenIM Blog | ||||||
|     url: https://www.openim.io/ |     url: https://www.openim.io/ | ||||||
|  | |||||||
							
								
								
									
										3
									
								
								.github/ISSUE_TEMPLATE/other.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.github/ISSUE_TEMPLATE/other.yml
									
									
									
									
										vendored
									
									
								
							| @ -4,7 +4,6 @@ title: "[Other]: <give this problem a name>" | |||||||
| labels: ["other"] | labels: ["other"] | ||||||
| # assignees: [] | # assignees: [] | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| body: | body: | ||||||
|   - type: markdown |   - type: markdown | ||||||
|     attributes: |     attributes: | ||||||
| @ -26,5 +25,5 @@ body: | |||||||
|   - type: markdown |   - type: markdown | ||||||
|     attributes: |     attributes: | ||||||
|       value: | |       value: | | ||||||
|         You can also join our Discord community [here](https://join.slack.com/t/openimsdk/shared_invite/zt-1tmoj26uf-_FDy3dowVHBiGvLk9e5Xkg) |         You can also join our Discord community [here](https://join.slack.com/t/openimsdk/shared_invite/zt-2ijy1ys1f-O0aEDCr7ExRZ7mwsHAVg9A) | ||||||
|         Feel free to check out other cool repositories of the openim Community [here](https://github.com/openimsdk) |         Feel free to check out other cool repositories of the openim Community [here](https://github.com/openimsdk) | ||||||
|  | |||||||
							
								
								
									
										5
									
								
								.github/workflows/auto-invite-comment.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								.github/workflows/auto-invite-comment.yml
									
									
									
									
										vendored
									
									
								
							| @ -11,7 +11,6 @@ jobs: | |||||||
|     permissions: |     permissions: | ||||||
|       issues: write |       issues: write | ||||||
|     steps: |     steps: | ||||||
| 
 |  | ||||||
|       - name: Invite user to join OpenIM Community |       - name: Invite user to join OpenIM Community | ||||||
|         uses: peter-evans/create-or-update-comment@v4 |         uses: peter-evans/create-or-update-comment@v4 | ||||||
|         with: |         with: | ||||||
| @ -20,11 +19,11 @@ jobs: | |||||||
|           body: | |           body: | | ||||||
|             We value close connections with our users, developers, and contributors here at Open-IM-Server. With a large community and maintainer team, we're always here to help and support you. Whether you're looking to join our community or have any questions or suggestions, we welcome you to get in touch with us. |             We value close connections with our users, developers, and contributors here at Open-IM-Server. With a large community and maintainer team, we're always here to help and support you. Whether you're looking to join our community or have any questions or suggestions, we welcome you to get in touch with us. | ||||||
| 
 | 
 | ||||||
|             Our most recommended way to get in touch is through [Slack](https://join.slack.com/t/openimsdk/shared_invite/zt-22720d66b-o_FvKxMTGXtcnnnHiMqe9Q). Even if you're in China, Slack is usually not blocked by firewalls, making it an easy way to connect with us. Our Slack community is the ideal place to discuss and share ideas and suggestions with other users and developers of Open-IM-Server. You can ask technical questions, seek help, or share your experiences with other users of Open-IM-Server. |             Our most recommended way to get in touch is through [Slack](https://join.slack.com/t/openimsdk/shared_invite/zt-2ijy1ys1f-O0aEDCr7ExRZ7mwsHAVg9A). Even if you're in China, Slack is usually not blocked by firewalls, making it an easy way to connect with us. Our Slack community is the ideal place to discuss and share ideas and suggestions with other users and developers of Open-IM-Server. You can ask technical questions, seek help, or share your experiences with other users of Open-IM-Server. | ||||||
| 
 | 
 | ||||||
|             In addition to Slack, we also offer the following ways to get in touch: |             In addition to Slack, we also offer the following ways to get in touch: | ||||||
| 
 | 
 | ||||||
|             + <a href="https://join.slack.com/t/openimsdk/shared_invite/zt-22720d66b-o_FvKxMTGXtcnnnHiMqe9Q" target="_blank"><img src="https://img.shields.io/badge/Slack-OpenIM%2B-blueviolet?logo=slack&logoColor=white"></a> We also have Slack channels for you to communicate and discuss. To join, visit https://slack.com/ and join our [👀 Open-IM-Server slack](https://join.slack.com/t/openimsdk/shared_invite/zt-22720d66b-o_FvKxMTGXtcnnnHiMqe9Q) team channel. |             + <a href="https://join.slack.com/t/openimsdk/shared_invite/zt-2ijy1ys1f-O0aEDCr7ExRZ7mwsHAVg9A" target="_blank"><img src="https://img.shields.io/badge/Slack-OpenIM%2B-blueviolet?logo=slack&logoColor=white"></a> We also have Slack channels for you to communicate and discuss. To join, visit https://slack.com/ and join our [👀 Open-IM-Server slack](https://join.slack.com/t/openimsdk/shared_invite/zt-2ijy1ys1f-O0aEDCr7ExRZ7mwsHAVg9A) team channel. | ||||||
|             + <a href="https://mail.google.com/mail/u/0/?fs=1&tf=cm&to=info@openim.io" target="_blank"><img src="https://img.shields.io/badge/gmail-%40OOpenIMSDKCore?style=social&logo=gmail"></a> Get in touch with us on [Gmail](https://mail.google.com/mail/u/0/?fs=1&tf=cm&to=winxu81@gmail.com). If you have any questions or issues that need resolving, or any suggestions and feedback for our open source projects, please feel free to contact us via email. |             + <a href="https://mail.google.com/mail/u/0/?fs=1&tf=cm&to=info@openim.io" target="_blank"><img src="https://img.shields.io/badge/gmail-%40OOpenIMSDKCore?style=social&logo=gmail"></a> Get in touch with us on [Gmail](https://mail.google.com/mail/u/0/?fs=1&tf=cm&to=winxu81@gmail.com). If you have any questions or issues that need resolving, or any suggestions and feedback for our open source projects, please feel free to contact us via email. | ||||||
|             + <a href="https://doc.rentsoft.cn/" target="_blank"><img src="https://img.shields.io/badge/%E5%8D%9A%E5%AE%A2-%40OpenIMSDKCore-blue?style=social&logo=Octopus%20Deploy"></a> Read our [blog](https://doc.rentsoft.cn/). Our blog is a great place to stay up-to-date with Open-IM-Server projects and trends. On the blog, we share our latest developments, tech trends, and other interesting information. |             + <a href="https://doc.rentsoft.cn/" target="_blank"><img src="https://img.shields.io/badge/%E5%8D%9A%E5%AE%A2-%40OpenIMSDKCore-blue?style=social&logo=Octopus%20Deploy"></a> Read our [blog](https://doc.rentsoft.cn/). Our blog is a great place to stay up-to-date with Open-IM-Server projects and trends. On the blog, we share our latest developments, tech trends, and other interesting information. | ||||||
|             + <a href="https://github.com/OpenIMSDK/OpenIM-Docs/blob/main/docs/images/WechatIMG20.jpeg" target="_blank"><img src="https://img.shields.io/badge/%E5%BE%AE%E4%BF%A1-OpenIMSDKCore-brightgreen?logo=wechat&style=flat-square"></a> Add [Wechat](https://github.com/OpenIMSDK/OpenIM-Docs/blob/main/docs/images/WechatIMG20.jpeg) and indicate that you are a user or developer of Open-IM-Server. We will process your request as soon as possible. |             + <a href="https://github.com/OpenIMSDK/OpenIM-Docs/blob/main/docs/images/WechatIMG20.jpeg" target="_blank"><img src="https://img.shields.io/badge/%E5%BE%AE%E4%BF%A1-OpenIMSDKCore-brightgreen?logo=wechat&style=flat-square"></a> Add [Wechat](https://github.com/OpenIMSDK/OpenIM-Docs/blob/main/docs/images/WechatIMG20.jpeg) and indicate that you are a user or developer of Open-IM-Server. We will process your request as soon as possible. | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.github/workflows/help-comment-issue.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/help-comment-issue.yml
									
									
									
									
										vendored
									
									
								
							| @ -32,5 +32,5 @@ jobs: | |||||||
|           token: ${{ secrets.BOT_TOKEN }} |           token: ${{ secrets.BOT_TOKEN }} | ||||||
|           body: | |           body: | | ||||||
|             This issue is available for anyone to work on. **Make sure to reference this issue in your pull request.** :sparkles: Thank you for your contribution! :sparkles: |             This issue is available for anyone to work on. **Make sure to reference this issue in your pull request.** :sparkles: Thank you for your contribution! :sparkles: | ||||||
|             [Join slack 🤖](https://join.slack.com/t/openimsdk/shared_invite/zt-22720d66b-o_FvKxMTGXtcnnnHiMqe9Q) to connect and communicate with our developers. |             [Join slack 🤖](https://join.slack.com/t/openimsdk/shared_invite/zt-2ijy1ys1f-O0aEDCr7ExRZ7mwsHAVg9A) to connect and communicate with our developers. | ||||||
|             If you wish to accept this assignment, please leave a comment in the comments section: `/accept`.🎯 |             If you wish to accept this assignment, please leave a comment in the comments section: `/accept`.🎯 | ||||||
|  | |||||||
							
								
								
									
										16
									
								
								.github/workflows/merge-from-milestone.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										16
									
								
								.github/workflows/merge-from-milestone.yml
									
									
									
									
										vendored
									
									
								
							| @ -155,6 +155,17 @@ jobs: | |||||||
|                   '{title: $title, head: $head, base: $base, body: $body}')") |                   '{title: $title, head: $head, base: $base, body: $body}')") | ||||||
| 
 | 
 | ||||||
|               new_pr_number=$(echo "$response" | jq -r '.number') |               new_pr_number=$(echo "$response" | jq -r '.number') | ||||||
|  | 
 | ||||||
|  |               if [[ "$new_pr_number" == "null" || -z "$new_pr_number" ]]; then | ||||||
|  |                 echo "Failed to create PR. Response: $response" | ||||||
|  |                | ||||||
|  |                 git checkout $TARGET_BRANCH | ||||||
|  | 
 | ||||||
|  |                 git branch -D $cherry_pick_branch | ||||||
|  |                  | ||||||
|  |                 echo "Deleted branch: $cherry_pick_branch" | ||||||
|  |                 git push origin --delete $cherry_pick_branch | ||||||
|  |               else | ||||||
|                 echo "Created PR #$new_pr_number" |                 echo "Created PR #$new_pr_number" | ||||||
| 
 | 
 | ||||||
|                 curl -s -X POST -H "Authorization: token $GITHUB_TOKEN" \ |                 curl -s -X POST -H "Authorization: token $GITHUB_TOKEN" \ | ||||||
| @ -162,4 +173,9 @@ jobs: | |||||||
|                 -d '{"labels": ["milestone-merge"]}' \ |                 -d '{"labels": ["milestone-merge"]}' \ | ||||||
|                 "https://api.github.com/repos/${{ github.repository }}/issues/$new_pr_number/labels" |                 "https://api.github.com/repos/${{ github.repository }}/issues/$new_pr_number/labels" | ||||||
|               fi |               fi | ||||||
|  | 
 | ||||||
|  |               echo "" | ||||||
|  |               echo "----------------------------------------" | ||||||
|  |               echo "" | ||||||
|  |             fi | ||||||
|           done |           done | ||||||
|  | |||||||
| @ -15,12 +15,33 @@ 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 user.name "github-actions[bot]" |           git config --global user.name "github-actions[bot]" | ||||||
|           git config user.email "github-actions[bot]@users.noreply.github.com" |           git config --global 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 | ||||||
| @ -33,7 +54,8 @@ jobs: | |||||||
|       # Step 4: Update version file |       # Step 4: Update version file | ||||||
|       - name: Update version file |       - name: Update version file | ||||||
|         run: | |         run: | | ||||||
|           echo "${{ env.TAG_VERSION }}" > version/version |           mkdir -p 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 | ||||||
| @ -42,43 +64,56 @@ 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: Create and push tag |       # Step 6: Update tag | ||||||
|       - name: Create and push tag |       - name: Update tag | ||||||
|         env: |  | ||||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
|         run: | |         run: | | ||||||
|           git tag ${{ env.TAG_VERSION }} |           git tag -fa ${{ env.TAG_VERSION }} -m "Update version to ${{ env.TAG_VERSION }}" | ||||||
|           git push origin ${{ env.TAG_VERSION }} |           git push origin ${{ env.TAG_VERSION }} --force | ||||||
| 
 | 
 | ||||||
|       # 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@v6 |         uses: actions/github-script@v7 | ||||||
|         with: |         with: | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|           script: | |           script: | | ||||||
|             // Get the list of releases |             const { owner, repo } = context.repo; | ||||||
|  |             const tagName = process.env.TAG_VERSION; | ||||||
|  | 
 | ||||||
|  |             try { | ||||||
|  |               let release; | ||||||
|  |               try { | ||||||
|  |                 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({ |                 const releases = await github.rest.repos.listReleases({ | ||||||
|               owner: context.repo.owner, |                   owner, | ||||||
|               repo: context.repo.repo |                   repo, | ||||||
|  |                   per_page: 100 | ||||||
|                 }); |                 }); | ||||||
|              |              | ||||||
|             // Find the draft release where the title and tag_name are the same |                 release = releases.data.find(r => r.draft && r.tag_name === tagName);             | ||||||
|             const draftRelease = releases.data.find(release =>  |                 if (!release) { | ||||||
|               release.draft && release.name === release.tag_name |                   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 | ||||||
|               }); |               }); | ||||||
| 
 |              | ||||||
|               core.info(`Draft Release ${draftRelease.tag_name} published successfully.`); |               const status = release.draft ? "was draft" : "was already published"; | ||||||
|             } else { |               core.info(`Release ${tagName} ensured to be published (${status}).`); | ||||||
|               core.info("No matching draft release found."); |              | ||||||
|  |             } catch (error) { | ||||||
|  |               core.warning(`Could not find or update release for tag ${tagName}: ${error.message}`); | ||||||
|             } |             } | ||||||
							
								
								
									
										4
									
								
								.github/workflows/user-first-interaction.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/user-first-interaction.yml
									
									
									
									
										vendored
									
									
								
							| @ -22,7 +22,7 @@ jobs: | |||||||
| 
 | 
 | ||||||
|             If you are implementing a feature request, please check with the maintainers that the feature will be accepted first. |             If you are implementing a feature request, please check with the maintainers that the feature will be accepted first. | ||||||
| 
 | 
 | ||||||
|             [Join slack 🤖](https://join.slack.com/t/openimsdk/shared_invite/zt-22720d66b-o_FvKxMTGXtcnnnHiMqe9Q) to connect and communicate with our developers. |             [Join slack 🤖](https://join.slack.com/t/openimsdk/shared_invite/zt-2ijy1ys1f-O0aEDCr7ExRZ7mwsHAVg9A) to connect and communicate with our developers. | ||||||
| 
 | 
 | ||||||
|             Please leave your information in the [✨ discussions](https://github.com/orgs/OpenIMSDK/discussions/426), we expect anyone to join OpenIM developer community. |             Please leave your information in the [✨ discussions](https://github.com/orgs/OpenIMSDK/discussions/426), we expect anyone to join OpenIM developer community. | ||||||
| 
 | 
 | ||||||
| @ -31,5 +31,5 @@ jobs: | |||||||
| 
 | 
 | ||||||
|             If this is a bug report, please include relevant logs to help us debug the problem. |             If this is a bug report, please include relevant logs to help us debug the problem. | ||||||
| 
 | 
 | ||||||
|             [Join slack 🤖](https://join.slack.com/t/openimsdk/shared_invite/zt-22720d66b-o_FvKxMTGXtcnnnHiMqe9Q) to connect and communicate with our developers. |             [Join slack 🤖](https://join.slack.com/t/openimsdk/shared_invite/zt-2ijy1ys1f-O0aEDCr7ExRZ7mwsHAVg9A) to connect and communicate with our developers. | ||||||
|         continue-on-error: true |         continue-on-error: true | ||||||
							
								
								
									
										70
									
								
								CHANGELOG/CHANGELOG-3.8.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								CHANGELOG/CHANGELOG-3.8.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,70 @@ | |||||||
|  | ## [v3.8.3-patch.6](https://github.com/openimsdk/open-im-server/releases/tag/v3.8.3-patch.6) 	(2025-07-23) | ||||||
|  | 
 | ||||||
|  | ### Bug Fixes | ||||||
|  | * fix: Add friend DB in notification sender [#3438](https://github.com/openimsdk/open-im-server/pull/3438) | ||||||
|  | * fix: remove update version file workflows have new line in 3.8.3-patch branch. [#3452](https://github.com/openimsdk/open-im-server/pull/3452) | ||||||
|  | * fix: s3 aws init [#3454](https://github.com/openimsdk/open-im-server/pull/3454) | ||||||
|  | * fix: use safe submodule init in workflows in v3.8.3-patch. [#3469](https://github.com/openimsdk/open-im-server/pull/3469) | ||||||
|  | 
 | ||||||
|  | **Full Changelog**: [v3.8.3-patch.5...v3.8.3-patch.6](https://github.com/openimsdk/open-im-server/compare/v3.8.3-patch.5...v3.8.3-patch.6) | ||||||
|  | 
 | ||||||
|  | ## [v3.8.3-patch.5](https://github.com/openimsdk/open-im-server/releases/tag/v3.8.3-patch.5) 	(2025-06-10) | ||||||
|  | 
 | ||||||
|  | ### New Features | ||||||
|  | * feat: optimize friend and group applications [#3396](https://github.com/openimsdk/open-im-server/pull/3396) | ||||||
|  | 
 | ||||||
|  | ### Bug Fixes | ||||||
|  | * fix: solve unocrrect invite notification [Created [#3219](https://github.com/openimsdk/open-im-server/pull/3219) | ||||||
|  | 
 | ||||||
|  | ### Builds | ||||||
|  | * build: update gomake version in dockerfile.[Patch branch] [#3416](https://github.com/openimsdk/open-im-server/pull/3416) | ||||||
|  | 
 | ||||||
|  | **Full Changelog**: [v3.8.3...v3.8.3-patch.5](https://github.com/openimsdk/open-im-server/compare/v3.8.3...v3.8.3-patch.5) | ||||||
|  | 
 | ||||||
|  | ## [v3.8.3-patch.4](https://github.com/openimsdk/open-im-server/releases/tag/v3.8.3-patch.4) 	(2025-03-13) | ||||||
|  | 
 | ||||||
|  | ### Bug Fixes | ||||||
|  | * fix: solve unocrrect invite notificationfrom #3213 | ||||||
|  | 
 | ||||||
|  | **Full Changelog**: [v3.8.3-patch.3...v3.8.3-patch.4](https://github.com/openimsdk/open-im-server/compare/v3.8.3-patch.3...v3.8.3-patch.4) | ||||||
|  | 
 | ||||||
|  | ## [v3.8.3-patch.3](https://github.com/openimsdk/open-im-server/releases/tag/v3.8.3-patch.3) 	(2025-03-07) | ||||||
|  | 
 | ||||||
|  | ### New Features | ||||||
|  | * feat: optimizing BatchGetIncrementalGroupMember #3180 | ||||||
|  | 
 | ||||||
|  | ### Bug Fixes | ||||||
|  | * fix: solve uncorrect notification when set group info #3172 | ||||||
|  | * fix: the sorting is wrong after canceling the administrator in group settings #3185 | ||||||
|  | * fix: solve uncorrect GroupMember enter group notification type. #3188 | ||||||
|  | 
 | ||||||
|  | ### Refactors | ||||||
|  | * refactor: change sendNotification to sendMessage to avoid ambiguity regarding message sending behavior. #3173 | ||||||
|  | 
 | ||||||
|  | **Full Changelog**: [v3.8.3-patch.2...v3.8.3-patch.3](https://github.com/openimsdk/open-im-server/compare/v3.8.3-patch.2...v3.8.3-patch.3) | ||||||
|  | 
 | ||||||
|  | ## [v3.8.3-patch.2](https://github.com/openimsdk/open-im-server/releases/tag/v3.8.3-patch.2) 	(2025-02-28) | ||||||
|  | 
 | ||||||
|  | ### Bug Fixes | ||||||
|  | * fix: Offline push does not have a badge && Android offline push (#3146) [#3174](https://github.com/openimsdk/open-im-server/pull/3174) | ||||||
|  | 
 | ||||||
|  | **Full Changelog**: [v3.8.3-patch.1...v3.8.3-patch.2](https://github.com/openimsdk/open-im-server/compare/v3.8.3-patch.1...v3.8.3-patch.2) | ||||||
|  | 
 | ||||||
|  | ## [v3.8.3-patch.1](https://github.com/openimsdk/open-im-server/releases/tag/v3.8.3-patch.1) 	(2025-02-25) | ||||||
|  | 
 | ||||||
|  | ### New Features | ||||||
|  | * feat: add backup volume && optimize log print [Created [#3121](https://github.com/openimsdk/open-im-server/pull/3121) | ||||||
|  | 
 | ||||||
|  | ### Bug Fixes | ||||||
|  | * fix: seq conversion failed without exiting [Created [#3120](https://github.com/openimsdk/open-im-server/pull/3120) | ||||||
|  | * fix: check error in BatchSetTokenMapByUidPid [Created [#3123](https://github.com/openimsdk/open-im-server/pull/3123) | ||||||
|  | * fix: DeleteDoc crash [Created [#3124](https://github.com/openimsdk/open-im-server/pull/3124) | ||||||
|  | * fix: the abnormal message has no sending time, causing the SDK to be abnormal [Created [#3126](https://github.com/openimsdk/open-im-server/pull/3126) | ||||||
|  | * fix: crash caused [#3127](https://github.com/openimsdk/open-im-server/pull/3127) | ||||||
|  | * fix: the user sets the conversation timer cleanup timestamp unit incorrectly [Created [#3128](https://github.com/openimsdk/open-im-server/pull/3128) | ||||||
|  | * fix: seq conversion not reading env in docker environment [Created [#3131](https://github.com/openimsdk/open-im-server/pull/3131) | ||||||
|  | 
 | ||||||
|  | ### Builds | ||||||
|  | * build: improve workflows contents. [Created [#3125](https://github.com/openimsdk/open-im-server/pull/3125) | ||||||
|  | 
 | ||||||
|  | **Full Changelog**: [v3.8.3-e-v1.1.5...v3.8.3-patch.1-e-v1.1.5](https://github.com/openimsdk/open-im-server-enterprise/compare/v3.8.3-e-v1.1.5...v3.8.3-patch.1-e-v1.1.5) | ||||||
							
								
								
									
										4
									
								
								CHANGELOG/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								CHANGELOG/README.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,4 @@ | |||||||
|  | # CHANGELOGs | ||||||
|  | 
 | ||||||
|  | - [CHANGELOG-3.8.md](./CHANGELOG-3.8.md) | ||||||
|  | 
 | ||||||
| @ -43,7 +43,7 @@ COPY --from=builder $SERVER_DIR/start-config.yml $SERVER_DIR/ | |||||||
| COPY --from=builder $SERVER_DIR/go.mod $SERVER_DIR/ | COPY --from=builder $SERVER_DIR/go.mod $SERVER_DIR/ | ||||||
| COPY --from=builder $SERVER_DIR/go.sum $SERVER_DIR/ | COPY --from=builder $SERVER_DIR/go.sum $SERVER_DIR/ | ||||||
| 
 | 
 | ||||||
| RUN go get github.com/openimsdk/gomake@v0.0.14-alpha.5 | RUN go get github.com/openimsdk/gomake@v0.0.15-alpha.1 | ||||||
| 
 | 
 | ||||||
| # Set the command to run when the container starts | # Set the command to run when the container starts | ||||||
| ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ||||||
|  | |||||||
							
								
								
									
										48
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										48
									
								
								README.md
									
									
									
									
									
								
							| @ -12,11 +12,11 @@ | |||||||
| [](https://goreportcard.com/report/github.com/openimsdk/open-im-server) | [](https://goreportcard.com/report/github.com/openimsdk/open-im-server) | ||||||
| [](https://pkg.go.dev/github.com/openimsdk/open-im-server/v3) | [](https://pkg.go.dev/github.com/openimsdk/open-im-server/v3) | ||||||
| [](https://github.com/openimsdk/open-im-server/blob/main/LICENSE) | [](https://github.com/openimsdk/open-im-server/blob/main/LICENSE) | ||||||
| [](https://join.slack.com/t/openimsdk/shared_invite/zt-22720d66b-o_FvKxMTGXtcnnnHiMqe9Q) | [](https://join.slack.com/t/openimsdk/shared_invite/zt-2ijy1ys1f-O0aEDCr7ExRZ7mwsHAVg9A) | ||||||
| [](https://www.bestpractices.dev/projects/8045) | [](https://www.bestpractices.dev/projects/8045) | ||||||
| [](https://github.com/openimsdk/open-im-server/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc+label%3A%22good+first+issue%22) | [](https://github.com/openimsdk/open-im-server/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc+label%3A%22good+first+issue%22) | ||||||
| [](https://golang.org/) | [](https://golang.org/) | ||||||
| 
 | [](https://gurubase.io/g/openim) | ||||||
| 
 | 
 | ||||||
| <p align="center"> | <p align="center"> | ||||||
|   <a href="./README.md">English</a> ·  |   <a href="./README.md">English</a> ·  | ||||||
| @ -46,16 +46,15 @@ | |||||||
|   <a href="./docs/readme/README_tr.md">Türkçe</a> |   <a href="./docs/readme/README_tr.md">Türkçe</a> | ||||||
| </p> | </p> | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| </div> | </div> | ||||||
| 
 | 
 | ||||||
| </p> | </p> | ||||||
| 
 | 
 | ||||||
| ## :busts_in_silhouette: Join Our Community | ## :busts_in_silhouette: Join Our Community | ||||||
| 
 | 
 | ||||||
| + 💬 [Follow us on Twitter](https://twitter.com/founder_im63606) | - 💬 [Follow us on Twitter](https://twitter.com/founder_im63606) | ||||||
| + 🚀 [Join our Slack](https://join.slack.com/t/openimsdk/shared_invite/zt-2ijy1ys1f-O0aEDCr7ExRZ7mwsHAVg9A) | - 🚀 [Join our Slack](https://join.slack.com/t/openimsdk/shared_invite/zt-2ijy1ys1f-O0aEDCr7ExRZ7mwsHAVg9A) | ||||||
| + :eyes: [Join our WeChat Group](https://openim-1253691595.cos.ap-nanjing.myqcloud.com/WechatIMG20.jpeg) | - :eyes: [Join our WeChat Group](https://openim-1253691595.cos.ap-nanjing.myqcloud.com/WechatIMG20.jpeg) | ||||||
| 
 | 
 | ||||||
| ## Ⓜ️ About OpenIM | ## Ⓜ️ About OpenIM | ||||||
| 
 | 
 | ||||||
| @ -67,13 +66,14 @@ Unlike standalone chat applications such as Telegram, Signal, and Rocket.Chat, O | |||||||
| 
 | 
 | ||||||
| **OpenIMSDK**, designed for **OpenIMServer**, is an IM SDK created specifically for integration into client applications. It supports various functionalities and modules: | **OpenIMSDK**, designed for **OpenIMServer**, is an IM SDK created specifically for integration into client applications. It supports various functionalities and modules: | ||||||
| 
 | 
 | ||||||
| + 🌟 Main Features: | - 🌟 Main Features: | ||||||
|  | 
 | ||||||
|   - 📦 Local Storage |   - 📦 Local Storage | ||||||
|   - 🔔 Listener Callbacks |   - 🔔 Listener Callbacks | ||||||
|   - 🛡️ API Wrapping |   - 🛡️ API Wrapping | ||||||
|   - 🌐 Connection Management |   - 🌐 Connection Management | ||||||
| 
 | 
 | ||||||
| + 📚 Main Modules: | - 📚 Main Modules: | ||||||
|   1. 🚀 Initialization and Login |   1. 🚀 Initialization and Login | ||||||
|   2. 👤 User Management |   2. 👤 User Management | ||||||
|   3. 👫 Friends Management |   3. 👫 Friends Management | ||||||
| @ -86,16 +86,16 @@ Built with Golang and supports cross-platform deployment to ensure a consistent | |||||||
| 
 | 
 | ||||||
| ## 🌐 Introduction to OpenIMServer | ## 🌐 Introduction to OpenIMServer | ||||||
| 
 | 
 | ||||||
| + **OpenIMServer** features include: | - **OpenIMServer** features include: | ||||||
|   - 🌐 Microservices Architecture: Supports cluster mode, including a gateway and multiple rpc services. |   - 🌐 Microservices Architecture: Supports cluster mode, including a gateway and multiple rpc services. | ||||||
|   - 🚀 Diverse Deployment Options: Supports source code, Kubernetes, or Docker deployment. |   - 🚀 Diverse Deployment Options: Supports source code, Kubernetes, or Docker deployment. | ||||||
|   - Massive User Support: Supports large-scale groups with hundreds of thousands, millions of users, and billions of messages. |   - Massive User Support: Supports large-scale groups with hundreds of thousands, millions of users, and billions of messages. | ||||||
| 
 | 
 | ||||||
| ### Enhanced Business Functions: | ### Enhanced Business Functions: | ||||||
| 
 | 
 | ||||||
| + **REST API**: Provides a REST API for business systems to enhance functionality, such as group creation and message pushing through backend interfaces. | - **REST API**: Provides a REST API for business systems to enhance functionality, such as group creation and message pushing through backend interfaces. | ||||||
| 
 | 
 | ||||||
| + **Webhooks**: Expands business forms through callbacks, sending requests to business servers before or after certain events. | - **Webhooks**: Expands business forms through callbacks, sending requests to business servers before or after certain events. | ||||||
| 
 | 
 | ||||||
|    |    | ||||||
| 
 | 
 | ||||||
| @ -107,8 +107,8 @@ Experience online for iOS/Android/H5/PC/Web: | |||||||
| 
 | 
 | ||||||
| To facilitate user experience, we offer various deployment solutions. You can choose your preferred deployment method from the list below: | To facilitate user experience, we offer various deployment solutions. You can choose your preferred deployment method from the list below: | ||||||
| 
 | 
 | ||||||
| + **[Source Code Deployment Guide](https://docs.openim.io/guides/gettingStarted/imSourceCodeDeployment)** | - **[Source Code Deployment Guide](https://docs.openim.io/guides/gettingStarted/imSourceCodeDeployment)** | ||||||
| + **[Docker Deployment Guide](https://docs.openim.io/guides/gettingStarted/dockerCompose)** | - **[Docker Deployment Guide](https://docs.openim.io/guides/gettingStarted/dockerCompose)** | ||||||
| 
 | 
 | ||||||
| ## System Support | ## System Support | ||||||
| 
 | 
 | ||||||
| @ -116,32 +116,22 @@ Supports Linux, Windows, Mac systems, and ARM and AMD CPU architectures. | |||||||
| 
 | 
 | ||||||
| ## :link: Links | ## :link: Links | ||||||
| 
 | 
 | ||||||
|   + **[Developer Manual](https://docs.openim.io/)** | - **[Developer Manual](https://docs.openim.io/)** | ||||||
|   + **[Changelog](https://github.com/openimsdk/open-im-server/blob/main/CHANGELOG.md)** | - **[Changelog](https://github.com/openimsdk/open-im-server/blob/main/CHANGELOG.md)** | ||||||
| 
 | 
 | ||||||
| ## :writing_hand: How to Contribute | ## :writing_hand: How to Contribute | ||||||
| 
 | 
 | ||||||
| We welcome contributions of any kind! Please make sure to read our [Contributor Documentation](https://github.com/openimsdk/open-im-server/blob/main/CONTRIBUTING.md) before submitting a Pull Request. | We welcome contributions of any kind! Please make sure to read our [Contributor Documentation](https://github.com/openimsdk/open-im-server/blob/main/CONTRIBUTING.md) before submitting a Pull Request. | ||||||
| 
 | 
 | ||||||
|   + **[Report a Bug](https://github.com/openimsdk/open-im-server/issues/new?assignees=&labels=bug&template=bug_report.md&title=)** | - **[Report a Bug](https://github.com/openimsdk/open-im-server/issues/new?assignees=&labels=bug&template=bug_report.md&title=)** | ||||||
|   + **[Suggest a Feature](https://github.com/openimsdk/open-im-server/issues/new?assignees=&labels=enhancement&template=feature_request.md&title=)** | - **[Suggest a Feature](https://github.com/openimsdk/open-im-server/issues/new?assignees=&labels=enhancement&template=feature_request.md&title=)** | ||||||
|   + **[Submit a Pull Request](https://github.com/openimsdk/open-im-server/pulls)** | - **[Submit a Pull Request](https://github.com/openimsdk/open-im-server/pulls)** | ||||||
| 
 | 
 | ||||||
| Thank you for contributing to building a powerful instant messaging solution! | Thank you for contributing to building a powerful instant messaging solution! | ||||||
| 
 | 
 | ||||||
| ## :closed_book: License | ## :closed_book: License | ||||||
| 
 | 
 | ||||||
| This software is licensed under a dual-license model: | This software is licensed under the Apache License 2.0 | ||||||
| 
 |  | ||||||
| - The GNU Affero General Public License (AGPL), Version 3 or later; **OR** |  | ||||||
| - Commercial license terms from OpenIMSDK. |  | ||||||
| 
 |  | ||||||
| If you wish to use this software under commercial terms, please contact us at: contact@openim.io |  | ||||||
| 
 |  | ||||||
| For more information, see: https://www.openim.io/en/licensing |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 | 
 | ||||||
| ## 🔮 Thanks to our contributors! | ## 🔮 Thanks to our contributors! | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -12,12 +12,11 @@ | |||||||
| [](https://goreportcard.com/report/github.com/openimsdk/open-im-server) | [](https://goreportcard.com/report/github.com/openimsdk/open-im-server) | ||||||
| [](https://pkg.go.dev/github.com/openimsdk/open-im-server/v3) | [](https://pkg.go.dev/github.com/openimsdk/open-im-server/v3) | ||||||
| [](https://github.com/openimsdk/open-im-server/blob/main/LICENSE) | [](https://github.com/openimsdk/open-im-server/blob/main/LICENSE) | ||||||
| [](https://join.slack.com/t/openimsdk/shared_invite/zt-22720d66b-o_FvKxMTGXtcnnnHiMqe9Q) | [](https://join.slack.com/t/openimsdk/shared_invite/zt-2ijy1ys1f-O0aEDCr7ExRZ7mwsHAVg9A) | ||||||
| [](https://www.bestpractices.dev/projects/8045) | [](https://www.bestpractices.dev/projects/8045) | ||||||
| [](https://github.com/openimsdk/open-im-server/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc+label%3A%22good+first+issue%22) | [](https://github.com/openimsdk/open-im-server/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc+label%3A%22good+first+issue%22) | ||||||
| [](https://golang.org/) | [](https://golang.org/) | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| <p align="center"> | <p align="center"> | ||||||
|   <a href="./README.md">English</a> ·  |   <a href="./README.md">English</a> ·  | ||||||
|   <a href="./README_zh_CN.md">中文</a> ·  |   <a href="./README_zh_CN.md">中文</a> ·  | ||||||
| @ -46,16 +45,15 @@ | |||||||
|   <a href="./docs/readme/README_tr.md">Türkçe</a> |   <a href="./docs/readme/README_tr.md">Türkçe</a> | ||||||
| </p> | </p> | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| </div> | </div> | ||||||
| 
 | 
 | ||||||
| </p> | </p> | ||||||
| 
 | 
 | ||||||
| ## :busts_in_silhouette: 加入我们的社区 | ## :busts_in_silhouette: 加入我们的社区 | ||||||
| 
 | 
 | ||||||
| + 💬 [关注我们的 Twitter](https://twitter.com/founder_im63606) | - 💬 [关注我们的 Twitter](https://twitter.com/founder_im63606) | ||||||
| + 🚀 [加入我们的 Slack](https://join.slack.com/t/openimsdk/shared_invite/zt-2hljfom5u-9ZuzP3NfEKW~BJKbpLm0Hw) | - 🚀 [加入我们的 Slack](https://join.slack.com/t/openimsdk/shared_invite/zt-2hljfom5u-9ZuzP3NfEKW~BJKbpLm0Hw) | ||||||
| + :eyes: [加入我们的微信群](https://openim-1253691595.cos.ap-nanjing.myqcloud.com/WechatIMG20.jpeg) | - :eyes: [加入我们的微信群](https://openim-1253691595.cos.ap-nanjing.myqcloud.com/WechatIMG20.jpeg) | ||||||
| 
 | 
 | ||||||
| ## Ⓜ️ 关于 OpenIM | ## Ⓜ️ 关于 OpenIM | ||||||
| 
 | 
 | ||||||
| @ -67,13 +65,14 @@ | |||||||
| 
 | 
 | ||||||
| **OpenIMSDK** 是为 **OpenIMServer** 设计的 IM SDK,专为集成到客户端应用而生。它支持多种功能和模块: | **OpenIMSDK** 是为 **OpenIMServer** 设计的 IM SDK,专为集成到客户端应用而生。它支持多种功能和模块: | ||||||
| 
 | 
 | ||||||
| + 🌟 主要功能: | - 🌟 主要功能: | ||||||
|  | 
 | ||||||
|   - 📦 本地存储 |   - 📦 本地存储 | ||||||
|   - 🔔 监听器回调 |   - 🔔 监听器回调 | ||||||
|   - 🛡️ API 封装 |   - 🛡️ API 封装 | ||||||
|   - 🌐 连接管理 |   - 🌐 连接管理 | ||||||
| 
 | 
 | ||||||
| + 📚 主要模块: | - 📚 主要模块: | ||||||
|   1. 🚀 初始化及登录 |   1. 🚀 初始化及登录 | ||||||
|   2. 👤 用户管理 |   2. 👤 用户管理 | ||||||
|   3. 👫 好友管理 |   3. 👫 好友管理 | ||||||
| @ -86,21 +85,19 @@ | |||||||
| 
 | 
 | ||||||
| ## 🌐 OpenIMServer 介绍 | ## 🌐 OpenIMServer 介绍 | ||||||
| 
 | 
 | ||||||
| + **OpenIMServer** 的特点包括: | - **OpenIMServer** 的特点包括: | ||||||
|   - 🌐 微服务架构:支持集群模式,包括网关(gateway)和多个 rpc 服务。 |   - 🌐 微服务架构:支持集群模式,包括网关(gateway)和多个 rpc 服务。 | ||||||
|   - 🚀 多样的部署方式:支持源代码、Kubernetes 或 Docker 部署。 |   - 🚀 多样的部署方式:支持源代码、Kubernetes 或 Docker 部署。 | ||||||
|   - 海量用户支持:支持十万级超大群组,千万级用户和百亿级消息。 |   - 海量用户支持:支持十万级超大群组,千万级用户和百亿级消息。 | ||||||
| 
 | 
 | ||||||
| ### 增强的业务功能: | ### 增强的业务功能: | ||||||
| 
 | 
 | ||||||
| + **REST API**:为业务系统提供REST API,增加群组创建、消息推送等后台接口功能。 | - **REST API**:为业务系统提供 REST API,增加群组创建、消息推送等后台接口功能。 | ||||||
| 
 | 
 | ||||||
| + **Webhooks**:通过事件前后的回调,向业务服务器发送请求,扩展更多的业务形态。 | - **Webhooks**:通过事件前后的回调,向业务服务器发送请求,扩展更多的业务形态。 | ||||||
| 
 | 
 | ||||||
|    |    | ||||||
| 
 | 
 | ||||||
|    |  | ||||||
| 
 |  | ||||||
| ## :rocket: 快速入门 | ## :rocket: 快速入门 | ||||||
| 
 | 
 | ||||||
| 在线体验 iOS/Android/H5/PC/Web: | 在线体验 iOS/Android/H5/PC/Web: | ||||||
| @ -109,8 +106,8 @@ | |||||||
| 
 | 
 | ||||||
| 为了便于用户体验,我们提供了多种部署解决方案,您可以根据以下列表选择适合您的部署方式: | 为了便于用户体验,我们提供了多种部署解决方案,您可以根据以下列表选择适合您的部署方式: | ||||||
| 
 | 
 | ||||||
| + **[源代码部署指南](https://docs.openim.io/guides/gettingStarted/imSourceCodeDeployment)** | - **[源代码部署指南](https://docs.openim.io/guides/gettingStarted/imSourceCodeDeployment)** | ||||||
| + **[Docker 部署指南](https://docs.openim.io/guides/gettingStarted/dockerCompose)** | - **[Docker 部署指南](https://docs.openim.io/guides/gettingStarted/dockerCompose)** | ||||||
| 
 | 
 | ||||||
| ## 系统支持 | ## 系统支持 | ||||||
| 
 | 
 | ||||||
| @ -118,30 +115,22 @@ | |||||||
| 
 | 
 | ||||||
| ## :link: 相关链接 | ## :link: 相关链接 | ||||||
| 
 | 
 | ||||||
|   + **[开发手册](https://docs.openim.io/)** | - **[开发手册](https://docs.openim.io/)** | ||||||
|   + **[更新日志](https://github.com/openimsdk/open-im-server/blob/main/CHANGELOG.md)** | - **[更新日志](https://github.com/openimsdk/open-im-server/blob/main/CHANGELOG.md)** | ||||||
| 
 | 
 | ||||||
| ## :writing_hand: 如何贡献 | ## :writing_hand: 如何贡献 | ||||||
| 
 | 
 | ||||||
| 我们欢迎任何形式的贡献!在提交 Pull Request 之前,请确保阅读我们的[贡献者文档](https://github.com/openimsdk/open-im-server/blob/main/CONTRIBUTING.md) | 我们欢迎任何形式的贡献!在提交 Pull Request 之前,请确保阅读我们的[贡献者文档](https://github.com/openimsdk/open-im-server/blob/main/CONTRIBUTING.md) | ||||||
| 
 | 
 | ||||||
|   + **[报告 Bug](https://github.com/openimsdk/open-im-server/issues/new?assignees=&labels=bug&template=bug_report.md&title=)** | - **[报告 Bug](https://github.com/openimsdk/open-im-server/issues/new?assignees=&labels=bug&template=bug_report.md&title=)** | ||||||
|   + **[提出新特性](https://github.com/openimsdk/open-im-server/issues/new?assignees=&labels=enhancement&template=feature_request.md&title=)** | - **[提出新特性](https://github.com/openimsdk/open-im-server/issues/new?assignees=&labels=enhancement&template=feature_request.md&title=)** | ||||||
|   + **[提交 Pull Request](https://github.com/openimsdk/open-im-server/pulls)** | - **[提交 Pull Request](https://github.com/openimsdk/open-im-server/pulls)** | ||||||
| 
 | 
 | ||||||
| 感谢您的贡献,一起来打造强大的即时通讯解决方案! | 感谢您的贡献,一起来打造强大的即时通讯解决方案! | ||||||
| 
 | 
 | ||||||
| ## :closed_book: 开源许可证 License | ## :closed_book: 开源许可证 License | ||||||
| 
 | 
 | ||||||
| 本软件采用双重授权模型: | This software is licensed under the Apache License 2.0 | ||||||
| 
 |  | ||||||
| GNU Affero 通用公共许可证(AGPL)第 3 版或更高版本;或 |  | ||||||
| 
 |  | ||||||
| 来自 OpenIMSDK 的商业授权条款。 |  | ||||||
| 
 |  | ||||||
| 如需商用,请联系:contact@openim.io |  | ||||||
| 详见:https://www.openim.io/en/licensing |  | ||||||
| 
 |  | ||||||
| 
 | 
 | ||||||
| ## 🔮 Thanks to our contributors! | ## 🔮 Thanks to our contributors! | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,24 +1,24 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. | # # Copyright © 2023 OpenIM. All rights reserved. | ||||||
| # | # # | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | # # Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
| # you may not use this file except in compliance with the License. | # # you may not use this file except in compliance with the License. | ||||||
| # You may obtain a copy of the License at | # # You may obtain a copy of the License at | ||||||
| # | # # | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | # #     http://www.apache.org/licenses/LICENSE-2.0 | ||||||
| # | # # | ||||||
| # Unless required by applicable law or agreed to in writing, software | # # Unless required by applicable law or agreed to in writing, software | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, | # # distributed under the License is distributed on an "AS IS" BASIS, | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | # # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
| # See the License for the specific language governing permissions and | # # See the License for the specific language governing permissions and | ||||||
| # limitations under the License. | # # limitations under the License. | ||||||
| 
 | 
 | ||||||
| FROM BASE_IMAGE | # FROM BASE_IMAGE | ||||||
| 
 | 
 | ||||||
| WORKDIR ${SERVER_WORKDIR} | # WORKDIR ${SERVER_WORKDIR} | ||||||
| 
 | 
 | ||||||
| # Set HTTP proxy | # # Set HTTP proxy | ||||||
| ARG BINARY_NAME | # ARG BINARY_NAME | ||||||
| 
 | 
 | ||||||
| COPY BINARY_NAME ./bin/BINARY_NAME | # COPY BINARY_NAME ./bin/BINARY_NAME | ||||||
| 
 | 
 | ||||||
| ENTRYPOINT ["./bin/BINARY_NAME"] | # ENTRYPOINT ["./bin/BINARY_NAME"] | ||||||
| @ -1,44 +1,36 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| # | FROM golang:1.22-alpine AS builder | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 | 
 | ||||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | # Define the base directory for the application as an environment variable | ||||||
|  | ENV SERVER_DIR=/openim-server | ||||||
| 
 | 
 | ||||||
| # Set go mod installation source and proxy | # Set the working directory inside the container based on the environment variable | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| FROM golang:1.20 AS builder | # Set the Go proxy to improve dependency resolution speed | ||||||
| 
 | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| WORKDIR /openim/openim-server |  | ||||||
| 
 |  | ||||||
| ENV GO111MODULE=$GO111MODULE |  | ||||||
| ENV GOPROXY=$GOPROXY |  | ||||||
| 
 |  | ||||||
| COPY go.mod go.sum ./ |  | ||||||
| RUN go mod download |  | ||||||
| 
 | 
 | ||||||
|  | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN make build BINS=openim-api | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-api /usr/bin/openim-api | RUN go build -o _output/openim-api ./cmd/openim-api | ||||||
| 
 | 
 | ||||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest | # Using Alpine Linux for the final image | ||||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest | FROM alpine:latest | ||||||
| 
 | 
 | ||||||
| WORKDIR /openim/openim-server | # Install necessary packages, such as bash | ||||||
|  | RUN apk add --no-cache bash | ||||||
| 
 | 
 | ||||||
| COPY --from=builder /usr/bin/openim-api ./bin/openim-api | # Set the environment and work directory | ||||||
|  | ENV SERVER_DIR=/openim-server | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| ENTRYPOINT ["./bin/openim-api"] | 
 | ||||||
|  | # Copy the compiled binaries and mage from the builder image to the final image | ||||||
|  | COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||||
|  | COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||||
|  | 
 | ||||||
|  | # Set the command to run when the container starts | ||||||
|  | ENTRYPOINT ["sh", "-c", "_output/openim-api"] | ||||||
|  | |||||||
| @ -1,44 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image |  | ||||||
| 
 |  | ||||||
| # Set go mod installation source and proxy |  | ||||||
| 
 |  | ||||||
| FROM golang:1.20 AS builder |  | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| WORKDIR /openim/openim-server |  | ||||||
| 
 |  | ||||||
| ENV GO111MODULE=$GO111MODULE |  | ||||||
| ENV GOPROXY=$GOPROXY |  | ||||||
| 
 |  | ||||||
| COPY go.mod go.sum ./ |  | ||||||
| RUN go mod download |  | ||||||
| 
 |  | ||||||
| COPY . . |  | ||||||
| 
 |  | ||||||
| RUN make build BINS=openim-cmdutils |  | ||||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-cmdutils /usr/bin/openim-cmdutils |  | ||||||
| 
 |  | ||||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| 
 |  | ||||||
| WORKDIR /openim/openim-server |  | ||||||
| 
 |  | ||||||
| COPY --from=builder /usr/bin/openim-cmdutils ./bin/openim-cmdutils |  | ||||||
| 
 |  | ||||||
| ENTRYPOINT ["./bin/openim-cmdutils"] |  | ||||||
| 
 |  | ||||||
| CMD ["--help"] |  | ||||||
| @ -1,44 +1,39 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| # | FROM golang:1.22-alpine AS builder | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | # Define the base directory for the application as an environment variable | ||||||
| # you may not use this file except in compliance with the License. | ENV SERVER_DIR=/openim-server | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 | 
 | ||||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | # Set the working directory inside the container based on the environment variable | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set go mod installation source and proxy | # Set the Go proxy to improve dependency resolution speed | ||||||
| 
 | 
 | ||||||
| FROM golang:1.20 AS builder | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| WORKDIR /openim/openim-server |  | ||||||
| 
 |  | ||||||
| ENV GO111MODULE=$GO111MODULE |  | ||||||
| ENV GOPROXY=$GOPROXY |  | ||||||
| 
 |  | ||||||
| COPY go.mod go.sum ./ |  | ||||||
| RUN go mod download |  | ||||||
| 
 | 
 | ||||||
|  | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN make build BINS=openim-crontask | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-crontask /usr/bin/openim-crontask |  | ||||||
| 
 | 
 | ||||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| 
 | 
 | ||||||
| WORKDIR /openim/openim-server | RUN go build -o _output/openim-crontask ./cmd/openim-crontask | ||||||
| 
 | 
 | ||||||
| COPY --from=builder /usr/bin/openim-crontask ./bin/openim-crontask |  | ||||||
| 
 | 
 | ||||||
| ENTRYPOINT ["./bin/openim-crontask"] | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
|  | 
 | ||||||
|  | # Install necessary packages, such as bash | ||||||
|  | RUN apk add --no-cache bash | ||||||
|  | 
 | ||||||
|  | # Set the environment and work directory | ||||||
|  | ENV SERVER_DIR=/openim-server | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | # Copy the compiled binaries and mage from the builder image to the final image | ||||||
|  | COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||||
|  | # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||||
|  | 
 | ||||||
|  | # Set the command to run when the container starts | ||||||
|  | ENTRYPOINT ["sh", "-c", "_output/openim-crontask"] | ||||||
|  | |||||||
| @ -1,44 +1,39 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| # | FROM golang:1.22-alpine AS builder | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | # Define the base directory for the application as an environment variable | ||||||
| # you may not use this file except in compliance with the License. | ENV SERVER_DIR=/openim-server | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 | 
 | ||||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | # Set the working directory inside the container based on the environment variable | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set go mod installation source and proxy | # Set the Go proxy to improve dependency resolution speed | ||||||
| 
 | 
 | ||||||
| FROM golang:1.20 AS builder | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| WORKDIR /openim/openim-server |  | ||||||
| 
 |  | ||||||
| ENV GO111MODULE=$GO111MODULE |  | ||||||
| ENV GOPROXY=$GOPROXY |  | ||||||
| 
 |  | ||||||
| COPY go.mod go.sum ./ |  | ||||||
| RUN go mod download |  | ||||||
| 
 | 
 | ||||||
|  | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN make build BINS=openim-msggateway | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-msggateway /usr/bin/openim-msggateway |  | ||||||
| 
 | 
 | ||||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| 
 | 
 | ||||||
| WORKDIR /openim/openim-server | RUN go build -o _output/openim-msggateway ./cmd/openim-msggateway | ||||||
| 
 | 
 | ||||||
| COPY --from=builder /usr/bin/openim-msggateway ./bin/openim-msggateway |  | ||||||
| 
 | 
 | ||||||
| ENTRYPOINT ["./bin/openim-msggateway"] | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
|  | 
 | ||||||
|  | # Install necessary packages, such as bash | ||||||
|  | RUN apk add --no-cache bash | ||||||
|  | 
 | ||||||
|  | # Set the environment and work directory | ||||||
|  | ENV SERVER_DIR=/openim-server | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | # Copy the compiled binaries and mage from the builder image to the final image | ||||||
|  | COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||||
|  | # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||||
|  | 
 | ||||||
|  | # Set the command to run when the container starts | ||||||
|  | ENTRYPOINT ["sh", "-c", "_output/openim-msggateway"] | ||||||
|  | |||||||
| @ -1,44 +1,39 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| # | FROM golang:1.22-alpine AS builder | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | # Define the base directory for the application as an environment variable | ||||||
| # you may not use this file except in compliance with the License. | ENV SERVER_DIR=/openim-server | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 | 
 | ||||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | # Set the working directory inside the container based on the environment variable | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set go mod installation source and proxy | # Set the Go proxy to improve dependency resolution speed | ||||||
| 
 | 
 | ||||||
| FROM golang:1.20 AS builder | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| WORKDIR /openim/openim-server |  | ||||||
| 
 |  | ||||||
| ENV GO111MODULE=$GO111MODULE |  | ||||||
| ENV GOPROXY=$GOPROXY |  | ||||||
| 
 |  | ||||||
| COPY go.mod go.sum ./ |  | ||||||
| RUN go mod download |  | ||||||
| 
 | 
 | ||||||
|  | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN make build BINS=openim-msgtransfer | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-msgtransfer /usr/bin/openim-msgtransfer |  | ||||||
| 
 | 
 | ||||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| 
 | 
 | ||||||
| WORKDIR /openim/openim-server | RUN go build -o _output/openim-msgtransfer ./cmd/openim-msgtransfer | ||||||
| 
 | 
 | ||||||
| COPY --from=builder /usr/bin/openim-msgtransfer ./bin/openim-msgtransfer |  | ||||||
| 
 | 
 | ||||||
| ENTRYPOINT ["./bin/openim-msgtransfer"] | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
|  | 
 | ||||||
|  | # Install necessary packages, such as bash | ||||||
|  | RUN apk add --no-cache bash | ||||||
|  | 
 | ||||||
|  | # Set the environment and work directory | ||||||
|  | ENV SERVER_DIR=/openim-server | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | # Copy the compiled binaries and mage from the builder image to the final image | ||||||
|  | COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||||
|  | # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||||
|  | 
 | ||||||
|  | # Set the command to run when the container starts | ||||||
|  | ENTRYPOINT ["sh", "-c", "_output/openim-msgtransfer"] | ||||||
|  | |||||||
| @ -1,44 +1,39 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| # | FROM golang:1.22-alpine AS builder | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | # Define the base directory for the application as an environment variable | ||||||
| # you may not use this file except in compliance with the License. | ENV SERVER_DIR=/openim-server | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 | 
 | ||||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | # Set the working directory inside the container based on the environment variable | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set go mod installation source and proxy | # Set the Go proxy to improve dependency resolution speed | ||||||
| 
 | 
 | ||||||
| FROM golang:1.20 AS builder | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| WORKDIR /openim/openim-server |  | ||||||
| 
 |  | ||||||
| ENV GO111MODULE=$GO111MODULE |  | ||||||
| ENV GOPROXY=$GOPROXY |  | ||||||
| 
 |  | ||||||
| COPY go.mod go.sum ./ |  | ||||||
| RUN go mod download |  | ||||||
| 
 | 
 | ||||||
|  | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN make build BINS=openim-push | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-push /usr/bin/openim-push |  | ||||||
| 
 | 
 | ||||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| 
 | 
 | ||||||
| WORKDIR /openim/openim-server | RUN go build -o _output/openim-push ./cmd/openim-push | ||||||
| 
 | 
 | ||||||
| COPY --from=builder /usr/bin/openim-push ./bin/openim-push |  | ||||||
| 
 | 
 | ||||||
| ENTRYPOINT ["./bin/openim-push"] | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
|  | 
 | ||||||
|  | # Install necessary packages, such as bash | ||||||
|  | RUN apk add --no-cache bash | ||||||
|  | 
 | ||||||
|  | # Set the environment and work directory | ||||||
|  | ENV SERVER_DIR=/openim-server | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | # Copy the compiled binaries and mage from the builder image to the final image | ||||||
|  | COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||||
|  | # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||||
|  | 
 | ||||||
|  | # Set the command to run when the container starts | ||||||
|  | ENTRYPOINT ["sh", "-c", "_output/openim-push"] | ||||||
|  | |||||||
| @ -1,44 +1,39 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| # | FROM golang:1.22-alpine AS builder | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | # Define the base directory for the application as an environment variable | ||||||
| # you may not use this file except in compliance with the License. | ENV SERVER_DIR=/openim-server | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 | 
 | ||||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | # Set the working directory inside the container based on the environment variable | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set go mod installation source and proxy | # Set the Go proxy to improve dependency resolution speed | ||||||
| 
 | 
 | ||||||
| FROM golang:1.20 AS builder | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| WORKDIR /openim/openim-server |  | ||||||
| 
 |  | ||||||
| ENV GO111MODULE=$GO111MODULE |  | ||||||
| ENV GOPROXY=$GOPROXY |  | ||||||
| 
 |  | ||||||
| COPY go.mod go.sum ./ |  | ||||||
| RUN go mod download |  | ||||||
| 
 | 
 | ||||||
|  | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN make build BINS=openim-rpc-auth | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-auth /usr/bin/openim-rpc-auth |  | ||||||
| 
 | 
 | ||||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| 
 | 
 | ||||||
| WORKDIR /openim/openim-server | RUN go build -o _output/openim-rpc-auth ./cmd/openim-rpc/openim-rpc-auth | ||||||
| 
 | 
 | ||||||
| COPY --from=builder /usr/bin/openim-rpc-auth ./bin/openim-rpc-auth |  | ||||||
| 
 | 
 | ||||||
| ENTRYPOINT ["./bin/openim-rpc-auth"] | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
|  | 
 | ||||||
|  | # Install necessary packages, such as bash | ||||||
|  | RUN apk add --no-cache bash | ||||||
|  | 
 | ||||||
|  | # Set the environment and work directory | ||||||
|  | ENV SERVER_DIR=/openim-server | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | # Copy the compiled binaries and mage from the builder image to the final image | ||||||
|  | COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||||
|  | # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||||
|  | 
 | ||||||
|  | # Set the command to run when the container starts | ||||||
|  | ENTRYPOINT ["sh", "-c", "_output/openim-rpc-auth"] | ||||||
|  | |||||||
| @ -1,44 +1,39 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| # | FROM golang:1.22-alpine AS builder | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | # Define the base directory for the application as an environment variable | ||||||
| # you may not use this file except in compliance with the License. | ENV SERVER_DIR=/openim-server | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 | 
 | ||||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | # Set the working directory inside the container based on the environment variable | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set go mod installation source and proxy | # Set the Go proxy to improve dependency resolution speed | ||||||
| 
 | 
 | ||||||
| FROM golang:1.20 AS builder | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| WORKDIR /openim/openim-server |  | ||||||
| 
 |  | ||||||
| ENV GO111MODULE=$GO111MODULE |  | ||||||
| ENV GOPROXY=$GOPROXY |  | ||||||
| 
 |  | ||||||
| COPY go.mod go.sum ./ |  | ||||||
| RUN go mod download |  | ||||||
| 
 | 
 | ||||||
|  | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN make build BINS=openim-rpc-conversation | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-conversation /usr/bin/openim-rpc-conversation |  | ||||||
| 
 | 
 | ||||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| 
 | 
 | ||||||
| WORKDIR /openim/openim-server | RUN go build -o _output/openim-rpc-conversation ./cmd/openim-rpc/openim-rpc-conversation | ||||||
| 
 | 
 | ||||||
| COPY --from=builder /usr/bin/openim-rpc-conversation ./bin/openim-rpc-conversation |  | ||||||
| 
 | 
 | ||||||
| ENTRYPOINT ["./bin/openim-rpc-conversation"] | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
|  | 
 | ||||||
|  | # Install necessary packages, such as bash | ||||||
|  | RUN apk add --no-cache bash | ||||||
|  | 
 | ||||||
|  | # Set the environment and work directory | ||||||
|  | ENV SERVER_DIR=/openim-server | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | # Copy the compiled binaries and mage from the builder image to the final image | ||||||
|  | COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||||
|  | # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||||
|  | 
 | ||||||
|  | # Set the command to run when the container starts | ||||||
|  | ENTRYPOINT ["sh", "-c", "_output/openim-rpc-conversation"] | ||||||
|  | |||||||
| @ -1,44 +1,39 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| # | FROM golang:1.22-alpine AS builder | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | # Define the base directory for the application as an environment variable | ||||||
| # you may not use this file except in compliance with the License. | ENV SERVER_DIR=/openim-server | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 | 
 | ||||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | # Set the working directory inside the container based on the environment variable | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set go mod installation source and proxy | # Set the Go proxy to improve dependency resolution speed | ||||||
| 
 | 
 | ||||||
| FROM golang:1.20 AS builder | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| WORKDIR /openim/openim-server |  | ||||||
| 
 |  | ||||||
| ENV GO111MODULE=$GO111MODULE |  | ||||||
| ENV GOPROXY=$GOPROXY |  | ||||||
| 
 |  | ||||||
| COPY go.mod go.sum ./ |  | ||||||
| RUN go mod download |  | ||||||
| 
 | 
 | ||||||
|  | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN make build BINS=openim-rpc-friend | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-friend /usr/bin/openim-rpc-friend |  | ||||||
| 
 | 
 | ||||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| 
 | 
 | ||||||
| WORKDIR /openim/openim-server | RUN go build -o _output/openim-rpc-friend ./cmd/openim-rpc/openim-rpc-friend | ||||||
| 
 | 
 | ||||||
| COPY --from=builder /usr/bin/openim-rpc-friend ./bin/openim-rpc-friend |  | ||||||
| 
 | 
 | ||||||
| ENTRYPOINT ["./bin/openim-rpc-friend"] | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
|  | 
 | ||||||
|  | # Install necessary packages, such as bash | ||||||
|  | RUN apk add --no-cache bash | ||||||
|  | 
 | ||||||
|  | # Set the environment and work directory | ||||||
|  | ENV SERVER_DIR=/openim-server | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | # Copy the compiled binaries and mage from the builder image to the final image | ||||||
|  | COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||||
|  | # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||||
|  | 
 | ||||||
|  | # Set the command to run when the container starts | ||||||
|  | ENTRYPOINT ["sh", "-c", "_output/openim-rpc-friend"] | ||||||
|  | |||||||
| @ -1,44 +1,39 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| # | FROM golang:1.22-alpine AS builder | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | # Define the base directory for the application as an environment variable | ||||||
| # you may not use this file except in compliance with the License. | ENV SERVER_DIR=/openim-server | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 | 
 | ||||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | # Set the working directory inside the container based on the environment variable | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set go mod installation source and proxy | # Set the Go proxy to improve dependency resolution speed | ||||||
| 
 | 
 | ||||||
| FROM golang:1.20 AS builder | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| WORKDIR /openim/openim-server |  | ||||||
| 
 |  | ||||||
| ENV GO111MODULE=$GO111MODULE |  | ||||||
| ENV GOPROXY=$GOPROXY |  | ||||||
| 
 |  | ||||||
| COPY go.mod go.sum ./ |  | ||||||
| RUN go mod download |  | ||||||
| 
 | 
 | ||||||
|  | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN make build BINS=openim-rpc-group | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-group /usr/bin/openim-rpc-group |  | ||||||
| 
 | 
 | ||||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| 
 | 
 | ||||||
| WORKDIR /openim/openim-server | RUN go build -o _output/openim-rpc-group ./cmd/openim-rpc/openim-rpc-group | ||||||
| 
 | 
 | ||||||
| COPY --from=builder /usr/bin/openim-rpc-group ./bin/openim-rpc-group |  | ||||||
| 
 | 
 | ||||||
| ENTRYPOINT ["./bin/openim-rpc-group"] | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
|  | 
 | ||||||
|  | # Install necessary packages, such as bash | ||||||
|  | RUN apk add --no-cache bash | ||||||
|  | 
 | ||||||
|  | # Set the environment and work directory | ||||||
|  | ENV SERVER_DIR=/openim-server | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | # Copy the compiled binaries and mage from the builder image to the final image | ||||||
|  | COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||||
|  | # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||||
|  | 
 | ||||||
|  | # Set the command to run when the container starts | ||||||
|  | ENTRYPOINT ["sh", "-c", "_output/openim-rpc-group"] | ||||||
|  | |||||||
| @ -1,44 +1,39 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| # | FROM golang:1.22-alpine AS builder | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | # Define the base directory for the application as an environment variable | ||||||
| # you may not use this file except in compliance with the License. | ENV SERVER_DIR=/openim-server | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 | 
 | ||||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | # Set the working directory inside the container based on the environment variable | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set go mod installation source and proxy | # Set the Go proxy to improve dependency resolution speed | ||||||
| 
 | 
 | ||||||
| FROM golang:1.20 AS builder | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| WORKDIR /openim/openim-server |  | ||||||
| 
 |  | ||||||
| ENV GO111MODULE=$GO111MODULE |  | ||||||
| ENV GOPROXY=$GOPROXY |  | ||||||
| 
 |  | ||||||
| COPY go.mod go.sum ./ |  | ||||||
| RUN go mod download |  | ||||||
| 
 | 
 | ||||||
|  | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN make build BINS=openim-rpc-msg | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-msg /usr/bin/openim-rpc-msg |  | ||||||
| 
 | 
 | ||||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| 
 | 
 | ||||||
| WORKDIR /openim/openim-server | RUN go build -o _output/openim-rpc-msg ./cmd/openim-rpc/openim-rpc-msg | ||||||
| 
 | 
 | ||||||
| COPY --from=builder /usr/bin/openim-rpc-msg ./bin/openim-rpc-msg |  | ||||||
| 
 | 
 | ||||||
| ENTRYPOINT ["./bin/openim-rpc-msg"] | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
|  | 
 | ||||||
|  | # Install necessary packages, such as bash | ||||||
|  | RUN apk add --no-cache bash | ||||||
|  | 
 | ||||||
|  | # Set the environment and work directory | ||||||
|  | ENV SERVER_DIR=/openim-server | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | # Copy the compiled binaries and mage from the builder image to the final image | ||||||
|  | COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||||
|  | # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||||
|  | 
 | ||||||
|  | # Set the command to run when the container starts | ||||||
|  | ENTRYPOINT ["sh", "-c", "_output/openim-rpc-msg"] | ||||||
|  | |||||||
| @ -1,44 +1,39 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| # | FROM golang:1.22-alpine AS builder | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | # Define the base directory for the application as an environment variable | ||||||
| # you may not use this file except in compliance with the License. | ENV SERVER_DIR=/openim-server | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 | 
 | ||||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | # Set the working directory inside the container based on the environment variable | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set go mod installation source and proxy | # Set the Go proxy to improve dependency resolution speed | ||||||
| 
 | 
 | ||||||
| FROM golang:1.20 AS builder | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| WORKDIR /openim/openim-server |  | ||||||
| 
 |  | ||||||
| ENV GO111MODULE=$GO111MODULE |  | ||||||
| ENV GOPROXY=$GOPROXY |  | ||||||
| 
 |  | ||||||
| COPY go.mod go.sum ./ |  | ||||||
| RUN go mod download |  | ||||||
| 
 | 
 | ||||||
|  | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN make build BINS=openim-rpc-third | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-third /usr/bin/openim-rpc-third |  | ||||||
| 
 | 
 | ||||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| 
 | 
 | ||||||
| WORKDIR /openim/openim-server | RUN go build -o _output/openim-rpc-third ./cmd/openim-rpc/openim-rpc-third | ||||||
| 
 | 
 | ||||||
| COPY --from=builder /usr/bin/openim-rpc-third ./bin/openim-rpc-third |  | ||||||
| 
 | 
 | ||||||
| ENTRYPOINT ["./bin/openim-rpc-third"] | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
|  | 
 | ||||||
|  | # Install necessary packages, such as bash | ||||||
|  | RUN apk add --no-cache bash | ||||||
|  | 
 | ||||||
|  | # Set the environment and work directory | ||||||
|  | ENV SERVER_DIR=/openim-server | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | # Copy the compiled binaries and mage from the builder image to the final image | ||||||
|  | COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||||
|  | # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||||
|  | 
 | ||||||
|  | # Set the command to run when the container starts | ||||||
|  | ENTRYPOINT ["sh", "-c", "_output/openim-rpc-third"] | ||||||
|  | |||||||
| @ -1,44 +1,37 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| # | FROM golang:1.22-alpine AS builder | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | # Define the base directory for the application as an environment variable | ||||||
| # you may not use this file except in compliance with the License. | ENV SERVER_DIR=/openim-server | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 | 
 | ||||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | # Set the working directory inside the container based on the environment variable | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set go mod installation source and proxy | # Set the Go proxy to improve dependency resolution speed | ||||||
| 
 | 
 | ||||||
| FROM golang:1.20 AS builder | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| WORKDIR /openim/openim-server |  | ||||||
| 
 |  | ||||||
| ENV GO111MODULE=$GO111MODULE |  | ||||||
| ENV GOPROXY=$GOPROXY |  | ||||||
| 
 |  | ||||||
| COPY go.mod go.sum ./ |  | ||||||
| RUN go mod download |  | ||||||
| 
 | 
 | ||||||
|  | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN make build BINS=openim-rpc-user | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-user /usr/bin/openim-rpc-user | RUN go build -o _output/openim-rpc-user ./cmd/openim-rpc/openim-rpc-user | ||||||
| 
 | 
 | ||||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest |  | ||||||
| 
 | 
 | ||||||
| WORKDIR /openim/openim-server | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
| 
 | 
 | ||||||
| COPY --from=builder /usr/bin/openim-rpc-user ./bin/openim-rpc-user | # Install necessary packages, such as bash | ||||||
|  | RUN apk add --no-cache bash | ||||||
| 
 | 
 | ||||||
| ENTRYPOINT ["./bin/openim-rpc-user"] | # Set the environment and work directory | ||||||
|  | ENV SERVER_DIR=/openim-server | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | # Copy the compiled binaries and mage from the builder image to the final image | ||||||
|  | COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||||
|  | # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||||
|  | 
 | ||||||
|  | # Set the command to run when the container starts | ||||||
|  | ENTRYPOINT ["sh", "-c", "_output/openim-rpc-user"] | ||||||
|  | |||||||
| @ -1,48 +1,108 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. | # # Copyright © 2023 OpenIM. All rights reserved. | ||||||
|  | # # | ||||||
|  | # # Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | # # you may not use this file except in compliance with the License. | ||||||
|  | # # You may obtain a copy of the License at | ||||||
|  | # # | ||||||
|  | # #     http://www.apache.org/licenses/LICENSE-2.0 | ||||||
|  | # # | ||||||
|  | # # Unless required by applicable law or agreed to in writing, software | ||||||
|  | # # distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | # # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | # # See the License for the specific language governing permissions and | ||||||
|  | # # limitations under the License. | ||||||
|  | 
 | ||||||
|  | # # OpenIM base image: https://github.com/openim-sigs/openim-base-image | ||||||
|  | 
 | ||||||
|  | # # Set go mod installation source and proxy | ||||||
|  | 
 | ||||||
|  | # FROM golang:1.20 AS builder | ||||||
|  | 
 | ||||||
| #  | #  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | 
 | ||||||
| # you may not use this file except in compliance with the License. | # WORKDIR /openim/openim-server | ||||||
| # You may obtain a copy of the License at | 
 | ||||||
| #  | #  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | # ENV GOPROXY=$GOPROXY | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 | 
 | ||||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | # COPY go.mod go.sum ./ | ||||||
|  | # RUN go mod download | ||||||
| 
 | 
 | ||||||
| # Set go mod installation source and proxy | # COPY . . | ||||||
| 
 | 
 | ||||||
| FROM golang:1.20 AS builder | # RUN make clean | ||||||
|  | # RUN make build BINS=component | ||||||
| 
 | 
 | ||||||
| ARG GO111MODULE=on | # # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||||
|  | # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||||
| 
 | 
 | ||||||
| WORKDIR /openim/openim-server | # WORKDIR /openim/openim-server | ||||||
| 
 | 
 | ||||||
| ENV GO111MODULE=$GO111MODULE | # COPY --from=builder /openim/openim-server/_output/bin/tools /openim/openim-server/_output/bin/tools/ | ||||||
| ENV GOPROXY=$GOPROXY | # COPY --from=builder /openim/openim-server/config /openim/openim-server/config | ||||||
| 
 | 
 | ||||||
| COPY go.mod go.sum ./ | # ENV OPENIM_SERVER_CONFIG_NAME=/openim/openim-server/config | ||||||
| RUN go mod download |  | ||||||
| 
 | 
 | ||||||
|  | # RUN mv ${OPENIM_SERVER_BINDIR}/platforms/$(get_os)/$(get_arch)/component /usr/bin/component | ||||||
|  | 
 | ||||||
|  | # ENTRYPOINT ["bash", "-c", "component -c $OPENIM_SERVER_CONFIG_NAME"] | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | # Use Go 1.22 Alpine as the base image for building the application | ||||||
|  | FROM golang:1.22-alpine AS builder | ||||||
|  | # Define the base directory for the application as an environment variable | ||||||
|  | ENV SERVER_DIR=/openim-server | ||||||
|  | 
 | ||||||
|  | # Set the working directory inside the container based on the environment variable | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
|  | 
 | ||||||
|  | # Set the Go proxy to improve dependency resolution speed | ||||||
|  | 
 | ||||||
|  | #ENV GOPROXY=https://goproxy.io,direct | ||||||
|  | 
 | ||||||
|  | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN make clean | RUN go mod download | ||||||
| RUN make build BINS=component |  | ||||||
| 
 | 
 | ||||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest | # Install Mage to use for building the application | ||||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest | RUN go install github.com/magefile/mage@v1.15.0 | ||||||
| 
 | 
 | ||||||
| WORKDIR /openim/openim-server | # ENV BINS=openim-rpc-user | ||||||
| 
 | 
 | ||||||
| COPY --from=builder /openim/openim-server/_output/bin/tools /openim/openim-server/_output/bin/tools/ | # Optionally build your application if needed | ||||||
| COPY --from=builder /openim/openim-server/config /openim/openim-server/config | # RUN mage build ${BINS} check-free-memory seq || true | ||||||
|  | RUN mage build check-free-memory seq || true | ||||||
| 
 | 
 | ||||||
| ENV OPENIM_SERVER_CONFIG_NAME=/openim/openim-server/config | # Using Alpine Linux with Go environment for the final image | ||||||
|  | FROM golang:1.22-alpine | ||||||
| 
 | 
 | ||||||
| RUN mv ${OPENIM_SERVER_BINDIR}/platforms/$(get_os)/$(get_arch)/component /usr/bin/component | # Install necessary packages, such as bash | ||||||
|  | RUN apk add bash | ||||||
| 
 | 
 | ||||||
| ENTRYPOINT ["bash", "-c", "component -c $OPENIM_SERVER_CONFIG_NAME"] | # Set the environment and work directory | ||||||
|  | ENV SERVER_DIR=/openim-server | ||||||
|  | WORKDIR $SERVER_DIR | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | # Copy the compiled binaries and mage from the builder image to the final image | ||||||
|  | COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||||
|  | COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||||
|  | COPY --from=builder /go/bin/mage /usr/local/bin/mage | ||||||
|  | COPY --from=builder $SERVER_DIR/magefile_windows.go $SERVER_DIR/ | ||||||
|  | COPY --from=builder $SERVER_DIR/magefile_unix.go $SERVER_DIR/ | ||||||
|  | COPY --from=builder $SERVER_DIR/magefile.go $SERVER_DIR/ | ||||||
|  | # COPY --from=builder $SERVER_DIR/start-config.yml $SERVER_DIR/ | ||||||
|  | COPY --from=builder $SERVER_DIR/go.mod $SERVER_DIR/ | ||||||
|  | COPY --from=builder $SERVER_DIR/go.sum $SERVER_DIR/ | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | RUN echo -e "serviceBinaries:\n  \n" \ | ||||||
|  |     > $SERVER_DIR/start-config.yml && \ | ||||||
|  |     echo -e "toolBinaries:\n  - check-free-memory\n  - seq\n" >> $SERVER_DIR/start-config.yml && \ | ||||||
|  |     echo "maxFileDescriptors: 10000" >> $SERVER_DIR/start-config.yml | ||||||
|  | 
 | ||||||
|  | RUN go get github.com/openimsdk/gomake@v0.0.15-alpha.1 | ||||||
|  | 
 | ||||||
|  | # Set the command to run when the container starts | ||||||
|  | ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ||||||
|  | |||||||
							
								
								
									
										17
									
								
								cmd/main.go
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								cmd/main.go
									
									
									
									
									
								
							| @ -3,7 +3,6 @@ package main | |||||||
| import ( | import ( | ||||||
| 	"bytes" | 	"bytes" | ||||||
| 	"context" | 	"context" | ||||||
| 	"encoding/json" |  | ||||||
| 	"flag" | 	"flag" | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"net" | 	"net" | ||||||
| @ -39,7 +38,6 @@ import ( | |||||||
| 	"github.com/openimsdk/tools/log" | 	"github.com/openimsdk/tools/log" | ||||||
| 	"github.com/openimsdk/tools/system/program" | 	"github.com/openimsdk/tools/system/program" | ||||||
| 	"github.com/openimsdk/tools/utils/datautil" | 	"github.com/openimsdk/tools/utils/datautil" | ||||||
| 	"github.com/openimsdk/tools/utils/network" |  | ||||||
| 	"github.com/spf13/viper" | 	"github.com/spf13/viper" | ||||||
| 	"google.golang.org/grpc" | 	"google.golang.org/grpc" | ||||||
| ) | ) | ||||||
| @ -250,23 +248,12 @@ func (x *cmds) run(ctx context.Context) error { | |||||||
| 				return err | 				return err | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		ip, err := network.GetLocalIP() |  | ||||||
| 		if err != nil { |  | ||||||
| 			return err |  | ||||||
| 		} |  | ||||||
| 		listener, err := net.Listen("tcp", fmt.Sprintf(":%d", port)) | 		listener, err := net.Listen("tcp", fmt.Sprintf(":%d", port)) | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			return fmt.Errorf("prometheus listen %d error %w", port, err) | 			return fmt.Errorf("prometheus listen %d error %w", port, err) | ||||||
| 		} | 		} | ||||||
| 		defer listener.Close() | 		defer listener.Close() | ||||||
| 		log.ZDebug(ctx, "prometheus start", "addr", listener.Addr()) | 		log.ZDebug(ctx, "prometheus start", "addr", listener.Addr()) | ||||||
| 		target, err := json.Marshal(prommetrics.BuildDefaultTarget(ip, listener.Addr().(*net.TCPAddr).Port)) |  | ||||||
| 		if err != nil { |  | ||||||
| 			return err |  | ||||||
| 		} |  | ||||||
| 		if err := standalone.GetKeyValue().SetKey(ctx, prommetrics.BuildDiscoveryKey(prommetrics.APIKeyName), target); err != nil { |  | ||||||
| 			return err |  | ||||||
| 		} |  | ||||||
| 		go func() { | 		go func() { | ||||||
| 			err := prommetrics.Start(listener) | 			err := prommetrics.Start(listener) | ||||||
| 			if err == nil { | 			if err == nil { | ||||||
| @ -342,7 +329,7 @@ func (x *cmds) run(ctx context.Context) error { | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func putCmd[C any](cmd *cmds, block bool, fn func(ctx context.Context, config *C, client discovery.Conn, server grpc.ServiceRegistrar) error) { | func putCmd[C any](cmd *cmds, block bool, fn func(ctx context.Context, config *C, client discovery.SvcDiscoveryRegistry, server grpc.ServiceRegistrar) error) { | ||||||
| 	name := path.Base(runtime.FuncForPC(reflect.ValueOf(fn).Pointer()).Name()) | 	name := path.Base(runtime.FuncForPC(reflect.ValueOf(fn).Pointer()).Name()) | ||||||
| 	if index := strings.Index(name, "."); index >= 0 { | 	if index := strings.Index(name, "."); index >= 0 { | ||||||
| 		name = name[:index] | 		name = name[:index] | ||||||
| @ -352,7 +339,7 @@ func putCmd[C any](cmd *cmds, block bool, fn func(ctx context.Context, config *C | |||||||
| 		if err := cmd.parseConf(&conf); err != nil { | 		if err := cmd.parseConf(&conf); err != nil { | ||||||
| 			return err | 			return err | ||||||
| 		} | 		} | ||||||
| 		return fn(ctx, &conf, standalone.GetDiscoveryConn(), standalone.GetServiceRegistrar()) | 		return fn(ctx, &conf, standalone.GetSvcDiscoveryRegistry(), standalone.GetServiceRegistrar()) | ||||||
| 	}) | 	}) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										100
									
								
								config/README.md
									
									
									
									
									
								
							
							
						
						
									
										100
									
								
								config/README.md
									
									
									
									
									
								
							| @ -1,48 +1,66 @@ | |||||||
| --- | # 						OpenIM Configuration File Descriptions and Common Configuration Modifications | ||||||
| title: 'OpenIM Configuration Files and Common Configuration Item Modifications Guide' |  | ||||||
| 
 | 
 | ||||||
| ## Configuration Files Explanation | ## External Component Configurations | ||||||
| 
 | 
 | ||||||
| | Configuration File | Description                                                 | | | Configuration File | Description                                                 | | ||||||
| | ------------------------------- | ------------------------------------------------------------ | | | ------------------ |-------------------------------------------------------------| | ||||||
| | **kafka.yml**                   | Configurations for Kafka username, password, address, etc.   | | | **kafka.yml**      | Configuration for Kafka username, password, address, etc.   | | ||||||
| | **redis.yml**                   | Configurations for Redis password, address, etc.             | | | **redis.yml**      | Configuration for Redis password, address, etc.             | | ||||||
| | **minio.yml**                   | Configurations for MinIO username, password, address, and external IP/domain; failing to modify external IP or domain may cause image file sending failures | | | **minio.yml**      | Configuration for MinIO username, password, address, etc.   | | ||||||
| | **zookeeper.yml**               | Configurations for ZooKeeper user, password, address, etc.   | | | **mongodb.yml**    | Configuration for MongoDB username, password, address, etc. | | ||||||
| | **mongodb.yml**                 | Configurations for MongoDB username, password, address, etc. | | | **discovery.yml**  | Service discovery and etcd credentials and address.         | | ||||||
| | **log.yml**                     | Configurations for log level and storage directory.          | |  | ||||||
| | **notification.yml**            | Configurations for events like adding friends, creating groups, etc. | |  | ||||||
| | **share.yml**                   | Common configurations needed by various OpenIM services, such as secret. | |  | ||||||
| | **webhooks.yml**                | Configurations for URLs in Webhook.                          | |  | ||||||
| | **local-cache.yml**             | Local cache configurations.                                  | |  | ||||||
| | **openim-rpc-third.yml**        | Configurations for listening IP, port, and storage settings for images and videos in openim-rpc-third service. | |  | ||||||
| | **openim-rpc-user.yml**         | Configurations for listening IP and port in openim-rpc-user service. | |  | ||||||
| | **openim-api.yml**              | Configurations for listening IP, port, etc., in openim-api service. | |  | ||||||
| | **openim-crontask.yml**         | Configurations for openim-crontask service.                  | |  | ||||||
| | **openim-msggateway.yml**       | Configurations for listening IP, port, etc., in openim-msggateway service. | |  | ||||||
| | **openim-msgtransfer.yml**      | Configurations for openim-msgtransfer service.               | |  | ||||||
| | **openim-push.yml**             | Configurations for listening IP, port, and offline push settings in openim-push service. | |  | ||||||
| | **openim-rpc-auth.yml**         | Configurations for listening IP, port, and token expiration settings in openim-rpc-auth service. | |  | ||||||
| | **openim-rpc-conversation.yml** | Configurations for listening IP, port, etc., in openim-rpc-conversation service. | |  | ||||||
| | **openim-rpc-friend.yml**       | Configurations for listening IP, port, etc., in openim-rpc-friend service. | |  | ||||||
| | **openim-rpc-group.yml**        | Configurations for listening IP, port, etc., in openim-rpc-group service. | |  | ||||||
| | **openim-rpc-msg.yml**          | Configurations for listening IP, port, and whether to verify friendship before sending messages in openim-rpc-msg service. | |  | ||||||
| 
 | 
 | ||||||
| ## Common Configuration Item Modifications | ## OpenIMServer Related Configurations | ||||||
|  | | Configuration File              | Description                                    | | ||||||
|  | | ------------------------------- | ---------------------------------------------- | | ||||||
|  | | **log.yml**                     | Configuration for logging levels and storage directory                   | | ||||||
|  | | **notification.yml**            | Event notification settings (e.g., add friend, create group)           | | ||||||
|  | | **share.yml**                   | Common settings for all services (e.g., secrets)            | | ||||||
|  | | **webhooks.yml**                | Webhook URLs and related settings                           | | ||||||
|  | | **local-cache.yml**             | Local cache settings (generally do not modify)                 | | ||||||
|  | | **openim-rpc-third.yml**        | openim-rpc-third listen IP, port, and object storage settings  | | ||||||
|  | | **openim-rpc-user.yml**         | openim-rpc-user listen IP and port settings              | | ||||||
|  | | **openim-api.yml**              | openim-api listen IP, port, and other settings               | | ||||||
|  | | **openim-crontask.yml**         | openim-crontask scheduled task settings                   | | ||||||
|  | | **openim-msggateway.yml**       | openim-msggateway listen IP, port, and other settings           | | ||||||
|  | | **openim-msgtransfer.yml**      | Settings for openim-msgtransfer service                   | | ||||||
|  | | **openim-push.yml**             | openim-push listen IP, port, and offline push settings        | | ||||||
|  | | **openim-rpc-auth.yml**         | openim-rpc-auth listen IP, port, token validity settings | | ||||||
|  | | **openim-rpc-conversation.yml** | openim-rpc-conversation listen IP and port settings     | | ||||||
|  | | **openim-rpc-friend.yml**       | openim-rpc-friend listen IP and port settings           | | ||||||
|  | | **openim-rpc-group.yml**        | openim-rpc-group listen IP and port settings           | | ||||||
|  | | **openim-rpc-msg.yml**          | openim-rpc-msg listen IP and port settings         | | ||||||
| 
 | 
 | ||||||
| | Configuration Item Modification                       | Configuration File      | |  | ||||||
| | ----------------------------------------------------- | ----------------------- | |  | ||||||
| | Using MinIO for image and video file object storage   | `minio.yml`             | |  | ||||||
| | Adjusting production environment logs                 | `log.yml`               | |  | ||||||
| | Verifying friendship before sending messages          | `openim-rpc-msg.yml`    | |  | ||||||
| | Modifying secret                                      | `share.yml`             | |  | ||||||
| | Using OSS, COS, AWS, Kodo for image and video storage | `openim-rpc-third.yml`  | |  | ||||||
| | Setting multiple login policy                         | `openim-msggateway.yml` | |  | ||||||
| | Setting up offline push                               | `openim-push.yml`       | |  | ||||||
| 
 | 
 | ||||||
| ## Starting Multiple Instances of an OpenIM Service | ## Monitoring and Alerting Related Configurations | ||||||
|  | | Configuration File             | Description     | | ||||||
|  | | ------------------------------ | --------------- | | ||||||
|  | | **prometheus.yml**             | Prometheus configuration | | ||||||
|  | | **instance-down-rules.yml**    | Alert rules       | | ||||||
|  | | **alertmanager.yml**           | Alertmanager configuration   | | ||||||
|  | | **email.tmpl**                 | Email alert template   | | ||||||
|  | | **grefana-template/Demo.json** | Default Grafana dashboard | | ||||||
| 
 | 
 | ||||||
| To start multiple instances of an OpenIM service, simply increase the corresponding port numbers and modify the `start-config.yml` file in the project root directory. Restart the service to take effect. For example, the configuration to start 2 instances of `openim-rpc-user` is as follows: | ## Common Configuration Modifications | ||||||
|  | | Configuration Item                                              | Configuration File                | | ||||||
|  | | -------------------------------------------------------- | ----------------------- | | ||||||
|  | | Configure MinIO as object storage (focus on the externalAddress field) | `minio.yml`             | | ||||||
|  | | Adjust log level and number of log files                              | `log.yml`               | | ||||||
|  | | Enable or disable friend verification when sending messages                           | `openim-rpc-msg.yml`    | | ||||||
|  | | OpenIMServer secret                                         | `share.yml`             | | ||||||
|  | | Configure OSS, COS, AWS, or Kodo as object storage               | `openim-rpc-third.yml`  | | ||||||
|  | | Multi-end mutual kick strategy and max concurrent connections per gateway                 | `openim-msggateway.yml` | | ||||||
|  | | Offline message push configuration                                            | `openim-push.yml`       | | ||||||
|  | | Configure webhooks for callback notifications (e.g., before/after message send)         | `webhooks.yml`          | | ||||||
|  | | Whether new group members can view historical messages                          | `openim-rpc-group.yml`  | | ||||||
|  | | Token expiration time settings                                      | `openim-rpc-auth.yml`     | | ||||||
|  | | Scheduled task settings (e.g., how long to retain messages)                      | `openim-crontask.yml`   | | ||||||
|  | 
 | ||||||
|  | ## Starting Multiple Instances of a Service and Maximum File Descriptors | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | To start multiple instances of an OpenIM service, simply add the corresponding port numbers and modify the `start-config.yml` file in the project’s root directory,  | ||||||
|  | then restart the service. For example, to start 2 instances of `openim-rpc-user`: | ||||||
| 
 | 
 | ||||||
| ```yaml | ```yaml | ||||||
| rpc: | rpc: | ||||||
| @ -61,3 +79,9 @@ Modify `start-config.yml`: | |||||||
| serviceBinaries: | serviceBinaries: | ||||||
|   openim-rpc-user: 2 |   openim-rpc-user: 2 | ||||||
| ``` | ``` | ||||||
|  | 
 | ||||||
|  | To set the maximum number of open file descriptors (typically one per online user): | ||||||
|  | 
 | ||||||
|  | ``` | ||||||
|  | maxFileDescriptors: 10000 | ||||||
|  | ``` | ||||||
|  | |||||||
| @ -1,45 +1,63 @@ | |||||||
| # 						OpenIM配置文件说明以及常用配置修改说明 | # 						OpenIM配置文件说明以及常用配置修改说明 | ||||||
| 
 | 
 | ||||||
| ## 配置文件说明 | ## 外部组件相关配置 | ||||||
| 
 | 
 | ||||||
| | Configuration File | Description                        | | | Configuration File | Description                        | | ||||||
| | ------------------------------- | ------------------------------------------------------------ | | | ------------------ | ---------------------------------- | | ||||||
| | **kafka.yml**      | Kafka用户名、密码、地址等配置      | | | **kafka.yml**      | Kafka用户名、密码、地址等配置      | | ||||||
| | **redis.yml**      | Redis密码、地址等配置              | | | **redis.yml**      | Redis密码、地址等配置              | | ||||||
| | **minio.yml**                   | MinIO用户名、密码、地址及外网IP域名等配置;未修改外网IP或域名可能导致图片文件发送失败 | | | **minio.yml**      | MinIO用户名、密码、地址等配置      | | ||||||
| | **zookeeper.yml**               | ZooKeeper用户、密码、地址等配置                              | |  | ||||||
| | **mongodb.yml**    | MongoDB用户名、密码、地址等配置    | | | **mongodb.yml**    | MongoDB用户名、密码、地址等配置    | | ||||||
|  | | **discovery.yml**  | 服务发现以及etcd用户名、密码、地址 | | ||||||
|  | 
 | ||||||
|  | ## OpenIMServer相关配置 | ||||||
|  | | Configuration File              | Description                                    | | ||||||
|  | | ------------------------------- | ---------------------------------------------- | | ||||||
| | **log.yml**                     | 日志级别及存储目录等配置                       | | | **log.yml**                     | 日志级别及存储目录等配置                       | | ||||||
| | **notification.yml**            | 添加好友、创建群组等事件通知配置               | | | **notification.yml**            | 添加好友、创建群组等事件通知配置               | | ||||||
| | **share.yml**                   | OpenIM各服务所需的公共配置,如secret等                       | | | **share.yml**                   | 各服务所需的公共配置,如secret等               | | ||||||
| | **webhooks.yml**                | Webhook中URL等配置                             | | | **webhooks.yml**                | Webhook中URL等配置                             | | ||||||
| | **local-cache.yml**             | 本地缓存配置                                                 | | | **local-cache.yml**             | 本地缓存配置,一般不用修改                     | | ||||||
| | **openim-rpc-third.yml**        | openim-rpc-third服务的监听IP、端口及图片视频对象存储配置     | | | **openim-rpc-third.yml**        | openim-rpc-third监听IP、端口及对象存储配置     | | ||||||
| | **openim-rpc-user.yml**         | openim-rpc-user服务的监听IP、端口配置                        | | | **openim-rpc-user.yml**         | openim-rpc-user监听IP、端口配置                | | ||||||
| | **openim-api.yml**              | openim-api服务的监听IP、端口等配置项                         | | | **openim-api.yml**              | openim-api监听IP、端口等配置                   | | ||||||
| | **openim-crontask.yml**         | openim-crontask服务配置                                      | | | **openim-crontask.yml**         | openim-crontask定时任务配置                    | | ||||||
| | **openim-msggateway.yml**       | openim-msggateway服务的监听IP、端口等配置                    | | | **openim-msggateway.yml**       | openim-msggateway监听IP、端口等配置            | | ||||||
| | **openim-msgtransfer.yml**      | openim-msgtransfer服务配置                     | | | **openim-msgtransfer.yml**      | openim-msgtransfer服务配置                     | | ||||||
| | **openim-push.yml**             | openim-push服务的监听IP、端口及离线推送配置                  | | | **openim-push.yml**             | openim-push监听IP、端口及离线推送配置          | | ||||||
| | **openim-rpc-auth.yml**         | openim-rpc-auth服务的监听IP、端口及token有效期等配置         | | | **openim-rpc-auth.yml**         | openim-rpc-auth监听IP、端口及token有效期等配置 | | ||||||
| | **openim-rpc-conversation.yml** | openim-rpc-conversation服务的监听IP、端口等配置              | | | **openim-rpc-conversation.yml** | openim-rpc-conversation监听IP、端口等配置      | | ||||||
| | **openim-rpc-friend.yml**       | openim-rpc-friend服务的监听IP、端口等配置                    | | | **openim-rpc-friend.yml**       | openim-rpc-friend监听IP、端口等配置            | | ||||||
| | **openim-rpc-group.yml**        | openim-rpc-group服务的监听IP、端口等配置                     | | | **openim-rpc-group.yml**        | openim-rpc-group监听IP、端口等配置             | | ||||||
| | **openim-rpc-msg.yml**          | openim-rpc-msg服务的监听IP、端口及消息发送是否验证好友关系等配置 | | | **openim-rpc-msg.yml**          | openim-rpc-msg服务的监听IP、端口等配置         | | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | ## 监控告警相关配置 | ||||||
|  | | Configuration File             | Description     | | ||||||
|  | | ------------------------------ | --------------- | | ||||||
|  | | **prometheus.yml**             | prometheus配置  | | ||||||
|  | | **instance-down-rules.yml**    | 告警规则        | | ||||||
|  | | **alertmanager.yml**           | 告警管理配置    | | ||||||
|  | | **email.tmpl**                 | 邮件告警模版    | | ||||||
|  | | **grefana-template/Demo.json** | 默认的dashboard | | ||||||
| 
 | 
 | ||||||
| ## 常用配置修改 | ## 常用配置修改 | ||||||
| 
 |  | ||||||
| | 修改配置项                                               | 配置文件                | | | 修改配置项                                               | 配置文件                | | ||||||
| | ----------------------------------------------- | ----------------------- | | | -------------------------------------------------------- | ----------------------- | | ||||||
| | 使用minio作为图片视频文件对象存储               | `minio.yml`             | | | 使用minio作为对象存储时配置,重点关注externalAddress字段 | `minio.yml`             | | ||||||
| | 生产环境日志调整                                | `log.yml`               | | | 日志级别及日志文件数量调整                               | `log.yml`               | | ||||||
| | 发送消息是否验证好友关系                        | `openim-rpc-msg.yml`    | | | 发送消息是否需要验证好友关系                             | `openim-rpc-msg.yml`    | | ||||||
| | 修改secret                                      | `share.yml`             | | | OpenIMServer秘钥                                         | `share.yml`             | | ||||||
| | 使用oss, cos, aws, kodo作为图片视频文件对象存储 | `openim-rpc-third.yml`  | | | 使用oss, cos, aws, kodo作为对象存储时配置                | `openim-rpc-third.yml`  | | ||||||
| | 设置多端互踢策略                                | `openim-msggateway.yml` | | | 多端互踢策略,单个gateway同时最大连接数                  | `openim-msggateway.yml` | | ||||||
| | 设置离线推送                                    | `openim-push.yml`       | | | 消息离线推送                                             | `openim-push.yml`       | | ||||||
|  | | 配置webhook来通知回调服务器,如消息发送前后回调          | `webhooks.yml`          | | ||||||
|  | | 新入群用户是否可以查看历史消息                           | `openim-rpc-group.yml`  | | ||||||
|  | | token 过期时间设置                                       | `openim-rpc-auth.yml`     | | ||||||
|  | | 定时任务设置,例如消息保存多长时间                       | `openim-crontask.yml`   | | ||||||
|  | 
 | ||||||
|  | ## 启动某个服务的多个实例和最大文件句柄数 | ||||||
| 
 | 
 | ||||||
| ## 启动某个OpenIM服务的多个实例 |  | ||||||
| 
 | 
 | ||||||
| 若要启动某个OpenIM的多个实例,只需增加对应的端口数,并修改项目根目录下的`start-config.yml`文件,重启服务即可生效。例如,启动2个`openim-rpc-user`实例的配置如下: | 若要启动某个OpenIM的多个实例,只需增加对应的端口数,并修改项目根目录下的`start-config.yml`文件,重启服务即可生效。例如,启动2个`openim-rpc-user`实例的配置如下: | ||||||
| 
 | 
 | ||||||
| @ -61,5 +79,8 @@ serviceBinaries: | |||||||
|   openim-rpc-user: 2 |   openim-rpc-user: 2 | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | 修改最大同时打开的文件句柄数,一般是每个在线用户占用一个 | ||||||
| 
 | 
 | ||||||
| 
 | ``` | ||||||
|  | maxFileDescriptors: 10000 | ||||||
|  | ``` | ||||||
|  | |||||||
| @ -2,8 +2,13 @@ enable: etcd | |||||||
| etcd: | etcd: | ||||||
|   rootDirectory: openim |   rootDirectory: openim | ||||||
|   address: [localhost:12379] |   address: [localhost:12379] | ||||||
|   username: '' |   ## Attention: If you set auth in etcd | ||||||
|   password: '' |   ## you must also update the username and password in Chat project. | ||||||
|  |   username: | ||||||
|  |   password: | ||||||
|  | 
 | ||||||
|  | kubernetes: | ||||||
|  |   namespace: default | ||||||
| 
 | 
 | ||||||
| rpcService: | rpcService: | ||||||
|   user: user-rpc-service |   user: user-rpc-service | ||||||
|  | |||||||
| @ -1,7 +1,7 @@ | |||||||
| # Username for authentication | ## Kafka authentication | ||||||
| username: '' | username: | ||||||
| # Password for authentication | password: | ||||||
| password: '' | 
 | ||||||
| # Producer acknowledgment settings | # Producer acknowledgment settings | ||||||
| producerAck: | producerAck: | ||||||
| # Compression type to use (e.g., none, gzip, snappy) | # Compression type to use (e.g., none, gzip, snappy) | ||||||
|  | |||||||
| @ -14,3 +14,38 @@ authSource: openim_v3 | |||||||
| maxPoolSize: 100 | maxPoolSize: 100 | ||||||
| # Maximum number of retry attempts for a failed database connection | # Maximum number of retry attempts for a failed database connection | ||||||
| maxRetry: 10 | maxRetry: 10 | ||||||
|  | # MongoDB Mode, including "standalone", "replicaSet" | ||||||
|  | mongoMode: "standalone" | ||||||
|  | 
 | ||||||
|  | # The following configurations only take effect when mongoMode is set to "replicaSet" | ||||||
|  | replicaSet: | ||||||
|  |   name: rs0 | ||||||
|  |   hosts: [127.0.0.1:37017, 127.0.0.1:37018, 127.0.0.1:37019] | ||||||
|  |   # Read concern level: "local", "available", "majority", "linearizable", "snapshot" | ||||||
|  |   readConcern: majority | ||||||
|  |   # maximum staleness of data in seconds | ||||||
|  |   maxStaleness: 90s | ||||||
|  | 
 | ||||||
|  | # The following configurations only take effect when mongoMode is set to "replicaSet" | ||||||
|  | readPreference: | ||||||
|  |   # Read preference mode, can be "primary", "primaryPreferred", "secondary", "secondaryPreferred", "nearest" | ||||||
|  |   mode: primary | ||||||
|  |   maxStaleness: 90s | ||||||
|  |   # TagSets is an array of maps with priority based on order, empty map must be placed last for fallback tagSets | ||||||
|  |   tagSets: | ||||||
|  |     - datacenter: "cn-east" | ||||||
|  |       rack: "1" | ||||||
|  |       storage: "ssd" | ||||||
|  |     - datacenter: "cn-east" | ||||||
|  |       storage: "ssd" | ||||||
|  |     - datacenter: "cn-east" | ||||||
|  |     - {} # Empty map, indicates any node | ||||||
|  | 
 | ||||||
|  | # The following configurations only take effect when mongoMode is set to "replicaSet" | ||||||
|  | writeConcern: | ||||||
|  |   # Write node count or tag (int, "majority", or custom tag) | ||||||
|  |   w: majority | ||||||
|  |   # Whether to wait for journal confirmation | ||||||
|  |   j: true | ||||||
|  |   # Write timeout duration | ||||||
|  |   wtimeout: 30s | ||||||
|  | |||||||
| @ -14,6 +14,6 @@ prometheus: | |||||||
|   autoSetPorts: true |   autoSetPorts: true | ||||||
|   # Prometheus listening ports, must match the number of api.ports |   # Prometheus listening ports, must match the number of api.ports | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 12002 ] |   ports: | ||||||
|   # This address can be accessed via a browser |   # This address can be accessed via a browser | ||||||
|   grafanaURL: http://127.0.0.1:13000/ |   grafanaURL: | ||||||
|  | |||||||
| @ -2,18 +2,18 @@ rpc: | |||||||
|   # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP |   # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP | ||||||
|   registerIP: |   registerIP: | ||||||
|   # autoSetPorts indicates whether to automatically set the ports |   # autoSetPorts indicates whether to automatically set the ports | ||||||
|  |   # if you use in kubernetes, set it to false | ||||||
|   autoSetPorts: true |   autoSetPorts: true | ||||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports |   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 10140, 10141, 10142, 10143, 10144, 10145, 10146, 10147, 10148, 10149, 10150, 10151, 10152, 10153, 10154, 10155 ] |   ports: | ||||||
| 
 | 
 | ||||||
| prometheus: | prometheus: | ||||||
|   # Enable or disable Prometheus monitoring |   # Enable or disable Prometheus monitoring | ||||||
|   enable: true |   enable: true | ||||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup |   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 12140, 12141, 12142, 12143, 12144, 12145, 12146, 12147, 12148, 12149, 12150, 12151, 12152, 12153, 12154, 12155 ] |   ports: | ||||||
| 
 |  | ||||||
| # IP address that the RPC/WebSocket service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP | # IP address that the RPC/WebSocket service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP | ||||||
| listenIP: 0.0.0.0 | listenIP: 0.0.0.0 | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -5,4 +5,4 @@ prometheus: | |||||||
|   autoSetPorts: true |   autoSetPorts: true | ||||||
|   # List of ports that Prometheus listens on; each port corresponds to an instance of monitoring. Ensure these are managed accordingly |   # List of ports that Prometheus listens on; each port corresponds to an instance of monitoring. Ensure these are managed accordingly | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 12020, 12021, 12022, 12023, 12024, 12025, 12026, 12027, 12028, 12029, 12030, 12031, 12032, 12033, 12034, 12035 ] |   ports: | ||||||
|  | |||||||
| @ -4,22 +4,24 @@ rpc: | |||||||
|   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP |   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP | ||||||
|   listenIP: 0.0.0.0 |   listenIP: 0.0.0.0 | ||||||
|   # autoSetPorts indicates whether to automatically set the ports |   # autoSetPorts indicates whether to automatically set the ports | ||||||
|  |   # if you use in kubernetes, set it to false | ||||||
|   autoSetPorts: true |   autoSetPorts: true | ||||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports |   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 10170, 10171, 10172, 10173, 10174, 10175, 10176, 10177, 10178, 10179, 10180, 10181, 10182, 10183, 10184, 10185 ] |   ports: | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| prometheus: | prometheus: | ||||||
|   # Enable or disable Prometheus monitoring |   # Enable or disable Prometheus monitoring | ||||||
|   enable: true |   enable: true | ||||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup |   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 12170, 12171, 12172, 12173, 12174, 12175, 12176, 12177, 12178, 12179, 12180, 12182, 12183, 12184, 12185, 12186 ] |   ports: | ||||||
| 
 | 
 | ||||||
| maxConcurrentWorkers: 3 | maxConcurrentWorkers: 3 | ||||||
| #Use geTui for offline push notifications, or choose fcm or jpush; corresponding configuration settings must be specified. | #Use geTui for offline push notifications, or choose fcm or jpns; corresponding configuration settings must be specified. | ||||||
| enable: geTui | enable: | ||||||
| geTui: | getui: | ||||||
|   pushUrl: https://restapi.getui.com/v2/$appId |   pushUrl: https://restapi.getui.com/v2/$appId | ||||||
|   masterSecret: |   masterSecret: | ||||||
|   appKey: |   appKey: | ||||||
|  | |||||||
| @ -4,17 +4,18 @@ rpc: | |||||||
|   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP |   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP | ||||||
|   listenIP: 0.0.0.0 |   listenIP: 0.0.0.0 | ||||||
|   # autoSetPorts indicates whether to automatically set the ports |   # autoSetPorts indicates whether to automatically set the ports | ||||||
|  |   # if you use in kubernetes, set it to false | ||||||
|   autoSetPorts: true |   autoSetPorts: true | ||||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports |   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 10200 ] |   ports: | ||||||
| 
 | 
 | ||||||
| prometheus: | prometheus: | ||||||
|   # Enable or disable Prometheus monitoring |   # Enable or disable Prometheus monitoring | ||||||
|   enable: true |   enable: true | ||||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup |   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 12200 ] |   ports: | ||||||
| 
 | 
 | ||||||
| tokenPolicy: | tokenPolicy: | ||||||
|   # Token validity period, in days |   # Token validity period, in days | ||||||
|  | |||||||
| @ -4,14 +4,15 @@ rpc: | |||||||
|   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP |   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP | ||||||
|   listenIP: 0.0.0.0 |   listenIP: 0.0.0.0 | ||||||
|   # autoSetPorts indicates whether to automatically set the ports |   # autoSetPorts indicates whether to automatically set the ports | ||||||
|  |   # if you use in kubernetes, set it to false | ||||||
|   autoSetPorts: true |   autoSetPorts: true | ||||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports |   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 10220 ] |   ports: | ||||||
| 
 | 
 | ||||||
| prometheus: | prometheus: | ||||||
|   # Enable or disable Prometheus monitoring |   # Enable or disable Prometheus monitoring | ||||||
|   enable: true |   enable: true | ||||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup |   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 12220 ] |   ports: | ||||||
|  | |||||||
| @ -4,14 +4,15 @@ rpc: | |||||||
|   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP |   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP | ||||||
|   listenIP: 0.0.0.0 |   listenIP: 0.0.0.0 | ||||||
|   # autoSetPorts indicates whether to automatically set the ports |   # autoSetPorts indicates whether to automatically set the ports | ||||||
|  |   # if you use in kubernetes, set it to false | ||||||
|   autoSetPorts: true |   autoSetPorts: true | ||||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports |   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 10240 ] |   ports: | ||||||
| 
 | 
 | ||||||
| prometheus: | prometheus: | ||||||
|   # Enable or disable Prometheus monitoring |   # Enable or disable Prometheus monitoring | ||||||
|   enable: true |   enable: true | ||||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup |   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 12240 ] |   ports: | ||||||
|  | |||||||
| @ -4,17 +4,18 @@ rpc: | |||||||
|   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP |   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP | ||||||
|   listenIP: 0.0.0.0 |   listenIP: 0.0.0.0 | ||||||
|   # autoSetPorts indicates whether to automatically set the ports |   # autoSetPorts indicates whether to automatically set the ports | ||||||
|  |   # if you use in kubernetes, set it to false | ||||||
|   autoSetPorts: true |   autoSetPorts: true | ||||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports |   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 10260 ] |   ports: | ||||||
| 
 | 
 | ||||||
| prometheus: | prometheus: | ||||||
|   # Enable or disable Prometheus monitoring |   # Enable or disable Prometheus monitoring | ||||||
|   enable: true |   enable: true | ||||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup |   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 12260 ] |   ports: | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| enableHistoryForNewMembers: true | enableHistoryForNewMembers: true | ||||||
|  | |||||||
| @ -4,17 +4,18 @@ rpc: | |||||||
|   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP |   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP | ||||||
|   listenIP: 0.0.0.0 |   listenIP: 0.0.0.0 | ||||||
|   # autoSetPorts indicates whether to automatically set the ports |   # autoSetPorts indicates whether to automatically set the ports | ||||||
|  |   # if you use in kubernetes, set it to false | ||||||
|   autoSetPorts: true |   autoSetPorts: true | ||||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports |   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 10280 ] |   ports: | ||||||
| 
 | 
 | ||||||
| prometheus: | prometheus: | ||||||
|   # Enable or disable Prometheus monitoring |   # Enable or disable Prometheus monitoring | ||||||
|   enable: true |   enable: true | ||||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup |   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 12280 ] |   ports: | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| # Does sending messages require friend verification | # Does sending messages require friend verification | ||||||
|  | |||||||
| @ -4,17 +4,18 @@ rpc: | |||||||
|   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP |   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP | ||||||
|   listenIP: 0.0.0.0 |   listenIP: 0.0.0.0 | ||||||
|   # autoSetPorts indicates whether to automatically set the ports |   # autoSetPorts indicates whether to automatically set the ports | ||||||
|  |   # if you use in kubernetes, set it to false | ||||||
|   autoSetPorts: true |   autoSetPorts: true | ||||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports |   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 10300 ] |   ports: | ||||||
| 
 | 
 | ||||||
| prometheus: | prometheus: | ||||||
|   # Enable or disable Prometheus monitoring |   # Enable or disable Prometheus monitoring | ||||||
|   enable: true |   enable: true | ||||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup |   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 12300 ] |   ports: | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| object: | object: | ||||||
| @ -35,9 +36,9 @@ object: | |||||||
|     sessionToken:  |     sessionToken:  | ||||||
|     publicRead: false |     publicRead: false | ||||||
|   kodo: |   kodo: | ||||||
|     endpoint: http://s3.cn-south-1.qiniucs.com |     endpoint: https://s3.cn-south-1.qiniucs.com | ||||||
|     bucket: kodo-bucket-test |     bucket: testdemo12313 | ||||||
|     bucketURL: http://kodo-bucket-test-oetobfb.qiniudns.com |     bucketURL: http://so2at6d05.hn-bkt.clouddn.com | ||||||
|     accessKeyID: |     accessKeyID: | ||||||
|     accessKeySecret: |     accessKeySecret: | ||||||
|     sessionToken:  |     sessionToken:  | ||||||
|  | |||||||
| @ -4,14 +4,15 @@ rpc: | |||||||
|   # Listening IP; 0.0.0.0 means both internal and external IPs are listened to, if blank, the internal network IP is automatically obtained by default |   # Listening IP; 0.0.0.0 means both internal and external IPs are listened to, if blank, the internal network IP is automatically obtained by default | ||||||
|   listenIP: 0.0.0.0 |   listenIP: 0.0.0.0 | ||||||
|   # autoSetPorts indicates whether to automatically set the ports |   # autoSetPorts indicates whether to automatically set the ports | ||||||
|  |   # if you use in kubernetes, set it to false | ||||||
|   autoSetPorts: true |   autoSetPorts: true | ||||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports |   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 10320 ] |   ports: | ||||||
| 
 | 
 | ||||||
| prometheus: | prometheus: | ||||||
|   # Whether to enable prometheus |   # Whether to enable prometheus | ||||||
|   enable: true |   enable: true | ||||||
|   # Prometheus listening ports, must be consistent with the number of rpc.ports |   # Prometheus listening ports, must be consistent with the number of rpc.ports | ||||||
|   # It will only take effect when autoSetPorts is set to false. |   # It will only take effect when autoSetPorts is set to false. | ||||||
|   ports: [ 12320 ] |   ports: | ||||||
|  | |||||||
| @ -1,7 +1,14 @@ | |||||||
| address: [localhost:16379] | address: [localhost:16379] | ||||||
| username: | username: | ||||||
| password: openIM123 | password: openIM123 | ||||||
| clusterMode: false | # redis Mode, including "standalone","cluster","sentinel" | ||||||
|  | redisMode: "standalone" | ||||||
| db: 0 | db: 0 | ||||||
| maxRetry: 10 | maxRetry: 10 | ||||||
| poolSize: 100 | poolSize: 100 | ||||||
|  | # Sentinel configuration (only used when redisMode is "sentinel") | ||||||
|  | sentinelMode: | ||||||
|  |   masterName: "redis-master" | ||||||
|  |   sentinelsAddrs: ["127.0.0.1:26379", "127.0.0.1:26380", "127.0.0.1:26381"] | ||||||
|  |   routeByLatency: true | ||||||
|  |   routeRandomly: true | ||||||
|  | |||||||
| @ -1,6 +1,13 @@ | |||||||
| secret: openIM123 | secret: openIM123 | ||||||
| 
 | 
 | ||||||
| imAdminUserID: [imAdmin] | # imAdminUser: Configuration for instant messaging system administrators | ||||||
|  | imAdminUser: | ||||||
|  |   # userIDs: List of administrator user IDs. | ||||||
|  |   # Each entry here corresponds by index to the matching entry in the nicknames list below. | ||||||
|  |   userIDs: [imAdmin] | ||||||
|  |   # nicknames: List of administrator display names. | ||||||
|  |   # Each entry here corresponds by index to the matching entry in the userIDs list above. | ||||||
|  |   nicknames: [superAdmin] | ||||||
| 
 | 
 | ||||||
| # 1: For Android, iOS, Windows, Mac, and web platforms, only one instance can be online at a time | # 1: For Android, iOS, Windows, Mac, and web platforms, only one instance can be online at a time | ||||||
| multiLogin: | multiLogin: | ||||||
|  | |||||||
| @ -16,7 +16,7 @@ afterUpdateUserInfoEx: | |||||||
| afterSendSingleMsg: | afterSendSingleMsg: | ||||||
|   enable: false |   enable: false | ||||||
|   timeout: 5 |   timeout: 5 | ||||||
|   # Only the recvID specified in attentionIds will send the callback |   # Only the recvIDs specified in attentionIds will send the callback | ||||||
|   # if not set, all user messages will be callback |   # if not set, all user messages will be callback | ||||||
|   attentionIds: [] |   attentionIds: [] | ||||||
|   # See beforeSendSingleMsg comment. |   # See beforeSendSingleMsg comment. | ||||||
| @ -36,7 +36,7 @@ beforeMsgModify: | |||||||
| afterSendGroupMsg: | afterSendGroupMsg: | ||||||
|   enable: false |   enable: false | ||||||
|   timeout: 5 |   timeout: 5 | ||||||
|   # Only the recvID specified in attentionIds will send the callback |   # Only the GroupIDs specified in attentionIds will send the callback | ||||||
|   # if not set, all user messages will be callback |   # if not set, all user messages will be callback | ||||||
|   attentionIds: [] |   attentionIds: [] | ||||||
|   # See beforeSendSingleMsg comment. |   # See beforeSendSingleMsg comment. | ||||||
|  | |||||||
| @ -1,34 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| {{- define "defaultValues" -}} |  | ||||||
| - ./generated-configs/helm-image.yaml |  | ||||||
| - ./generated-configs/config.yaml |  | ||||||
| - ./generated-configs/notification.yaml |  | ||||||
| {{- end -}} |  | ||||||
| 
 |  | ||||||
| {{- define "defaultRelease" -}} |  | ||||||
| namespace: openim |  | ||||||
| chart: ./{{ .name }} |  | ||||||
| values: |  | ||||||
|   - ./{{ .name }}/values.yaml |  | ||||||
|   {{- template "defaultValues" . }} |  | ||||||
| {{- end -}} |  | ||||||
| 
 |  | ||||||
| releases: |  | ||||||
| {{- $apps := list "openim-api" "openim-msggateway" "openim-msgtransfer" "openim-push" "openim-rpc-auth" "openim-rpc-conversation" "openim-rpc-friend" "openim-rpc-group" "openim-rpc-msg" "openim-rpc-third" "openim-rpc-user" }} |  | ||||||
| {{- range $app := $apps }} |  | ||||||
|   - name: {{ $app }} |  | ||||||
|     {{- template "defaultRelease" dict "name" $app }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,23 +0,0 @@ | |||||||
| # Patterns to ignore when building packages. |  | ||||||
| # This supports shell glob matching, relative path matching, and |  | ||||||
| # negation (prefixed with !). Only one pattern per line. |  | ||||||
| .DS_Store |  | ||||||
| # Common VCS dirs |  | ||||||
| .git/ |  | ||||||
| .gitignore |  | ||||||
| .bzr/ |  | ||||||
| .bzrignore |  | ||||||
| .hg/ |  | ||||||
| .hgignore |  | ||||||
| .svn/ |  | ||||||
| # Common backup files |  | ||||||
| *.swp |  | ||||||
| *.bak |  | ||||||
| *.tmp |  | ||||||
| *.orig |  | ||||||
| *~ |  | ||||||
| # Various IDEs |  | ||||||
| .project |  | ||||||
| .idea/ |  | ||||||
| *.tmproj |  | ||||||
| .vscode/ |  | ||||||
| @ -1,53 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| apiVersion: v2 |  | ||||||
| name: openim-api |  | ||||||
| description: A OpenIM Api Helm chart for Kubernetes |  | ||||||
| 
 |  | ||||||
| # A chart can be either an 'application' or a 'library' chart. |  | ||||||
| # |  | ||||||
| # Application charts are a collection of templates that can be packaged into versioned archives |  | ||||||
| # to be deployed. |  | ||||||
| # |  | ||||||
| # Library charts provide useful utilities or functions for the chart developer. They're included as |  | ||||||
| # a dependency of application charts to inject those utilities and functions into the rendering |  | ||||||
| # pipeline. Library charts do not define any templates and therefore cannot be deployed. |  | ||||||
| type: application |  | ||||||
| 
 |  | ||||||
| # This is the chart version. This version number should be incremented each time you make changes |  | ||||||
| # to the chart and its templates, including the app version. |  | ||||||
| # Versions are expected to follow Semantic Versioning (https://semver.org/) |  | ||||||
| version: 0.1.0 |  | ||||||
| 
 |  | ||||||
| # This is the version number of the application being deployed. This version number should be |  | ||||||
| # incremented each time you make changes to the application. Versions are not expected to |  | ||||||
| # follow Semantic Versioning. They should reflect the version the application is using. |  | ||||||
| # It is recommended to use it with quotes. |  | ||||||
| appVersion: "1.16.0" |  | ||||||
| 
 |  | ||||||
| icon: https://raw.githubusercontent.com/openimsdk/open-im-server/main/assets/openim-logo-gradient.svg |  | ||||||
| 
 |  | ||||||
| maintainers: |  | ||||||
|   - name: "OpenIM" |  | ||||||
|     url: "https://github.com/openimsdk" |  | ||||||
| 
 |  | ||||||
| keywords: |  | ||||||
|   - openim |  | ||||||
|   - im |  | ||||||
|   - chat |  | ||||||
| 
 |  | ||||||
| sources: |  | ||||||
|   - "https://github.com/openimsdk/open-im-server" |  | ||||||
|   - "https://github.com/openimsdk/helm-charts" |  | ||||||
| @ -1,201 +0,0 @@ | |||||||
|                                  Apache License |  | ||||||
|                            Version 2.0, January 2004 |  | ||||||
|                         http://www.apache.org/licenses/ |  | ||||||
| 
 |  | ||||||
|    TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION |  | ||||||
| 
 |  | ||||||
|    1. Definitions. |  | ||||||
| 
 |  | ||||||
|       "License" shall mean the terms and conditions for use, reproduction, |  | ||||||
|       and distribution as defined by Sections 1 through 9 of this document. |  | ||||||
| 
 |  | ||||||
|       "Licensor" shall mean the copyright owner or entity authorized by |  | ||||||
|       the copyright owner that is granting the License. |  | ||||||
| 
 |  | ||||||
|       "Legal Entity" shall mean the union of the acting entity and all |  | ||||||
|       other entities that control, are controlled by, or are under common |  | ||||||
|       control with that entity. For the purposes of this definition, |  | ||||||
|       "control" means (i) the power, direct or indirect, to cause the |  | ||||||
|       direction or management of such entity, whether by contract or |  | ||||||
|       otherwise, or (ii) ownership of fifty percent (50%) or more of the |  | ||||||
|       outstanding shares, or (iii) beneficial ownership of such entity. |  | ||||||
| 
 |  | ||||||
|       "You" (or "Your") shall mean an individual or Legal Entity |  | ||||||
|       exercising permissions granted by this License. |  | ||||||
| 
 |  | ||||||
|       "Source" form shall mean the preferred form for making modifications, |  | ||||||
|       including but not limited to software source code, documentation |  | ||||||
|       source, and configuration files. |  | ||||||
| 
 |  | ||||||
|       "Object" form shall mean any form resulting from mechanical |  | ||||||
|       transformation or translation of a Source form, including but |  | ||||||
|       not limited to compiled object code, generated documentation, |  | ||||||
|       and conversions to other media types. |  | ||||||
| 
 |  | ||||||
|       "Work" shall mean the work of authorship, whether in Source or |  | ||||||
|       Object form, made available under the License, as indicated by a |  | ||||||
|       copyright notice that is included in or attached to the work |  | ||||||
|       (an example is provided in the Appendix below). |  | ||||||
| 
 |  | ||||||
|       "Derivative Works" shall mean any work, whether in Source or Object |  | ||||||
|       form, that is based on (or derived from) the Work and for which the |  | ||||||
|       editorial revisions, annotations, elaborations, or other modifications |  | ||||||
|       represent, as a whole, an original work of authorship. For the purposes |  | ||||||
|       of this License, Derivative Works shall not include works that remain |  | ||||||
|       separable from, or merely link (or bind by name) to the interfaces of, |  | ||||||
|       the Work and Derivative Works thereof. |  | ||||||
| 
 |  | ||||||
|       "Contribution" shall mean any work of authorship, including |  | ||||||
|       the original version of the Work and any modifications or additions |  | ||||||
|       to that Work or Derivative Works thereof, that is intentionally |  | ||||||
|       submitted to Licensor for inclusion in the Work by the copyright owner |  | ||||||
|       or by an individual or Legal Entity authorized to submit on behalf of |  | ||||||
|       the copyright owner. For the purposes of this definition, "submitted" |  | ||||||
|       means any form of electronic, verbal, or written communication sent |  | ||||||
|       to the Licensor or its representatives, including but not limited to |  | ||||||
|       communication on electronic mailing lists, source code control systems, |  | ||||||
|       and issue tracking systems that are managed by, or on behalf of, the |  | ||||||
|       Licensor for the purpose of discussing and improving the Work, but |  | ||||||
|       excluding communication that is conspicuously marked or otherwise |  | ||||||
|       designated in writing by the copyright owner as "Not a Contribution." |  | ||||||
| 
 |  | ||||||
|       "Contributor" shall mean Licensor and any individual or Legal Entity |  | ||||||
|       on behalf of whom a Contribution has been received by Licensor and |  | ||||||
|       subsequently incorporated within the Work. |  | ||||||
| 
 |  | ||||||
|    2. Grant of Copyright License. Subject to the terms and conditions of |  | ||||||
|       this License, each Contributor hereby grants to You a perpetual, |  | ||||||
|       worldwide, non-exclusive, no-charge, royalty-free, irrevocable |  | ||||||
|       copyright license to reproduce, prepare Derivative Works of, |  | ||||||
|       publicly display, publicly perform, sublicense, and distribute the |  | ||||||
|       Work and such Derivative Works in Source or Object form. |  | ||||||
| 
 |  | ||||||
|    3. Grant of Patent License. Subject to the terms and conditions of |  | ||||||
|       this License, each Contributor hereby grants to You a perpetual, |  | ||||||
|       worldwide, non-exclusive, no-charge, royalty-free, irrevocable |  | ||||||
|       (except as stated in this section) patent license to make, have made, |  | ||||||
|       use, offer to sell, sell, import, and otherwise transfer the Work, |  | ||||||
|       where such license applies only to those patent claims licensable |  | ||||||
|       by such Contributor that are necessarily infringed by their |  | ||||||
|       Contribution(s) alone or by combination of their Contribution(s) |  | ||||||
|       with the Work to which such Contribution(s) was submitted. If You |  | ||||||
|       institute patent litigation against any entity (including a |  | ||||||
|       cross-claim or counterclaim in a lawsuit) alleging that the Work |  | ||||||
|       or a Contribution incorporated within the Work constitutes direct |  | ||||||
|       or contributory patent infringement, then any patent licenses |  | ||||||
|       granted to You under this License for that Work shall terminate |  | ||||||
|       as of the date such litigation is filed. |  | ||||||
| 
 |  | ||||||
|    4. Redistribution. You may reproduce and distribute copies of the |  | ||||||
|       Work or Derivative Works thereof in any medium, with or without |  | ||||||
|       modifications, and in Source or Object form, provided that You |  | ||||||
|       meet the following conditions: |  | ||||||
| 
 |  | ||||||
|       (a) You must give any other recipients of the Work or |  | ||||||
|           Derivative Works a copy of this License; and |  | ||||||
| 
 |  | ||||||
|       (b) You must cause any modified files to carry prominent notices |  | ||||||
|           stating that You changed the files; and |  | ||||||
| 
 |  | ||||||
|       (c) You must retain, in the Source form of any Derivative Works |  | ||||||
|           that You distribute, all copyright, patent, trademark, and |  | ||||||
|           attribution notices from the Source form of the Work, |  | ||||||
|           excluding those notices that do not pertain to any part of |  | ||||||
|           the Derivative Works; and |  | ||||||
| 
 |  | ||||||
|       (d) If the Work includes a "NOTICE" text file as part of its |  | ||||||
|           distribution, then any Derivative Works that You distribute must |  | ||||||
|           include a readable copy of the attribution notices contained |  | ||||||
|           within such NOTICE file, excluding those notices that do not |  | ||||||
|           pertain to any part of the Derivative Works, in at least one |  | ||||||
|           of the following places: within a NOTICE text file distributed |  | ||||||
|           as part of the Derivative Works; within the Source form or |  | ||||||
|           documentation, if provided along with the Derivative Works; or, |  | ||||||
|           within a display generated by the Derivative Works, if and |  | ||||||
|           wherever such third-party notices normally appear. The contents |  | ||||||
|           of the NOTICE file are for informational purposes only and |  | ||||||
|           do not modify the License. You may add Your own attribution |  | ||||||
|           notices within Derivative Works that You distribute, alongside |  | ||||||
|           or as an addendum to the NOTICE text from the Work, provided |  | ||||||
|           that such additional attribution notices cannot be construed |  | ||||||
|           as modifying the License. |  | ||||||
| 
 |  | ||||||
|       You may add Your own copyright statement to Your modifications and |  | ||||||
|       may provide additional or different license terms and conditions |  | ||||||
|       for use, reproduction, or distribution of Your modifications, or |  | ||||||
|       for any such Derivative Works as a whole, provided Your use, |  | ||||||
|       reproduction, and distribution of the Work otherwise complies with |  | ||||||
|       the conditions stated in this License. |  | ||||||
| 
 |  | ||||||
|    5. Submission of Contributions. Unless You explicitly state otherwise, |  | ||||||
|       any Contribution intentionally submitted for inclusion in the Work |  | ||||||
|       by You to the Licensor shall be under the terms and conditions of |  | ||||||
|       this License, without any additional terms or conditions. |  | ||||||
|       Notwithstanding the above, nothing herein shall supersede or modify |  | ||||||
|       the terms of any separate license agreement you may have executed |  | ||||||
|       with Licensor regarding such Contributions. |  | ||||||
| 
 |  | ||||||
|    6. Trademarks. This License does not grant permission to use the trade |  | ||||||
|       names, trademarks, service marks, or product names of the Licensor, |  | ||||||
|       except as required for reasonable and customary use in describing the |  | ||||||
|       origin of the Work and reproducing the content of the NOTICE file. |  | ||||||
| 
 |  | ||||||
|    7. Disclaimer of Warranty. Unless required by applicable law or |  | ||||||
|       agreed to in writing, Licensor provides the Work (and each |  | ||||||
|       Contributor provides its Contributions) on an "AS IS" BASIS, |  | ||||||
|       WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or |  | ||||||
|       implied, including, without limitation, any warranties or conditions |  | ||||||
|       of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A |  | ||||||
|       PARTICULAR PURPOSE. You are solely responsible for determining the |  | ||||||
|       appropriateness of using or redistributing the Work and assume any |  | ||||||
|       risks associated with Your exercise of permissions under this License. |  | ||||||
| 
 |  | ||||||
|    8. Limitation of Liability. In no event and under no legal theory, |  | ||||||
|       whether in tort (including negligence), contract, or otherwise, |  | ||||||
|       unless required by applicable law (such as deliberate and grossly |  | ||||||
|       negligent acts) or agreed to in writing, shall any Contributor be |  | ||||||
|       liable to You for damages, including any direct, indirect, special, |  | ||||||
|       incidental, or consequential damages of any character arising as a |  | ||||||
|       result of this License or out of the use or inability to use the |  | ||||||
|       Work (including but not limited to damages for loss of goodwill, |  | ||||||
|       work stoppage, computer failure or malfunction, or any and all |  | ||||||
|       other commercial damages or losses), even if such Contributor |  | ||||||
|       has been advised of the possibility of such damages. |  | ||||||
| 
 |  | ||||||
|    9. Accepting Warranty or Additional Liability. While redistributing |  | ||||||
|       the Work or Derivative Works thereof, You may choose to offer, |  | ||||||
|       and charge a fee for, acceptance of support, warranty, indemnity, |  | ||||||
|       or other liability obligations and/or rights consistent with this |  | ||||||
|       License. However, in accepting such obligations, You may act only |  | ||||||
|       on Your own behalf and on Your sole responsibility, not on behalf |  | ||||||
|       of any other Contributor, and only if You agree to indemnify, |  | ||||||
|       defend, and hold each Contributor harmless for any liability |  | ||||||
|       incurred by, or claims asserted against, such Contributor by reason |  | ||||||
|       of your accepting any such warranty or additional liability. |  | ||||||
| 
 |  | ||||||
|    END OF TERMS AND CONDITIONS |  | ||||||
| 
 |  | ||||||
|    APPENDIX: How to apply the Apache License to your work. |  | ||||||
| 
 |  | ||||||
|       To apply the Apache License to your work, attach the following |  | ||||||
|       boilerplate notice, with the fields enclosed by brackets "[]" |  | ||||||
|       replaced with your own identifying information. (Don't include |  | ||||||
|       the brackets!)  The text should be enclosed in the appropriate |  | ||||||
|       comment syntax for the file format. We also recommend that a |  | ||||||
|       file or class name and description of purpose be included on the |  | ||||||
|       same "printed page" as the copyright notice for easier |  | ||||||
|       identification within third-party archives. |  | ||||||
| 
 |  | ||||||
|    Copyright [yyyy] [name of copyright owner] |  | ||||||
| 
 |  | ||||||
|    Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
|    you may not use this file except in compliance with the License. |  | ||||||
|    You may obtain a copy of the License at |  | ||||||
| 
 |  | ||||||
|        http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| 
 |  | ||||||
|    Unless required by applicable law or agreed to in writing, software |  | ||||||
|    distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
|    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
|    See the License for the specific language governing permissions and |  | ||||||
|    limitations under the License. |  | ||||||
| @ -1,22 +0,0 @@ | |||||||
| 1. Get the application URL by running these commands: |  | ||||||
| {{- if .Values.ingress.enabled }} |  | ||||||
| {{- range $host := .Values.ingress.hosts }} |  | ||||||
|   {{- range .paths }} |  | ||||||
|   http{{ if $.Values.ingress.tls }}s{{ end }}://{{ $host.host }}{{ .path }} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| {{- else if contains "NodePort" .Values.service.type }} |  | ||||||
|   export NODE_PORT=$(kubectl get --namespace {{ .Release.Namespace }} -o jsonpath="{.spec.ports[0].nodePort}" services {{ include "openim-api.fullname" . }}) |  | ||||||
|   export NODE_IP=$(kubectl get nodes --namespace {{ .Release.Namespace }} -o jsonpath="{.items[0].status.addresses[0].address}") |  | ||||||
|   echo http://$NODE_IP:$NODE_PORT |  | ||||||
| {{- else if contains "LoadBalancer" .Values.service.type }} |  | ||||||
|      NOTE: It may take a few minutes for the LoadBalancer IP to be available. |  | ||||||
|            You can watch the status of by running 'kubectl get --namespace {{ .Release.Namespace }} svc -w {{ include "openim-api.fullname" . }}' |  | ||||||
|   export SERVICE_IP=$(kubectl get svc --namespace {{ .Release.Namespace }} {{ include "openim-api.fullname" . }} --template "{{"{{ range (index .status.loadBalancer.ingress 0) }}{{.}}{{ end }}"}}") |  | ||||||
|   echo http://$SERVICE_IP:{{ .Values.service.port }} |  | ||||||
| {{- else if contains "ClusterIP" .Values.service.type }} |  | ||||||
|   export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app.kubernetes.io/name={{ include "openim-api.name" . }},app.kubernetes.io/instance={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}") |  | ||||||
|   export CONTAINER_PORT=$(kubectl get pod --namespace {{ .Release.Namespace }} $POD_NAME -o jsonpath="{.spec.containers[0].ports[0].containerPort}") |  | ||||||
|   echo "Visit http://127.0.0.1:8080 to use your application" |  | ||||||
|   kubectl --namespace {{ .Release.Namespace }} port-forward $POD_NAME 8080:$CONTAINER_PORT |  | ||||||
| {{- end }} |  | ||||||
| @ -1,62 +0,0 @@ | |||||||
| {{/* |  | ||||||
| Expand the name of the chart. |  | ||||||
| */}} |  | ||||||
| {{- define "openim-api.name" -}} |  | ||||||
| {{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Create a default fully qualified app name. |  | ||||||
| We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). |  | ||||||
| If release name contains chart name it will be used as a full name. |  | ||||||
| */}} |  | ||||||
| {{- define "openim-api.fullname" -}} |  | ||||||
| {{- if .Values.fullnameOverride }} |  | ||||||
| {{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- else }} |  | ||||||
| {{- $name := default .Chart.Name .Values.nameOverride }} |  | ||||||
| {{- if contains $name .Release.Name }} |  | ||||||
| {{- .Release.Name | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- else }} |  | ||||||
| {{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Create chart name and version as used by the chart label. |  | ||||||
| */}} |  | ||||||
| {{- define "openim-api.chart" -}} |  | ||||||
| {{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Common labels |  | ||||||
| */}} |  | ||||||
| {{- define "openim-api.labels" -}} |  | ||||||
| helm.sh/chart: {{ include "openim-api.chart" . }} |  | ||||||
| {{ include "openim-api.selectorLabels" . }} |  | ||||||
| {{- if .Chart.AppVersion }} |  | ||||||
| app.kubernetes.io/version: {{ .Chart.AppVersion | quote }} |  | ||||||
| {{- end }} |  | ||||||
| app.kubernetes.io/managed-by: {{ .Release.Service }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Selector labels |  | ||||||
| */}} |  | ||||||
| {{- define "openim-api.selectorLabels" -}} |  | ||||||
| app.kubernetes.io/name: {{ include "openim-api.name" . }} |  | ||||||
| app.kubernetes.io/instance: {{ .Release.Name }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Create the name of the service account to use |  | ||||||
| */}} |  | ||||||
| {{- define "openim-api.serviceAccountName" -}} |  | ||||||
| {{- if .Values.serviceAccount.create }} |  | ||||||
| {{- default (include "openim-api.fullname" .) .Values.serviceAccount.name }} |  | ||||||
| {{- else }} |  | ||||||
| {{- default "default" .Values.serviceAccount.name }} |  | ||||||
| {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,27 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| apiVersion: v1 |  | ||||||
| kind: ConfigMap |  | ||||||
| metadata: |  | ||||||
|   name: openim-cm |  | ||||||
| data: |  | ||||||
|   config.yaml: |+ |  | ||||||
|     {{- with .Values.config }} |  | ||||||
|         {{- toYaml . | nindent 4 }} |  | ||||||
|     {{- end }} |  | ||||||
|   notification.yaml: |+ |  | ||||||
|     {{- with .Values.notification }} |  | ||||||
|         {{- toYaml . | nindent 4 }} |  | ||||||
|     {{- end }} |  | ||||||
| @ -1,86 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| apiVersion: apps/v1 |  | ||||||
| kind: Deployment |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-api.fullname" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-api.labels" . | nindent 4 }} |  | ||||||
| spec: |  | ||||||
|   {{- if not .Values.autoscaling.enabled }} |  | ||||||
|   replicas: {{ .Values.replicaCount }} |  | ||||||
|   {{- end }} |  | ||||||
|   selector: |  | ||||||
|     matchLabels: |  | ||||||
|       {{- include "openim-api.selectorLabels" . | nindent 6 }} |  | ||||||
|   template: |  | ||||||
|     metadata: |  | ||||||
|       {{- with .Values.podAnnotations }} |  | ||||||
|       annotations: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       labels: |  | ||||||
|         {{- include "openim-api.selectorLabels" . | nindent 8 }} |  | ||||||
|     spec: |  | ||||||
|       {{- with .Values.imagePullSecrets }} |  | ||||||
|       imagePullSecrets: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       serviceAccountName: {{ include "openim-api.serviceAccountName" . }} |  | ||||||
|       securityContext: |  | ||||||
|         {{- toYaml .Values.podSecurityContext | nindent 8 }} |  | ||||||
|       containers: |  | ||||||
|         - name: {{ .Chart.Name }} |  | ||||||
|           securityContext: |  | ||||||
|             {{- toYaml .Values.securityContext | nindent 12 }} |  | ||||||
|           image: "{{ .Values.image.repository }}:{{ .Values.image.tag | default .Chart.AppVersion }}" |  | ||||||
|           imagePullPolicy: {{ .Values.image.pullPolicy }} |  | ||||||
|           ports: |  | ||||||
|             - name: webhook |  | ||||||
|               containerPort: 80 |  | ||||||
|               protocol: TCP |  | ||||||
|           #livenessProbe: |  | ||||||
|           #  httpGet: |  | ||||||
|           #    path: / |  | ||||||
|           #    port: webhook |  | ||||||
|           #readinessProbe: |  | ||||||
|           #  httpGet: |  | ||||||
|           #    path: / |  | ||||||
|           #    port: webhook |  | ||||||
|           resources: |  | ||||||
|             {{- toYaml .Values.resources | nindent 12 }} |  | ||||||
|           volumeMounts: |  | ||||||
|             - mountPath: /openim/openim-server/config/config.yaml |  | ||||||
|               name: config |  | ||||||
|               subPath: config.yaml |  | ||||||
|             - mountPath: /openim/openim-server/config/ |  | ||||||
|               name: config |  | ||||||
|               subPath: notification.yaml |  | ||||||
|       volumes: |  | ||||||
|         - name: config |  | ||||||
|           configMap: |  | ||||||
|             name: openim-cm |  | ||||||
|       {{- with .Values.nodeSelector }} |  | ||||||
|       nodeSelector: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       {{- with .Values.affinity }} |  | ||||||
|       affinity: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       {{- with .Values.tolerations }} |  | ||||||
|       tolerations: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
| @ -1,42 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| {{- if .Values.autoscaling.enabled }} |  | ||||||
| apiVersion: autoscaling/v2beta1 |  | ||||||
| kind: HorizontalPodAutoscaler |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-api.fullname" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-api.labels" . | nindent 4 }} |  | ||||||
| spec: |  | ||||||
|   scaleTargetRef: |  | ||||||
|     apiVersion: apps/v1 |  | ||||||
|     kind: Deployment |  | ||||||
|     name: {{ include "openim-api.fullname" . }} |  | ||||||
|   minReplicas: {{ .Values.autoscaling.minReplicas }} |  | ||||||
|   maxReplicas: {{ .Values.autoscaling.maxReplicas }} |  | ||||||
|   metrics: |  | ||||||
|     {{- if .Values.autoscaling.targetCPUUtilizationPercentage }} |  | ||||||
|     - type: Resource |  | ||||||
|       resource: |  | ||||||
|         name: cpu |  | ||||||
|         targetAverageUtilization: {{ .Values.autoscaling.targetCPUUtilizationPercentage }} |  | ||||||
|     {{- end }} |  | ||||||
|     {{- if .Values.autoscaling.targetMemoryUtilizationPercentage }} |  | ||||||
|     - type: Resource |  | ||||||
|       resource: |  | ||||||
|         name: memory |  | ||||||
|         targetAverageUtilization: {{ .Values.autoscaling.targetMemoryUtilizationPercentage }} |  | ||||||
|     {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,75 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| {{- if .Values.ingress.enabled -}} |  | ||||||
| {{- $fullName := include "openim-api.fullname" . -}} |  | ||||||
| {{- $svcPort := .Values.service.port -}} |  | ||||||
| {{- if and .Values.ingress.className (not (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion)) }} |  | ||||||
|   {{- if not (hasKey .Values.ingress.annotations "kubernetes.io/ingress.class") }} |  | ||||||
|   {{- $_ := set .Values.ingress.annotations "kubernetes.io/ingress.class" .Values.ingress.className}} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| {{- if semverCompare ">=1.19-0" .Capabilities.KubeVersion.GitVersion -}} |  | ||||||
| apiVersion: networking.k8s.io/v1 |  | ||||||
| {{- else if semverCompare ">=1.14-0" .Capabilities.KubeVersion.GitVersion -}} |  | ||||||
| apiVersion: networking.k8s.io/v1beta1 |  | ||||||
| {{- else -}} |  | ||||||
| apiVersion: extensions/v1beta1 |  | ||||||
| {{- end }} |  | ||||||
| kind: Ingress |  | ||||||
| metadata: |  | ||||||
|   name: {{ $fullName }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-api.labels" . | nindent 4 }} |  | ||||||
|   {{- with .Values.ingress.annotations }} |  | ||||||
|   annotations: |  | ||||||
|     {{- toYaml . | nindent 4 }} |  | ||||||
|   {{- end }} |  | ||||||
| spec: |  | ||||||
|   {{- if and .Values.ingress.className (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion) }} |  | ||||||
|   ingressClassName: {{ .Values.ingress.className }} |  | ||||||
|   {{- end }} |  | ||||||
|   {{- if .Values.ingress.tls }} |  | ||||||
|   tls: |  | ||||||
|     {{- range .Values.ingress.tls }} |  | ||||||
|     - hosts: |  | ||||||
|         {{- range .hosts }} |  | ||||||
|         - {{ . | quote }} |  | ||||||
|         {{- end }} |  | ||||||
|       secretName: {{ .secretName }} |  | ||||||
|     {{- end }} |  | ||||||
|   {{- end }} |  | ||||||
|   rules: |  | ||||||
|     {{- range .Values.ingress.hosts }} |  | ||||||
|     - host: {{ .host | quote }} |  | ||||||
|       http: |  | ||||||
|         paths: |  | ||||||
|           {{- range .paths }} |  | ||||||
|           - path: {{ .path }} |  | ||||||
|             {{- if and .pathType (semverCompare ">=1.18-0" $.Capabilities.KubeVersion.GitVersion) }} |  | ||||||
|             pathType: {{ .pathType }} |  | ||||||
|             {{- end }} |  | ||||||
|             backend: |  | ||||||
|               {{- if semverCompare ">=1.19-0" $.Capabilities.KubeVersion.GitVersion }} |  | ||||||
|               service: |  | ||||||
|                 name: {{ $fullName }} |  | ||||||
|                 port: |  | ||||||
|                   number: {{ $svcPort }} |  | ||||||
|               {{- else }} |  | ||||||
|               serviceName: {{ $fullName }} |  | ||||||
|               servicePort: {{ $svcPort }} |  | ||||||
|               {{- end }} |  | ||||||
|           {{- end }} |  | ||||||
|     {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,29 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| apiVersion: v1 |  | ||||||
| kind: Service |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-api.fullname" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-api.labels" . | nindent 4 }} |  | ||||||
| spec: |  | ||||||
|   type: {{ .Values.service.type }} |  | ||||||
|   ports: |  | ||||||
|     - port: {{ .Values.service.port }} |  | ||||||
|       targetPort: webhook |  | ||||||
|       protocol: TCP |  | ||||||
|       name: webhook |  | ||||||
|   selector: |  | ||||||
|     {{- include "openim-api.selectorLabels" . | nindent 4 }} |  | ||||||
| @ -1,26 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| {{- if .Values.serviceAccount.create -}} |  | ||||||
| apiVersion: v1 |  | ||||||
| kind: ServiceAccount |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-api.serviceAccountName" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-api.labels" . | nindent 4 }} |  | ||||||
|   {{- with .Values.serviceAccount.annotations }} |  | ||||||
|   annotations: |  | ||||||
|     {{- toYaml . | nindent 4 }} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,100 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| # Default values for openim-api. |  | ||||||
| # This is a YAML-formatted file. |  | ||||||
| # Declare variables to be passed into your templates. |  | ||||||
| 
 |  | ||||||
| replicaCount: 1 |  | ||||||
| 
 |  | ||||||
| image: |  | ||||||
|   repository: ghcr.io/openimsdk/openim-api |  | ||||||
|   pullPolicy: IfNotPresent |  | ||||||
|   # Overrides the image tag whose default is the chart appVersion. |  | ||||||
|   tag: "" |  | ||||||
| 
 |  | ||||||
| imagePullSecrets: [] |  | ||||||
| nameOverride: "" |  | ||||||
| fullnameOverride: "" |  | ||||||
| 
 |  | ||||||
| serviceAccount: |  | ||||||
|   # Specifies whether a service account should be created |  | ||||||
|   create: false |  | ||||||
|   # Annotations to add to the service account |  | ||||||
|   annotations: {} |  | ||||||
|   # The name of the service account to use. |  | ||||||
|   # If not set and create is true, a name is generated using the fullname template |  | ||||||
|   name: "" |  | ||||||
| 
 |  | ||||||
| podAnnotations: {} |  | ||||||
| 
 |  | ||||||
| podSecurityContext: {} |  | ||||||
|   # fsGroup: 2000 |  | ||||||
| 
 |  | ||||||
| securityContext: {} |  | ||||||
|   # capabilities: |  | ||||||
|   #   drop: |  | ||||||
|   #   - ALL |  | ||||||
|   # readOnlyRootFilesystem: true |  | ||||||
|   # runAsNonRoot: true |  | ||||||
|   # runAsUser: 1000 |  | ||||||
| 
 |  | ||||||
| service: |  | ||||||
|   type: ClusterIP |  | ||||||
|   port: 80 |  | ||||||
| 
 |  | ||||||
| ingress: |  | ||||||
|   enabled: false |  | ||||||
|   className: "nginx" |  | ||||||
|   annotations: |  | ||||||
|   # kubernetes.io/ingress.class: nginx |  | ||||||
|   # kubernetes.io/tls-acme: "true" |  | ||||||
|   hosts: |  | ||||||
|     - host: chart-example.local |  | ||||||
|       paths: |  | ||||||
|         - path: / |  | ||||||
|           pathType: ImplementationSpecific |  | ||||||
|   tls: [] |  | ||||||
|   #  - secretName: chart-example-tls |  | ||||||
|   #    hosts: |  | ||||||
|   #      - chart-example.local |  | ||||||
| 
 |  | ||||||
| resources: {} |  | ||||||
|   # We usually recommend not to specify default resources and to leave this as a conscious |  | ||||||
|   # choice for the user. This also increases chances charts run on environments with little |  | ||||||
|   # resources, such as Minikube. If you do want to specify resources, uncomment the following |  | ||||||
|   # lines, adjust them as necessary, and remove the curly braces after 'resources:'. |  | ||||||
|   # limits: |  | ||||||
|   #   cpu: 100m |  | ||||||
|   #   memory: 128Mi |  | ||||||
|   # requests: |  | ||||||
|   #   cpu: 100m |  | ||||||
|   #   memory: 128Mi |  | ||||||
| 
 |  | ||||||
| autoscaling: |  | ||||||
|   enabled: false |  | ||||||
|   minReplicas: 1 |  | ||||||
|   maxReplicas: 100 |  | ||||||
|   targetCPUUtilizationPercentage: 80 |  | ||||||
|   # targetMemoryUtilizationPercentage: 80 |  | ||||||
| 
 |  | ||||||
| nodeSelector: {} |  | ||||||
| 
 |  | ||||||
| tolerations: [] |  | ||||||
| 
 |  | ||||||
| affinity: {} |  | ||||||
| 
 |  | ||||||
| notification: |  | ||||||
| 
 |  | ||||||
| config: |  | ||||||
| @ -1,23 +0,0 @@ | |||||||
| # Patterns to ignore when building packages. |  | ||||||
| # This supports shell glob matching, relative path matching, and |  | ||||||
| # negation (prefixed with !). Only one pattern per line. |  | ||||||
| .DS_Store |  | ||||||
| # Common VCS dirs |  | ||||||
| .git/ |  | ||||||
| .gitignore |  | ||||||
| .bzr/ |  | ||||||
| .bzrignore |  | ||||||
| .hg/ |  | ||||||
| .hgignore |  | ||||||
| .svn/ |  | ||||||
| # Common backup files |  | ||||||
| *.swp |  | ||||||
| *.bak |  | ||||||
| *.tmp |  | ||||||
| *.orig |  | ||||||
| *~ |  | ||||||
| # Various IDEs |  | ||||||
| .project |  | ||||||
| .idea/ |  | ||||||
| *.tmproj |  | ||||||
| .vscode/ |  | ||||||
| @ -1,53 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| apiVersion: v2 |  | ||||||
| name: openim-msggateway |  | ||||||
| description: A Helm chart for Kubernetes |  | ||||||
| 
 |  | ||||||
| # A chart can be either an 'application' or a 'library' chart. |  | ||||||
| # |  | ||||||
| # Application charts are a collection of templates that can be packaged into versioned archives |  | ||||||
| # to be deployed. |  | ||||||
| # |  | ||||||
| # Library charts provide useful utilities or functions for the chart developer. They're included as |  | ||||||
| # a dependency of application charts to inject those utilities and functions into the rendering |  | ||||||
| # pipeline. Library charts do not define any templates and therefore cannot be deployed. |  | ||||||
| type: application |  | ||||||
| 
 |  | ||||||
| # This is the chart version. This version number should be incremented each time you make changes |  | ||||||
| # to the chart and its templates, including the app version. |  | ||||||
| # Versions are expected to follow Semantic Versioning (https://semver.org/) |  | ||||||
| version: 0.1.0 |  | ||||||
| 
 |  | ||||||
| # This is the version number of the application being deployed. This version number should be |  | ||||||
| # incremented each time you make changes to the application. Versions are not expected to |  | ||||||
| # follow Semantic Versioning. They should reflect the version the application is using. |  | ||||||
| # It is recommended to use it with quotes. |  | ||||||
| appVersion: "1.16.0" |  | ||||||
| 
 |  | ||||||
| icon: https://raw.githubusercontent.com/openimsdk/open-im-server/main/assets/openim-logo-gradient.svg |  | ||||||
| 
 |  | ||||||
| maintainers: |  | ||||||
|   - name: "OpenIM" |  | ||||||
|     url: "https://github.com/openimsdk" |  | ||||||
| 
 |  | ||||||
| keywords: |  | ||||||
|   - openim |  | ||||||
|   - im |  | ||||||
|   - chat |  | ||||||
| 
 |  | ||||||
| sources: |  | ||||||
|   - "https://github.com/openimsdk/open-im-server" |  | ||||||
|   - "https://github.com/openimsdk/helm-charts" |  | ||||||
| @ -1,22 +0,0 @@ | |||||||
| 1. Get the application URL by running these commands: |  | ||||||
| {{- if .Values.ingress.enabled }} |  | ||||||
| {{- range $host := .Values.ingress.hosts }} |  | ||||||
|   {{- range .paths }} |  | ||||||
|   http{{ if $.Values.ingress.tls }}s{{ end }}://{{ $host.host }}{{ .path }} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| {{- else if contains "NodePort" .Values.service.type }} |  | ||||||
|   export NODE_PORT=$(kubectl get --namespace {{ .Release.Namespace }} -o jsonpath="{.spec.ports[0].nodePort}" services {{ include "openim-msggateway.fullname" . }}) |  | ||||||
|   export NODE_IP=$(kubectl get nodes --namespace {{ .Release.Namespace }} -o jsonpath="{.items[0].status.addresses[0].address}") |  | ||||||
|   echo http://$NODE_IP:$NODE_PORT |  | ||||||
| {{- else if contains "LoadBalancer" .Values.service.type }} |  | ||||||
|      NOTE: It may take a few minutes for the LoadBalancer IP to be available. |  | ||||||
|            You can watch the status of by running 'kubectl get --namespace {{ .Release.Namespace }} svc -w {{ include "openim-msggateway.fullname" . }}' |  | ||||||
|   export SERVICE_IP=$(kubectl get svc --namespace {{ .Release.Namespace }} {{ include "openim-msggateway.fullname" . }} --template "{{"{{ range (index .status.loadBalancer.ingress 0) }}{{.}}{{ end }}"}}") |  | ||||||
|   echo http://$SERVICE_IP:{{ .Values.service.port }} |  | ||||||
| {{- else if contains "ClusterIP" .Values.service.type }} |  | ||||||
|   export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app.kubernetes.io/name={{ include "openim-msggateway.name" . }},app.kubernetes.io/instance={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}") |  | ||||||
|   export CONTAINER_PORT=$(kubectl get pod --namespace {{ .Release.Namespace }} $POD_NAME -o jsonpath="{.spec.containers[0].ports[0].containerPort}") |  | ||||||
|   echo "Visit http://127.0.0.1:8080 to use your application" |  | ||||||
|   kubectl --namespace {{ .Release.Namespace }} port-forward $POD_NAME 8080:$CONTAINER_PORT |  | ||||||
| {{- end }} |  | ||||||
| @ -1,62 +0,0 @@ | |||||||
| {{/* |  | ||||||
| Expand the name of the chart. |  | ||||||
| */}} |  | ||||||
| {{- define "openim-msggateway.name" -}} |  | ||||||
| {{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Create a default fully qualified app name. |  | ||||||
| We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). |  | ||||||
| If release name contains chart name it will be used as a full name. |  | ||||||
| */}} |  | ||||||
| {{- define "openim-msggateway.fullname" -}} |  | ||||||
| {{- if .Values.fullnameOverride }} |  | ||||||
| {{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- else }} |  | ||||||
| {{- $name := default .Chart.Name .Values.nameOverride }} |  | ||||||
| {{- if contains $name .Release.Name }} |  | ||||||
| {{- .Release.Name | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- else }} |  | ||||||
| {{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Create chart name and version as used by the chart label. |  | ||||||
| */}} |  | ||||||
| {{- define "openim-msggateway.chart" -}} |  | ||||||
| {{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Common labels |  | ||||||
| */}} |  | ||||||
| {{- define "openim-msggateway.labels" -}} |  | ||||||
| helm.sh/chart: {{ include "openim-msggateway.chart" . }} |  | ||||||
| {{ include "openim-msggateway.selectorLabels" . }} |  | ||||||
| {{- if .Chart.AppVersion }} |  | ||||||
| app.kubernetes.io/version: {{ .Chart.AppVersion | quote }} |  | ||||||
| {{- end }} |  | ||||||
| app.kubernetes.io/managed-by: {{ .Release.Service }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Selector labels |  | ||||||
| */}} |  | ||||||
| {{- define "openim-msggateway.selectorLabels" -}} |  | ||||||
| app.kubernetes.io/name: {{ include "openim-msggateway.name" . }} |  | ||||||
| app.kubernetes.io/instance: {{ .Release.Name }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Create the name of the service account to use |  | ||||||
| */}} |  | ||||||
| {{- define "openim-msggateway.serviceAccountName" -}} |  | ||||||
| {{- if .Values.serviceAccount.create }} |  | ||||||
| {{- default (include "openim-msggateway.fullname" .) .Values.serviceAccount.name }} |  | ||||||
| {{- else }} |  | ||||||
| {{- default "default" .Values.serviceAccount.name }} |  | ||||||
| {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,89 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| apiVersion: apps/v1 |  | ||||||
| kind: Deployment |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-msggateway.fullname" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-msggateway.labels" . | nindent 4 }} |  | ||||||
| spec: |  | ||||||
|   {{- if not .Values.autoscaling.enabled }} |  | ||||||
|   replicas: {{ .Values.replicaCount }} |  | ||||||
|   {{- end }} |  | ||||||
|   selector: |  | ||||||
|     matchLabels: |  | ||||||
|       {{- include "openim-msggateway.selectorLabels" . | nindent 6 }} |  | ||||||
|   template: |  | ||||||
|     metadata: |  | ||||||
|       {{- with .Values.podAnnotations }} |  | ||||||
|       annotations: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       labels: |  | ||||||
|         {{- include "openim-msggateway.selectorLabels" . | nindent 8 }} |  | ||||||
|     spec: |  | ||||||
|       {{- with .Values.imagePullSecrets }} |  | ||||||
|       imagePullSecrets: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       serviceAccountName: {{ include "openim-msggateway.serviceAccountName" . }} |  | ||||||
|       securityContext: |  | ||||||
|         {{- toYaml .Values.podSecurityContext | nindent 8 }} |  | ||||||
|       containers: |  | ||||||
|         - name: {{ .Chart.Name }} |  | ||||||
|           securityContext: |  | ||||||
|             {{- toYaml .Values.securityContext | nindent 12 }} |  | ||||||
|           image: "{{ .Values.image.repository }}:{{ .Values.image.tag | default .Chart.AppVersion }}" |  | ||||||
|           imagePullPolicy: {{ .Values.image.pullPolicy }} |  | ||||||
|           ports: |  | ||||||
|             - name: webhook |  | ||||||
|               containerPort: 80 |  | ||||||
|               protocol: TCP |  | ||||||
|             - name: rpc |  | ||||||
|               containerPort: 88 |  | ||||||
|               protocol: TCP |  | ||||||
|           #livenessProbe: |  | ||||||
|           #  httpGet: |  | ||||||
|           #    path: / |  | ||||||
|           #    port: webhook |  | ||||||
|           #readinessProbe: |  | ||||||
|           #  httpGet: |  | ||||||
|           #    path: / |  | ||||||
|           #    port: webhook |  | ||||||
|           resources: |  | ||||||
|             {{- toYaml .Values.resources | nindent 12 }} |  | ||||||
|           volumeMounts: |  | ||||||
|             - mountPath: /openim/openim-server/config/config.yaml |  | ||||||
|               name: config |  | ||||||
|               subPath: config.yaml |  | ||||||
|             - mountPath: /openim/openim-server/config/ |  | ||||||
|               name: config |  | ||||||
|               subPath: notification.yaml |  | ||||||
|       volumes: |  | ||||||
|         - name: config |  | ||||||
|           configMap: |  | ||||||
|             name: openim-cm |  | ||||||
|       {{- with .Values.nodeSelector }} |  | ||||||
|       nodeSelector: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       {{- with .Values.affinity }} |  | ||||||
|       affinity: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       {{- with .Values.tolerations }} |  | ||||||
|       tolerations: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
| @ -1,42 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| {{- if .Values.autoscaling.enabled }} |  | ||||||
| apiVersion: autoscaling/v2beta1 |  | ||||||
| kind: HorizontalPodAutoscaler |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-msggateway.fullname" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-msggateway.labels" . | nindent 4 }} |  | ||||||
| spec: |  | ||||||
|   scaleTargetRef: |  | ||||||
|     apiVersion: apps/v1 |  | ||||||
|     kind: Deployment |  | ||||||
|     name: {{ include "openim-msggateway.fullname" . }} |  | ||||||
|   minReplicas: {{ .Values.autoscaling.minReplicas }} |  | ||||||
|   maxReplicas: {{ .Values.autoscaling.maxReplicas }} |  | ||||||
|   metrics: |  | ||||||
|     {{- if .Values.autoscaling.targetCPUUtilizationPercentage }} |  | ||||||
|     - type: Resource |  | ||||||
|       resource: |  | ||||||
|         name: cpu |  | ||||||
|         targetAverageUtilization: {{ .Values.autoscaling.targetCPUUtilizationPercentage }} |  | ||||||
|     {{- end }} |  | ||||||
|     {{- if .Values.autoscaling.targetMemoryUtilizationPercentage }} |  | ||||||
|     - type: Resource |  | ||||||
|       resource: |  | ||||||
|         name: memory |  | ||||||
|         targetAverageUtilization: {{ .Values.autoscaling.targetMemoryUtilizationPercentage }} |  | ||||||
|     {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,75 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| {{- if .Values.ingress.enabled -}} |  | ||||||
| {{- $fullName := include "openim-msggateway.fullname" . -}} |  | ||||||
| {{- $svcPort := .Values.service.port -}} |  | ||||||
| {{- if and .Values.ingress.className (not (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion)) }} |  | ||||||
|   {{- if not (hasKey .Values.ingress.annotations "kubernetes.io/ingress.class") }} |  | ||||||
|   {{- $_ := set .Values.ingress.annotations "kubernetes.io/ingress.class" .Values.ingress.className}} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| {{- if semverCompare ">=1.19-0" .Capabilities.KubeVersion.GitVersion -}} |  | ||||||
| apiVersion: networking.k8s.io/v1 |  | ||||||
| {{- else if semverCompare ">=1.14-0" .Capabilities.KubeVersion.GitVersion -}} |  | ||||||
| apiVersion: networking.k8s.io/v1beta1 |  | ||||||
| {{- else -}} |  | ||||||
| apiVersion: extensions/v1beta1 |  | ||||||
| {{- end }} |  | ||||||
| kind: Ingress |  | ||||||
| metadata: |  | ||||||
|   name: {{ $fullName }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-msggateway.labels" . | nindent 4 }} |  | ||||||
|   {{- with .Values.ingress.annotations }} |  | ||||||
|   annotations: |  | ||||||
|     {{- toYaml . | nindent 4 }} |  | ||||||
|   {{- end }} |  | ||||||
| spec: |  | ||||||
|   {{- if and .Values.ingress.className (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion) }} |  | ||||||
|   ingressClassName: {{ .Values.ingress.className }} |  | ||||||
|   {{- end }} |  | ||||||
|   {{- if .Values.ingress.tls }} |  | ||||||
|   tls: |  | ||||||
|     {{- range .Values.ingress.tls }} |  | ||||||
|     - hosts: |  | ||||||
|         {{- range .hosts }} |  | ||||||
|         - {{ . | quote }} |  | ||||||
|         {{- end }} |  | ||||||
|       secretName: {{ .secretName }} |  | ||||||
|     {{- end }} |  | ||||||
|   {{- end }} |  | ||||||
|   rules: |  | ||||||
|     {{- range .Values.ingress.hosts }} |  | ||||||
|     - host: {{ .host | quote }} |  | ||||||
|       http: |  | ||||||
|         paths: |  | ||||||
|           {{- range .paths }} |  | ||||||
|           - path: {{ .path }} |  | ||||||
|             {{- if and .pathType (semverCompare ">=1.18-0" $.Capabilities.KubeVersion.GitVersion) }} |  | ||||||
|             pathType: {{ .pathType }} |  | ||||||
|             {{- end }} |  | ||||||
|             backend: |  | ||||||
|               {{- if semverCompare ">=1.19-0" $.Capabilities.KubeVersion.GitVersion }} |  | ||||||
|               service: |  | ||||||
|                 name: {{ $fullName }} |  | ||||||
|                 port: |  | ||||||
|                   number: {{ $svcPort }} |  | ||||||
|               {{- else }} |  | ||||||
|               serviceName: {{ $fullName }} |  | ||||||
|               servicePort: {{ $svcPort }} |  | ||||||
|               {{- end }} |  | ||||||
|           {{- end }} |  | ||||||
|     {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,33 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| apiVersion: v1 |  | ||||||
| kind: Service |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-msggateway.fullname" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-msggateway.labels" . | nindent 4 }} |  | ||||||
| spec: |  | ||||||
|   type: {{ .Values.service.type }} |  | ||||||
|   ports: |  | ||||||
|     - port: {{ .Values.service.port }} |  | ||||||
|       targetPort: webhook |  | ||||||
|       protocol: TCP |  | ||||||
|       name: webhook |  | ||||||
|     - port: 88 |  | ||||||
|       targetPort: rpc |  | ||||||
|       protocol: TCP |  | ||||||
|       name: rpc |  | ||||||
|   selector: |  | ||||||
|     {{- include "openim-msggateway.selectorLabels" . | nindent 4 }} |  | ||||||
| @ -1,26 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| {{- if .Values.serviceAccount.create -}} |  | ||||||
| apiVersion: v1 |  | ||||||
| kind: ServiceAccount |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-msggateway.serviceAccountName" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-msggateway.labels" . | nindent 4 }} |  | ||||||
|   {{- with .Values.serviceAccount.annotations }} |  | ||||||
|   annotations: |  | ||||||
|     {{- toYaml . | nindent 4 }} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,96 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| # Default values for openim-msggateway. |  | ||||||
| # This is a YAML-formatted file. |  | ||||||
| # Declare variables to be passed into your templates. |  | ||||||
| 
 |  | ||||||
| replicaCount: 1 |  | ||||||
| 
 |  | ||||||
| image: |  | ||||||
|   repository: ghcr.io/openimsdk/openim-msggateway |  | ||||||
|   pullPolicy: IfNotPresent |  | ||||||
|   # Overrides the image tag whose default is the chart appVersion. |  | ||||||
|   tag: "" |  | ||||||
| 
 |  | ||||||
| imagePullSecrets: [] |  | ||||||
| nameOverride: "" |  | ||||||
| fullnameOverride: "" |  | ||||||
| 
 |  | ||||||
| serviceAccount: |  | ||||||
|   # Specifies whether a service account should be created |  | ||||||
|   create: false |  | ||||||
|   # Annotations to add to the service account |  | ||||||
|   annotations: {} |  | ||||||
|   # The name of the service account to use. |  | ||||||
|   # If not set and create is true, a name is generated using the fullname template |  | ||||||
|   name: "" |  | ||||||
| 
 |  | ||||||
| podAnnotations: {} |  | ||||||
| 
 |  | ||||||
| podSecurityContext: {} |  | ||||||
|   # fsGroup: 2000 |  | ||||||
| 
 |  | ||||||
| securityContext: {} |  | ||||||
|   # capabilities: |  | ||||||
|   #   drop: |  | ||||||
|   #   - ALL |  | ||||||
|   # readOnlyRootFilesystem: true |  | ||||||
|   # runAsNonRoot: true |  | ||||||
|   # runAsUser: 1000 |  | ||||||
| 
 |  | ||||||
| service: |  | ||||||
|   type: ClusterIP |  | ||||||
|   port: 80 |  | ||||||
| 
 |  | ||||||
| ingress: |  | ||||||
|   enabled: false |  | ||||||
|   className: "nginx" |  | ||||||
|   annotations: |  | ||||||
|   # kubernetes.io/ingress.class: nginx |  | ||||||
|   # kubernetes.io/tls-acme: "true" |  | ||||||
|   hosts: |  | ||||||
|     - host: chart-example.local |  | ||||||
|       paths: |  | ||||||
|         - path: / |  | ||||||
|           pathType: ImplementationSpecific |  | ||||||
|   tls: [] |  | ||||||
|   #  - secretName: chart-example-tls |  | ||||||
|   #    hosts: |  | ||||||
|   #      - chart-example.local |  | ||||||
| 
 |  | ||||||
| resources: {} |  | ||||||
|   # We usually recommend not to specify default resources and to leave this as a conscious |  | ||||||
|   # choice for the user. This also increases chances charts run on environments with little |  | ||||||
|   # resources, such as Minikube. If you do want to specify resources, uncomment the following |  | ||||||
|   # lines, adjust them as necessary, and remove the curly braces after 'resources:'. |  | ||||||
|   # limits: |  | ||||||
|   #   cpu: 100m |  | ||||||
|   #   memory: 128Mi |  | ||||||
|   # requests: |  | ||||||
|   #   cpu: 100m |  | ||||||
|   #   memory: 128Mi |  | ||||||
| 
 |  | ||||||
| autoscaling: |  | ||||||
|   enabled: false |  | ||||||
|   minReplicas: 1 |  | ||||||
|   maxReplicas: 100 |  | ||||||
|   targetCPUUtilizationPercentage: 80 |  | ||||||
|   # targetMemoryUtilizationPercentage: 80 |  | ||||||
| 
 |  | ||||||
| nodeSelector: {} |  | ||||||
| 
 |  | ||||||
| tolerations: [] |  | ||||||
| 
 |  | ||||||
| affinity: {} |  | ||||||
| @ -1,23 +0,0 @@ | |||||||
| # Patterns to ignore when building packages. |  | ||||||
| # This supports shell glob matching, relative path matching, and |  | ||||||
| # negation (prefixed with !). Only one pattern per line. |  | ||||||
| .DS_Store |  | ||||||
| # Common VCS dirs |  | ||||||
| .git/ |  | ||||||
| .gitignore |  | ||||||
| .bzr/ |  | ||||||
| .bzrignore |  | ||||||
| .hg/ |  | ||||||
| .hgignore |  | ||||||
| .svn/ |  | ||||||
| # Common backup files |  | ||||||
| *.swp |  | ||||||
| *.bak |  | ||||||
| *.tmp |  | ||||||
| *.orig |  | ||||||
| *~ |  | ||||||
| # Various IDEs |  | ||||||
| .project |  | ||||||
| .idea/ |  | ||||||
| *.tmproj |  | ||||||
| .vscode/ |  | ||||||
| @ -1,53 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| apiVersion: v2 |  | ||||||
| name: openim-msgtransfer |  | ||||||
| description: A Helm chart for Kubernetes |  | ||||||
| 
 |  | ||||||
| # A chart can be either an 'application' or a 'library' chart. |  | ||||||
| # |  | ||||||
| # Application charts are a collection of templates that can be packaged into versioned archives |  | ||||||
| # to be deployed. |  | ||||||
| # |  | ||||||
| # Library charts provide useful utilities or functions for the chart developer. They're included as |  | ||||||
| # a dependency of application charts to inject those utilities and functions into the rendering |  | ||||||
| # pipeline. Library charts do not define any templates and therefore cannot be deployed. |  | ||||||
| type: application |  | ||||||
| 
 |  | ||||||
| # This is the chart version. This version number should be incremented each time you make changes |  | ||||||
| # to the chart and its templates, including the app version. |  | ||||||
| # Versions are expected to follow Semantic Versioning (https://semver.org/) |  | ||||||
| version: 0.1.0 |  | ||||||
| 
 |  | ||||||
| # This is the version number of the application being deployed. This version number should be |  | ||||||
| # incremented each time you make changes to the application. Versions are not expected to |  | ||||||
| # follow Semantic Versioning. They should reflect the version the application is using. |  | ||||||
| # It is recommended to use it with quotes. |  | ||||||
| appVersion: "1.16.0" |  | ||||||
| 
 |  | ||||||
| icon: https://raw.githubusercontent.com/openimsdk/open-im-server/main/assets/openim-logo-gradient.svg |  | ||||||
| 
 |  | ||||||
| maintainers: |  | ||||||
|   - name: "OpenIM" |  | ||||||
|     url: "https://github.com/openimsdk" |  | ||||||
| 
 |  | ||||||
| keywords: |  | ||||||
|   - openim |  | ||||||
|   - im |  | ||||||
|   - chat |  | ||||||
| 
 |  | ||||||
| sources: |  | ||||||
|   - "https://github.com/openimsdk/open-im-server" |  | ||||||
|   - "https://github.com/openimsdk/helm-charts" |  | ||||||
| @ -1,22 +0,0 @@ | |||||||
| 1. Get the application URL by running these commands: |  | ||||||
| {{- if .Values.ingress.enabled }} |  | ||||||
| {{- range $host := .Values.ingress.hosts }} |  | ||||||
|   {{- range .paths }} |  | ||||||
|   http{{ if $.Values.ingress.tls }}s{{ end }}://{{ $host.host }}{{ .path }} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| {{- else if contains "NodePort" .Values.service.type }} |  | ||||||
|   export NODE_PORT=$(kubectl get --namespace {{ .Release.Namespace }} -o jsonpath="{.spec.ports[0].nodePort}" services {{ include "openim-msgtransfer.fullname" . }}) |  | ||||||
|   export NODE_IP=$(kubectl get nodes --namespace {{ .Release.Namespace }} -o jsonpath="{.items[0].status.addresses[0].address}") |  | ||||||
|   echo http://$NODE_IP:$NODE_PORT |  | ||||||
| {{- else if contains "LoadBalancer" .Values.service.type }} |  | ||||||
|      NOTE: It may take a few minutes for the LoadBalancer IP to be available. |  | ||||||
|            You can watch the status of by running 'kubectl get --namespace {{ .Release.Namespace }} svc -w {{ include "openim-msgtransfer.fullname" . }}' |  | ||||||
|   export SERVICE_IP=$(kubectl get svc --namespace {{ .Release.Namespace }} {{ include "openim-msgtransfer.fullname" . }} --template "{{"{{ range (index .status.loadBalancer.ingress 0) }}{{.}}{{ end }}"}}") |  | ||||||
|   echo http://$SERVICE_IP:{{ .Values.service.port }} |  | ||||||
| {{- else if contains "ClusterIP" .Values.service.type }} |  | ||||||
|   export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app.kubernetes.io/name={{ include "openim-msgtransfer.name" . }},app.kubernetes.io/instance={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}") |  | ||||||
|   export CONTAINER_PORT=$(kubectl get pod --namespace {{ .Release.Namespace }} $POD_NAME -o jsonpath="{.spec.containers[0].ports[0].containerPort}") |  | ||||||
|   echo "Visit http://127.0.0.1:8080 to use your application" |  | ||||||
|   kubectl --namespace {{ .Release.Namespace }} port-forward $POD_NAME 8080:$CONTAINER_PORT |  | ||||||
| {{- end }} |  | ||||||
| @ -1,62 +0,0 @@ | |||||||
| {{/* |  | ||||||
| Expand the name of the chart. |  | ||||||
| */}} |  | ||||||
| {{- define "openim-msgtransfer.name" -}} |  | ||||||
| {{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Create a default fully qualified app name. |  | ||||||
| We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). |  | ||||||
| If release name contains chart name it will be used as a full name. |  | ||||||
| */}} |  | ||||||
| {{- define "openim-msgtransfer.fullname" -}} |  | ||||||
| {{- if .Values.fullnameOverride }} |  | ||||||
| {{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- else }} |  | ||||||
| {{- $name := default .Chart.Name .Values.nameOverride }} |  | ||||||
| {{- if contains $name .Release.Name }} |  | ||||||
| {{- .Release.Name | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- else }} |  | ||||||
| {{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Create chart name and version as used by the chart label. |  | ||||||
| */}} |  | ||||||
| {{- define "openim-msgtransfer.chart" -}} |  | ||||||
| {{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Common labels |  | ||||||
| */}} |  | ||||||
| {{- define "openim-msgtransfer.labels" -}} |  | ||||||
| helm.sh/chart: {{ include "openim-msgtransfer.chart" . }} |  | ||||||
| {{ include "openim-msgtransfer.selectorLabels" . }} |  | ||||||
| {{- if .Chart.AppVersion }} |  | ||||||
| app.kubernetes.io/version: {{ .Chart.AppVersion | quote }} |  | ||||||
| {{- end }} |  | ||||||
| app.kubernetes.io/managed-by: {{ .Release.Service }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Selector labels |  | ||||||
| */}} |  | ||||||
| {{- define "openim-msgtransfer.selectorLabels" -}} |  | ||||||
| app.kubernetes.io/name: {{ include "openim-msgtransfer.name" . }} |  | ||||||
| app.kubernetes.io/instance: {{ .Release.Name }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Create the name of the service account to use |  | ||||||
| */}} |  | ||||||
| {{- define "openim-msgtransfer.serviceAccountName" -}} |  | ||||||
| {{- if .Values.serviceAccount.create }} |  | ||||||
| {{- default (include "openim-msgtransfer.fullname" .) .Values.serviceAccount.name }} |  | ||||||
| {{- else }} |  | ||||||
| {{- default "default" .Values.serviceAccount.name }} |  | ||||||
| {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,86 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| apiVersion: apps/v1 |  | ||||||
| kind: Deployment |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-msgtransfer.fullname" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-msgtransfer.labels" . | nindent 4 }} |  | ||||||
| spec: |  | ||||||
|   {{- if not .Values.autoscaling.enabled }} |  | ||||||
|   replicas: {{ .Values.replicaCount }} |  | ||||||
|   {{- end }} |  | ||||||
|   selector: |  | ||||||
|     matchLabels: |  | ||||||
|       {{- include "openim-msgtransfer.selectorLabels" . | nindent 6 }} |  | ||||||
|   template: |  | ||||||
|     metadata: |  | ||||||
|       {{- with .Values.podAnnotations }} |  | ||||||
|       annotations: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       labels: |  | ||||||
|         {{- include "openim-msgtransfer.selectorLabels" . | nindent 8 }} |  | ||||||
|     spec: |  | ||||||
|       {{- with .Values.imagePullSecrets }} |  | ||||||
|       imagePullSecrets: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       serviceAccountName: {{ include "openim-msgtransfer.serviceAccountName" . }} |  | ||||||
|       securityContext: |  | ||||||
|         {{- toYaml .Values.podSecurityContext | nindent 8 }} |  | ||||||
|       containers: |  | ||||||
|         - name: {{ .Chart.Name }} |  | ||||||
|           securityContext: |  | ||||||
|             {{- toYaml .Values.securityContext | nindent 12 }} |  | ||||||
|           image: "{{ .Values.image.repository }}:{{ .Values.image.tag | default .Chart.AppVersion }}" |  | ||||||
|           imagePullPolicy: {{ .Values.image.pullPolicy }} |  | ||||||
|           ports: |  | ||||||
|             - name: webhook |  | ||||||
|               containerPort: 80 |  | ||||||
|               protocol: TCP |  | ||||||
|           #livenessProbe: |  | ||||||
|           #  httpGet: |  | ||||||
|           #    path: / |  | ||||||
|           #    port: webhook |  | ||||||
|           #readinessProbe: |  | ||||||
|           #  httpGet: |  | ||||||
|           #    path: / |  | ||||||
|           #    port: webhook |  | ||||||
|           resources: |  | ||||||
|             {{- toYaml .Values.resources | nindent 12 }} |  | ||||||
|           volumeMounts: |  | ||||||
|             - mountPath: /openim/openim-server/config/config.yaml |  | ||||||
|               name: config |  | ||||||
|               subPath: config.yaml |  | ||||||
|             - mountPath: /openim/openim-server/config/ |  | ||||||
|               name: config |  | ||||||
|               subPath: notification.yaml |  | ||||||
|       volumes: |  | ||||||
|         - name: config |  | ||||||
|           configMap: |  | ||||||
|             name: openim-cm |  | ||||||
|       {{- with .Values.nodeSelector }} |  | ||||||
|       nodeSelector: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       {{- with .Values.affinity }} |  | ||||||
|       affinity: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       {{- with .Values.tolerations }} |  | ||||||
|       tolerations: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
| @ -1,42 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| {{- if .Values.autoscaling.enabled }} |  | ||||||
| apiVersion: autoscaling/v2beta1 |  | ||||||
| kind: HorizontalPodAutoscaler |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-msgtransfer.fullname" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-msgtransfer.labels" . | nindent 4 }} |  | ||||||
| spec: |  | ||||||
|   scaleTargetRef: |  | ||||||
|     apiVersion: apps/v1 |  | ||||||
|     kind: Deployment |  | ||||||
|     name: {{ include "openim-msgtransfer.fullname" . }} |  | ||||||
|   minReplicas: {{ .Values.autoscaling.minReplicas }} |  | ||||||
|   maxReplicas: {{ .Values.autoscaling.maxReplicas }} |  | ||||||
|   metrics: |  | ||||||
|     {{- if .Values.autoscaling.targetCPUUtilizationPercentage }} |  | ||||||
|     - type: Resource |  | ||||||
|       resource: |  | ||||||
|         name: cpu |  | ||||||
|         targetAverageUtilization: {{ .Values.autoscaling.targetCPUUtilizationPercentage }} |  | ||||||
|     {{- end }} |  | ||||||
|     {{- if .Values.autoscaling.targetMemoryUtilizationPercentage }} |  | ||||||
|     - type: Resource |  | ||||||
|       resource: |  | ||||||
|         name: memory |  | ||||||
|         targetAverageUtilization: {{ .Values.autoscaling.targetMemoryUtilizationPercentage }} |  | ||||||
|     {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,75 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| {{- if .Values.ingress.enabled -}} |  | ||||||
| {{- $fullName := include "openim-msgtransfer.fullname" . -}} |  | ||||||
| {{- $svcPort := .Values.service.port -}} |  | ||||||
| {{- if and .Values.ingress.className (not (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion)) }} |  | ||||||
|   {{- if not (hasKey .Values.ingress.annotations "kubernetes.io/ingress.class") }} |  | ||||||
|   {{- $_ := set .Values.ingress.annotations "kubernetes.io/ingress.class" .Values.ingress.className}} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| {{- if semverCompare ">=1.19-0" .Capabilities.KubeVersion.GitVersion -}} |  | ||||||
| apiVersion: networking.k8s.io/v1 |  | ||||||
| {{- else if semverCompare ">=1.14-0" .Capabilities.KubeVersion.GitVersion -}} |  | ||||||
| apiVersion: networking.k8s.io/v1beta1 |  | ||||||
| {{- else -}} |  | ||||||
| apiVersion: extensions/v1beta1 |  | ||||||
| {{- end }} |  | ||||||
| kind: Ingress |  | ||||||
| metadata: |  | ||||||
|   name: {{ $fullName }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-msgtransfer.labels" . | nindent 4 }} |  | ||||||
|   {{- with .Values.ingress.annotations }} |  | ||||||
|   annotations: |  | ||||||
|     {{- toYaml . | nindent 4 }} |  | ||||||
|   {{- end }} |  | ||||||
| spec: |  | ||||||
|   {{- if and .Values.ingress.className (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion) }} |  | ||||||
|   ingressClassName: {{ .Values.ingress.className }} |  | ||||||
|   {{- end }} |  | ||||||
|   {{- if .Values.ingress.tls }} |  | ||||||
|   tls: |  | ||||||
|     {{- range .Values.ingress.tls }} |  | ||||||
|     - hosts: |  | ||||||
|         {{- range .hosts }} |  | ||||||
|         - {{ . | quote }} |  | ||||||
|         {{- end }} |  | ||||||
|       secretName: {{ .secretName }} |  | ||||||
|     {{- end }} |  | ||||||
|   {{- end }} |  | ||||||
|   rules: |  | ||||||
|     {{- range .Values.ingress.hosts }} |  | ||||||
|     - host: {{ .host | quote }} |  | ||||||
|       http: |  | ||||||
|         paths: |  | ||||||
|           {{- range .paths }} |  | ||||||
|           - path: {{ .path }} |  | ||||||
|             {{- if and .pathType (semverCompare ">=1.18-0" $.Capabilities.KubeVersion.GitVersion) }} |  | ||||||
|             pathType: {{ .pathType }} |  | ||||||
|             {{- end }} |  | ||||||
|             backend: |  | ||||||
|               {{- if semverCompare ">=1.19-0" $.Capabilities.KubeVersion.GitVersion }} |  | ||||||
|               service: |  | ||||||
|                 name: {{ $fullName }} |  | ||||||
|                 port: |  | ||||||
|                   number: {{ $svcPort }} |  | ||||||
|               {{- else }} |  | ||||||
|               serviceName: {{ $fullName }} |  | ||||||
|               servicePort: {{ $svcPort }} |  | ||||||
|               {{- end }} |  | ||||||
|           {{- end }} |  | ||||||
|     {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,29 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| apiVersion: v1 |  | ||||||
| kind: Service |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-msgtransfer.fullname" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-msgtransfer.labels" . | nindent 4 }} |  | ||||||
| spec: |  | ||||||
|   type: {{ .Values.service.type }} |  | ||||||
|   ports: |  | ||||||
|     - port: {{ .Values.service.port }} |  | ||||||
|       targetPort: webhook |  | ||||||
|       protocol: TCP |  | ||||||
|       name: webhook |  | ||||||
|   selector: |  | ||||||
|     {{- include "openim-msgtransfer.selectorLabels" . | nindent 4 }} |  | ||||||
| @ -1,26 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| {{- if .Values.serviceAccount.create -}} |  | ||||||
| apiVersion: v1 |  | ||||||
| kind: ServiceAccount |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-msgtransfer.serviceAccountName" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-msgtransfer.labels" . | nindent 4 }} |  | ||||||
|   {{- with .Values.serviceAccount.annotations }} |  | ||||||
|   annotations: |  | ||||||
|     {{- toYaml . | nindent 4 }} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,96 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| # Default values for openim-msgtransfer. |  | ||||||
| # This is a YAML-formatted file. |  | ||||||
| # Declare variables to be passed into your templates. |  | ||||||
| 
 |  | ||||||
| replicaCount: 1 |  | ||||||
| 
 |  | ||||||
| image: |  | ||||||
|   repository: ghcr.io/openimsdk/openim-msgtransfer |  | ||||||
|   pullPolicy: IfNotPresent |  | ||||||
|   # Overrides the image tag whose default is the chart appVersion. |  | ||||||
|   tag: "" |  | ||||||
| 
 |  | ||||||
| imagePullSecrets: [] |  | ||||||
| nameOverride: "" |  | ||||||
| fullnameOverride: "" |  | ||||||
| 
 |  | ||||||
| serviceAccount: |  | ||||||
|   # Specifies whether a service account should be created |  | ||||||
|   create: false |  | ||||||
|   # Annotations to add to the service account |  | ||||||
|   annotations: {} |  | ||||||
|   # The name of the service account to use. |  | ||||||
|   # If not set and create is true, a name is generated using the fullname template |  | ||||||
|   name: "" |  | ||||||
| 
 |  | ||||||
| podAnnotations: {} |  | ||||||
| 
 |  | ||||||
| podSecurityContext: {} |  | ||||||
|   # fsGroup: 2000 |  | ||||||
| 
 |  | ||||||
| securityContext: {} |  | ||||||
|   # capabilities: |  | ||||||
|   #   drop: |  | ||||||
|   #   - ALL |  | ||||||
|   # readOnlyRootFilesystem: true |  | ||||||
|   # runAsNonRoot: true |  | ||||||
|   # runAsUser: 1000 |  | ||||||
| 
 |  | ||||||
| service: |  | ||||||
|   type: ClusterIP |  | ||||||
|   port: 80 |  | ||||||
| 
 |  | ||||||
| ingress: |  | ||||||
|   enabled: false |  | ||||||
|   className: "" |  | ||||||
|   annotations: {} |  | ||||||
|     # kubernetes.io/ingress.class: nginx |  | ||||||
|     # kubernetes.io/tls-acme: "true" |  | ||||||
|   hosts: |  | ||||||
|     - host: chart-example.local |  | ||||||
|       paths: |  | ||||||
|         - path: / |  | ||||||
|           pathType: ImplementationSpecific |  | ||||||
|   tls: [] |  | ||||||
|   #  - secretName: chart-example-tls |  | ||||||
|   #    hosts: |  | ||||||
|   #      - chart-example.local |  | ||||||
| 
 |  | ||||||
| resources: {} |  | ||||||
|   # We usually recommend not to specify default resources and to leave this as a conscious |  | ||||||
|   # choice for the user. This also increases chances charts run on environments with little |  | ||||||
|   # resources, such as Minikube. If you do want to specify resources, uncomment the following |  | ||||||
|   # lines, adjust them as necessary, and remove the curly braces after 'resources:'. |  | ||||||
|   # limits: |  | ||||||
|   #   cpu: 100m |  | ||||||
|   #   memory: 128Mi |  | ||||||
|   # requests: |  | ||||||
|   #   cpu: 100m |  | ||||||
|   #   memory: 128Mi |  | ||||||
| 
 |  | ||||||
| autoscaling: |  | ||||||
|   enabled: false |  | ||||||
|   minReplicas: 1 |  | ||||||
|   maxReplicas: 100 |  | ||||||
|   targetCPUUtilizationPercentage: 80 |  | ||||||
|   # targetMemoryUtilizationPercentage: 80 |  | ||||||
| 
 |  | ||||||
| nodeSelector: {} |  | ||||||
| 
 |  | ||||||
| tolerations: [] |  | ||||||
| 
 |  | ||||||
| affinity: {} |  | ||||||
| @ -1,23 +0,0 @@ | |||||||
| # Patterns to ignore when building packages. |  | ||||||
| # This supports shell glob matching, relative path matching, and |  | ||||||
| # negation (prefixed with !). Only one pattern per line. |  | ||||||
| .DS_Store |  | ||||||
| # Common VCS dirs |  | ||||||
| .git/ |  | ||||||
| .gitignore |  | ||||||
| .bzr/ |  | ||||||
| .bzrignore |  | ||||||
| .hg/ |  | ||||||
| .hgignore |  | ||||||
| .svn/ |  | ||||||
| # Common backup files |  | ||||||
| *.swp |  | ||||||
| *.bak |  | ||||||
| *.tmp |  | ||||||
| *.orig |  | ||||||
| *~ |  | ||||||
| # Various IDEs |  | ||||||
| .project |  | ||||||
| .idea/ |  | ||||||
| *.tmproj |  | ||||||
| .vscode/ |  | ||||||
| @ -1,53 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| apiVersion: v2 |  | ||||||
| name: openim-push |  | ||||||
| description: A Helm chart for Kubernetes |  | ||||||
| 
 |  | ||||||
| # A chart can be either an 'application' or a 'library' chart. |  | ||||||
| # |  | ||||||
| # Application charts are a collection of templates that can be packaged into versioned archives |  | ||||||
| # to be deployed. |  | ||||||
| # |  | ||||||
| # Library charts provide useful utilities or functions for the chart developer. They're included as |  | ||||||
| # a dependency of application charts to inject those utilities and functions into the rendering |  | ||||||
| # pipeline. Library charts do not define any templates and therefore cannot be deployed. |  | ||||||
| type: application |  | ||||||
| 
 |  | ||||||
| # This is the chart version. This version number should be incremented each time you make changes |  | ||||||
| # to the chart and its templates, including the app version. |  | ||||||
| # Versions are expected to follow Semantic Versioning (https://semver.org/) |  | ||||||
| version: 0.1.0 |  | ||||||
| 
 |  | ||||||
| # This is the version number of the application being deployed. This version number should be |  | ||||||
| # incremented each time you make changes to the application. Versions are not expected to |  | ||||||
| # follow Semantic Versioning. They should reflect the version the application is using. |  | ||||||
| # It is recommended to use it with quotes. |  | ||||||
| appVersion: "1.16.0" |  | ||||||
| 
 |  | ||||||
| icon: https://raw.githubusercontent.com/openimsdk/open-im-server/main/assets/openim-logo-gradient.svg |  | ||||||
| 
 |  | ||||||
| maintainers: |  | ||||||
|   - name: "OpenIM" |  | ||||||
|     url: "https://github.com/openimsdk" |  | ||||||
| 
 |  | ||||||
| keywords: |  | ||||||
|   - openim |  | ||||||
|   - im |  | ||||||
|   - chat |  | ||||||
| 
 |  | ||||||
| sources: |  | ||||||
|   - "https://github.com/openimsdk/open-im-server" |  | ||||||
|   - "https://github.com/openimsdk/helm-charts" |  | ||||||
| @ -1,22 +0,0 @@ | |||||||
| 1. Get the application URL by running these commands: |  | ||||||
| {{- if .Values.ingress.enabled }} |  | ||||||
| {{- range $host := .Values.ingress.hosts }} |  | ||||||
|   {{- range .paths }} |  | ||||||
|   http{{ if $.Values.ingress.tls }}s{{ end }}://{{ $host.host }}{{ .path }} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| {{- else if contains "NodePort" .Values.service.type }} |  | ||||||
|   export NODE_PORT=$(kubectl get --namespace {{ .Release.Namespace }} -o jsonpath="{.spec.ports[0].nodePort}" services {{ include "openim-push.fullname" . }}) |  | ||||||
|   export NODE_IP=$(kubectl get nodes --namespace {{ .Release.Namespace }} -o jsonpath="{.items[0].status.addresses[0].address}") |  | ||||||
|   echo http://$NODE_IP:$NODE_PORT |  | ||||||
| {{- else if contains "LoadBalancer" .Values.service.type }} |  | ||||||
|      NOTE: It may take a few minutes for the LoadBalancer IP to be available. |  | ||||||
|            You can watch the status of by running 'kubectl get --namespace {{ .Release.Namespace }} svc -w {{ include "openim-push.fullname" . }}' |  | ||||||
|   export SERVICE_IP=$(kubectl get svc --namespace {{ .Release.Namespace }} {{ include "openim-push.fullname" . }} --template "{{"{{ range (index .status.loadBalancer.ingress 0) }}{{.}}{{ end }}"}}") |  | ||||||
|   echo http://$SERVICE_IP:{{ .Values.service.port }} |  | ||||||
| {{- else if contains "ClusterIP" .Values.service.type }} |  | ||||||
|   export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app.kubernetes.io/name={{ include "openim-push.name" . }},app.kubernetes.io/instance={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}") |  | ||||||
|   export CONTAINER_PORT=$(kubectl get pod --namespace {{ .Release.Namespace }} $POD_NAME -o jsonpath="{.spec.containers[0].ports[0].containerPort}") |  | ||||||
|   echo "Visit http://127.0.0.1:8080 to use your application" |  | ||||||
|   kubectl --namespace {{ .Release.Namespace }} port-forward $POD_NAME 8080:$CONTAINER_PORT |  | ||||||
| {{- end }} |  | ||||||
| @ -1,62 +0,0 @@ | |||||||
| {{/* |  | ||||||
| Expand the name of the chart. |  | ||||||
| */}} |  | ||||||
| {{- define "openim-push.name" -}} |  | ||||||
| {{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Create a default fully qualified app name. |  | ||||||
| We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). |  | ||||||
| If release name contains chart name it will be used as a full name. |  | ||||||
| */}} |  | ||||||
| {{- define "openim-push.fullname" -}} |  | ||||||
| {{- if .Values.fullnameOverride }} |  | ||||||
| {{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- else }} |  | ||||||
| {{- $name := default .Chart.Name .Values.nameOverride }} |  | ||||||
| {{- if contains $name .Release.Name }} |  | ||||||
| {{- .Release.Name | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- else }} |  | ||||||
| {{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Create chart name and version as used by the chart label. |  | ||||||
| */}} |  | ||||||
| {{- define "openim-push.chart" -}} |  | ||||||
| {{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Common labels |  | ||||||
| */}} |  | ||||||
| {{- define "openim-push.labels" -}} |  | ||||||
| helm.sh/chart: {{ include "openim-push.chart" . }} |  | ||||||
| {{ include "openim-push.selectorLabels" . }} |  | ||||||
| {{- if .Chart.AppVersion }} |  | ||||||
| app.kubernetes.io/version: {{ .Chart.AppVersion | quote }} |  | ||||||
| {{- end }} |  | ||||||
| app.kubernetes.io/managed-by: {{ .Release.Service }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Selector labels |  | ||||||
| */}} |  | ||||||
| {{- define "openim-push.selectorLabels" -}} |  | ||||||
| app.kubernetes.io/name: {{ include "openim-push.name" . }} |  | ||||||
| app.kubernetes.io/instance: {{ .Release.Name }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Create the name of the service account to use |  | ||||||
| */}} |  | ||||||
| {{- define "openim-push.serviceAccountName" -}} |  | ||||||
| {{- if .Values.serviceAccount.create }} |  | ||||||
| {{- default (include "openim-push.fullname" .) .Values.serviceAccount.name }} |  | ||||||
| {{- else }} |  | ||||||
| {{- default "default" .Values.serviceAccount.name }} |  | ||||||
| {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,86 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| apiVersion: apps/v1 |  | ||||||
| kind: Deployment |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-push.fullname" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-push.labels" . | nindent 4 }} |  | ||||||
| spec: |  | ||||||
|   {{- if not .Values.autoscaling.enabled }} |  | ||||||
|   replicas: {{ .Values.replicaCount }} |  | ||||||
|   {{- end }} |  | ||||||
|   selector: |  | ||||||
|     matchLabels: |  | ||||||
|       {{- include "openim-push.selectorLabels" . | nindent 6 }} |  | ||||||
|   template: |  | ||||||
|     metadata: |  | ||||||
|       {{- with .Values.podAnnotations }} |  | ||||||
|       annotations: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       labels: |  | ||||||
|         {{- include "openim-push.selectorLabels" . | nindent 8 }} |  | ||||||
|     spec: |  | ||||||
|       {{- with .Values.imagePullSecrets }} |  | ||||||
|       imagePullSecrets: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       serviceAccountName: {{ include "openim-push.serviceAccountName" . }} |  | ||||||
|       securityContext: |  | ||||||
|         {{- toYaml .Values.podSecurityContext | nindent 8 }} |  | ||||||
|       containers: |  | ||||||
|         - name: {{ .Chart.Name }} |  | ||||||
|           securityContext: |  | ||||||
|             {{- toYaml .Values.securityContext | nindent 12 }} |  | ||||||
|           image: "{{ .Values.image.repository }}:{{ .Values.image.tag | default .Chart.AppVersion }}" |  | ||||||
|           imagePullPolicy: {{ .Values.image.pullPolicy }} |  | ||||||
|           ports: |  | ||||||
|             - name: webhook |  | ||||||
|               containerPort: 80 |  | ||||||
|               protocol: TCP |  | ||||||
|           #livenessProbe: |  | ||||||
|           #  httpGet: |  | ||||||
|           #    path: / |  | ||||||
|           #    port: webhook |  | ||||||
|           #readinessProbe: |  | ||||||
|           #  httpGet: |  | ||||||
|           #    path: / |  | ||||||
|           #    port: webhook |  | ||||||
|           resources: |  | ||||||
|             {{- toYaml .Values.resources | nindent 12 }} |  | ||||||
|           volumeMounts: |  | ||||||
|             - mountPath: /openim/openim-server/config/config.yaml |  | ||||||
|               name: config |  | ||||||
|               subPath: config.yaml |  | ||||||
|             - mountPath: /openim/openim-server/config/ |  | ||||||
|               name: config |  | ||||||
|               subPath: notification.yaml |  | ||||||
|       volumes: |  | ||||||
|         - name: config |  | ||||||
|           configMap: |  | ||||||
|             name: openim-cm |  | ||||||
|       {{- with .Values.nodeSelector }} |  | ||||||
|       nodeSelector: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       {{- with .Values.affinity }} |  | ||||||
|       affinity: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       {{- with .Values.tolerations }} |  | ||||||
|       tolerations: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
| @ -1,42 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| {{- if .Values.autoscaling.enabled }} |  | ||||||
| apiVersion: autoscaling/v2beta1 |  | ||||||
| kind: HorizontalPodAutoscaler |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-push.fullname" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-push.labels" . | nindent 4 }} |  | ||||||
| spec: |  | ||||||
|   scaleTargetRef: |  | ||||||
|     apiVersion: apps/v1 |  | ||||||
|     kind: Deployment |  | ||||||
|     name: {{ include "openim-push.fullname" . }} |  | ||||||
|   minReplicas: {{ .Values.autoscaling.minReplicas }} |  | ||||||
|   maxReplicas: {{ .Values.autoscaling.maxReplicas }} |  | ||||||
|   metrics: |  | ||||||
|     {{- if .Values.autoscaling.targetCPUUtilizationPercentage }} |  | ||||||
|     - type: Resource |  | ||||||
|       resource: |  | ||||||
|         name: cpu |  | ||||||
|         targetAverageUtilization: {{ .Values.autoscaling.targetCPUUtilizationPercentage }} |  | ||||||
|     {{- end }} |  | ||||||
|     {{- if .Values.autoscaling.targetMemoryUtilizationPercentage }} |  | ||||||
|     - type: Resource |  | ||||||
|       resource: |  | ||||||
|         name: memory |  | ||||||
|         targetAverageUtilization: {{ .Values.autoscaling.targetMemoryUtilizationPercentage }} |  | ||||||
|     {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,75 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| {{- if .Values.ingress.enabled -}} |  | ||||||
| {{- $fullName := include "openim-push.fullname" . -}} |  | ||||||
| {{- $svcPort := .Values.service.port -}} |  | ||||||
| {{- if and .Values.ingress.className (not (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion)) }} |  | ||||||
|   {{- if not (hasKey .Values.ingress.annotations "kubernetes.io/ingress.class") }} |  | ||||||
|   {{- $_ := set .Values.ingress.annotations "kubernetes.io/ingress.class" .Values.ingress.className}} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| {{- if semverCompare ">=1.19-0" .Capabilities.KubeVersion.GitVersion -}} |  | ||||||
| apiVersion: networking.k8s.io/v1 |  | ||||||
| {{- else if semverCompare ">=1.14-0" .Capabilities.KubeVersion.GitVersion -}} |  | ||||||
| apiVersion: networking.k8s.io/v1beta1 |  | ||||||
| {{- else -}} |  | ||||||
| apiVersion: extensions/v1beta1 |  | ||||||
| {{- end }} |  | ||||||
| kind: Ingress |  | ||||||
| metadata: |  | ||||||
|   name: {{ $fullName }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-push.labels" . | nindent 4 }} |  | ||||||
|   {{- with .Values.ingress.annotations }} |  | ||||||
|   annotations: |  | ||||||
|     {{- toYaml . | nindent 4 }} |  | ||||||
|   {{- end }} |  | ||||||
| spec: |  | ||||||
|   {{- if and .Values.ingress.className (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion) }} |  | ||||||
|   ingressClassName: {{ .Values.ingress.className }} |  | ||||||
|   {{- end }} |  | ||||||
|   {{- if .Values.ingress.tls }} |  | ||||||
|   tls: |  | ||||||
|     {{- range .Values.ingress.tls }} |  | ||||||
|     - hosts: |  | ||||||
|         {{- range .hosts }} |  | ||||||
|         - {{ . | quote }} |  | ||||||
|         {{- end }} |  | ||||||
|       secretName: {{ .secretName }} |  | ||||||
|     {{- end }} |  | ||||||
|   {{- end }} |  | ||||||
|   rules: |  | ||||||
|     {{- range .Values.ingress.hosts }} |  | ||||||
|     - host: {{ .host | quote }} |  | ||||||
|       http: |  | ||||||
|         paths: |  | ||||||
|           {{- range .paths }} |  | ||||||
|           - path: {{ .path }} |  | ||||||
|             {{- if and .pathType (semverCompare ">=1.18-0" $.Capabilities.KubeVersion.GitVersion) }} |  | ||||||
|             pathType: {{ .pathType }} |  | ||||||
|             {{- end }} |  | ||||||
|             backend: |  | ||||||
|               {{- if semverCompare ">=1.19-0" $.Capabilities.KubeVersion.GitVersion }} |  | ||||||
|               service: |  | ||||||
|                 name: {{ $fullName }} |  | ||||||
|                 port: |  | ||||||
|                   number: {{ $svcPort }} |  | ||||||
|               {{- else }} |  | ||||||
|               serviceName: {{ $fullName }} |  | ||||||
|               servicePort: {{ $svcPort }} |  | ||||||
|               {{- end }} |  | ||||||
|           {{- end }} |  | ||||||
|     {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,29 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| apiVersion: v1 |  | ||||||
| kind: Service |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-push.fullname" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-push.labels" . | nindent 4 }} |  | ||||||
| spec: |  | ||||||
|   type: {{ .Values.service.type }} |  | ||||||
|   ports: |  | ||||||
|     - port: {{ .Values.service.port }} |  | ||||||
|       targetPort: webhook |  | ||||||
|       protocol: TCP |  | ||||||
|       name: webhook |  | ||||||
|   selector: |  | ||||||
|     {{- include "openim-push.selectorLabels" . | nindent 4 }} |  | ||||||
| @ -1,26 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| {{- if .Values.serviceAccount.create -}} |  | ||||||
| apiVersion: v1 |  | ||||||
| kind: ServiceAccount |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-push.serviceAccountName" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-push.labels" . | nindent 4 }} |  | ||||||
|   {{- with .Values.serviceAccount.annotations }} |  | ||||||
|   annotations: |  | ||||||
|     {{- toYaml . | nindent 4 }} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,96 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| # Default values for openim-push. |  | ||||||
| # This is a YAML-formatted file. |  | ||||||
| # Declare variables to be passed into your templates. |  | ||||||
| 
 |  | ||||||
| replicaCount: 1 |  | ||||||
| 
 |  | ||||||
| image: |  | ||||||
|   repository: ghcr.io/openimsdk/openim-push |  | ||||||
|   pullPolicy: IfNotPresent |  | ||||||
|   # Overrides the image tag whose default is the chart appVersion. |  | ||||||
|   tag: "" |  | ||||||
| 
 |  | ||||||
| imagePullSecrets: [] |  | ||||||
| nameOverride: "" |  | ||||||
| fullnameOverride: "" |  | ||||||
| 
 |  | ||||||
| serviceAccount: |  | ||||||
|   # Specifies whether a service account should be created |  | ||||||
|   create: false |  | ||||||
|   # Annotations to add to the service account |  | ||||||
|   annotations: {} |  | ||||||
|   # The name of the service account to use. |  | ||||||
|   # If not set and create is true, a name is generated using the fullname template |  | ||||||
|   name: "" |  | ||||||
| 
 |  | ||||||
| podAnnotations: {} |  | ||||||
| 
 |  | ||||||
| podSecurityContext: {} |  | ||||||
|   # fsGroup: 2000 |  | ||||||
| 
 |  | ||||||
| securityContext: {} |  | ||||||
|   # capabilities: |  | ||||||
|   #   drop: |  | ||||||
|   #   - ALL |  | ||||||
|   # readOnlyRootFilesystem: true |  | ||||||
|   # runAsNonRoot: true |  | ||||||
|   # runAsUser: 1000 |  | ||||||
| 
 |  | ||||||
| service: |  | ||||||
|   type: ClusterIP |  | ||||||
|   port: 80 |  | ||||||
| 
 |  | ||||||
| ingress: |  | ||||||
|   enabled: false |  | ||||||
|   className: "" |  | ||||||
|   annotations: {} |  | ||||||
|     # kubernetes.io/ingress.class: nginx |  | ||||||
|     # kubernetes.io/tls-acme: "true" |  | ||||||
|   hosts: |  | ||||||
|     - host: chart-example.local |  | ||||||
|       paths: |  | ||||||
|         - path: / |  | ||||||
|           pathType: ImplementationSpecific |  | ||||||
|   tls: [] |  | ||||||
|   #  - secretName: chart-example-tls |  | ||||||
|   #    hosts: |  | ||||||
|   #      - chart-example.local |  | ||||||
| 
 |  | ||||||
| resources: {} |  | ||||||
|   # We usually recommend not to specify default resources and to leave this as a conscious |  | ||||||
|   # choice for the user. This also increases chances charts run on environments with little |  | ||||||
|   # resources, such as Minikube. If you do want to specify resources, uncomment the following |  | ||||||
|   # lines, adjust them as necessary, and remove the curly braces after 'resources:'. |  | ||||||
|   # limits: |  | ||||||
|   #   cpu: 100m |  | ||||||
|   #   memory: 128Mi |  | ||||||
|   # requests: |  | ||||||
|   #   cpu: 100m |  | ||||||
|   #   memory: 128Mi |  | ||||||
| 
 |  | ||||||
| autoscaling: |  | ||||||
|   enabled: false |  | ||||||
|   minReplicas: 1 |  | ||||||
|   maxReplicas: 100 |  | ||||||
|   targetCPUUtilizationPercentage: 80 |  | ||||||
|   # targetMemoryUtilizationPercentage: 80 |  | ||||||
| 
 |  | ||||||
| nodeSelector: {} |  | ||||||
| 
 |  | ||||||
| tolerations: [] |  | ||||||
| 
 |  | ||||||
| affinity: {} |  | ||||||
| @ -1,23 +0,0 @@ | |||||||
| # Patterns to ignore when building packages. |  | ||||||
| # This supports shell glob matching, relative path matching, and |  | ||||||
| # negation (prefixed with !). Only one pattern per line. |  | ||||||
| .DS_Store |  | ||||||
| # Common VCS dirs |  | ||||||
| .git/ |  | ||||||
| .gitignore |  | ||||||
| .bzr/ |  | ||||||
| .bzrignore |  | ||||||
| .hg/ |  | ||||||
| .hgignore |  | ||||||
| .svn/ |  | ||||||
| # Common backup files |  | ||||||
| *.swp |  | ||||||
| *.bak |  | ||||||
| *.tmp |  | ||||||
| *.orig |  | ||||||
| *~ |  | ||||||
| # Various IDEs |  | ||||||
| .project |  | ||||||
| .idea/ |  | ||||||
| *.tmproj |  | ||||||
| .vscode/ |  | ||||||
| @ -1,53 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| apiVersion: v2 |  | ||||||
| name: openim-rpc-auth |  | ||||||
| description: A Helm chart for Kubernetes |  | ||||||
| 
 |  | ||||||
| # A chart can be either an 'application' or a 'library' chart. |  | ||||||
| # |  | ||||||
| # Application charts are a collection of templates that can be packaged into versioned archives |  | ||||||
| # to be deployed. |  | ||||||
| # |  | ||||||
| # Library charts provide useful utilities or functions for the chart developer. They're included as |  | ||||||
| # a dependency of application charts to inject those utilities and functions into the rendering |  | ||||||
| # pipeline. Library charts do not define any templates and therefore cannot be deployed. |  | ||||||
| type: application |  | ||||||
| 
 |  | ||||||
| # This is the chart version. This version number should be incremented each time you make changes |  | ||||||
| # to the chart and its templates, including the app version. |  | ||||||
| # Versions are expected to follow Semantic Versioning (https://semver.org/) |  | ||||||
| version: 0.1.0 |  | ||||||
| 
 |  | ||||||
| # This is the version number of the application being deployed. This version number should be |  | ||||||
| # incremented each time you make changes to the application. Versions are not expected to |  | ||||||
| # follow Semantic Versioning. They should reflect the version the application is using. |  | ||||||
| # It is recommended to use it with quotes. |  | ||||||
| appVersion: "1.16.0" |  | ||||||
| 
 |  | ||||||
| icon: https://raw.githubusercontent.com/openimsdk/open-im-server/main/assets/openim-logo-gradient.svg |  | ||||||
| 
 |  | ||||||
| maintainers: |  | ||||||
|   - name: "OpenIM" |  | ||||||
|     url: "https://github.com/openimsdk" |  | ||||||
| 
 |  | ||||||
| keywords: |  | ||||||
|   - openim |  | ||||||
|   - im |  | ||||||
|   - chat |  | ||||||
| 
 |  | ||||||
| sources: |  | ||||||
|   - "https://github.com/openimsdk/open-im-server" |  | ||||||
|   - "https://github.com/openimsdk/helm-charts" |  | ||||||
| @ -1,22 +0,0 @@ | |||||||
| 1. Get the application URL by running these commands: |  | ||||||
| {{- if .Values.ingress.enabled }} |  | ||||||
| {{- range $host := .Values.ingress.hosts }} |  | ||||||
|   {{- range .paths }} |  | ||||||
|   http{{ if $.Values.ingress.tls }}s{{ end }}://{{ $host.host }}{{ .path }} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| {{- else if contains "NodePort" .Values.service.type }} |  | ||||||
|   export NODE_PORT=$(kubectl get --namespace {{ .Release.Namespace }} -o jsonpath="{.spec.ports[0].nodePort}" services {{ include "openim-rpc-auth.fullname" . }}) |  | ||||||
|   export NODE_IP=$(kubectl get nodes --namespace {{ .Release.Namespace }} -o jsonpath="{.items[0].status.addresses[0].address}") |  | ||||||
|   echo http://$NODE_IP:$NODE_PORT |  | ||||||
| {{- else if contains "LoadBalancer" .Values.service.type }} |  | ||||||
|      NOTE: It may take a few minutes for the LoadBalancer IP to be available. |  | ||||||
|            You can watch the status of by running 'kubectl get --namespace {{ .Release.Namespace }} svc -w {{ include "openim-rpc-auth.fullname" . }}' |  | ||||||
|   export SERVICE_IP=$(kubectl get svc --namespace {{ .Release.Namespace }} {{ include "openim-rpc-auth.fullname" . }} --template "{{"{{ range (index .status.loadBalancer.ingress 0) }}{{.}}{{ end }}"}}") |  | ||||||
|   echo http://$SERVICE_IP:{{ .Values.service.port }} |  | ||||||
| {{- else if contains "ClusterIP" .Values.service.type }} |  | ||||||
|   export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app.kubernetes.io/name={{ include "openim-rpc-auth.name" . }},app.kubernetes.io/instance={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}") |  | ||||||
|   export CONTAINER_PORT=$(kubectl get pod --namespace {{ .Release.Namespace }} $POD_NAME -o jsonpath="{.spec.containers[0].ports[0].containerPort}") |  | ||||||
|   echo "Visit http://127.0.0.1:8080 to use your application" |  | ||||||
|   kubectl --namespace {{ .Release.Namespace }} port-forward $POD_NAME 8080:$CONTAINER_PORT |  | ||||||
| {{- end }} |  | ||||||
| @ -1,62 +0,0 @@ | |||||||
| {{/* |  | ||||||
| Expand the name of the chart. |  | ||||||
| */}} |  | ||||||
| {{- define "openim-rpc-auth.name" -}} |  | ||||||
| {{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Create a default fully qualified app name. |  | ||||||
| We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). |  | ||||||
| If release name contains chart name it will be used as a full name. |  | ||||||
| */}} |  | ||||||
| {{- define "openim-rpc-auth.fullname" -}} |  | ||||||
| {{- if .Values.fullnameOverride }} |  | ||||||
| {{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- else }} |  | ||||||
| {{- $name := default .Chart.Name .Values.nameOverride }} |  | ||||||
| {{- if contains $name .Release.Name }} |  | ||||||
| {{- .Release.Name | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- else }} |  | ||||||
| {{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Create chart name and version as used by the chart label. |  | ||||||
| */}} |  | ||||||
| {{- define "openim-rpc-auth.chart" -}} |  | ||||||
| {{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Common labels |  | ||||||
| */}} |  | ||||||
| {{- define "openim-rpc-auth.labels" -}} |  | ||||||
| helm.sh/chart: {{ include "openim-rpc-auth.chart" . }} |  | ||||||
| {{ include "openim-rpc-auth.selectorLabels" . }} |  | ||||||
| {{- if .Chart.AppVersion }} |  | ||||||
| app.kubernetes.io/version: {{ .Chart.AppVersion | quote }} |  | ||||||
| {{- end }} |  | ||||||
| app.kubernetes.io/managed-by: {{ .Release.Service }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Selector labels |  | ||||||
| */}} |  | ||||||
| {{- define "openim-rpc-auth.selectorLabels" -}} |  | ||||||
| app.kubernetes.io/name: {{ include "openim-rpc-auth.name" . }} |  | ||||||
| app.kubernetes.io/instance: {{ .Release.Name }} |  | ||||||
| {{- end }} |  | ||||||
| 
 |  | ||||||
| {{/* |  | ||||||
| Create the name of the service account to use |  | ||||||
| */}} |  | ||||||
| {{- define "openim-rpc-auth.serviceAccountName" -}} |  | ||||||
| {{- if .Values.serviceAccount.create }} |  | ||||||
| {{- default (include "openim-rpc-auth.fullname" .) .Values.serviceAccount.name }} |  | ||||||
| {{- else }} |  | ||||||
| {{- default "default" .Values.serviceAccount.name }} |  | ||||||
| {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,86 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| apiVersion: apps/v1 |  | ||||||
| kind: Deployment |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-rpc-auth.fullname" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-rpc-auth.labels" . | nindent 4 }} |  | ||||||
| spec: |  | ||||||
|   {{- if not .Values.autoscaling.enabled }} |  | ||||||
|   replicas: {{ .Values.replicaCount }} |  | ||||||
|   {{- end }} |  | ||||||
|   selector: |  | ||||||
|     matchLabels: |  | ||||||
|       {{- include "openim-rpc-auth.selectorLabels" . | nindent 6 }} |  | ||||||
|   template: |  | ||||||
|     metadata: |  | ||||||
|       {{- with .Values.podAnnotations }} |  | ||||||
|       annotations: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       labels: |  | ||||||
|         {{- include "openim-rpc-auth.selectorLabels" . | nindent 8 }} |  | ||||||
|     spec: |  | ||||||
|       {{- with .Values.imagePullSecrets }} |  | ||||||
|       imagePullSecrets: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       serviceAccountName: {{ include "openim-rpc-auth.serviceAccountName" . }} |  | ||||||
|       securityContext: |  | ||||||
|         {{- toYaml .Values.podSecurityContext | nindent 8 }} |  | ||||||
|       containers: |  | ||||||
|         - name: {{ .Chart.Name }} |  | ||||||
|           securityContext: |  | ||||||
|             {{- toYaml .Values.securityContext | nindent 12 }} |  | ||||||
|           image: "{{ .Values.image.repository }}:{{ .Values.image.tag | default .Chart.AppVersion }}" |  | ||||||
|           imagePullPolicy: {{ .Values.image.pullPolicy }} |  | ||||||
|           ports: |  | ||||||
|             - name: webhook |  | ||||||
|               containerPort: 80 |  | ||||||
|               protocol: TCP |  | ||||||
|           #livenessProbe: |  | ||||||
|           #  httpGet: |  | ||||||
|           #    path: / |  | ||||||
|           #    port: webhook |  | ||||||
|           #readinessProbe: |  | ||||||
|           #  httpGet: |  | ||||||
|           #    path: / |  | ||||||
|           #    port: webhook |  | ||||||
|           resources: |  | ||||||
|             {{- toYaml .Values.resources | nindent 12 }} |  | ||||||
|           volumeMounts: |  | ||||||
|             - mountPath: /openim/openim-server/config/config.yaml |  | ||||||
|               name: config |  | ||||||
|               subPath: config.yaml |  | ||||||
|             - mountPath: /openim/openim-server/config/ |  | ||||||
|               name: config |  | ||||||
|               subPath: notification.yaml |  | ||||||
|       volumes: |  | ||||||
|         - name: config |  | ||||||
|           configMap: |  | ||||||
|             name: openim-cm |  | ||||||
|       {{- with .Values.nodeSelector }} |  | ||||||
|       nodeSelector: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       {{- with .Values.affinity }} |  | ||||||
|       affinity: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
|       {{- with .Values.tolerations }} |  | ||||||
|       tolerations: |  | ||||||
|         {{- toYaml . | nindent 8 }} |  | ||||||
|       {{- end }} |  | ||||||
| @ -1,42 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| {{- if .Values.autoscaling.enabled }} |  | ||||||
| apiVersion: autoscaling/v2beta1 |  | ||||||
| kind: HorizontalPodAutoscaler |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-rpc-auth.fullname" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-rpc-auth.labels" . | nindent 4 }} |  | ||||||
| spec: |  | ||||||
|   scaleTargetRef: |  | ||||||
|     apiVersion: apps/v1 |  | ||||||
|     kind: Deployment |  | ||||||
|     name: {{ include "openim-rpc-auth.fullname" . }} |  | ||||||
|   minReplicas: {{ .Values.autoscaling.minReplicas }} |  | ||||||
|   maxReplicas: {{ .Values.autoscaling.maxReplicas }} |  | ||||||
|   metrics: |  | ||||||
|     {{- if .Values.autoscaling.targetCPUUtilizationPercentage }} |  | ||||||
|     - type: Resource |  | ||||||
|       resource: |  | ||||||
|         name: cpu |  | ||||||
|         targetAverageUtilization: {{ .Values.autoscaling.targetCPUUtilizationPercentage }} |  | ||||||
|     {{- end }} |  | ||||||
|     {{- if .Values.autoscaling.targetMemoryUtilizationPercentage }} |  | ||||||
|     - type: Resource |  | ||||||
|       resource: |  | ||||||
|         name: memory |  | ||||||
|         targetAverageUtilization: {{ .Values.autoscaling.targetMemoryUtilizationPercentage }} |  | ||||||
|     {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,75 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| {{- if .Values.ingress.enabled -}} |  | ||||||
| {{- $fullName := include "openim-rpc-auth.fullname" . -}} |  | ||||||
| {{- $svcPort := .Values.service.port -}} |  | ||||||
| {{- if and .Values.ingress.className (not (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion)) }} |  | ||||||
|   {{- if not (hasKey .Values.ingress.annotations "kubernetes.io/ingress.class") }} |  | ||||||
|   {{- $_ := set .Values.ingress.annotations "kubernetes.io/ingress.class" .Values.ingress.className}} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| {{- if semverCompare ">=1.19-0" .Capabilities.KubeVersion.GitVersion -}} |  | ||||||
| apiVersion: networking.k8s.io/v1 |  | ||||||
| {{- else if semverCompare ">=1.14-0" .Capabilities.KubeVersion.GitVersion -}} |  | ||||||
| apiVersion: networking.k8s.io/v1beta1 |  | ||||||
| {{- else -}} |  | ||||||
| apiVersion: extensions/v1beta1 |  | ||||||
| {{- end }} |  | ||||||
| kind: Ingress |  | ||||||
| metadata: |  | ||||||
|   name: {{ $fullName }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-rpc-auth.labels" . | nindent 4 }} |  | ||||||
|   {{- with .Values.ingress.annotations }} |  | ||||||
|   annotations: |  | ||||||
|     {{- toYaml . | nindent 4 }} |  | ||||||
|   {{- end }} |  | ||||||
| spec: |  | ||||||
|   {{- if and .Values.ingress.className (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion) }} |  | ||||||
|   ingressClassName: {{ .Values.ingress.className }} |  | ||||||
|   {{- end }} |  | ||||||
|   {{- if .Values.ingress.tls }} |  | ||||||
|   tls: |  | ||||||
|     {{- range .Values.ingress.tls }} |  | ||||||
|     - hosts: |  | ||||||
|         {{- range .hosts }} |  | ||||||
|         - {{ . | quote }} |  | ||||||
|         {{- end }} |  | ||||||
|       secretName: {{ .secretName }} |  | ||||||
|     {{- end }} |  | ||||||
|   {{- end }} |  | ||||||
|   rules: |  | ||||||
|     {{- range .Values.ingress.hosts }} |  | ||||||
|     - host: {{ .host | quote }} |  | ||||||
|       http: |  | ||||||
|         paths: |  | ||||||
|           {{- range .paths }} |  | ||||||
|           - path: {{ .path }} |  | ||||||
|             {{- if and .pathType (semverCompare ">=1.18-0" $.Capabilities.KubeVersion.GitVersion) }} |  | ||||||
|             pathType: {{ .pathType }} |  | ||||||
|             {{- end }} |  | ||||||
|             backend: |  | ||||||
|               {{- if semverCompare ">=1.19-0" $.Capabilities.KubeVersion.GitVersion }} |  | ||||||
|               service: |  | ||||||
|                 name: {{ $fullName }} |  | ||||||
|                 port: |  | ||||||
|                   number: {{ $svcPort }} |  | ||||||
|               {{- else }} |  | ||||||
|               serviceName: {{ $fullName }} |  | ||||||
|               servicePort: {{ $svcPort }} |  | ||||||
|               {{- end }} |  | ||||||
|           {{- end }} |  | ||||||
|     {{- end }} |  | ||||||
| {{- end }} |  | ||||||
| @ -1,29 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| apiVersion: v1 |  | ||||||
| kind: Service |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-rpc-auth.fullname" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-rpc-auth.labels" . | nindent 4 }} |  | ||||||
| spec: |  | ||||||
|   type: {{ .Values.service.type }} |  | ||||||
|   ports: |  | ||||||
|     - port: {{ .Values.service.port }} |  | ||||||
|       targetPort: webhook |  | ||||||
|       protocol: TCP |  | ||||||
|       name: webhook |  | ||||||
|   selector: |  | ||||||
|     {{- include "openim-rpc-auth.selectorLabels" . | nindent 4 }} |  | ||||||
| @ -1,26 +0,0 @@ | |||||||
| # Copyright © 2023 OpenIM. All rights reserved. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| 
 |  | ||||||
| {{- if .Values.serviceAccount.create -}} |  | ||||||
| apiVersion: v1 |  | ||||||
| kind: ServiceAccount |  | ||||||
| metadata: |  | ||||||
|   name: {{ include "openim-rpc-auth.serviceAccountName" . }} |  | ||||||
|   labels: |  | ||||||
|     {{- include "openim-rpc-auth.labels" . | nindent 4 }} |  | ||||||
|   {{- with .Values.serviceAccount.annotations }} |  | ||||||
|   annotations: |  | ||||||
|     {{- toYaml . | nindent 4 }} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end }} |  | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user