mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-27 05:52:29 +08:00 
			
		
		
		
	merge: update release-v3.8 with main changes
This commit is contained in:
		
						commit
						c487966558
					
				
							
								
								
									
										8
									
								
								.env
									
									
									
									
									
								
							
							
						
						
									
										8
									
								
								.env
									
									
									
									
									
								
							| @ -8,12 +8,12 @@ PROMETHEUS_IMAGE=prom/prometheus:v2.45.6 | ||||
| ALERTMANAGER_IMAGE=prom/alertmanager:v0.27.0 | ||||
| GRAFANA_IMAGE=grafana/grafana:11.0.1 | ||||
| 
 | ||||
| OPENIM_WEB_FRONT_IMAGE=openim/openim-web-front:release-v3.5.1 | ||||
| OPENIM_ADMIN_FRONT_IMAGE=openim/openim-admin-front:release-v1.7 | ||||
| OPENIM_WEB_FRONT_IMAGE=openim/openim-web-front:release-v3.8.1 | ||||
| OPENIM_ADMIN_FRONT_IMAGE=openim/openim-admin-front:release-v1.8.2 | ||||
| 
 | ||||
| #FRONT_IMAGE: use aliyun images | ||||
| #OPENIM_WEB_FRONT_IMAGE=registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-web-front:release-v3.5.1 | ||||
| #OPENIM_ADMIN_FRONT_IMAGE=registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-admin-front:release-v1.7 | ||||
| #OPENIM_WEB_FRONT_IMAGE=registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-web-front:release-v3.8.1 | ||||
| #OPENIM_ADMIN_FRONT_IMAGE=registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-admin-front:release-v1.8.2 | ||||
| 
 | ||||
| DATA_DIR=./ | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										15
									
								
								.github/.codecov.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										15
									
								
								.github/.codecov.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,17 +1,3 @@ | ||||
| # 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. | ||||
| 
 | ||||
| coverage: | ||||
|   status: | ||||
|     project: | ||||
| @ -28,6 +14,7 @@ coverage: | ||||
|         paths: | ||||
|           - test/* # only include coverage in "test/" folder | ||||
|         informational: true # Always pass check | ||||
|        | ||||
|       # internal: # declare a new status context "internal" | ||||
|       #   paths: | ||||
|       #     - internal/* # only include coverage in "internal/" folder | ||||
|  | ||||
							
								
								
									
										65
									
								
								.github/ISSUE_TEMPLATE/bug-report.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								.github/ISSUE_TEMPLATE/bug-report.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,65 @@ | ||||
| name: Bug Report | ||||
| title: "[BUG] " | ||||
| labels: ["bug"] | ||||
| description: "Create a detailed report to help us identify and resolve issues." | ||||
| # assignees: [] | ||||
| 
 | ||||
| body: | ||||
|   - type: markdown | ||||
|     attributes: | ||||
|       value: "Thank you for taking the time to fill out the bug report. Please provide as much information as possible to help us understand and replicate the bug." | ||||
| 
 | ||||
|   - type: input | ||||
|     id: openim-server-version | ||||
|     attributes: | ||||
|       label: OpenIM Server Version | ||||
|       description: "Please provide the version number of OpenIM Server you are using." | ||||
|       placeholder: "e.g., 3.8.0" | ||||
|     validations: | ||||
|       required: true | ||||
| 
 | ||||
|   - type: dropdown | ||||
|     id: operating-system | ||||
|     attributes: | ||||
|       label: Operating System and CPU Architecture | ||||
|       description: "Please select the operating system and describe the CPU architecture." | ||||
|       options: | ||||
|         - Linux (AMD) | ||||
|         - Linux (ARM) | ||||
|         - Windows (AMD) | ||||
|         - Windows (ARM) | ||||
|         - macOS (AMD) | ||||
|         - macOS (ARM) | ||||
|     validations: | ||||
|       required: true | ||||
| 
 | ||||
|   - type: dropdown | ||||
|     id: deployment-method | ||||
|     attributes: | ||||
|       label: Deployment Method | ||||
|       description: "Please specify how OpenIM Server was deployed." | ||||
|       options: | ||||
|         - Source Code Deployment | ||||
|         - Docker Deployment | ||||
|     validations: | ||||
|       required: true | ||||
|        | ||||
|   - type: textarea | ||||
|     id: bug-description-reproduction | ||||
|     attributes: | ||||
|       label: Bug Description and Steps to Reproduce | ||||
|       description: "Provide a detailed description of the bug and a step-by-step guide on how to reproduce it." | ||||
|       placeholder: "Describe the bug in detail here...\n\nSteps to reproduce the bug on the server:\n1. Start the server with specific configurations (mention any relevant config details).\n2. Make an API call to '...' endpoint with the following payload '...'.\n3. Observe the behavior and note any error messages or logs.\n4. Mention any additional setup relevant to the bug (e.g., database version, external service dependencies)." | ||||
|     validations: | ||||
|       required: true | ||||
| 
 | ||||
|   - type: markdown | ||||
|     attributes: | ||||
|       value: "If possible, please add screenshots to help explain your problem." | ||||
| 
 | ||||
|   - type: textarea | ||||
|     id: screenshots-link | ||||
|     attributes: | ||||
|       label: Screenshots Link | ||||
|       description: "If applicable, please provide any links to screenshots here." | ||||
|       placeholder: "Paste your screenshot URL here, e.g., http://imgur.com/example" | ||||
							
								
								
									
										11
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| blank_issues_enabled: false | ||||
| contact_links: | ||||
|   # - name: "Bug Report" | ||||
|   #   description: "Report a bug in the project" | ||||
|   #   file: "bug-report.yml" | ||||
|   - name: 📢 Connect on slack | ||||
|     url: https://join.slack.com/t/openimsdk/shared_invite/zt-1tmoj26uf-_FDy3dowVHBiGvLk9e5Xkg | ||||
|     about: Support OpenIM-related requests or issues, get in touch with developers and help on slack | ||||
|   - name: 🌐 OpenIM Blog | ||||
|     url: https://www.openim.io/ | ||||
|     about: Open the OpenIM community blog | ||||
							
								
								
									
										65
									
								
								.github/ISSUE_TEMPLATE/deployment.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								.github/ISSUE_TEMPLATE/deployment.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,65 @@ | ||||
| name: Deployment issue | ||||
| title: "[Deployment] " | ||||
| labels: ["deployment"] | ||||
| description: "Create a detailed report to help us identify and resolve deployment issues." | ||||
| # assignees: [] | ||||
| 
 | ||||
| body: | ||||
|   - type: markdown | ||||
|     attributes: | ||||
|       value: "Thank you for taking the time to fill out the deployment issue report. Please provide as much information as possible to help us understand and resolve the issue." | ||||
| 
 | ||||
|   - type: input | ||||
|     id: openim-server-version | ||||
|     attributes: | ||||
|       label: OpenIM Server Version | ||||
|       description: "Please provide the version number of OpenIM Server you are using." | ||||
|       placeholder: "e.g., 3.8.0" | ||||
|     validations: | ||||
|       required: true | ||||
| 
 | ||||
|   - type: dropdown | ||||
|     id: operating-system | ||||
|     attributes: | ||||
|       label: Operating System and CPU Architecture | ||||
|       description: "Please select the operating system and describe the CPU architecture." | ||||
|       options: | ||||
|         - Linux (AMD) | ||||
|         - Linux (ARM) | ||||
|         - Windows (AMD) | ||||
|         - Windows (ARM) | ||||
|         - macOS (AMD) | ||||
|         - macOS (ARM) | ||||
|     validations: | ||||
|       required: true | ||||
| 
 | ||||
|   - type: dropdown | ||||
|     id: deployment-method | ||||
|     attributes: | ||||
|       label: Deployment Method | ||||
|       description: "Please specify how OpenIM Server was deployed." | ||||
|       options: | ||||
|         - Source Code Deployment | ||||
|         - Docker Deployment | ||||
|     validations: | ||||
|       required: true | ||||
|        | ||||
|   - type: textarea | ||||
|     id: issue-description-reproduction | ||||
|     attributes: | ||||
|       label: Issue Description and Steps to Reproduce | ||||
|       description: "Provide a detailed description of the issue and a step-by-step guide on how to reproduce it." | ||||
|       placeholder: "Describe the issue in detail here...\n\nSteps to reproduce the issue on the server:\n1. Start the server with specific configurations (mention any relevant config details).\n2. Make an API call to '...' endpoint with the following payload '...'.\n3. Observe the behavior and note any error messages or logs.\n4. Mention any additional setup relevant to the bug (e.g., database version, external service dependencies)." | ||||
|     validations: | ||||
|       required: true | ||||
| 
 | ||||
|   - type: markdown | ||||
|     attributes: | ||||
|       value: "If possible, please add screenshots to help explain your problem." | ||||
| 
 | ||||
|   - type: textarea | ||||
|     id: screenshots-link | ||||
|     attributes: | ||||
|       label: Screenshots Link | ||||
|       description: "If applicable, please provide any links to screenshots here." | ||||
|       placeholder: "Paste your screenshot URL here, e.g., http://imgur.com/example" | ||||
							
								
								
									
										20
									
								
								.github/ISSUE_TEMPLATE/documentation.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								.github/ISSUE_TEMPLATE/documentation.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,20 @@ | ||||
| --- | ||||
| name: Documentation Update | ||||
| about: Propose updates to documentation, including README files and other docs. | ||||
| title: "[DOC]: "  # Prefix for the title to help identify documentation issues | ||||
| labels: documentation  # Labels to be automatically added | ||||
| assignees: ''  # Optionally, specify maintainers or teams to be auto-assigned | ||||
| 
 | ||||
| --- | ||||
| 
 | ||||
| ## Documentation Updates | ||||
| Describe the documentation that needs to be updated or corrected. Please specify the files and sections if possible. | ||||
| 
 | ||||
| ## Motivation | ||||
| Explain why these updates are necessary. What is missing, misleading, or outdated? | ||||
| 
 | ||||
| ## Suggested Changes | ||||
| Detail the changes that you propose. If you are suggesting large changes, include examples or mockups of what the updated documentation should look like. | ||||
| 
 | ||||
| ## Additional Information | ||||
| Include any other information that might be relevant, such as links to discussions or related issues in the repository. | ||||
							
								
								
									
										43
									
								
								.github/ISSUE_TEMPLATE/feature-request.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								.github/ISSUE_TEMPLATE/feature-request.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,43 @@ | ||||
| name: Feature Request | ||||
| title: "[FEATURE REQUEST] " | ||||
| labels: ["feature request","enhancement"] | ||||
| description: "Propose a new feature or improvement that you believe will help enhance the project." | ||||
| # assignees: [] | ||||
| 
 | ||||
| body: | ||||
|   - type: markdown | ||||
|     attributes: | ||||
|       value: "Thank you for taking the time to propose a feature request. Please fill in as much detail as possible to help us understand why this feature is necessary and how it should work." | ||||
| 
 | ||||
|   - type: textarea | ||||
|     id: feature-reason | ||||
|     attributes: | ||||
|       label: Why this feature? | ||||
|       description: "Explain why this feature is needed. What problem does it solve? How does it benefit the project and its users?" | ||||
|       placeholder: "Describe the need for this feature..." | ||||
|     validations: | ||||
|       required: true | ||||
| 
 | ||||
|   - type: textarea | ||||
|     id: solution-proposal | ||||
|     attributes: | ||||
|       label: Suggested Solution | ||||
|       description: "Describe your proposed solution for this feature. How do you envision it working?" | ||||
|       placeholder: "Detail your solution here..." | ||||
|     validations: | ||||
|       required: true | ||||
| 
 | ||||
|   - type: markdown | ||||
|     attributes: | ||||
|       value: "Please provide any other relevant information or screenshots that could help illustrate your idea." | ||||
| 
 | ||||
|   - type: textarea | ||||
|     id: additional-info | ||||
|     attributes: | ||||
|       label: Additional Information | ||||
|       description: "Include any additional information, links, or screenshots that might be relevant to your feature request." | ||||
|       placeholder: "Add more context or links to relevant resources..." | ||||
| 
 | ||||
|   - type: markdown | ||||
|     attributes: | ||||
|       value: "Thank you for contributing to the project! We appreciate your input and will review your suggestion as soon as possible." | ||||
							
								
								
									
										30
									
								
								.github/ISSUE_TEMPLATE/other.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								.github/ISSUE_TEMPLATE/other.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,30 @@ | ||||
| name: 🐧 Other | ||||
| description: Use this for any other issues. Please do NOT create blank issues | ||||
| title: "[Other]: <give this problem a name>" | ||||
| labels: ["other"] | ||||
| # assignees: [] | ||||
| 
 | ||||
| 
 | ||||
| body: | ||||
|   - type: markdown | ||||
|     attributes: | ||||
|       value: "# Other issue" | ||||
|   - type: textarea | ||||
|     id: issuedescription | ||||
|     attributes: | ||||
|       label: What would you like to share? | ||||
|       description: Provide a clear and concise explanation of your issue. | ||||
|     validations: | ||||
|       required: true | ||||
|   - type: textarea | ||||
|     id: extrainfo | ||||
|     attributes: | ||||
|       label: Additional information | ||||
|       description: Is there anything else we should know about this issue? | ||||
|     validations: | ||||
|       required: false | ||||
|   - type: markdown | ||||
|     attributes: | ||||
|       value: | | ||||
|         You can also join our Discord community [here](https://join.slack.com/t/openimsdk/shared_invite/zt-1tmoj26uf-_FDy3dowVHBiGvLk9e5Xkg) | ||||
|         Feel free to check out other cool repositories of the openim Community [here](https://github.com/openimsdk) | ||||
							
								
								
									
										26
									
								
								.github/ISSUE_TEMPLATE/rfc.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								.github/ISSUE_TEMPLATE/rfc.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,26 @@ | ||||
| --- | ||||
| name: RFC - Feature Proposal | ||||
| about: Submit a proposal for a significant feature to invite community discussion. | ||||
| title: "[RFC]: "  # Prefix for the title to help identify RFC proposals | ||||
| labels: rfc, proposal  # Labels to be automatically added | ||||
| assignees: ''  # Optionally, specify maintainers or teams to be auto-assigned | ||||
| 
 | ||||
| --- | ||||
| 
 | ||||
| ## Proposal Overview | ||||
| Briefly describe the content and objectives of your proposal. | ||||
| 
 | ||||
| ## Motivation | ||||
| Why is this new feature necessary? What is the background of this problem? | ||||
| 
 | ||||
| ## Detailed Design | ||||
| Describe the technical details of the proposal, including implementation steps, code snippets, or architecture diagrams. | ||||
| 
 | ||||
| ## Alternatives Considered | ||||
| Have other alternatives been considered? Why is this approach preferred over others? | ||||
| 
 | ||||
| ## Impact | ||||
| How will this proposal affect existing practices and community users? | ||||
| 
 | ||||
| ## Additional Information | ||||
| Include any other relevant information such as related discussions, prior related work, etc. | ||||
							
								
								
									
										22
									
								
								.github/code-language-detector.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										22
									
								
								.github/code-language-detector.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,22 +0,0 @@ | ||||
| # Copyright © 2024 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. | ||||
| 
 | ||||
| # https://github.com/marketplace/actions/code-language-detector | ||||
| directory: ./ | ||||
| file_types: | ||||
|   - .go | ||||
|   - .yaml | ||||
|   - .yml | ||||
| languages: | ||||
|   - Chinese | ||||
							
								
								
									
										43
									
								
								.github/labels.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										43
									
								
								.github/labels.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,43 +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. | ||||
| 
 | ||||
| # Refer to Kubernetes for size/* Settings | ||||
| # https://github.com/Kubernetes/Kubernetes | ||||
| XS: | ||||
|   name: size/XS | ||||
|   lines: 0 | ||||
|   color: 3CBF00 | ||||
| S: | ||||
|   name: size/S | ||||
|   lines: 10 | ||||
|   color: 5D9801 | ||||
| M: | ||||
|   name: size/M | ||||
|   lines: 30 | ||||
|   color: 7F7203 | ||||
| L: | ||||
|   name: size/L | ||||
|   lines: 100 | ||||
|   color: A14C05 | ||||
| XL: | ||||
|   name: size/XL | ||||
|   lines: 500 | ||||
|   color: C32607 | ||||
| XXL: | ||||
|   name: size/XXL | ||||
|   lines: 1000 | ||||
|   color: E50009 | ||||
|   comment: | | ||||
|     # Whoa! Easy there, Partner! | ||||
|     This PR is too big. Please break it up into smaller PRs. | ||||
							
								
								
									
										51
									
								
								.github/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										51
									
								
								.github/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,51 +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. | ||||
| 
 | ||||
| name-template: 'v$RESOLVED_VERSION 🌈' | ||||
| tag-template: 'v$RESOLVED_VERSION' | ||||
| categories: | ||||
|   - title: '🚀 Features' | ||||
|     labels: | ||||
|       - 'feature' | ||||
|       - 'enhancement' | ||||
|   - title: '🐛 Bug Fixes' | ||||
|     labels: | ||||
|       - 'kind/fix' | ||||
|       - 'kind/feature' | ||||
|       - 'enhancement' | ||||
|       - 'kind/documentation' | ||||
|       - 'good first issue' | ||||
|   - title: '🧰 Maintenance' | ||||
|     label: 'chore' | ||||
| change-template: '- $TITLE @$AUTHOR (#$NUMBER)' | ||||
| change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks. | ||||
| version-resolver: | ||||
|   major: | ||||
|     labels: | ||||
|       - 'major' | ||||
|   minor: | ||||
|     labels: | ||||
|       - 'minor' | ||||
|   patch: | ||||
|     labels: | ||||
|       - 'patch' | ||||
|   default: patch | ||||
| template: | | ||||
|   ## Changes $PREVIOUS_TAG | ||||
| 
 | ||||
|   $CHANGES | ||||
| 
 | ||||
|   ## Contributors to this $REPOSITORY	release | ||||
| 
 | ||||
|   $CONTRIBUTORS	 | ||||
							
								
								
									
										50
									
								
								.github/standardizer.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										50
									
								
								.github/standardizer.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,50 +0,0 @@ | ||||
| # https://github.com/marketplace/actions/conformity-checker-for-project | ||||
| baseConfig: | ||||
|   searchDirectory: "./" | ||||
|   ignoreCase: false | ||||
| 
 | ||||
| directoryNaming: | ||||
|   allowHyphens: true | ||||
|   allowUnderscores: false | ||||
|   mustBeLowercase: true | ||||
| 
 | ||||
| fileNaming: | ||||
|   allowHyphens: true | ||||
|   allowUnderscores: true | ||||
|   mustBeLowercase: true | ||||
| 
 | ||||
| ignoreFormats: | ||||
|   - "\\.log$" | ||||
|   - "\\.env$" | ||||
|   - "README\\.md$" | ||||
|   - "_test\\.go$" | ||||
|   - "\\.md$" | ||||
|   - _test\\.txt$ | ||||
|   - LICENSE | ||||
|   - Dockerfile | ||||
|   - CODEOWNERS | ||||
|   - Makefile | ||||
| 
 | ||||
| ignoreDirectories: | ||||
|   - "vendor" | ||||
|   - ".git" | ||||
|   - "deployments" | ||||
|   - "node_modules" | ||||
|   - "logs" | ||||
|   - "CHANGELOG" | ||||
|   - "components" | ||||
|   - "_output" | ||||
|   - "tools/openim-web" | ||||
|   - "CHANGELOG" | ||||
|   - "examples/Test_directory" | ||||
|   - test/testdata | ||||
| 
 | ||||
| fileTypeSpecificNaming: | ||||
|   ".yaml": | ||||
|     allowHyphens: true | ||||
|     allowUnderscores: false | ||||
|     mustBeLowercase: true | ||||
|   ".go": | ||||
|     allowHyphens: false | ||||
|     allowUnderscores: true | ||||
|     mustBeLowercase: true | ||||
							
								
								
									
										16
									
								
								.github/sync-release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										16
									
								
								.github/sync-release.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,18 +1,4 @@ | ||||
| # 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. | ||||
| 
 | ||||
| OpenIMSDK/openim-docker: | ||||
| openimsdk/openim-docker: | ||||
|   - source: ./config | ||||
|     dest: ./openim-server/release/config | ||||
|     replace: true | ||||
|  | ||||
							
								
								
									
										136
									
								
								.github/sync.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										136
									
								
								.github/sync.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,136 +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. | ||||
| 
 | ||||
| # https://github.com/BetaHuhn/repo-file-sync-action | ||||
| # Synchronization for the.github repository | ||||
| OpenIMSDK/.github: | ||||
|   - source: LICENSE | ||||
|     dest: LICENSE  | ||||
|   - source: scripts/LICENSE/ | ||||
|     dest: scripts/LICENSE/ | ||||
|     replace: false | ||||
| 
 | ||||
| OpenIMSDK/community: | ||||
|   - source: LICENSE | ||||
|     dest: LICENSE | ||||
|   - source: scripts/LICENSE/ | ||||
|     dest: scripts/LICENSE/ | ||||
|     replace: false | ||||
|   - source: .github/workflows/ | ||||
|     dest: .github/workflows/ | ||||
| 
 | ||||
| OpenIMSDK/openim-sdk-core: | ||||
|   - source: LICENSE | ||||
|     dest: LICENSE | ||||
|   - source: scripts/LICENSE/ | ||||
|     dest: scripts/LICENSE/ | ||||
|     replace: false | ||||
|   - source: .github/workflows/issue-robot.yml | ||||
|     dest: .github/workflows/issue-robot.yml | ||||
|     replace: false | ||||
|   - source: .github/workflows/stale.yml | ||||
|     dest: .github/workflows/stale.yml | ||||
|     replace: false | ||||
|   - source: .github/.codecov.yml | ||||
|     dest: .github/.codecov.yml | ||||
|     replace: false | ||||
| 
 | ||||
| OpenIMSDK/OpenIM-Docs: | ||||
|   - source: .github/workflows/ | ||||
|     dest: .github/workflows/ | ||||
|     exclude: | | ||||
|       e2e-test.yml | ||||
|       sync.yml | ||||
|   - source: scripts/githooks/ | ||||
|     dest: scripts/githooks/ | ||||
|     replace: true | ||||
|   - source: .github/.codecov.yml | ||||
|     dest: .github/.codecov.yml | ||||
|     replace: false | ||||
| 
 | ||||
| OpenIMSDK/OpenKF: | ||||
|   - source: LICENSE | ||||
|     dest: LICENSE | ||||
|   - source: scripts/LICENSE/ | ||||
|     dest: scripts/LICENSE/ | ||||
|     replace: false | ||||
|   - source: .github/workflows/issue-robot.yml | ||||
|     dest: .github/workflows/issue-robot.yml | ||||
|     replace: false | ||||
|   - source: .github/workflows/stale.yml | ||||
|     dest: .github/workflows/stale.yml | ||||
|     replace: false | ||||
|   - source: .github/.codecov.yml | ||||
|     dest: .github/.codecov.yml | ||||
|     replace: false | ||||
| 
 | ||||
| OpenIMSDK/openim-docker: | ||||
|   - source: ./config | ||||
|     dest: ./openim-server/main/config | ||||
|     replace: true | ||||
|   - source: ./docs | ||||
|     dest: ./openim-server/main/docs | ||||
|     replace: true | ||||
|   - source: ./scripts | ||||
|     dest: ./openim-server/main/scripts | ||||
|     replace: true | ||||
|   - source: ./scripts | ||||
|     dest: ./scripts | ||||
|     replace: true | ||||
|   - source: ./Makefile | ||||
|     dest: ./Makefile | ||||
|     replace: true | ||||
| 
 | ||||
| group: | ||||
|   # first group:common to all warehouses | ||||
|   # TODO: add the required warehouse here | ||||
|   - repos: | | ||||
|       OpenIMSDK/OpenKF@main | ||||
|       OpenIMSDK/openim-miniprogram-demo@main | ||||
|       OpenIMSDK/docs | ||||
|       OpenIMSDK/chat | ||||
|       OpenIMSDK/community | ||||
|       OpenIMSDK/openim-charts | ||||
|       OpenIMSDK/openim-sdk-cpp@main | ||||
|     files: | ||||
|       - source: LICENSE | ||||
|         dest: LICENSE | ||||
|         replace: false | ||||
|       - source: .github/workflows/issue-robot.yml | ||||
|         dest: .github/workflows/issue-robot.yml | ||||
|         replace: false | ||||
|       - source: .github/workflows/stale.yml | ||||
|         dest: .github/workflows/stale.yml | ||||
|         replace: false | ||||
|       - source: .github/workflows/project-progress.yml | ||||
|         dest: .github/workflows/project-progress.yml | ||||
|         replace: false  | ||||
|       - source: .github/workflows/help-comment-issue.yml | ||||
|         dest: .github/workflows/help-comment-issue.yml | ||||
|         replace: false | ||||
|       - source: .github/.codecov.yml | ||||
|         dest: .github/.codecov.yml | ||||
|         replace: false | ||||
|       - source: .github/workflows/cla.yml | ||||
|         dest: .github/workflows/cla.yml | ||||
|         replace: false | ||||
|       - source: .github/workflows/auto-assign-issue.yml | ||||
|         dest: .github/workflows/auto-assign-issue.yml | ||||
|         replace: false | ||||
|       - source: .github/workflows/release.yml | ||||
|         dest: .github/workflows/release.yml | ||||
|         replace: false | ||||
|       - source: ./scripts/githooks/ | ||||
|         dest: ./scripts/githooks/ | ||||
|         replace: true | ||||
							
								
								
									
										21
									
								
								.github/weekly-digest.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										21
									
								
								.github/weekly-digest.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,21 +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. | ||||
| 
 | ||||
| # https://github.com/apps/weekly-digest/installations/new | ||||
| publishDay: sun | ||||
| canPublishIssues: true | ||||
| canPublishPullRequests: true | ||||
| canPublishContributors: true | ||||
| canPublishStargazers: true | ||||
| canPublishCommits: true | ||||
							
								
								
									
										24
									
								
								.github/workflows/auto-assign-issue.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										24
									
								
								.github/workflows/auto-assign-issue.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,17 +1,3 @@ | ||||
| # Copyright © 2023 OpenIM open source community. 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. | ||||
| 
 | ||||
| name: Assign issue to comment author | ||||
| on: | ||||
|   issue_comment: | ||||
| @ -20,8 +6,7 @@ jobs: | ||||
|   assign-issue: | ||||
|     if: | | ||||
|       contains(github.event.comment.body, '/assign') || contains(github.event.comment.body, '/accept') && | ||||
|       !contains(github.event.comment.user.login, 'openimbot') && | ||||
|       !contains(github.event.comment.user.login, 'kubbot') | ||||
|       !contains(github.event.comment.user.login, 'openim-robot') | ||||
|     runs-on: ubuntu-latest | ||||
|     permissions: | ||||
|       issues: write | ||||
| @ -33,11 +18,12 @@ jobs: | ||||
|         run: | | ||||
|           export LETASE_MILESTONES=$(curl 'https://api.github.com/repos/$OWNER/$PEPO/milestones' | jq -r 'last(.[]).title') | ||||
|           gh issue edit ${{ github.event.issue.number }} --add-assignee "${{ github.event.comment.user.login }}" | ||||
|           gh issue edit ${{ github.event.issue.number }} --add-label "triage/accepted" | ||||
|           gh issue edit ${{ github.event.issue.number }} --milestone "$LETASE_MILESTONES" | ||||
|           gh issue edit ${{ github.event.issue.number }} --add-label "accepted" | ||||
|           gh issue comment $ISSUE --body "@${{ github.event.comment.user.login }} Glad to see you accepted this issue🤲, this issue has been assigned to you. I set the milestones for this issue to [$LETASE_MILESTONES](https://github.com/$OWNER/$PEPO/milestones), We are looking forward to your PR!" | ||||
| 
 | ||||
|         # gh issue edit ${{ github.event.issue.number }} --milestone "$LETASE_MILESTONES" | ||||
|         env: | ||||
|           GH_TOKEN: ${{ secrets.REDBOT_GITHUB_TOKEN }} | ||||
|           GH_TOKEN: ${{ secrets.BOT_TOKEN }} | ||||
|           ISSUE: ${{ github.event.issue.html_url }} | ||||
|           OWNER: ${{ github.repository_owner }} | ||||
|           REPO: ${{ github.event.repository.name }} | ||||
							
								
								
									
										72
									
								
								.github/workflows/auto-gh-pr.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										72
									
								
								.github/workflows/auto-gh-pr.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,72 +0,0 @@ | ||||
| # Copyright © 2023 OpenIM open source community. 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. | ||||
| 
 | ||||
| name: Auto PR to release | ||||
| 
 | ||||
| on: | ||||
|   pull_request: | ||||
|     # types: | ||||
|     #   - closed | ||||
|   issue_comment: | ||||
|     types: [created] | ||||
|   pull_request_review_comment: | ||||
|     types: [created] | ||||
| 
 | ||||
| jobs: | ||||
|   sync-issue-to-pr: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout code | ||||
|         uses: actions/checkout@v4 | ||||
|        | ||||
|       - name: Sync Issue to PR | ||||
|         if: github.event_name == 'pull_request' && github.event.pull_request.base.ref == 'main' | ||||
|         run: | | ||||
|           PR_BODY="${{ github.event.pull_request.body }}" | ||||
| 
 | ||||
|           ISSUE_NUMBER=$(echo "$PR_BODY" | grep -oP 'Fixes #\K\d+') | ||||
|           if [[ -z "$ISSUE_NUMBER" ]]; then | ||||
|             echo "No Issue number found." | ||||
|             exit 1 | ||||
|           fi | ||||
| 
 | ||||
|           echo "Issue number found: $ISSUE_NUMBER" | ||||
| 
 | ||||
|           # Using GitHub CLI to get issue details | ||||
|           gh issue view "$ISSUE_NUMBER" --repo "${{ github.repository }}" --json labels,assignees,milestone,title > issue_data.json | ||||
| 
 | ||||
|           # Check if jq is installed | ||||
|           if ! command -v jq &> /dev/null; then | ||||
|             echo "Installing jq..." | ||||
|             sudo apt-get install -y jq | ||||
|           fi | ||||
| 
 | ||||
|           # Parse data with jq | ||||
|           LABELS=$(jq -r '.labels | map(.name) | join(",")' issue_data.json) | ||||
|           ASSIGNEES=$(jq -r '.assignees | map(.login) | join(",")' issue_data.json) | ||||
|           MILESTONE=$(jq -r '.milestone.title' issue_data.json) | ||||
| 
 | ||||
|           # Check if any of the fields are empty and set them to None | ||||
|           LABELS=${LABELS:-None} | ||||
|           ASSIGNEES=${ASSIGNEES:-None} | ||||
|           MILESTONE=${MILESTONE:-None} | ||||
| 
 | ||||
|           # Edit the PR with issue details, handling empty fields | ||||
|           gh pr edit "${{ github.event.pull_request.number }}" --repo "${{ github.repository }}" \ | ||||
|             ${LABELS:+--add-label "$LABELS"} \ | ||||
|             ${ASSIGNEES:+--add-assignee "$ASSIGNEES"} \ | ||||
|             ${MILESTONE:+--milestone "$MILESTONE"} | ||||
|         continue-on-error: true | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
| @ -1,32 +1,18 @@ | ||||
| # Copyright © 2023 OpenIM open source community. 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. | ||||
| 
 | ||||
| name: Invite users to join our group | ||||
| name: Invite users to join OpenIM Community. | ||||
| on: | ||||
|   issue_comment: | ||||
|     types: | ||||
|       - created | ||||
| jobs: | ||||
|   issue_comment: | ||||
|     name: Invite users to join our group | ||||
|     name: Invite users to join OpenIM Community | ||||
|     if: ${{ github.event.comment.body == '/invite' || github.event.comment.body == '/close' || github.event.comment.body == '/comment' }} | ||||
|     runs-on: ubuntu-latest | ||||
|     permissions: | ||||
|       issues: write | ||||
|     steps: | ||||
| 
 | ||||
|       - name: Invite user to join our group | ||||
|       - name: Invite user to join OpenIM Community | ||||
|         uses: peter-evans/create-or-update-comment@v4 | ||||
|         with: | ||||
|           token: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
| @ -43,11 +29,11 @@ jobs: | ||||
|             + <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. | ||||
| 
 | ||||
|       - name: Close Issue | ||||
|         uses: peter-evans/close-issue@v3 | ||||
|         with: | ||||
|           token: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
|           issue-number: ${{ github.event.issue.number }} | ||||
|           comment: 🤖 Auto-closing issue, if you still need help please reopen the issue or ask for help in the community above | ||||
|           labels: | | ||||
|             triage/accepted | ||||
|       # - name: Close Issue | ||||
|       #   uses: peter-evans/close-issue@v3 | ||||
|       #   with: | ||||
|       #     token: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
|       #     issue-number: ${{ github.event.issue.number }} | ||||
|       #     comment: 🤖 Auto-closing issue, if you still need help please reopen the issue or ask for help in the community above | ||||
|       #     labels: | | ||||
|       #       accepted | ||||
							
								
								
									
										52
									
								
								.github/workflows/auto-tag.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										52
									
								
								.github/workflows/auto-tag.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,52 +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. | ||||
| 
 | ||||
| name: OpenIM Create Tag | ||||
| 
 | ||||
| on: | ||||
|   issue_comment: | ||||
|     types: [created] | ||||
|   pull_request_review_comment: | ||||
|     types: [created] | ||||
| 
 | ||||
| jobs: | ||||
|   create_tag: | ||||
|     runs-on: ubuntu-latest | ||||
|     if: startsWith(github.event.comment.body, '/create tag') | ||||
|     steps: | ||||
|       - name: Checkout code | ||||
|         uses: actions/checkout@v4 | ||||
| 
 | ||||
|       - name: Validate version number and get comment | ||||
|         id: validate | ||||
|         run: | | ||||
|           COMMENT="${{ github.event.comment.body }}" | ||||
|           VERSION=$(echo $COMMENT | cut -d ' ' -f 3) | ||||
|           TAG_COMMENT=$(echo $COMMENT | cut -d '"' -f 2) | ||||
|           if [[ $VERSION =~ ^v([0-9]+\.){2}[0-9]+$ ]]; then | ||||
|             echo "version=$VERSION" >> $GITHUB_STATE | ||||
|             echo "tag_comment=$TAG_COMMENT" >> $GITHUB_STATE | ||||
|           else | ||||
|             echo "Invalid version number." | ||||
|             exit 1 | ||||
|           fi | ||||
| 
 | ||||
|       - name: Create a new tag | ||||
|         env: | ||||
|           GH_TOKEN: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
|         run: | | ||||
|           source $GITHUB_STATE | ||||
|           git tag -a $VERSION -m "$tag_comment" | ||||
|           git push origin $VERSION | ||||
|           echo "tag_created=$VERSION" >> $GITHUB_OUTPUT | ||||
							
								
								
									
										67
									
								
								.github/workflows/bot-auto-cherry-pick.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										67
									
								
								.github/workflows/bot-auto-cherry-pick.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,67 +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. | ||||
| 
 | ||||
| name: Github Rebot for Cherry Pick when PR is merged | ||||
| on: | ||||
|   pull_request_target: | ||||
|     types: | ||||
|       - closed | ||||
| 
 | ||||
| jobs: | ||||
|   comment: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Comment cherry-pick command | ||||
|         uses: actions/github-script@v7 | ||||
|         with: | ||||
|           github-token: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
|           script: | | ||||
|             const pr = context.payload.pull_request; | ||||
|             if (!pr.merged) { | ||||
|               console.log("PR is not merged. Skipping..."); | ||||
|               return; | ||||
|             } | ||||
|             if (!pr.milestone || !pr.milestone.title) { | ||||
|               console.log("Milestone is not set. Skipping..."); | ||||
|               return; | ||||
|             } | ||||
|             const milestone = pr.milestone.title; | ||||
|             const ref = `heads/release-${milestone}`; | ||||
|             let branchExists; | ||||
|             try { | ||||
|               await github.rest.git.getRef({ | ||||
|                 owner: context.repo.owner, | ||||
|                 repo: context.repo.repo, | ||||
|                 ref: ref | ||||
|               }); | ||||
|               branchExists = true; | ||||
|             } catch (error) { | ||||
|               if (error.status === 404) { | ||||
|                 console.log(`Branch ${ref} does not exist. Skipping...`); | ||||
|                 branchExists = false; | ||||
|               } else { | ||||
|                 throw error; // Rethrow if it's another error | ||||
|               } | ||||
|             } | ||||
|             if (!branchExists) { | ||||
|               return; | ||||
|             } | ||||
|             const cherryPickCmd = `/cherry-pick release-${milestone}`; | ||||
|             console.log(`Adding comment: ${cherryPickCmd}`); | ||||
|             await github.rest.issues.createComment({ | ||||
|               owner: context.repo.owner, | ||||
|               repo: context.repo.repo, | ||||
|               issue_number: pr.number, | ||||
|               body: cherryPickCmd | ||||
|             }); | ||||
							
								
								
									
										68
									
								
								.github/workflows/bot-cherry-pick.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										68
									
								
								.github/workflows/bot-cherry-pick.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,68 +0,0 @@ | ||||
| # Copyright © 2023 OpenIM open source community. 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. | ||||
| 
 | ||||
| name: Github Robot for Cherry Pick On Comment | ||||
| 
 | ||||
| on: | ||||
|   issue_comment: | ||||
|     types: [created] | ||||
| 
 | ||||
| jobs: | ||||
|   cherry-pick: | ||||
|     name: Cherry Pick | ||||
|     if: github.event.issue.pull_request != '' && contains(github.event.comment.body, '/cherry-pick') | ||||
|     runs-on: ubuntu-latest | ||||
| 
 | ||||
|     steps: | ||||
|       - name: Checkout the latest code | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           token: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
|           fetch-depth: 0 # To ensure all history is available for cherry-picking | ||||
| 
 | ||||
|       - name: Automatic Cherry Pick | ||||
|         uses: vendoo/gha-cherry-pick@v1 | ||||
|         with: | ||||
|           # Assuming the cherry-pick commit SHA is passed in the comment like '/cherry-pick sha' | ||||
|           commit-sha: ${{ github.event.comment.body }} | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
| 
 | ||||
|       - name: Create a new branch for PR | ||||
|         run: | | ||||
|           PR_BRANCH="cherry-pick-${GITHUB_SHA}-to-${{ github.base_ref }}" | ||||
|           git checkout -b $PR_BRANCH | ||||
|           git push origin $PR_BRANCH | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
| 
 | ||||
|       - name: Create Pull Request | ||||
|         uses: actions/github-script@v5 | ||||
|         with: | ||||
|           script: | | ||||
|             const prTitle = "Cherry-pick to ${{ github.base_ref }}" | ||||
|             const prBody = "Automated cherry-pick of ${{ github.event.comment.body }}\n\n/cc @kubbot" | ||||
|             const base = "${{ github.base_ref }}" | ||||
|             const head = "cherry-pick-${{ github.sha }}-to-${{ github.base_ref }}" | ||||
|             const createPr = await github.rest.pulls.create({ | ||||
|               owner: context.repo.owner, | ||||
|               repo: context.repo.repo, | ||||
|               title: prTitle, | ||||
|               body: prBody, | ||||
|               head: head, | ||||
|               base: base, | ||||
|               maintainer_can_modify: true, // Allows maintainers to edit the PR | ||||
|             }) | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
							
								
								
									
										198
									
								
								.github/workflows/build-docker-image.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										198
									
								
								.github/workflows/build-docker-image.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,198 +0,0 @@ | ||||
| # Copyright © 2023 OpenIM open source community. 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. | ||||
| 
 | ||||
| name: Publish Docker image | ||||
| 
 | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - main | ||||
|       - release-* | ||||
|     paths-ignore: | ||||
|       - "docs/**" | ||||
|       - "README.md" | ||||
|       - "README_zh-CN.md" | ||||
|       - "**.md" | ||||
|       - "docs/**" | ||||
|       - "CONTRIBUTING.md" | ||||
|     tags: | ||||
|       - v* | ||||
|   pull_request: | ||||
|     types: [closed] | ||||
|     branches: | ||||
|       - main | ||||
|       - release-* | ||||
|     paths-ignore: | ||||
|       - "docs/**" | ||||
|       - "README.md" | ||||
|       - "README_zh-CN.md" | ||||
|       - "**.md" | ||||
|       - "docs/**" | ||||
|       - "CONTRIBUTING.md" | ||||
|   workflow_dispatch: | ||||
| 
 | ||||
| env: | ||||
|   # Common versions | ||||
|   GO_VERSION: "1.20" | ||||
| 
 | ||||
| jobs: | ||||
|   build-dockerhub: | ||||
|     runs-on: ubuntu-latest | ||||
|     if: ${{ !(github.event_name == 'pull_request' && github.event.pull_request.merged == false) }} | ||||
|     steps: | ||||
|       - name: Checkout main repository | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           path: main-repo | ||||
| 
 | ||||
|       - name: Set up QEMU | ||||
|         uses: docker/setup-qemu-action@v3 | ||||
|       - name: Set up Docker Buildx | ||||
|         uses: docker/setup-buildx-action@v3 | ||||
| 
 | ||||
|       - name: Build and push Docker image | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: ./main-repo | ||||
|           load: true | ||||
|           tags: "openim/openim-server:local" | ||||
| 
 | ||||
|       - name: Checkout compose repository | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           repository: "openimsdk/openim-docker" | ||||
|           path: "compose-repo" | ||||
| 
 | ||||
|       - name: Get Internal IP Address | ||||
|         id: get-ip | ||||
|         run: | | ||||
|           IP=$(hostname -I | awk '{print $1}') | ||||
|           echo "The IP Address is: $IP" | ||||
|           echo "::set-output name=ip::$IP" | ||||
| 
 | ||||
|       - name: Update .env to use the local image | ||||
|         run: | | ||||
|           sed -i 's|OPENIM_SERVER_IMAGE=.*|OPENIM_SERVER_IMAGE=openim/openim-server:local|' ${{ github.workspace }}/compose-repo/.env | ||||
|           sed -i 's|MINIO_EXTERNAL_ADDRESS=.*|MINIO_EXTERNAL_ADDRESS=http://${{ steps.get-ip.outputs.ip }}:10005|' ${{ github.workspace }}/compose-repo/.env | ||||
| 
 | ||||
|       - name: Start services using Docker Compose | ||||
|         run: | | ||||
|           cd ${{ github.workspace }}/compose-repo | ||||
|           docker compose up -d | ||||
|           sleep 30 | ||||
| 
 | ||||
|       - name: Check openim-server health | ||||
|         run: | | ||||
|           timeout=300 | ||||
|           interval=30 | ||||
|           elapsed=0 | ||||
|           while [[ $elapsed -le $timeout ]]; do | ||||
|             if ! docker exec openim-server mage check; then | ||||
|               echo "openim-server is not ready, waiting..." | ||||
|               sleep $interval | ||||
|               elapsed=$(($elapsed + $interval)) | ||||
|             else | ||||
|               echo "Health check successful" | ||||
|               exit 0 | ||||
|             fi | ||||
|           done | ||||
|           echo "Health check failed after 5 minutes" | ||||
|           exit 1 | ||||
| 
 | ||||
|       - name: Check openim-chat health | ||||
|         if: success() | ||||
|         run: | | ||||
|           if ! docker exec openim-chat mage check; then | ||||
|               echo "openim-chat check failed" | ||||
|               exit 1 | ||||
|             else | ||||
|               echo "Health check successful" | ||||
|               exit 0 | ||||
|             fi | ||||
| 
 | ||||
|       # - name: Checkout e2e | ||||
|       #   if: success() | ||||
|       #   uses: actions/checkout@v4 | ||||
|       #   with: | ||||
|       #     repository: "openimsdk/test-e2e" | ||||
|       #     path: e2e-repo | ||||
| 
 | ||||
|       # - name: Set up Python 3.9 | ||||
|       #   uses: actions/setup-python@v4 | ||||
|       #   with: | ||||
|       #     python-version: '3.9' | ||||
|        | ||||
|       # - name: Install dependencies | ||||
|       #   run: | | ||||
|       #     sudo apt-get update | ||||
|       #     sudo apt-get install -y xvfb libxi6 libgconf-2-4 | ||||
|       #     cd ${{ github.workspace }}/e2e-repo | ||||
|       #     pip install -r requirements.txt | ||||
|        | ||||
|       # - name: Run tests | ||||
|       #   run: | | ||||
|       #     cd ${{ github.workspace }}/e2e-repo | ||||
|       #     xvfb-run --auto-servernum --server-args='-screen 0 1920x1080x24' pytest -v -s ./script | ||||
| 
 | ||||
|       - name: Extract metadata (tags, labels) for Docker | ||||
|         if: success() | ||||
|         id: meta | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         with: | ||||
|           images: | | ||||
|             openim/openim-server | ||||
|             ghcr.io/openimsdk/openim-server | ||||
|             registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-server | ||||
|           # generate Docker tags based on the following events/attributes | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=ref,event=pr | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern={{major}} | ||||
|             type=sha | ||||
| 
 | ||||
|       - name: Log in to Docker Hub | ||||
|         uses: docker/login-action@v2 | ||||
|         with: | ||||
|           username: ${{ secrets.DOCKER_USERNAME }} | ||||
|           password: ${{ secrets.DOCKER_PASSWORD }} | ||||
| 
 | ||||
|       - name: Log in to GitHub Container Registry | ||||
|         uses: docker/login-action@v2 | ||||
|         with: | ||||
|           registry: ghcr.io | ||||
|           username: ${{ github.repository_owner }} | ||||
|           password: ${{ secrets.GITHUB_TOKEN }} | ||||
| 
 | ||||
|       - name: Log in to Aliyun Container Registry | ||||
|         uses: docker/login-action@v2 | ||||
|         with: | ||||
|           registry: registry.cn-hangzhou.aliyuncs.com | ||||
|           username: ${{ secrets.ALIREGISTRY_USERNAME }} | ||||
|           password: ${{ secrets.ALIREGISTRY_TOKEN }} | ||||
| 
 | ||||
|       - name: Build and push Docker image | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: ./main-repo | ||||
|           push: true | ||||
|           # linux/ppc64le,linux/s390x | ||||
|           platforms: linux/amd64,linux/arm64 | ||||
|           tags: ${{ steps.meta.outputs.tags }} | ||||
|           labels: ${{ steps.meta.outputs.labels }} | ||||
|        | ||||
							
								
								
									
										59
									
								
								.github/workflows/check-coverage.bak
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										59
									
								
								.github/workflows/check-coverage.bak
									
									
									
									
										vendored
									
									
								
							| @ -1,59 +0,0 @@ | ||||
| # Copyright © 2023 OpenIM open source community. 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. | ||||
| 
 | ||||
| name: OpenIM Check Coverage | ||||
| 
 | ||||
| on: | ||||
|   workflow_dispatch: | ||||
|   push: | ||||
|     branches: [ "main" ] | ||||
|     paths-ignore: | ||||
|       - "docs/**" | ||||
|       - "**/*.md" | ||||
|       - "**/*.yaml" | ||||
|       - "CONTRIBUTORS" | ||||
|       - "CHANGELOG/**" | ||||
|   pull_request: | ||||
|     branches: [ "*" ] | ||||
|     paths-ignore: | ||||
|       - "docs/**" | ||||
|       - "**/*.md" | ||||
|       - "**/*.yaml" | ||||
|       - "CONTRIBUTORS" | ||||
|       - "CHANGELOG/**" | ||||
| env: | ||||
|   # Common versions | ||||
|   GO_VERSION: "1.20" | ||||
| 
 | ||||
| jobs: | ||||
|   coverage: | ||||
|     runs-on: ubuntu-20.04 | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v4 | ||||
| 
 | ||||
|       - name: Setup Golang with cache | ||||
|         uses: magnetikonline/action-golang-cache@v4 | ||||
|         with: | ||||
|           go-version: ${{ env.GO_VERSION }} | ||||
| 
 | ||||
|       - name: Install Dependencies | ||||
|         run: sudo apt update && sudo apt install -y libgpgme-dev libbtrfs-dev libdevmapper-dev | ||||
| 
 | ||||
|       - name: Run Cover | ||||
|         run: make cover | ||||
|         continue-on-error: true | ||||
| 
 | ||||
|       - name: Upload Coverage to Codecov | ||||
|         uses: codecov/codecov-action@v4 | ||||
							
								
								
									
										40
									
								
								.github/workflows/cla-assistant.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								.github/workflows/cla-assistant.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,40 @@ | ||||
| name: CLA Assistant | ||||
| on: | ||||
|   issue_comment: | ||||
|     types: [created] | ||||
|   pull_request_target: | ||||
|     types: [opened,closed,synchronize] | ||||
| 
 | ||||
| # explicitly configure permissions, in case your GITHUB_TOKEN workflow permissions are set to read-only in repository settings | ||||
| permissions: | ||||
|   actions: write | ||||
|   contents: write # this can be 'read' if the signatures are in remote repository | ||||
|   pull-requests: write | ||||
|   statuses: write | ||||
| 
 | ||||
| jobs: | ||||
|   CLA-Assistant: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: "CLA Assistant" | ||||
|         if: (github.event.comment.body == 'recheck' || github.event.comment.body == 'I have read the CLA Document and I hereby sign the CLA') || github.event_name == 'pull_request_target' | ||||
|         uses: contributor-assistant/github-action@v2.4.0 | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||
|           PERSONAL_ACCESS_TOKEN: ${{ secrets.BOT_TOKEN }} | ||||
|         with: | ||||
|           path-to-signatures: 'signatures/cla.json' | ||||
|           path-to-document: 'https://github.com/OpenIM-Robot/cla/blob/main/README.md' # e.g. a CLA or a DCO document | ||||
|           branch: 'main' | ||||
|           allowlist: 'bot*,*bot,OpenIM-Robot' | ||||
| 
 | ||||
|          # the followings are the optional inputs - If the optional inputs are not given, then default values will be taken | ||||
|           remote-organization-name: OpenIM-Robot | ||||
|           remote-repository-name: cla | ||||
|           create-file-commit-message: 'Creating file for storing CLA Signatures' | ||||
|           # signed-commit-message: '$contributorName has signed the CLA in $owner/$repo#$pullRequestNo' | ||||
|           custom-notsigned-prcomment: '💕 Thank you for your contribution and please kindly read and sign our CLA. [CLA Docs](https://github.com/OpenIM-Robot/cla/blob/main/README.md)' | ||||
|           custom-pr-sign-comment: 'I have read the CLA Document and I hereby sign the CLA' | ||||
|           custom-allsigned-prcomment: '🤖 All Contributors have signed the [CLA](https://github.com/OpenIM-Robot/cla/blob/main/README.md).<br> The signed information is recorded [**here**](https://github.com/OpenIM-Robot/cla/blob/main/signatures/cla.json)' | ||||
|           #lock-pullrequest-aftermerge: false - if you don't want this bot to automatically lock the pull request after merging (default - true) | ||||
|           #use-dco-flag: true - If you are using DCO instead of CLA | ||||
							
								
								
									
										62
									
								
								.github/workflows/cla.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										62
									
								
								.github/workflows/cla.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,62 +0,0 @@ | ||||
| # Copyright © 2023 OpenIM open source community. 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. | ||||
| 
 | ||||
| name: OpenIM CLA Assistant | ||||
| on: | ||||
|   issue_comment: | ||||
|     types: [created] | ||||
|   pull_request_target: | ||||
|     types: [opened,closed,synchronize] | ||||
| 
 | ||||
| # explicitly configure permissions, in case your GITHUB_TOKEN workflow permissions are set to read-only in repository settings | ||||
| permissions: | ||||
|   actions: write | ||||
|   contents: write | ||||
|   pull-requests: write | ||||
|   statuses: write | ||||
| 
 | ||||
| env: | ||||
|   # Define Open-IM-Server variables here | ||||
|   OPEN_IM_SERVER_REMOTE_ORGANIZATION: openim-sigs | ||||
|   REMOTE_REPOSITORY: cla | ||||
|   OPEN_IM_SERVER_CLA_DOCUMENT: https://github.com/openim-sigs/cla/blob/main/README.md | ||||
|   OPEN_IM_SERVER_SIGNATURES_PATH: signatures/${{ github.event.repository.name }}/cla.json | ||||
| 
 | ||||
|   OPEN_IM_SERVER_ALLOWLIST: kubbot,openimbot,bot*,dependabot,sweep-ai,*bot,bot-*,bot/*,bot-/*,bot,*[bot] | ||||
| 
 | ||||
| jobs: | ||||
|   CLAAssistant: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: "CLA Assistant" | ||||
|         if: (github.event.comment.body == 'recheck' || github.event.comment.body == 'I have read the CLA Document and I hereby sign the CLA') || github.event_name == 'pull_request_target' | ||||
|         uses: contributor-assistant/github-action@v2.3.1 | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
|           PERSONAL_ACCESS_TOKEN: ${{ secrets.REDBOT_GITHUB_TOKEN }} | ||||
|         with: | ||||
|           path-to-signatures: ${{ env.OPEN_IM_SERVER_SIGNATURES_PATH }} | ||||
|           path-to-document: ${{ env.OPEN_IM_SERVER_CLA_DOCUMENT }} | ||||
|           branch: 'main' | ||||
|           allowlist: ${{ env.OPEN_IM_SERVER_ALLOWLIST }} | ||||
| 
 | ||||
|           remote-organization-name: ${{ env.OPEN_IM_SERVER_REMOTE_ORGANIZATION }} | ||||
|           remote-repository-name: ${{ env.REMOTE_REPOSITORY }} | ||||
| 
 | ||||
|           create-file-commit-message: '📚 Docs: Creating file for storing ${{ github.event.repository.name }} CLA Signatures' | ||||
|           custom-notsigned-prcomment: '💕 Thank you for your contribution and please kindly read and sign our [🎯https://github.com/openim-sigs/cla/blob/main/README.md](https://github.com/openim-sigs/cla/blob/main/README.md). <br> If you wish to sign the CRA, **Please copy and comment on the following sentence:**' | ||||
|           custom-pr-sign-comment: 'I have read the CLA Document and I hereby sign the CLA' | ||||
|           custom-allsigned-prcomment: '🤖 All Contributors have signed the [${{ github.event.repository.name }} CLA](https://github.com/openim-sigs/cla/blob/main/README.md).<br> The signed information is recorded [🤖here](https://github.com/openim-sigs/cla/tree/main/signatures/${{ github.event.repository.name }}/cla.json)' | ||||
|         #   lock-pullrequest-aftermerge: false - if you don't want this bot to automatically lock the pull request after merging (default - true) | ||||
|         #   use-dco-flag: true - If you are using DCO instead of CLA | ||||
							
								
								
									
										27
									
								
								.github/workflows/code-language-detector.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										27
									
								
								.github/workflows/code-language-detector.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,27 +0,0 @@ | ||||
| # Copyright © 2024 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. | ||||
| 
 | ||||
| name: Language Check Workflow Test | ||||
| 
 | ||||
| on: [pull_request] | ||||
| 
 | ||||
| jobs: | ||||
|   comment-language-detector: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout Repository | ||||
|         uses: actions/checkout@v4 | ||||
| 
 | ||||
|       - name: Code Language Detector | ||||
|         uses: kubecub/comment-lang-detector@v1.0.0 | ||||
							
								
								
									
										103
									
								
								.github/workflows/codeql-analysis.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										103
									
								
								.github/workflows/codeql-analysis.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,76 +1,67 @@ | ||||
| # Copyright © 2023 OpenIM open source community. All rights reserved. | ||||
| # For most projects, this workflow file will not need changing; you simply need | ||||
| # to commit it to your repository. | ||||
| # | ||||
| # 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 | ||||
| # You may wish to alter this file to override the set of languages analyzed, | ||||
| # or to provide custom queries or build logic. | ||||
| # | ||||
| #     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. | ||||
| # ******** NOTE ******** | ||||
| # We have attempted to detect the languages in your repository. Please check | ||||
| # the `language` matrix defined below to confirm you have the correct set of | ||||
| # supported CodeQL languages. | ||||
| 
 | ||||
| 
 | ||||
| name: "OpenIM Code Scanning - Action" | ||||
| name: "CodeQL" | ||||
| 
 | ||||
| on: | ||||
|   push: | ||||
|     branches: [main] | ||||
|     branches: [ main ] | ||||
|   pull_request: | ||||
|     branches: [main] | ||||
|     # The branches below must be a subset of the branches above | ||||
|     branches: [ main ] | ||||
|   schedule: | ||||
|     #        ┌───────────── minute (0 - 59) | ||||
|     #        │  ┌───────────── hour (0 - 23) | ||||
|     #        │  │ ┌───────────── day of the month (1 - 31) | ||||
|     #        │  │ │ ┌───────────── month (1 - 12 or JAN-DEC) | ||||
|     #        │  │ │ │ ┌───────────── day of the week (0 - 6 or SUN-SAT) | ||||
|     #        │  │ │ │ │ | ||||
|     #        │  │ │ │ │ | ||||
|     #        │  │ │ │ │ | ||||
|     #        *  * * * * | ||||
|     - cron: '30 1 * * 0' | ||||
|     - cron: '18 19 * * 6' | ||||
| 
 | ||||
| jobs: | ||||
|   CodeQL-Build: | ||||
|     # CodeQL runs on ubuntu-latest, windows-latest, and macos-latest | ||||
|   analyze: | ||||
|     name: Analyze | ||||
|     runs-on: ubuntu-latest | ||||
| 
 | ||||
|     permissions: | ||||
|       # required for all workflows | ||||
|       security-events: write | ||||
| 
 | ||||
|       # only required for workflows in private repositories | ||||
|       actions: write | ||||
|       contents: write | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         language: [ 'go' ] | ||||
|         # CodeQL supports [ 'cpp', 'csharp', 'go', 'java', 'javascript', 'python' ] | ||||
|         # Learn more: | ||||
|         # https://docs.github.com/en/free-pro-team@latest/github/finding-security-vulnerabilities-and-errors-in-your-code/configuring-code-scanning#changing-the-languages-that-are-analyzed | ||||
| 
 | ||||
|     steps: | ||||
|       - name: Checkout repository | ||||
|         uses: actions/checkout@v4 | ||||
|     - name: Checkout repository | ||||
|       uses: actions/checkout@v4 | ||||
| 
 | ||||
|       # Initializes the CodeQL tools for scanning. | ||||
|       - name: Initialize CodeQL | ||||
|         uses: github/codeql-action/init@v3 | ||||
|         # Override language selection by uncommenting this and choosing your languages | ||||
|         with: | ||||
|           languages: go | ||||
|     # Initializes the CodeQL tools for scanning. | ||||
|     - name: Initialize CodeQL | ||||
|       uses: github/codeql-action/init@v3 | ||||
|       with: | ||||
|         languages: ${{ matrix.language }} | ||||
|         # If you wish to specify custom queries, you can do so here or in a config file. | ||||
|         # By default, queries listed here will override any specified in a config file. | ||||
|         # Prefix the list here with "+" to use these queries and those in the config file. | ||||
|         # queries: ./path/to/local/query, your-org/your-repo/queries@main | ||||
| 
 | ||||
|       # Autobuild attempts to build any compiled languages (C/C++, C#, Go, or Java). | ||||
|       # If this step fails, then you should remove it and run the build manually (see below). | ||||
|       - name: Autobuild | ||||
|         uses: github/codeql-action/autobuild@v3 | ||||
|     # Autobuild attempts to build any compiled languages  (C/C++, C#, or Java). | ||||
|     # If this step fails, then you should remove it and run the build manually (see below) | ||||
|     - name: Autobuild | ||||
|       uses: github/codeql-action/autobuild@v3 | ||||
| 
 | ||||
|       # ℹ️ Command-line programs to run using the OS shell. | ||||
|       # 📚 See https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idstepsrun | ||||
|     # ℹ️ Command-line programs to run using the OS shell. | ||||
|     # 📚 https://git.io/JvXDl | ||||
| 
 | ||||
|       # ✏️ If the Autobuild fails above, remove it and uncomment the following | ||||
|       #    three lines and modify them (or add more) to build your code if your | ||||
|       #    project uses a compiled language | ||||
|     # ✏️ If the Autobuild fails above, remove it and uncomment the following three lines | ||||
|     #    and modify them (or add more) to build your code if your project | ||||
|     #    uses a compiled language | ||||
| 
 | ||||
|     #   - run: | | ||||
|     #       make bootstrap | ||||
|     #       make release | ||||
|     #- run: | | ||||
|     #   make bootstrap | ||||
|     #   make release | ||||
| 
 | ||||
|       - name: Perform CodeQL Analysis | ||||
|         uses: github/codeql-action/analyze@v3 | ||||
|     - name: Perform CodeQL Analysis | ||||
|       uses: github/codeql-action/analyze@v3 | ||||
							
								
								
									
										51
									
								
								.github/workflows/comment-check.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								.github/workflows/comment-check.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,51 @@ | ||||
| name: Non-English Comments Check | ||||
| 
 | ||||
| on: | ||||
|   pull_request: | ||||
|     branches: | ||||
|       - main | ||||
|   workflow_dispatch: | ||||
| 
 | ||||
| jobs: | ||||
|   non-english-comments-check: | ||||
|     runs-on: ubuntu-latest | ||||
| 
 | ||||
|     env: | ||||
|       # need ignore Dirs | ||||
|       EXCLUDE_DIRS: ".git docs tests scripts assets node_modules build" | ||||
|       # need ignore Files | ||||
|       EXCLUDE_FILES: "*.md *.txt *.html *.css *.min.js *.mdx" | ||||
| 
 | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
| 
 | ||||
|       - name: Search for Non-English comments | ||||
|         run: | | ||||
|           set -e | ||||
|           # Define the regex pattern to match Chinese characters | ||||
|           pattern='[\p{Han}]' | ||||
| 
 | ||||
|           # Process the directories to be excluded | ||||
|           exclude_dirs="" | ||||
|           for dir in $EXCLUDE_DIRS; do | ||||
|             exclude_dirs="$exclude_dirs --exclude-dir=$dir" | ||||
|           done | ||||
| 
 | ||||
|           # Process the file types to be excluded | ||||
|           exclude_files="" | ||||
|           for file in $EXCLUDE_FILES; do | ||||
|             exclude_files="$exclude_files --exclude=$file" | ||||
|           done | ||||
| 
 | ||||
|           # Use grep to find all comments containing Non-English characters and save to file | ||||
|           grep -Pnr "$pattern" . $exclude_dirs $exclude_files > non_english_comments.txt || true | ||||
| 
 | ||||
|       - name: Output non-English comments are found | ||||
|         run: | | ||||
|           if [ -s non_english_comments.txt ]; then | ||||
|             echo "Non-English comments found in the following locations:" | ||||
|             cat non_english_comments.txt | ||||
|             exit 1  # terminate the workflow | ||||
|           else | ||||
|             echo "No Non_English comments found." | ||||
|           fi | ||||
							
								
								
									
										77
									
								
								.github/workflows/create-branch-on-tag.bak
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										77
									
								
								.github/workflows/create-branch-on-tag.bak
									
									
									
									
										vendored
									
									
								
							| @ -1,77 +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. | ||||
| 
 | ||||
| name: Create Branch on Tag | ||||
| 
 | ||||
| on: | ||||
|   push: | ||||
|     tags: | ||||
|       - 'v*.*.0' | ||||
| 
 | ||||
| permissions: | ||||
|   contents: write | ||||
|   actions: write | ||||
| 
 | ||||
| jobs: | ||||
|   create-branch: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|     - name: Check out code | ||||
|       uses: actions/checkout@v4 | ||||
|       with: | ||||
|         fetch-depth: 0 | ||||
| 
 | ||||
|     - name: Set up Git | ||||
|       run: | | ||||
|         git config --global user.name 'kubbot' | ||||
|         git config --global user.email '3293172751yxy@gmail.com' | ||||
| 
 | ||||
|     - name: Install git-chglog | ||||
|       run: make install.git-chglog | ||||
| 
 | ||||
|     - name: Create Branch and Push | ||||
|       env: | ||||
|         TAG_NAME: ${{ github.ref_name }} | ||||
|       run: | | ||||
|         IFS='.' read -ra VERSION_PARTS <<< "$TAG_NAME" | ||||
|         if [[ "${VERSION_PARTS[2]}" = "0" ]]; then | ||||
|           BRANCH_NAME="release-v${VERSION_PARTS[0]}.${VERSION_PARTS[1]}" | ||||
|           echo "Creating branch $BRANCH_NAME" | ||||
|           git checkout -b "$BRANCH_NAME" | ||||
|           git push origin "$BRANCH_NAME" | ||||
|         else | ||||
|           echo "Not a release tag. Skipping branch creation." | ||||
|         fi | ||||
|       continue-on-error: true | ||||
| 
 | ||||
|     - name: Create and Commit CHANGELOG | ||||
|       if: endsWith(github.ref_name, '.0') | ||||
|       run: | | ||||
|         git fetch --all | ||||
|         TAG_NAME=${GITHUB_REF#refs/tags/} | ||||
|         IFS='.' read -ra VERSION_PARTS <<< "$TAG_NAME" | ||||
|         git checkout main | ||||
|         cd CHANGELOG | ||||
|         git-chglog --tag-filter-pattern "v${VERSION_PARTS[0]}.${VERSION_PARTS[1]}.*" -o "CHANGELOG-${VERSION_PARTS[0]}.${VERSION_PARTS[1]}.md" | ||||
|         git add "CHANGELOG-${VERSION_PARTS[0]}.${VERSION_PARTS[1]}.md" | ||||
|         git commit -m "Update CHANGELOG for $TAG_NAME" || echo "No changes to commit." | ||||
|       continue-on-error: true | ||||
| 
 | ||||
|     - name: Push CHANGELOG to Main | ||||
|       if: steps.create-and-commit-changelog.outputs.changes == 'true' | ||||
|       uses: ad-m/github-push-action@v0.8.0 | ||||
|       with: | ||||
|         github_token: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
|         branch: main | ||||
|     continue-on-error: true | ||||
							
								
								
									
										18
									
								
								.github/workflows/depsreview.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								.github/workflows/depsreview.yaml
									
									
									
									
										vendored
									
									
								
							| @ -1,18 +0,0 @@ | ||||
| # Copyright © 2023 KubeCub open source community. All rights reserved. | ||||
| # Licensed under the MIT License (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| 
 | ||||
| name: OpenIM Dependency Review | ||||
| on: [pull_request] | ||||
| 
 | ||||
| permissions: | ||||
|   contents: read | ||||
| 
 | ||||
| jobs: | ||||
|   dependency-review: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: 'Checkout Repository' | ||||
|         uses: actions/checkout@v4 | ||||
|       - name: 'Dependency Review' | ||||
|         uses: actions/dependency-review-action@v4 | ||||
							
								
								
									
										502
									
								
								.github/workflows/docker-buildx.bak
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										502
									
								
								.github/workflows/docker-buildx.bak
									
									
									
									
										vendored
									
									
								
							| @ -1,502 +0,0 @@ | ||||
| # Copyright © 2023 OpenIM open source community. 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. | ||||
| 
 | ||||
| name: Docker Buildx Images CI | ||||
| 
 | ||||
| on: | ||||
|   schedule: | ||||
|   - cron: '30 1 * * *' | ||||
|   push: | ||||
|     branches: | ||||
|       - release-* | ||||
|     tags: | ||||
|       - v* | ||||
|   workflow_dispatch: | ||||
| 
 | ||||
| jobs: | ||||
|   build-ghcr: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v4 | ||||
|          | ||||
|       - name: Set up QEMU | ||||
|         uses: docker/setup-qemu-action@v3 | ||||
|          | ||||
|       - name: Set up Docker Buildx | ||||
|         uses: docker/setup-buildx-action@v3 | ||||
|         with: | ||||
|           install: true | ||||
| 
 | ||||
|       - name: Cache Docker layers | ||||
|         uses: actions/cache@v4 | ||||
|         with: | ||||
|           path: /tmp/.buildx-cache | ||||
|           key: ${{ runner.os }}-buildx-${{ github.sha }} | ||||
|           restore-keys: | | ||||
|             ${{ runner.os }}-buildx- | ||||
| 
 | ||||
|       - name: Log in to GitHub Container Registry | ||||
|         uses: docker/login-action@v3 | ||||
|         with: | ||||
|           registry: ghcr.io | ||||
|           username: ${{ github.repository_owner }} | ||||
|           password: ${{ secrets.GITHUB_TOKEN }} | ||||
| 
 | ||||
|       - name: Log in to Docker Hub | ||||
|         uses: docker/login-action@v3 | ||||
|         with: | ||||
|           username: ${{ secrets.DOCKER_USERNAME }} | ||||
|           password: ${{ secrets.DOCKER_PASSWORD }} | ||||
| 
 | ||||
|       - name: Log in to AliYun Docker Hub | ||||
|         uses: docker/login-action@v3 | ||||
|         with: | ||||
|           registry: registry.cn-hangzhou.aliyuncs.com | ||||
|           username: ${{ secrets.ALIREGISTRY_USERNAME }} | ||||
|           password: ${{ secrets.ALIREGISTRY_TOKEN }} | ||||
| 
 | ||||
| ################################################ | ||||
| # build/ | ||||
| # └── docker | ||||
| #     ├── openim-api | ||||
| #     │   └── Dockerfile | ||||
| #     ├── openim-cmdutils | ||||
| #     │   └── Dockerfile | ||||
| #     ├── openim-crontask | ||||
| #     │   └── Dockerfile | ||||
| #     ├── openim-msggateway | ||||
| #     │   └── Dockerfile | ||||
| #     ├── openim-msgtransfer | ||||
| #     │   └── Dockerfile | ||||
| #     ├── openim-push | ||||
| #     │   └── Dockerfile | ||||
| #     ├── openim-rpc-auth | ||||
| #     │   └── Dockerfile | ||||
| #     ├── openim-rpc-conversation | ||||
| #     │   └── Dockerfile | ||||
| #     ├── openim-rpc-friend | ||||
| #     │   └── Dockerfile | ||||
| #     ├── openim-rpc-group | ||||
| #     │   └── Dockerfile | ||||
| #     ├── openim-rpc-msg | ||||
| #     │   └── Dockerfile | ||||
| #     ├── openim-rpc-third | ||||
| #     │   └── Dockerfile | ||||
| #     └── openim-rpc-user | ||||
| #         └── Dockerfile | ||||
| ############################################# | ||||
| 
 | ||||
|       - name: Extract metadata (tags, labels) for Docker openim-api | ||||
|         id: meta1 | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         with: | ||||
|           images: | | ||||
|             ghcr.io/openimsdk/openim-api | ||||
|             openim/openim-api | ||||
|             registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-api | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=ref,event=pr | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern={{major}} | ||||
|             type=sha | ||||
| 
 | ||||
|       - name: Build and push Docker image for openim-api | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: . | ||||
|           file: ./build/images/openim-api/Dockerfile | ||||
|           platforms: linux/amd64,linux/arm64 | ||||
|           push: ${{ github.event_name != 'pull_request' }} | ||||
|           tags: ${{ steps.meta1.outputs.tags }} | ||||
|           labels: ${{ steps.meta1.outputs.labels }} | ||||
|           cache-from: type=local,src=/tmp/.buildx-cache | ||||
|           cache-to: type=local,dest=/tmp/.buildx-cache | ||||
| 
 | ||||
|       - name: Extract metadata (tags, labels) for Docker openim-cmdutils | ||||
|         id: meta2 | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         with: | ||||
|           images: | | ||||
|             ghcr.io/openimsdk/openim-cmdutils | ||||
|             openim/openim-cmdutils | ||||
|             registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-cmdutils | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=ref,event=pr | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern={{major}} | ||||
|             type=sha | ||||
| 
 | ||||
|       - name: Build and push Docker image for openim-cmdutils | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: . | ||||
|           file: ./build/images/openim-cmdutils/Dockerfile | ||||
|           platforms: linux/amd64,linux/arm64 | ||||
|           push: ${{ github.event_name != 'pull_request' }} | ||||
|           tags: ${{ steps.meta2.outputs.tags }} | ||||
|           labels: ${{ steps.meta2.outputs.labels }} | ||||
|           cache-from: type=local,src=/tmp/.buildx-cache | ||||
|           cache-to: type=local,dest=/tmp/.buildx-cache | ||||
| 
 | ||||
|       - name: Extract metadata (tags, labels) for Docker openim-crontask | ||||
|         id: meta3 | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         with: | ||||
|           images: | | ||||
|             ghcr.io/openimsdk/openim-crontask | ||||
|             openim/openim-crontask | ||||
|             registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-crontask | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=ref,event=pr | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern={{major}} | ||||
|             type=sha | ||||
| 
 | ||||
|       - name: Build and push Docker image for openim-crontask | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: . | ||||
|           file: ./build/images/openim-crontask/Dockerfile | ||||
|           platforms: linux/amd64,linux/arm64 | ||||
|           push: ${{ github.event_name != 'pull_request' }} | ||||
|           tags: ${{ steps.meta3.outputs.tags }} | ||||
|           labels: ${{ steps.meta3.outputs.labels }} | ||||
|           cache-from: type=local,src=/tmp/.buildx-cache | ||||
|           cache-to: type=local,dest=/tmp/.buildx-cache | ||||
| 
 | ||||
|       - name: Extract metadata (tags, labels) for Docker openim-msggateway | ||||
|         id: meta4 | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         with: | ||||
|           images: | | ||||
|             ghcr.io/openimsdk/openim-msggateway | ||||
|             openim/openim-msggateway | ||||
|             registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-msggateway | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=ref,event=pr | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern={{major}} | ||||
|             type=sha | ||||
| 
 | ||||
|       - name: Build and push Docker image for openim-msggateway | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: . | ||||
|           file: ./build/images/openim-msggateway/Dockerfile | ||||
|           platforms: linux/amd64,linux/arm64 | ||||
|           push: ${{ github.event_name != 'pull_request' }} | ||||
|           tags: ${{ steps.meta4.outputs.tags }} | ||||
|           labels: ${{ steps.meta4.outputs.labels }} | ||||
|           cache-from: type=local,src=/tmp/.buildx-cache | ||||
|           cache-to: type=local,dest=/tmp/.buildx-cache | ||||
| 
 | ||||
|       - name: Extract metadata (tags, labels) for Docker openim-msgtransfer | ||||
|         id: meta5 | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         with: | ||||
|           images: | | ||||
|             ghcr.io/openimsdk/openim-msgtransfer | ||||
|             openim/openim-msgtransfer | ||||
|             registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-msgtransfer | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=ref,event=pr | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern={{major}} | ||||
|             type=sha | ||||
| 
 | ||||
|       - name: Build and push Docker image for openim-msgtransfer | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: . | ||||
|           file: ./build/images/openim-msgtransfer/Dockerfile | ||||
|           platforms: linux/amd64,linux/arm64 | ||||
|           push: ${{ github.event_name != 'pull_request' }} | ||||
|           tags: ${{ steps.meta5.outputs.tags }} | ||||
|           labels: ${{ steps.meta5.outputs.labels }} | ||||
|           cache-from: type=local,src=/tmp/.buildx-cache | ||||
|           cache-to: type=local,dest=/tmp/.buildx-cache | ||||
|            | ||||
|       - name: Extract metadata (tags, labels) for Docker openim-push | ||||
|         id: meta6 | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         with: | ||||
|           images: | | ||||
|             ghcr.io/openimsdk/openim-push | ||||
|             openim/openim-push | ||||
|             registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-push | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=ref,event=pr | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern={{major}} | ||||
|             type=sha | ||||
| 
 | ||||
|       - name: Build and push Docker image for openim-push | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: . | ||||
|           file: ./build/images/openim-push/Dockerfile | ||||
|           platforms: linux/amd64,linux/arm64 | ||||
|           push: ${{ github.event_name != 'pull_request' }} | ||||
|           tags: ${{ steps.meta6.outputs.tags }} | ||||
|           labels: ${{ steps.meta6.outputs.labels }} | ||||
|           cache-from: type=local,src=/tmp/.buildx-cache | ||||
|           cache-to: type=local,dest=/tmp/.buildx-cache | ||||
| 
 | ||||
|       - name: Extract metadata (tags, labels) for Docker openim-rpc-auth | ||||
|         id: meta7 | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         with: | ||||
|           images: | | ||||
|             ghcr.io/openimsdk/openim-rpc-auth | ||||
|             openim/openim-rpc-auth | ||||
|             registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-rpc-auth | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=ref,event=pr | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern={{major}} | ||||
|             type=sha | ||||
| 
 | ||||
|       - name: Build and push Docker image for openim-rpc-auth | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: . | ||||
|           file: ./build/images/openim-rpc-auth/Dockerfile | ||||
|           platforms: linux/amd64,linux/arm64 | ||||
|           push: ${{ github.event_name != 'pull_request' }} | ||||
|           tags: ${{ steps.meta7.outputs.tags }} | ||||
|           labels: ${{ steps.meta7.outputs.labels }} | ||||
|           cache-from: type=local,src=/tmp/.buildx-cache | ||||
|           cache-to: type=local,dest=/tmp/.buildx-cache | ||||
| 
 | ||||
|       - name: Extract metadata (tags, labels) for Docker openim-rpc-conversation | ||||
|         id: meta8 | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         with: | ||||
|           images: | | ||||
|             ghcr.io/openimsdk/openim-rpc-conversation | ||||
|             openim/openim-rpc-conversation | ||||
|             registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-rpc-conversation | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=ref,event=pr | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern={{major}} | ||||
|             type=sha | ||||
| 
 | ||||
|       - name: Build and push Docker image for openim-rpc-conversation | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: . | ||||
|           file: ./build/images/openim-rpc-conversation/Dockerfile | ||||
|           platforms: linux/amd64,linux/arm64 | ||||
|           push: ${{ github.event_name != 'pull_request' }} | ||||
|           tags: ${{ steps.meta8.outputs.tags }} | ||||
|           labels: ${{ steps.meta8.outputs.labels }} | ||||
|           cache-from: type=local,src=/tmp/.buildx-cache | ||||
|           cache-to: type=local,dest=/tmp/.buildx-cache | ||||
| 
 | ||||
|       - name: Extract metadata (tags, labels) for Docker openim-rpc-friend | ||||
|         id: meta9 | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         with: | ||||
|           images: | | ||||
|             ghcr.io/openimsdk/openim-rpc-friend | ||||
|             openim/openim-rpc-friend | ||||
|             registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-rpc-friend | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=ref,event=pr | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern={{major}} | ||||
|             type=sha | ||||
| 
 | ||||
|       - name: Build and push Docker image for openim-rpc-friend | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: . | ||||
|           file: ./build/images/openim-rpc-friend/Dockerfile | ||||
|           platforms: linux/amd64,linux/arm64 | ||||
|           push: ${{ github.event_name != 'pull_request' }} | ||||
|           tags: ${{ steps.meta9.outputs.tags }} | ||||
|           labels: ${{ steps.meta9.outputs.labels }} | ||||
|           cache-from: type=local,src=/tmp/.buildx-cache | ||||
|           cache-to: type=local,dest=/tmp/.buildx-cache | ||||
| 
 | ||||
|       - name: Extract metadata (tags, labels) for Docker openim-rpc-group | ||||
|         id: meta10 | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         with: | ||||
|           images: | | ||||
|             ghcr.io/openimsdk/openim-rpc-group | ||||
|             openim/openim-rpc-group | ||||
|             registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-rpc-group | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=ref,event=pr | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern={{major}} | ||||
|             type=sha | ||||
| 
 | ||||
|       - name: Build and push Docker image for openim-rpc-group | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: . | ||||
|           file: ./build/images/openim-rpc-group/Dockerfile | ||||
|           platforms: linux/amd64,linux/arm64 | ||||
|           push: ${{ github.event_name != 'pull_request' }} | ||||
|           tags: ${{ steps.meta10.outputs.tags }} | ||||
|           labels: ${{ steps.meta10.outputs.labels }} | ||||
|           cache-from: type=local,src=/tmp/.buildx-cache | ||||
|           cache-to: type=local,dest=/tmp/.buildx-cache | ||||
| 
 | ||||
|       - name: Extract metadata (tags, labels) for Docker openim-rpc-msg | ||||
|         id: meta11 | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         with: | ||||
|           images: | | ||||
|             ghcr.io/openimsdk/openim-rpc-msg | ||||
|             openim/openim-rpc-msg | ||||
|             registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-rpc-msg | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=ref,event=pr | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern={{major}} | ||||
|             type=sha | ||||
| 
 | ||||
|       - name: Build and push Docker image for openim-rpc-msg | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: . | ||||
|           file: ./build/images/openim-rpc-msg/Dockerfile | ||||
|           platforms: linux/amd64,linux/arm64 | ||||
|           push: ${{ github.event_name != 'pull_request' }} | ||||
|           tags: ${{ steps.meta11.outputs.tags }} | ||||
|           labels: ${{ steps.meta11.outputs.labels }} | ||||
|           cache-from: type=local,src=/tmp/.buildx-cache | ||||
|           cache-to: type=local,dest=/tmp/.buildx-cache | ||||
| 
 | ||||
|       - name: Extract metadata (tags, labels) for Docker openim-rpc-third | ||||
|         id: meta12 | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         with: | ||||
|           images: | | ||||
|             ghcr.io/openimsdk/openim-rpc-third | ||||
|             openim/openim-rpc-third | ||||
|             registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-rpc-third | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=ref,event=pr | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern={{major}} | ||||
|             type=sha | ||||
| 
 | ||||
|       - name: Build and push Docker image for openim-rpc-third | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: . | ||||
|           file: ./build/images/openim-rpc-third/Dockerfile | ||||
|           platforms: linux/amd64,linux/arm64 | ||||
|           push: ${{ github.event_name != 'pull_request' }} | ||||
|           tags: ${{ steps.meta12.outputs.tags }} | ||||
|           labels: ${{ steps.meta12.outputs.labels }} | ||||
|           cache-from: type=local,src=/tmp/.buildx-cache | ||||
|           cache-to: type=local,dest=/tmp/.buildx-cache | ||||
| 
 | ||||
|       - name: Extract metadata (tags, labels) for Docker openim-rpc-user | ||||
|         id: meta13 | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         with: | ||||
|           images: | | ||||
|             ghcr.io/openimsdk/openim-rpc-user | ||||
|             openim/openim-rpc-user | ||||
|             registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-rpc-user | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=ref,event=pr | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern={{major}} | ||||
|             type=sha | ||||
| 
 | ||||
|       - name: Build and push Docker image for openim-rpc-user | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: . | ||||
|           file: ./build/images/openim-rpc-user/Dockerfile | ||||
|           platforms: linux/amd64,linux/arm64 | ||||
|           push: ${{ github.event_name != 'pull_request' }} | ||||
|           tags: ${{ steps.meta13.outputs.tags }} | ||||
|           labels: ${{ steps.meta13.outputs.labels }} | ||||
|           cache-from: type=local,src=/tmp/.buildx-cache | ||||
|           cache-to: type=local,dest=/tmp/.buildx-cache | ||||
							
								
								
									
										159
									
								
								.github/workflows/e2e-test.bak
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										159
									
								
								.github/workflows/e2e-test.bak
									
									
									
									
										vendored
									
									
								
							| @ -1,159 +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. | ||||
| 
 | ||||
| name: OpenIM E2E And API Test | ||||
| 
 | ||||
| on: | ||||
|   workflow_dispatch: | ||||
|   pull_request: | ||||
|   push: | ||||
|   schedule: | ||||
|     # run e2e test every 4 hours | ||||
|     - cron: 0 */4 * * * | ||||
| 
 | ||||
| env: | ||||
|   CALLBACK_ENABLE: true | ||||
| 
 | ||||
| jobs: | ||||
|   build: | ||||
|     name: Test | ||||
|     runs-on: ubuntu-latest | ||||
|     env: | ||||
|       GO111MODULE: on | ||||
|     steps: | ||||
| 
 | ||||
|       - name: Set up Go 1.21 | ||||
|         uses: actions/setup-go@v5 | ||||
|         with: | ||||
|           go-version: 1.21 | ||||
|         id: go | ||||
| 
 | ||||
|       - name: Check out code into the Go module directory | ||||
|         uses: actions/checkout@v4 | ||||
| 
 | ||||
|       - name: Create e2e test | ||||
|         run: | | ||||
|           echo "...test e2e" | ||||
| 
 | ||||
|   execute-linux-systemd-scripts: | ||||
|     name: Execute OpenIM script on ${{ matrix.os }} | ||||
|     runs-on: ${{ matrix.os }} | ||||
|     environment: | ||||
|       name: openim | ||||
|     strategy: | ||||
|       matrix: | ||||
|         go_version: ["1.20"] | ||||
|         os: ["ubuntu-latest"] | ||||
|     steps: | ||||
|     - name: Checkout code | ||||
|       uses: actions/checkout@v4 | ||||
| 
 | ||||
|     - name: Set up Go ${{ matrix.go_version }} | ||||
|       uses: actions/setup-go@v5 | ||||
|       with: | ||||
|         go-version: ${{ matrix.go_version }} | ||||
|       id: go | ||||
| 
 | ||||
|     - name: Install Task | ||||
|       uses: arduino/setup-task@v1 | ||||
|       with: | ||||
|         version: '3.x' # If available, use the latest major version that's compatible | ||||
|         repo-token: ${{ secrets.GITHUB_TOKEN }} | ||||
| 
 | ||||
|     - name: Docker Operations | ||||
|       run: | | ||||
|         sudo docker compose up -d | ||||
|         sudo bash bootstrap.sh | ||||
|         sudo mage | ||||
|         sudo sleep 20 | ||||
| 
 | ||||
|     - name: Module Operations | ||||
|       run: | | ||||
|         echo "===========> Verifying go-gitlint is installed" | ||||
|         if [ ! -f ./_output/tools/go-gitlint ]; then | ||||
|           export GOBIN=$(pwd)/_output/tools | ||||
|           echo "===========> Installing The default installation path is /home/ubuntu/DF/open-im-server/_output/tools/go-gitlint" | ||||
|           sudo go install github.com/marmotedu/go-gitlint/cmd/go-gitlint@latest | ||||
|           echo "===========> go-gitlint is installed in /home/ubuntu/DF/open-im-server/_output/tools/go-gitlint" | ||||
|         fi | ||||
| 
 | ||||
|     - name: Build, Start(make build && make start) | ||||
|       run: | | ||||
|         sudo ./scripts/install/install.sh -i | ||||
| 
 | ||||
|     - name: Exec OpenIM System Status Chack | ||||
|       run: | | ||||
|         sudo ./scripts/install/install.sh -s | ||||
| 
 | ||||
| #    - name: Exec OpenIM API test (make test-api) | ||||
|     - name: Exec OpenIM test (make test) | ||||
|       run: | | ||||
|         mkdir -p ./tmp | ||||
|         touch ./tmp/test.md | ||||
|         echo "# OpenIM Test" >> ./tmp/test.md | ||||
|         echo "## OpenIM API Test" >> ./tmp/test.md | ||||
|         echo "<details><summary>Command Output for OpenIM API Test</summary>" >> ./tmp/test.md | ||||
|         echo "<pre><code>" >> ./tmp/test.md | ||||
|         echo "===========> Run api test" | ||||
|         ./scripts/install/test.sh | ||||
|         echo "===========> Run api test" >> ./tmp/test.md | ||||
|         ./scripts/install/test.sh >> ./tmp/test.md | ||||
|         echo "</code></pre>" >> ./tmp/test.md | ||||
|         echo "</details>" >> ./tmp/test.md | ||||
| 
 | ||||
|         echo "===========> Run api test" | ||||
|         ./scripts/install/test.sh | ||||
| 
 | ||||
|  #   - name: Exec OpenIM E2E Test (make test-e2e) | ||||
|  #     run: | | ||||
|  #       echo "" >> ./tmp/test.md | ||||
|  #       echo "## OpenIM E2E Test" >> ./tmp/test.md | ||||
|  #       echo "<details><summary>Command Output for OpenIM E2E Test</summary>" >> ./tmp/test.md | ||||
|  #       echo "<pre><code>" >> ./tmp/test.md | ||||
|  #       sudo make test-e2e | tee -a ./tmp/test.md | ||||
|  #       echo "</code></pre>" >> ./tmp/test.md | ||||
|  #       echo "</details>" >> ./tmp/test.md | ||||
| 
 | ||||
|  #       sudo make test-e2e | ||||
| 
 | ||||
|     - name: Comment PR with file | ||||
|       uses: thollander/actions-comment-pull-request@v2 | ||||
|       with: | ||||
|         filePath: ./tmp/test.md | ||||
|         comment_tag: nrt_file | ||||
|         reactions: eyes, rocket | ||||
|         mode: recreate | ||||
|         GITHUB_TOKEN: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
|       continue-on-error: true | ||||
| 
 | ||||
|     - name: Check outputs | ||||
|       run: | | ||||
|         echo "id : ${{ steps.nrt_message.outputs.id }}" | ||||
|         echo "body : ${{ steps.nrt_message.outputs.body }}" | ||||
|         echo "html_url : ${{ steps.nrt_message.outputs.html_url }}" | ||||
| 
 | ||||
|     - name: Exec OpenIM System uninstall | ||||
|       run: | | ||||
|         sudo ./scripts/install/install.sh -u | ||||
| 
 | ||||
|     - name: gobenchdata publish | ||||
|       uses: bobheadxi/gobenchdata@v1 | ||||
|       with: | ||||
|         PRUNE_COUNT: 30 | ||||
|         GO_TEST_FLAGS: -cpu 1,2 | ||||
|         PUBLISH: true | ||||
|         PUBLISH_BRANCH: gh-pages | ||||
|       env: | ||||
|         GITHUB_TOKEN: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
|       continue-on-error: true | ||||
							
								
								
									
										197
									
								
								.github/workflows/go-build-test.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										197
									
								
								.github/workflows/go-build-test.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,197 @@ | ||||
| name: Go Build Test | ||||
| 
 | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - main | ||||
|   pull_request: | ||||
|     branches: | ||||
|       - main | ||||
|     paths-ignore: | ||||
|       - '**/*.md' | ||||
| 
 | ||||
|   workflow_dispatch: | ||||
| 
 | ||||
| jobs: | ||||
|   go-build: | ||||
|     name: Test with go ${{ matrix.go_version }} on ${{ matrix.os }} | ||||
|     runs-on: ${{ matrix.os }} | ||||
|     permissions: | ||||
|       contents: write | ||||
|       pull-requests: write | ||||
|     strategy: | ||||
|       matrix: | ||||
|         os: [ubuntu-latest] | ||||
|         go_version: ["1.21.x", "1.22.x"] | ||||
| 
 | ||||
|     steps: | ||||
|       - name: Checkout Server repository | ||||
|         uses: actions/checkout@v4 | ||||
| 
 | ||||
|       - name: Set up Go ${{ matrix.go_version }} | ||||
|         uses: actions/setup-go@v5 | ||||
|         with: | ||||
|           go-version: ${{ matrix.go_version }} | ||||
| 
 | ||||
|       - name: Get Server dependencies | ||||
|         run: | | ||||
|           go install github.com/magefile/mage@latest | ||||
|           go mod tidy | ||||
|           go mod download | ||||
| 
 | ||||
|       - name: Set up infra services | ||||
|         uses: hoverkraft-tech/compose-action@v2.0.1 | ||||
|         # Uncomment and set the correct path to your docker-compose file | ||||
|         with: | ||||
|           compose-file: "./docker-compose.yml" | ||||
| 
 | ||||
|         # run: | | ||||
|         #   sudo docker compose up -d | ||||
|         #   sudo sleep 30  # Increased sleep time for better stability | ||||
|         # timeout-minutes: 60 # Increased timeout for Docker setup | ||||
| 
 | ||||
| 
 | ||||
|     # - name: Get Internal IP Address | ||||
|     #   id: get-ip | ||||
|     #   run: | | ||||
|     #     IP=$(hostname -I | awk '{print $1}') | ||||
|     #     echo "The IP Address is: $IP" | ||||
|     #     echo "::set-output name=ip::$IP" | ||||
|        | ||||
|     # - name: Update .env | ||||
|     #   run: | | ||||
|     #     sed -i 's|externalAddress:.*|externalAddress: "http://${{ steps.get-ip.outputs.ip }}:10005"|' config/minio.yml | ||||
|     #     cat config/minio.yml | ||||
| 
 | ||||
|       - name: Build and test Server Services | ||||
|         run: | | ||||
|           mage build | ||||
|           mage start | ||||
|           mage check | ||||
| 
 | ||||
|       - name: Checkout Chat repository | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           repository: "openimsdk/chat" | ||||
|           path: "chat-repo" | ||||
| 
 | ||||
|       - name: Get Chat dependencies | ||||
|         run: | | ||||
|           cd ${{ github.workspace }}/chat-repo | ||||
|           go mod tidy | ||||
|           go mod download | ||||
|           go install github.com/magefile/mage@latest | ||||
| 
 | ||||
|       - name: Build and test Chat Services | ||||
|         run: | | ||||
|           cd ${{ github.workspace }}/chat-repo | ||||
|           mage build | ||||
|           mage start | ||||
|           mage check | ||||
| 
 | ||||
|   go-test: | ||||
|     name: Benchmark Test with go ${{ matrix.go_version }} on ${{ matrix.os }} | ||||
|     runs-on: ${{ matrix.os }} | ||||
|     permissions: | ||||
|       contents: write | ||||
|     env: | ||||
|       SDK_DIR: openim-sdk-core | ||||
|       CONFIG_PATH: config/notification.yml | ||||
|     #   pull-requests: write | ||||
|     strategy: | ||||
|       matrix: | ||||
|         os: [ ubuntu-latest ] | ||||
|         go_version: [ "1.22.x" ] | ||||
| 
 | ||||
|     steps: | ||||
|       - name: Checkout Server repository | ||||
|         uses: actions/checkout@v4 | ||||
| 
 | ||||
|       - name: Checkout SDK repository | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           repository: 'openimsdk/openim-sdk-core' | ||||
|           path: ${{ env.SDK_DIR }} | ||||
| 
 | ||||
|       - name: Set up Go ${{ matrix.go_version }} | ||||
|         uses: actions/setup-go@v5 | ||||
|         with: | ||||
|           go-version: ${{ matrix.go_version }} | ||||
| 
 | ||||
|       - name: Get Server dependencies | ||||
|         run: | | ||||
|           go install github.com/magefile/mage@latest | ||||
|           go mod download | ||||
| 
 | ||||
|       - name: Install yq | ||||
|         run: | | ||||
|           sudo wget https://github.com/mikefarah/yq/releases/download/v4.34.1/yq_linux_amd64 -O /usr/bin/yq | ||||
|           sudo chmod +x /usr/bin/yq | ||||
| 
 | ||||
|       - name: Modify Server Configuration | ||||
|         run: | | ||||
|           yq e '.groupCreated.unreadCount = true' -i ${{ env.CONFIG_PATH }} | ||||
|           yq e '.friendApplicationApproved.unreadCount = true' -i ${{ env.CONFIG_PATH }} | ||||
| 
 | ||||
|       - name: Start Server Services | ||||
|         run: | | ||||
|           docker compose up -d | ||||
|           mage build | ||||
|           mage start | ||||
|           mage check | ||||
| 
 | ||||
|       - name: Build test SDK core | ||||
|         run: | | ||||
|           cd ${{ env.SDK_DIR }} | ||||
|           go mod tidy | ||||
|           cd integration_test | ||||
|           mkdir data | ||||
|           go run main.go -lgr 0.8 -imf -crg -ckgn -ckcon -sem -ckmsn -u 20 -su 5 -lg 2 -cg 2 -cgm 3 -sm 10 -gm 10 -reg | ||||
| 
 | ||||
|   dockerfile-test: | ||||
|     name: Build and Test Dockerfile | ||||
|     runs-on: ubuntu-latest | ||||
|     strategy: | ||||
|       matrix: | ||||
|         go_version: ["1.21"] | ||||
| 
 | ||||
|     steps: | ||||
|       - name: Checkout Repository | ||||
|         uses: actions/checkout@v4 | ||||
| 
 | ||||
|       - name: Set up Go ${{ matrix.go_version }} | ||||
|         uses: actions/setup-go@v5 | ||||
|         with: | ||||
|           go-version: ${{ matrix.go_version }} | ||||
| 
 | ||||
|       - name: Get dependencies | ||||
|         run: | | ||||
|           go mod tidy | ||||
|           go mod download | ||||
|           go install github.com/magefile/mage@latest | ||||
| 
 | ||||
|       - name: Build Docker Image | ||||
|         run: | | ||||
|           IMAGE_NAME="${{ github.event.repository.name }}-test" | ||||
|           CONTAINER_NAME="${{ github.event.repository.name }}-container" | ||||
|           docker build -t $IMAGE_NAME . | ||||
| 
 | ||||
|       - name: Run Docker Container | ||||
|         run: | | ||||
|           IMAGE_NAME="${{ github.event.repository.name }}-test" | ||||
|           CONTAINER_NAME="${{ github.event.repository.name }}-container" | ||||
|           docker run --name $CONTAINER_NAME -d $IMAGE_NAME | ||||
|           docker ps -a | ||||
| 
 | ||||
|       - name: Test Docker Container Logs | ||||
|         run: | | ||||
|           CONTAINER_NAME="${{ github.event.repository.name }}-container" | ||||
|           docker logs $CONTAINER_NAME | ||||
| 
 | ||||
|       # - name: Cleanup Docker Container | ||||
|       #   run: | | ||||
|       #     CONTAINER_NAME="${{ github.event.repository.name }}-container" | ||||
|       #     IMAGE_NAME="${{ github.event.repository.name }}-test" | ||||
|       #     docker stop $CONTAINER_NAME | ||||
|       #     docker rm $CONTAINER_NAME | ||||
|       #     docker rmi $IMAGE_NAME | ||||
							
								
								
									
										58
									
								
								.github/workflows/golangci-lint.bak
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										58
									
								
								.github/workflows/golangci-lint.bak
									
									
									
									
										vendored
									
									
								
							| @ -1,58 +0,0 @@ | ||||
| # Copyright © 2023 OpenIM open source community. 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. | ||||
| 
 | ||||
| 
 | ||||
| name: OpenIM golangci-lint | ||||
| on: | ||||
|   push: | ||||
|     branches: [main] | ||||
|   pull_request: | ||||
| jobs: | ||||
|     golangci: | ||||
|       name: lint | ||||
|       runs-on: ubuntu-latest | ||||
|       steps: | ||||
|         - uses: actions/checkout@v4 | ||||
|         - uses: actions/setup-go@v5 | ||||
|           with: | ||||
|             go-version: '1.21' | ||||
|             cache: false | ||||
|         - name: OpenIM Scripts Verification(make verify) | ||||
|           run: | | ||||
|             cd scripts | ||||
|             for script in verify-*; do | ||||
|               if [ -x "$script" ]; then | ||||
|                 ./"$script" | ||||
|               fi | ||||
|             done | ||||
|         - name: golangci-lint | ||||
|           uses: golangci/golangci-lint-action@v4.0.0 | ||||
|           with: | ||||
|             # Require: version of golangci-lint to use in form of v1.2 or v1.2.3 or `latest` to use the latest version | ||||
|             version: v1.54 | ||||
| 
 | ||||
|             # Optional: working directory, useful for monorepos | ||||
|             # working-directory: server | ||||
| 
 | ||||
|             # Optional: golangci-lint command line arguments. | ||||
|             #  | ||||
|             # Note: by default the `.golangci.yml` file should be at the root of the repository. | ||||
|             # The location of the configuration file can be changed by using `--config=` | ||||
|             # args: --timeout=30m --config=/scripts/.golangci.yml --issues-exit-code=0 | ||||
| 
 | ||||
|             # Optional: show only new issues if it's a pull request. The default value is `false`. | ||||
|             only-new-issues: true | ||||
| 
 | ||||
|             # Optional:The mode to install golangci-lint. It can be 'binary' or 'goinstall'. | ||||
|             # install-mode: "goinstall" | ||||
							
								
								
									
										45
									
								
								.github/workflows/gosec.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										45
									
								
								.github/workflows/gosec.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,45 +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. | ||||
| 
 | ||||
| name: OpenIM Run Gosec | ||||
| 
 | ||||
| # gosec is a source code security audit tool for the Go language. It performs a static  | ||||
| # analysis of the Go code, looking for potential security problems. The main functions of gosec are: | ||||
| #     1. Find common security vulnerabilities, such as SQL injection, command injection, and cross-site scripting (XSS). | ||||
| #     2. Audit codes according to common security standards and find non-standard codes. | ||||
| #     3. Assist the Go language engineer to write safe and reliable code. | ||||
| # https://github.com/securego/gosec/ | ||||
| on: | ||||
|   push: | ||||
|     branches: "*" | ||||
|   pull_request: | ||||
|     branches: "*" | ||||
|     paths-ignore: | ||||
|       - '*.md' | ||||
|       - '*.yml' | ||||
|       - '.github' | ||||
| 
 | ||||
| jobs: | ||||
|   golang-security-action: | ||||
|     runs-on: ubuntu-latest | ||||
|     env: | ||||
|       GO111MODULE: on | ||||
|     steps: | ||||
|       - name: Check out code | ||||
|         uses: actions/checkout@v4 | ||||
|       - name: Run Gosec Security Scanner | ||||
|         uses: securego/gosec@master | ||||
|         with: | ||||
|           args: ./... | ||||
|         continue-on-error: true | ||||
							
								
								
									
										2
									
								
								.github/workflows/help-comment-issue.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/help-comment-issue.yml
									
									
									
									
										vendored
									
									
								
							| @ -29,7 +29,7 @@ jobs: | ||||
|         uses: peter-evans/create-or-update-comment@v4 | ||||
|         with: | ||||
|           issue-number: ${{ github.event.issue.number }} | ||||
|           token: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
|           token: ${{ secrets.BOT_TOKEN }} | ||||
|           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: | ||||
|             [Join slack 🤖](https://join.slack.com/t/openimsdk/shared_invite/zt-22720d66b-o_FvKxMTGXtcnnnHiMqe9Q) to connect and communicate with our developers. | ||||
|  | ||||
							
								
								
									
										31
									
								
								.github/workflows/issue-robot.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										31
									
								
								.github/workflows/issue-robot.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,31 +0,0 @@ | ||||
| # Copyright © 2023 OpenIM open source community. 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. | ||||
| 
 | ||||
| name: OpenIM Issue Aotu Translator | ||||
| on: | ||||
|   issue_comment: | ||||
|     types: [created] | ||||
|   issues: | ||||
|     types: [opened] | ||||
| 
 | ||||
| jobs: | ||||
|   build: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: usthe/issues-translate-action@v2.7 | ||||
|         with: | ||||
|           # it is not necessary to decide whether you need to modify the issue header content | ||||
|           IS_MODIFY_TITLE: true | ||||
|           BOT_GITHUB_TOKEN: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
|           # Required, input your bot github token | ||||
							
								
								
									
										19
									
								
								.github/workflows/issue-translator.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								.github/workflows/issue-translator.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,19 @@ | ||||
| name: 'issue-translator' | ||||
| on:  | ||||
|   issue_comment:  | ||||
|     types: [created] | ||||
|   issues:  | ||||
|     types: [opened] | ||||
| 
 | ||||
| jobs: | ||||
|   build: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: usthe/issues-translate-action@v2.7 | ||||
|         with: | ||||
|           BOT_GITHUB_TOKEN: ${{ secrets.BOT_TOKEN }}  | ||||
|           IS_MODIFY_TITLE: true | ||||
|           # not require, default false, . Decide whether to modify the issue title | ||||
|           # if true, the robot account @Issues-translate-bot must have modification permissions, invite @Issues-translate-bot to your project or use your custom bot. | ||||
|           CUSTOM_BOT_NOTE: Bot detected the issue body's language is not English, translate it automatically. 👯👭🏻🧑🤝🧑👫🧑🏿🤝🧑🏻👩🏾🤝👨🏿👬🏿 | ||||
|           # not require. Customize the translation robot prefix message. | ||||
							
								
								
									
										65
									
								
								.github/workflows/lock-issue.bak
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										65
									
								
								.github/workflows/lock-issue.bak
									
									
									
									
										vendored
									
									
								
							| @ -1,65 +0,0 @@ | ||||
| # Copyright © 2023 OpenIM open source community. 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. | ||||
| 
 | ||||
| name: 'Lock Threads' | ||||
| 
 | ||||
| on: | ||||
|   schedule: | ||||
|     - cron: '0 * * * *' | ||||
|   workflow_dispatch: | ||||
| 
 | ||||
| permissions: | ||||
|   issues: write | ||||
|   pull-requests: write | ||||
| 
 | ||||
| concurrency: | ||||
|   group: lock | ||||
| 
 | ||||
| jobs: | ||||
|   action: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: dessant/lock-threads@v5 | ||||
|         with: | ||||
|           github-token: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
|           issue-inactive-days: '365' | ||||
|           exclude-issue-created-before: '' | ||||
|           exclude-issue-created-after: '' | ||||
|           exclude-issue-created-between: '' | ||||
|           exclude-issue-closed-before: '' | ||||
|           exclude-issue-closed-after: '' | ||||
|           exclude-issue-closed-between: '' | ||||
|           include-any-issue-labels: '' | ||||
|           include-all-issue-labels: '' | ||||
|           exclude-any-issue-labels: '' | ||||
|           add-issue-labels: '' | ||||
|           remove-issue-labels: '' | ||||
|           issue-comment: '' | ||||
|           issue-lock-reason: 'resolved' | ||||
|           pr-inactive-days: '365' | ||||
|           exclude-pr-created-before: '' | ||||
|           exclude-pr-created-after: '' | ||||
|           exclude-pr-created-between: '' | ||||
|           exclude-pr-closed-before: '' | ||||
|           exclude-pr-closed-after: '' | ||||
|           exclude-pr-closed-between: '' | ||||
|           include-any-pr-labels: '' | ||||
|           include-all-pr-labels: '' | ||||
|           exclude-any-pr-labels: '' | ||||
|           add-pr-labels: '' | ||||
|           remove-pr-labels: '' | ||||
|           pr-comment: '' | ||||
|           pr-lock-reason: 'resolved' | ||||
|           process-only: '' | ||||
|           log-output: false | ||||
							
								
								
									
										74
									
								
								.github/workflows/milestone.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										74
									
								
								.github/workflows/milestone.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,74 +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. | ||||
| 
 | ||||
| # shamelessly copied from https://github.com/sigstore/cosign/blob/main/.github/workflows/milestone.yaml | ||||
| 
 | ||||
| name: milestone | ||||
| 
 | ||||
| on: | ||||
|   pull_request_target: | ||||
|     types: [closed] | ||||
|     branches: | ||||
|       - main | ||||
| 
 | ||||
| jobs: | ||||
|   milestone: | ||||
|     runs-on: ubuntu-latest | ||||
| 
 | ||||
|     permissions: | ||||
|       actions: none | ||||
|       checks: none | ||||
|       contents: read | ||||
|       deployments: none | ||||
|       issues: write | ||||
|       packages: none | ||||
|       pull-requests: write | ||||
|       repository-projects: none | ||||
|       security-events: none | ||||
|       statuses: none | ||||
| 
 | ||||
|     steps: | ||||
|       - uses: actions/github-script@v7 # v6 | ||||
|         with: | ||||
|           github-token: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
|           script: | | ||||
|             if (!context.payload.pull_request.merged) { | ||||
|               console.log('PR was not merged, skipping.'); | ||||
|               return; | ||||
|             } | ||||
| 
 | ||||
|             if (!!context.payload.pull_request.milestone) { | ||||
|               console.log('PR has existing milestone, skipping.'); | ||||
|               return; | ||||
|             } | ||||
| 
 | ||||
|             milestones = await github.rest.issues.listMilestones({ | ||||
|               owner: context.repo.owner, | ||||
|               repo: context.repo.repo, | ||||
|               state: 'open', | ||||
|               sort: 'title', | ||||
|               direction: 'desc' | ||||
|             }) | ||||
| 
 | ||||
|             if (milestones.data.length === 0) { | ||||
|               console.log('There are no milestones, skipping.'); | ||||
|               return; | ||||
|             } | ||||
| 
 | ||||
|             await github.rest.issues.update({ | ||||
|               owner: context.repo.owner, | ||||
|               repo: context.repo.repo, | ||||
|               issue_number: context.payload.pull_request.number, | ||||
|               milestone: milestones.data[0].number | ||||
|             }); | ||||
							
								
								
									
										55
									
								
								.github/workflows/opencommit.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										55
									
								
								.github/workflows/opencommit.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,55 +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. | ||||
| 
 | ||||
| name: OpenIM OpenCommit Action | ||||
| 
 | ||||
| on: | ||||
|   push: | ||||
|     # this list of branches is often enough, | ||||
|     # but you may still ignore other public branches | ||||
|     branches-ignore: [main master dev development release] | ||||
| 
 | ||||
| jobs: | ||||
|   opencommit: | ||||
|     timeout-minutes: 10 | ||||
|     name: OpenCommit | ||||
|     runs-on: ubuntu-latest | ||||
|     permissions: write-all | ||||
|     steps: | ||||
|       - name: Setup Node.js Environment | ||||
|         uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           node-version: '16' | ||||
|       - uses: actions/checkout@v4 | ||||
|         with: | ||||
|           fetch-depth: 0 | ||||
|       - uses: di-sukharev/opencommit@github-action-v1.0.4 | ||||
|         with: | ||||
|           GITHUB_TOKEN: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
| 
 | ||||
|         env: | ||||
|           # set openAI api key in repo actions secrets, | ||||
|           # for openAI keys go to: https://platform.openai.com/account/api-keys | ||||
|           # for repo secret go to: <your_repo_url>/settings/secrets/actions | ||||
|           OCO_OPENAI_API_KEY: ${{ secrets.OPENAI_API_KEY }} | ||||
| 
 | ||||
|           # customization | ||||
|           OCO_OPENAI_MAX_TOKENS: 500 | ||||
|           OCO_OPENAI_BASE_PATH: '' | ||||
|           OCO_DESCRIPTION: false | ||||
|           OCO_EMOJI: false | ||||
|           OCO_MODEL: gpt-3.5-turbo-16k | ||||
|           OCO_LANGUAGE: en | ||||
|           OCO_PROMPT_MODULE: conventional-commit | ||||
|         continue-on-error: true | ||||
							
								
								
									
										135
									
								
								.github/workflows/openimci.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										135
									
								
								.github/workflows/openimci.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,135 +0,0 @@ | ||||
| 
 | ||||
| # Copyright © 2023 OpenIM open source community. 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. | ||||
| name: OpenIM CI Auto Build | ||||
| 
 | ||||
| on:  | ||||
|   push: | ||||
|     branches: | ||||
|         - main | ||||
|         - release-* | ||||
|     paths-ignore: | ||||
|         - "docs/**" | ||||
|         - "README.md" | ||||
|         - "README_zh-CN.md" | ||||
|         - "**.md" | ||||
|         - "docs/**" | ||||
|         - "CONTRIBUTING.md" | ||||
|   pull_request: | ||||
|     branches: | ||||
|         - main | ||||
|         - release-* | ||||
|     paths-ignore: | ||||
|         - "README.md" | ||||
|         - "README_zh-CN.md" | ||||
|         - "CONTRIBUTING/**" | ||||
|         - "**.md" | ||||
|         - "docs/**" | ||||
|   workflow_dispatch: | ||||
| 
 | ||||
| jobs: | ||||
| 
 | ||||
|   build-linux: | ||||
|     name: Execute OpenIM Script On Linux | ||||
|     runs-on: ubuntu-latest | ||||
|     permissions: | ||||
|       contents: write | ||||
|       pull-requests: write | ||||
|     environment: | ||||
|       name: openim | ||||
|     strategy: | ||||
|       matrix: | ||||
|         arch: [arm64, armv7, amd64] | ||||
|      | ||||
|     steps: | ||||
|     - uses: actions/checkout@v3 | ||||
| 
 | ||||
|     - name: Set up Go | ||||
|       uses: actions/setup-go@v4 | ||||
|       with: | ||||
|         go-version: '1.21' | ||||
| 
 | ||||
|     - name: Set up Docker for Linux | ||||
|       run: | | ||||
|         sudo docker compose up -d | ||||
|         sudo sleep 30  # Increased sleep time for better stability | ||||
|       timeout-minutes: 20  # Increased timeout for Docker setup | ||||
| 
 | ||||
| 
 | ||||
|     - name: init | ||||
|       run: sudo bash bootstrap.sh | ||||
|       timeout-minutes: 20 | ||||
| 
 | ||||
|     # - name: Get Internal IP Address | ||||
|     #   id: get-ip | ||||
|     #   run: | | ||||
|     #     IP=$(hostname -I | awk '{print $1}') | ||||
|     #     echo "The IP Address is: $IP" | ||||
|     #     echo "::set-output name=ip::$IP" | ||||
|        | ||||
|     # - name: Update .env | ||||
|     #   run: | | ||||
|     #     sed -i 's|externalAddress:.*|externalAddress: "http://${{ steps.get-ip.outputs.ip }}:10005"|' config/minio.yml | ||||
|     #     cat config/minio.yml | ||||
| 
 | ||||
|     - name: Build, Start, Check Services and Print Logs for Linux | ||||
|       run: | | ||||
|         sudo mage | ||||
|         sudo mage start | ||||
|         sudo mage check | ||||
|          | ||||
| 
 | ||||
|     - name: Restart Services and Print Logs | ||||
|       run: | | ||||
|         sudo mage stop | ||||
|         sudo mage start | ||||
|         sudo mage check | ||||
| 
 | ||||
|     - name: Checkout chat repository | ||||
|       uses: actions/checkout@v4 | ||||
|       with: | ||||
|         repository: 'openimsdk/chat' | ||||
|         path: 'chat-repo' | ||||
| 
 | ||||
|     - name: Build and Start Chat Services | ||||
|       run: | | ||||
|         cd ${{ github.workspace }}/chat-repo | ||||
|         sudo mage | ||||
|         sudo mage start | ||||
|         sudo mage check | ||||
|      | ||||
|     # - name: Checkout e2e repository | ||||
|     #   uses: actions/checkout@v4 | ||||
|     #   with: | ||||
|     #       repository: "openimsdk/test-e2e" | ||||
|     #       path: e2e-repo | ||||
| 
 | ||||
|     # - name: Set up Python 3.9 | ||||
|     #   uses: actions/setup-python@v4 | ||||
|     #   with: | ||||
|     #     python-version: '3.9' | ||||
|      | ||||
|     # - name: Install dependencies | ||||
|     #   run: | | ||||
|     #     sudo apt-get update | ||||
|     #     sudo apt-get install -y xvfb libxi6 libgconf-2-4 | ||||
|     #     cd ${{ github.workspace }}/e2e-repo | ||||
|     #     pip install -r requirements.txt | ||||
|      | ||||
|     # - name: Run tests | ||||
|     #   run: | | ||||
|     #     cd ${{ github.workspace }}/e2e-repo | ||||
|     #     xvfb-run --auto-servernum --server-args='-screen 0 1920x1080x24' pytest -v -s ./script | ||||
|      | ||||
|      | ||||
							
								
								
									
										39
									
								
								.github/workflows/project-progress.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										39
									
								
								.github/workflows/project-progress.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,39 +0,0 @@ | ||||
| # Copyright © 2023 OpenIM open source community. 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. | ||||
| 
 | ||||
| # GitHub recommends pinning actions to a commit SHA. | ||||
| # To get a newer version, you will need to update the SHA. | ||||
| # You can also reference a tag or branch, but the action may change without warning. | ||||
| 
 | ||||
| name: Move assigned card | ||||
| on: | ||||
|   issues: | ||||
|     types: | ||||
|       - assigned | ||||
|   pull_request: | ||||
|     types:  | ||||
|       - assigned | ||||
|     branches-ignore: | ||||
|       - 'asf-auto-updates' | ||||
|       - 'ignore' | ||||
| 
 | ||||
| jobs: | ||||
|   move-assigned-card: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: alex-page/github-project-automation-plus@v0.9.0 | ||||
|         with: | ||||
|           project: openim-powerful | ||||
|           column: In Progress | ||||
|           repo-token: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
							
								
								
									
										150
									
								
								.github/workflows/publish-docker-image.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										150
									
								
								.github/workflows/publish-docker-image.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,150 @@ | ||||
| name: Publish Docker image to registries | ||||
| 
 | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - release-* | ||||
|     # tags: | ||||
|     #   - 'v*' | ||||
| 
 | ||||
|   release: | ||||
|     types: [published] | ||||
| 
 | ||||
|   workflow_dispatch: | ||||
|     inputs: | ||||
|       tag: | ||||
|         description: "Tag version to be used for Docker image" | ||||
|         required: true | ||||
|         default: "v3.8.0" | ||||
| 
 | ||||
| jobs: | ||||
|   build-and-test: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|         with: | ||||
|           path: main-repo | ||||
| 
 | ||||
|       - name: Set up QEMU | ||||
|         uses: docker/setup-qemu-action@v3 | ||||
| 
 | ||||
|       - name: Set up Docker Buildx | ||||
|         uses: docker/setup-buildx-action@v3 | ||||
| 
 | ||||
|       - name: Build Docker image | ||||
|         id: build | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: ./main-repo | ||||
|           load: true | ||||
|           tags: "openim/openim-server:local" | ||||
|           cache-from: type=gha | ||||
|           cache-to: type=gha,mode=max | ||||
| 
 | ||||
|       - name: Save Docker image to file | ||||
|         run: docker save -o image.tar openim/openim-server:local | ||||
| 
 | ||||
|       - name: Checkout compose repository | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           repository: "openimsdk/openim-docker" | ||||
|           path: "compose-repo" | ||||
| 
 | ||||
|       - name: Get Internal IP Address | ||||
|         id: get-ip | ||||
|         run: | | ||||
|           IP=$(hostname -I | awk '{print $1}') | ||||
|           echo "The IP Address is: $IP" | ||||
|           echo "::set-output name=ip::$IP" | ||||
| 
 | ||||
|       - name: Update .env to use the local image | ||||
|         run: | | ||||
|           sed -i 's|OPENIM_SERVER_IMAGE=.*|OPENIM_SERVER_IMAGE=openim/openim-server:local|' ${{ github.workspace }}/compose-repo/.env | ||||
|           sed -i 's|MINIO_EXTERNAL_ADDRESS=.*|MINIO_EXTERNAL_ADDRESS=http://${{ steps.get-ip.outputs.ip }}:10005|' ${{ github.workspace }}/compose-repo/.env | ||||
| 
 | ||||
|       - name: Start services using Docker Compose | ||||
|         run: | | ||||
|           cd ${{ github.workspace }}/compose-repo | ||||
|           docker compose up -d | ||||
|           sleep 60 | ||||
| 
 | ||||
|       # - name: Check openim-server health | ||||
|       #   run: | | ||||
|       #     timeout=300 | ||||
|       #     interval=30 | ||||
|       #     elapsed=0 | ||||
|       #     while [[ $elapsed -le $timeout ]]; do | ||||
|       #       if ! docker exec openim-server mage check; then | ||||
|       #         echo "openim-server is not ready, waiting..." | ||||
|       #         sleep $interval | ||||
|       #         elapsed=$(($elapsed + $interval)) | ||||
|       #       else | ||||
|       #         echo "Health check successful" | ||||
|       #         exit 0 | ||||
|       #       fi | ||||
|       #     done | ||||
|       #     echo "Health check failed after 5 minutes" | ||||
|       #     exit 1 | ||||
| 
 | ||||
|       # - name: Check openim-chat health | ||||
|       #   if: success() | ||||
|       #   run: | | ||||
|       #     if ! docker exec openim-chat mage check; then | ||||
|       #         echo "openim-chat check failed" | ||||
|       #         exit 1 | ||||
|       #       else | ||||
|       #         echo "Health check successful" | ||||
|       #         exit 0 | ||||
|       #       fi | ||||
| 
 | ||||
|       - name: Load Docker image from file | ||||
|         run: docker load -i image.tar | ||||
| 
 | ||||
|       - name: Extract metadata for Docker (tags, labels) | ||||
|         id: meta | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         with: | ||||
|           images: | | ||||
|             openim/openim-server | ||||
|             ghcr.io/openimsdk/openim-server | ||||
|             registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-server | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern={{major}} | ||||
|             type=semver,pattern=release-{{raw}} | ||||
|             type=sha | ||||
|             type=raw,value=${{ github.event.inputs.tag }} | ||||
| 
 | ||||
|       - name: Log in to Docker Hub | ||||
|         uses: docker/login-action@v2 | ||||
|         with: | ||||
|           username: ${{ secrets.DOCKER_USERNAME }} | ||||
|           password: ${{ secrets.DOCKER_PASSWORD }} | ||||
| 
 | ||||
|       - name: Log in to GitHub Container Registry | ||||
|         uses: docker/login-action@v2 | ||||
|         with: | ||||
|           registry: ghcr.io | ||||
|           username: ${{ github.repository_owner }} | ||||
|           password: ${{ secrets.GITHUB_TOKEN }} | ||||
| 
 | ||||
|       - name: Log in to Aliyun Container Registry | ||||
|         uses: docker/login-action@v2 | ||||
|         with: | ||||
|           registry: registry.cn-hangzhou.aliyuncs.com | ||||
|           username: ${{ secrets.ALIREGISTRY_USERNAME }} | ||||
|           password: ${{ secrets.ALIREGISTRY_TOKEN }} | ||||
| 
 | ||||
|       - name: Push Docker images | ||||
|         uses: docker/build-push-action@v5 | ||||
|         with: | ||||
|           context: ./main-repo | ||||
|           push: true | ||||
|           platforms: linux/amd64,linux/arm64 | ||||
|           tags: ${{ steps.meta.outputs.tags }} | ||||
|           labels: ${{ steps.meta.outputs.labels }} | ||||
							
								
								
									
										130
									
								
								.github/workflows/pull-request.bak
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										130
									
								
								.github/workflows/pull-request.bak
									
									
									
									
										vendored
									
									
								
							| @ -1,130 +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. | ||||
| 
 | ||||
| name: Github Pull Request | ||||
| on: | ||||
|   workflow_dispatch: | ||||
|   schedule: | ||||
|     - cron: '0 2 * * *' | ||||
| 
 | ||||
| permissions: | ||||
|   contents: write | ||||
|   pull-requests: write | ||||
| 
 | ||||
| jobs: | ||||
|   build: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: checkout | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           fetch-depth: 0 | ||||
| 
 | ||||
|       - uses: actions/setup-node@v4 | ||||
|       - name: Setup Go | ||||
|         uses: actions/setup-go@v5 | ||||
|       - name: Run go modules tidy | ||||
|         run: | | ||||
|           sudo apt-get install jq | ||||
|           sudo make tidy | ||||
|           sudo make tools.verify.go-gitlint | ||||
|           echo "Run go modules tidy successfully"  | ||||
|         continue-on-error: true | ||||
| 
 | ||||
|       - name: Run go format and lint | ||||
|         run: | | ||||
|           sudo make format | ||||
|           echo "Run go format successfully"  | ||||
|         continue-on-error: true | ||||
| 
 | ||||
|       - name: Run go lint | ||||
|         run: | | ||||
|           sudo make lint | ||||
|           echo "Run go lint successfully"  | ||||
|         continue-on-error: true | ||||
| 
 | ||||
|       - name: Generate all necessary files, such as error code files | ||||
|         run: | | ||||
|           make gen.docgo.doc | ||||
|           make gen | ||||
|           echo "Generate all necessary files successfully" | ||||
|         continue-on-error: true | ||||
| 
 | ||||
|       - name: make init | ||||
|         run: | | ||||
|           export OPENIM_IP=127.0.0.1 | ||||
|           export LOG_STORAGE_LOCATION="../logs/" | ||||
|           ./scripts/init-config.sh --examples --force | ||||
|           echo "Generate all necessary files successfully" | ||||
|         continue-on-error: true | ||||
| 
 | ||||
|       - name: Generate Versions Including Pre-release Identifiers | ||||
|         run: | | ||||
|           latest_tag=$(git describe --tags `git rev-list --tags --max-count=1`) | ||||
|           echo $latest_tag > pkg/common/config/version | ||||
|         continue-on-error: true | ||||
| 
 | ||||
|       - name: Gen CHANGELOG file | ||||
|         run: | | ||||
|           current_tag=$(git describe --tags --abbrev=0) | ||||
|           version=$(echo "$current_tag" | sed -E 's/^v?([0-9]+)\.([0-9]+)\..*$/\1.\2/') | ||||
|           echo "OpenIM Version: $version" | ||||
|           make tools.install.git-chglog | ||||
|           cd CHANGELOG | ||||
|           git-chglog --tag-filter-pattern "v${version}.*" -o CHANGELOG-${version}.md | ||||
|           cd .. | ||||
|         continue-on-error: true | ||||
| 
 | ||||
|       - name: Run unit test and get test coverage | ||||
|         run: | | ||||
|           make cover | ||||
|           echo "Run unit test and get test coverage successfully"  | ||||
|         continue-on-error: true | ||||
| 
 | ||||
|       - name: OpenIM verify copyright | ||||
|         run: | | ||||
|           sudo make add-copyright | ||||
|           echo "OpenIM verify successfully"  | ||||
|         continue-on-error: true | ||||
| 
 | ||||
|       - name: Create Pull Request | ||||
|         uses: peter-evans/create-pull-request@v6 | ||||
|         with: | ||||
|           token: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
|           commit-message: "cicd: bump League Patch" | ||||
|           author: kubbot <3293172751ysy@gmail.com> | ||||
|           committer: kubbot <3293172751ysy@gmail.com> | ||||
|         #   signoff: false | ||||
|         #   draft: false | ||||
|           branch: "asf-auto-updates" | ||||
|           assignees: cubxxw | ||||
|           reviewers: cubxxw | ||||
|           title: "[Auto PR 🤖] Bump League Patch auto PR" | ||||
|           body: | | ||||
|             I am a PR generated by robot automation. | ||||
| 
 | ||||
|             Review criteria: | ||||
| 
 | ||||
|             - [ ] Disenchanter can connect and issue actions | ||||
| 
 | ||||
|             Github Actions Status: | ||||
| 
 | ||||
|             [](https://github.com/openimsdk/open-im-server/actions/workflows/pull-request.yml) | ||||
|              | ||||
|             This is an automated PR.  | ||||
|             <sub>[workflow](https://github.com/openimsdk/open-im-server/blob/main/.github/workflows/pull-request.yml).</sub> | ||||
|           labels: | | ||||
|             kind/documentation | ||||
|             enhancement | ||||
|             report | ||||
							
								
								
									
										55
									
								
								.github/workflows/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										55
									
								
								.github/workflows/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,55 +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. | ||||
| 
 | ||||
| name: Release Drafter | ||||
| 
 | ||||
| on: | ||||
|   push: | ||||
|     # branches to consider in the event; optional, defaults to all | ||||
|     branches: | ||||
|       - main | ||||
|   # pull_request event is required only for autolabeler | ||||
|   pull_request: | ||||
|     # Only following types are handled by the action, but one can default to all as well | ||||
|     # types: [opened, reopened, synchronize] | ||||
|   # pull_request_target event is required for autolabeler to support PRs from forks | ||||
|   # pull_request_target: | ||||
|   #   types: [opened, reopened, synchronize] | ||||
| 
 | ||||
| permissions: | ||||
|   contents: read | ||||
| 
 | ||||
| jobs: | ||||
|   update_release_draft: | ||||
|     permissions: | ||||
|       # write permission is required to create a github release | ||||
|       contents: write | ||||
|       # write permission is required for autolabeler | ||||
|       # otherwise, read permission is required at least | ||||
|       pull-requests: write | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       # (Optional) GitHub Enterprise requires GHE_HOST variable set | ||||
|       #- name: Set GHE_HOST | ||||
|       #  run: | | ||||
|       #    echo "GHE_HOST=${GITHUB_SERVER_URL##https:\/\/}" >> $GITHUB_ENV | ||||
| 
 | ||||
|       # Drafts your next Release notes as Pull Requests are merged into "master" | ||||
|       - uses: release-drafter/release-drafter@v6 | ||||
|         # (Optional) specify config name to use, relative to .github/. Default: release-drafter.yml | ||||
|         # with: | ||||
|         #   config-name: my-config.yml | ||||
|         #   disable-autolabeler: true | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.REDBOT_GITHUB_TOKEN }} | ||||
							
								
								
									
										81
									
								
								.github/workflows/release.bak
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										81
									
								
								.github/workflows/release.bak
									
									
									
									
										vendored
									
									
								
							| @ -1,81 +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. | ||||
| 
 | ||||
| name: OpenIM Server Release Workflow | ||||
| 
 | ||||
| on: | ||||
|   push: | ||||
|     # run only against tags | ||||
|     tags: | ||||
|       - '*' | ||||
| 
 | ||||
| permissions: | ||||
|   contents: write | ||||
|   packages: write | ||||
|   issues: write | ||||
| 
 | ||||
| jobs: | ||||
|   goreleaser: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|         with: | ||||
|           fetch-depth: 0 | ||||
|       - run: git fetch --force --tags | ||||
|       - uses: actions/setup-go@v5 | ||||
|         with: | ||||
|           go-version: stable | ||||
|       # More assembly might be required: Docker logins, GPG, etc. It all depends | ||||
|       # on your needs. | ||||
|       - uses: goreleaser/goreleaser-action@v5 | ||||
|         with: | ||||
|           # either 'goreleaser' (default) or 'goreleaser-pro': | ||||
|           distribution: goreleaser | ||||
|           version: latest | ||||
|           workdir: . | ||||
|           args: release -f ./build/goreleaser.yaml --clean --release-footer-tmpl=scripts/template/footer.md.tmpl --release-header-tmpl=scripts/template/head.md.tmpl | ||||
|         env: | ||||
|           USERNAME: ${{ github.repository_owner }} | ||||
|           GITHUB_TOKEN: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
|           FURY_TOKEN: ${{ secrets.FURY_TOKEN }} | ||||
|           # Your GoReleaser Pro key, if you are using the 'goreleaser-pro' | ||||
|           # distribution: | ||||
|           # GORELEASER_KEY: ${{ secrets.GORELEASER_KEY }} | ||||
| 
 | ||||
|   goreleaser-check-pkgs: | ||||
|     runs-on: ubuntu-latest | ||||
|     env: | ||||
|       DOCKER_CLI_EXPERIMENTAL: "enabled" | ||||
|     needs: [ goreleaser ] | ||||
|     if: github.ref == 'refs/heads/main' | ||||
|     strategy: | ||||
|       matrix: | ||||
|         format: [ deb, rpm, apk ] | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 # v3 | ||||
|         with: | ||||
|           fetch-depth: 0 | ||||
|       - uses: arduino/setup-task@e26d8975574116b0097a1161e0fe16ba75d84c1c # v1 | ||||
|         with: | ||||
|           version: 3.x | ||||
|           repo-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|       - uses: docker/setup-qemu-action@326560df218a7ea9cf6ab49bbc88b8b306bb437e # v2 | ||||
|       - uses: actions/cache@a2ed59d39b352305bdd2f628719a53b2cc4f9613 # v3 | ||||
|         with: | ||||
|           path: | | ||||
|             ./_output/dist/*.deb | ||||
|             ./_output/dist/*.rpm | ||||
|             ./_output/dist/*.apk | ||||
|           key: ${{ github.ref }} | ||||
|       - run: task goreleaser:test:${{ matrix.format }} | ||||
							
								
								
									
										74
									
								
								.github/workflows/remove-unused-labels.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										74
									
								
								.github/workflows/remove-unused-labels.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,74 @@ | ||||
| name: Remove Unused Labels | ||||
| on: | ||||
|   workflow_dispatch: | ||||
| 
 | ||||
| jobs: | ||||
|   cleanup: | ||||
|     runs-on: ubuntu-latest | ||||
|     permissions: | ||||
|       issues: write | ||||
|       pull-requests: write | ||||
|       contents: read | ||||
|     steps: | ||||
|       - name: Checkout Repository | ||||
|         uses: actions/checkout@v4 | ||||
| 
 | ||||
|       - name: Fetch All Issues and PRs | ||||
|         id: fetch_issues_prs | ||||
|         uses: actions/github-script@v7.0.1 | ||||
|         with: | ||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|           script: | | ||||
|             const issues = await github.paginate(github.rest.issues.listForRepo, { | ||||
|               owner: context.repo.owner, | ||||
|               repo: context.repo.repo, | ||||
|               state: 'all', | ||||
|               per_page: 100 | ||||
|             }); | ||||
| 
 | ||||
|             const labelsInUse = new Set(); | ||||
|             issues.forEach(issue => { | ||||
|               issue.labels.forEach(label => { | ||||
|                 labelsInUse.add(label.name); | ||||
|               }); | ||||
|             }); | ||||
| 
 | ||||
|             return JSON.stringify(Array.from(labelsInUse)); | ||||
|           result-encoding: string | ||||
| 
 | ||||
|       - name: Fetch All Labels | ||||
|         id: fetch_labels | ||||
|         uses: actions/github-script@v7.0.1 | ||||
|         with: | ||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|           script: | | ||||
|             const labels = await github.paginate(github.rest.issues.listLabelsForRepo, { | ||||
|               owner: context.repo.owner, | ||||
|               repo: context.repo.repo, | ||||
|               per_page: 100 | ||||
|             }); | ||||
| 
 | ||||
|             return JSON.stringify(labels.map(label => label.name)); | ||||
|           result-encoding: string | ||||
| 
 | ||||
|       - name: Remove Unused Labels | ||||
|         uses: actions/github-script@v7.0.1 | ||||
|         with: | ||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|           script: | | ||||
|             const labelsInUse = new Set(JSON.parse(process.env.LABELS_IN_USE)); | ||||
|             const allLabels = JSON.parse(process.env.ALL_LABELS); | ||||
| 
 | ||||
|             const unusedLabels = allLabels.filter(label => !labelsInUse.has(label)); | ||||
| 
 | ||||
|             for (const label of unusedLabels) { | ||||
|               await github.rest.issues.deleteLabel({ | ||||
|                 owner: context.repo.owner, | ||||
|                 repo: context.repo.repo, | ||||
|                 name: label | ||||
|               }); | ||||
|               console.log(`Deleted label: ${label}`); | ||||
|             } | ||||
|         env: | ||||
|           LABELS_IN_USE: ${{ steps.fetch_issues_prs.outputs.result }} | ||||
|           ALL_LABELS: ${{ steps.fetch_labels.outputs.result }} | ||||
							
								
								
									
										78
									
								
								.github/workflows/reopen-issue.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								.github/workflows/reopen-issue.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,78 @@ | ||||
| name: Reopen and Update Stale Issues | ||||
| 
 | ||||
| on: | ||||
|   workflow_dispatch: | ||||
| 
 | ||||
| jobs: | ||||
|   reopen_stale_issues: | ||||
|     runs-on: ubuntu-latest | ||||
|     permissions: | ||||
|       issues: write | ||||
|       contents: read | ||||
| 
 | ||||
|     steps: | ||||
|       - name: Checkout Repository | ||||
|         uses: actions/checkout@v4 | ||||
| 
 | ||||
|       - name: Fetch Closed Issues with lifecycle/stale Label | ||||
|         id: fetch_issues | ||||
|         uses: actions/github-script@v7 | ||||
|         with: | ||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|           script: | | ||||
|             const issues = await github.paginate(github.rest.issues.listForRepo, { | ||||
|               owner: context.repo.owner, | ||||
|               repo: context.repo.repo, | ||||
|               state: 'closed', | ||||
|               labels: 'lifecycle/stale', | ||||
|               per_page: 100 | ||||
|             }); | ||||
|             const issueNumbers = issues | ||||
|               .filter(issue => !issue.pull_request) // exclude PR | ||||
|               .map(issue => issue.number); | ||||
|             console.log(`Fetched issues: ${issueNumbers}`); | ||||
|             return issueNumbers; | ||||
| 
 | ||||
|       - name: Set issue numbers | ||||
|         id: set_issue_numbers | ||||
|         run: | | ||||
|           echo "ISSUE_NUMBERS=${{ steps.fetch_issues.outputs.result }}" >> $GITHUB_ENV | ||||
|           echo "Issue numbers: ${{ steps.fetch_issues.outputs.result }}" | ||||
| 
 | ||||
|       - name: Reopen Issues | ||||
|         uses: actions/github-script@v7 | ||||
|         with: | ||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|           script: | | ||||
|             const issueNumbers = JSON.parse(process.env.ISSUE_NUMBERS); | ||||
|             console.log(`Reopening issues: ${issueNumbers}`); | ||||
| 
 | ||||
|             for (const issue_number of issueNumbers) { | ||||
|               // Reopen the issue | ||||
|               await github.rest.issues.update({ | ||||
|                 owner: context.repo.owner, | ||||
|                 repo: context.repo.repo, | ||||
|                 issue_number: issue_number, | ||||
|                 state: 'open' | ||||
|               }); | ||||
|               console.log(`Reopened issue #${issue_number}`); | ||||
|             } | ||||
| 
 | ||||
|       - name: Remove lifecycle/stale Label | ||||
|         uses: actions/github-script@v7 | ||||
|         with: | ||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|           script: | | ||||
|             const issueNumbers = JSON.parse(process.env.ISSUE_NUMBERS); | ||||
|             console.log(`Removing 'lifecycle/stale' label from issues: ${issueNumbers}`); | ||||
| 
 | ||||
|             for (const issue_number of issueNumbers) { | ||||
|               // Remove the lifecycle/stale label | ||||
|               await github.rest.issues.removeLabel({ | ||||
|                 owner: context.repo.owner, | ||||
|                 repo: context.repo.repo, | ||||
|                 issue_number: issue_number, | ||||
|                 name: 'lifecycle/stale' | ||||
|               }); | ||||
|               console.log(`Removed label 'lifecycle/stale' from issue #${issue_number}`); | ||||
|             } | ||||
							
								
								
									
										44
									
								
								.github/workflows/sync-release.bak
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										44
									
								
								.github/workflows/sync-release.bak
									
									
									
									
										vendored
									
									
								
							| @ -1,44 +0,0 @@ | ||||
| # Copyright © 2023 KubeCub open source community. All rights reserved. | ||||
| # Licensed under the MIT License (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| 
 | ||||
| # https://github.com/BetaHuhn/repo-file-sync-action | ||||
| name: Synchronize OpenIM Release Branch Public Code To Other Repositories | ||||
| on: | ||||
|     push: | ||||
|         paths: | ||||
|             - scripts/* | ||||
|             - docs/* | ||||
|             - config/* | ||||
|         branches: | ||||
|           - release-v*.* | ||||
|     workflow_dispatch: | ||||
| 
 | ||||
| jobs: | ||||
|   sync: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v4 | ||||
| 
 | ||||
|       - name: Run GitHub File Sync | ||||
|         uses: BetaHuhn/repo-file-sync-action@latest | ||||
|         with: | ||||
|           GH_INSTALLATION_TOKEN: "${{ secrets.BOT_GITHUB_TOKEN }}" | ||||
|           CONFIG_PATH: .github/sync-release.yml | ||||
|           ORIGINAL_MESSAGE: true | ||||
|           SKIP_PR: true | ||||
|           COMMIT_EACH_FILE: false | ||||
|           COMMIT_BODY: "🤖 kubbot to synchronize the warehouse" | ||||
|           GIT_EMAIL: "3293172751ysy@gmail.com" | ||||
|           GIT_USERNAME: "kubbot" | ||||
|           PR_BODY: 👌 kubecub provides automated community services | ||||
|           REVIEWERS: | | ||||
|             kubbot | ||||
|             cubxxw | ||||
|           PR_LABELS: | | ||||
|             file-sync | ||||
|             automerge | ||||
|           ASSIGNEES: | | ||||
|             kubbot | ||||
|         continue-on-error: true | ||||
							
								
								
									
										40
									
								
								.github/workflows/sync.bak
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										40
									
								
								.github/workflows/sync.bak
									
									
									
									
										vendored
									
									
								
							| @ -1,40 +0,0 @@ | ||||
| # Copyright © 2023 KubeCub open source community. All rights reserved. | ||||
| # Licensed under the MIT License (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| 
 | ||||
| # https://github.com/BetaHuhn/repo-file-sync-action | ||||
| name: Synchronize OpenIM Main Branch Public Code To Other Repositories | ||||
| on: | ||||
|     push: | ||||
|         branches: | ||||
|           - main | ||||
|     workflow_dispatch: | ||||
| 
 | ||||
| jobs: | ||||
|   sync: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v4 | ||||
| 
 | ||||
|       - name: Run GitHub File Sync | ||||
|         uses: BetaHuhn/repo-file-sync-action@latest | ||||
|         with: | ||||
|           GH_INSTALLATION_TOKEN: "${{ secrets.BOT_GITHUB_TOKEN }}" | ||||
|           CONFIG_PATH: .github/sync.yml | ||||
|           ORIGINAL_MESSAGE: true | ||||
|           SKIP_PR: true | ||||
|           COMMIT_EACH_FILE: false | ||||
|           COMMIT_BODY: "🤖 kubbot to synchronize the warehouse" | ||||
|           GIT_EMAIL: "3293172751ysy@gmail.com" | ||||
|           GIT_USERNAME: "kubbot" | ||||
|           PR_BODY: 👌 kubecub provides automated community services | ||||
|           REVIEWERS: | | ||||
|             kubbot | ||||
|             cubxxw | ||||
|           PR_LABELS: | | ||||
|             file-sync | ||||
|             automerge | ||||
|           ASSIGNEES: | | ||||
|             kubbot | ||||
|         continue-on-error: true | ||||
| @ -1,18 +1,4 @@ | ||||
| # 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. | ||||
| 
 | ||||
| name: OpenIM First Interaction | ||||
| name: User First Interaction | ||||
| 
 | ||||
| on: | ||||
|   issues: | ||||
| @ -28,7 +14,7 @@ jobs: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/first-interaction@v1.3.0 | ||||
|         with: | ||||
|           repo-token: ${{ secrets.BOT_GITHUB_TOKEN }} | ||||
|           repo-token: ${{ secrets.BOT_TOKEN }} | ||||
|           pr-message: | | ||||
|             Hello! Thank you for your contribution. | ||||
|              | ||||
| @ -1,20 +1,3 @@ | ||||
| # Copyright © 2023 OpenIMSDK open source community. 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. | ||||
| 
 | ||||
| # This file contains all available configuration options | ||||
| # with their default values. | ||||
| 
 | ||||
| # options for analysis running | ||||
| run: | ||||
|   # default concurrency is a available CPU number | ||||
| @ -302,7 +285,7 @@ linters-settings: | ||||
| 
 | ||||
|   gofumpt: | ||||
|     # Select the Go version to target. The default is `1.18`. | ||||
|     lang-version: "1.20" | ||||
|     go-version: "1.21" | ||||
| 
 | ||||
|     # Choose whether or not to use the extra rules that are disabled | ||||
|     # by default | ||||
|  | ||||
| @ -1,5 +1,5 @@ | ||||
| # Use Go 1.21 Alpine as the base image for building the application | ||||
| FROM golang:1.21-alpine as builder | ||||
| FROM golang:1.21-alpine AS builder | ||||
| 
 | ||||
| # Define the base directory for the application as an environment variable | ||||
| ENV SERVER_DIR=/openim-server | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| enable: "etcd" | ||||
| enable: etcd | ||||
| etcd: | ||||
|   rootDirectory: openim | ||||
|   address: [ localhost:12379 ] | ||||
|  | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -3,34 +3,38 @@ username: '' | ||||
| # Password for authentication | ||||
| password: '' | ||||
| # Producer acknowledgment settings | ||||
| producerAck: "" | ||||
| producerAck:  | ||||
| # Compression type to use (e.g., none, gzip, snappy) | ||||
| compressType: "none" | ||||
| compressType: none | ||||
| # List of Kafka broker addresses | ||||
| address: [ localhost:19094 ] | ||||
| # Kafka topic for Redis integration | ||||
| toRedisTopic: "toRedis" | ||||
| toRedisTopic: toRedis | ||||
| # Kafka topic for MongoDB integration | ||||
| toMongoTopic: "toMongo" | ||||
| toMongoTopic: toMongo | ||||
| # Kafka topic for push notifications | ||||
| toPushTopic: "toPush" | ||||
| toPushTopic: toPush | ||||
| # Kafka topic for offline push notifications | ||||
| toOfflinePushTopic: toOfflinePush | ||||
| # Consumer group ID for Redis topic | ||||
| toRedisGroupID: redis | ||||
| # Consumer group ID for MongoDB topic | ||||
| toMongoGroupID: mongo | ||||
| # Consumer group ID for push notifications topic | ||||
| toPushGroupID: push | ||||
| # Consumer group ID for offline push notifications topic | ||||
| toOfflinePushGroupID: offlinePush | ||||
| # TLS (Transport Layer Security) configuration | ||||
| tls: | ||||
|   # Enable or disable TLS | ||||
|   enableTLS: false | ||||
|   # CA certificate file path | ||||
|   caCrt: "" | ||||
|   caCrt:  | ||||
|   # Client certificate file path | ||||
|   clientCrt: "" | ||||
|   clientCrt:  | ||||
|   # Client key file path | ||||
|   clientKey: "" | ||||
|   clientKey:  | ||||
|   # Client key password | ||||
|   clientKeyPwd: "" | ||||
|   clientKeyPwd:  | ||||
|   # Whether to skip TLS verification (not recommended for production) | ||||
|   insecureSkipVerify: false | ||||
|  | ||||
| @ -1,15 +1,15 @@ | ||||
| # Name of the bucket in MinIO | ||||
| bucket: "openim" | ||||
| bucket: openim | ||||
| # Access key ID for MinIO authentication | ||||
| accessKeyID: "root" | ||||
| accessKeyID: root | ||||
| # Secret access key for MinIO authentication | ||||
| secretAccessKey: "openIM123" | ||||
| secretAccessKey: openIM123 | ||||
| # Session token for MinIO authentication (optional) | ||||
| sessionToken: '' | ||||
| sessionToken:  | ||||
| # Internal address of the MinIO server | ||||
| internalAddress: "localhost:10005" | ||||
| internalAddress: localhost:10005 | ||||
| # External address of the MinIO server, accessible from outside. Supports both HTTP and HTTPS using a domain name | ||||
| externalAddress: "http://external_ip:10005" | ||||
| externalAddress: http://external_ip:10005 | ||||
| # Flag to enable or disable public read access to the bucket | ||||
| publicRead: false | ||||
| 
 | ||||
|  | ||||
| @ -1,5 +1,5 @@ | ||||
| # URI for database connection, leave empty if using address and credential settings directly | ||||
| uri: '' | ||||
| uri:  | ||||
| # List of MongoDB server addresses | ||||
| address: [ localhost:37017 ] | ||||
| # Name of the database | ||||
|  | ||||
| @ -28,11 +28,11 @@ groupCreated: | ||||
|     # Enables or disables offline push notifications. | ||||
|     enable: false | ||||
|     # Title for the notification when a group is created. | ||||
|     title: "create group title" | ||||
|     title: create group title | ||||
|     # Description for the notification. | ||||
|     desc: "create group desc" | ||||
|     desc: create group desc | ||||
|     # Additional information for the notification. | ||||
|     ext: "create group ext" | ||||
|     ext: create group ext | ||||
| 
 | ||||
| groupInfoSet: | ||||
|   isSendMsg: false | ||||
| @ -40,9 +40,9 @@ groupInfoSet: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "groupInfoSet title" | ||||
|     desc: "groupInfoSet desc" | ||||
|     ext: "groupInfoSet ext" | ||||
|     title: groupInfoSet title | ||||
|     desc: groupInfoSet desc | ||||
|     ext: groupInfoSet ext | ||||
| 
 | ||||
| 
 | ||||
| joinGroupApplication: | ||||
| @ -51,9 +51,9 @@ joinGroupApplication: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "joinGroupApplication title" | ||||
|     desc: "joinGroupApplication desc" | ||||
|     ext: "joinGroupApplication ext" | ||||
|     title: joinGroupApplication title | ||||
|     desc: joinGroupApplication desc | ||||
|     ext: joinGroupApplication ext | ||||
| 
 | ||||
| memberQuit: | ||||
|   isSendMsg: true | ||||
| @ -61,9 +61,9 @@ memberQuit: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "memberQuit title" | ||||
|     desc: "memberQuit desc" | ||||
|     ext: "memberQuit ext" | ||||
|     title: memberQuit title | ||||
|     desc: memberQuit desc | ||||
|     ext: memberQuit ext | ||||
| 
 | ||||
| groupApplicationAccepted: | ||||
|   isSendMsg: false | ||||
| @ -71,9 +71,9 @@ groupApplicationAccepted: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "groupApplicationAccepted title" | ||||
|     desc: "groupApplicationAccepted desc" | ||||
|     ext: "groupApplicationAccepted ext" | ||||
|     title: groupApplicationAccepted title | ||||
|     desc: groupApplicationAccepted desc | ||||
|     ext: groupApplicationAccepted ext | ||||
| 
 | ||||
| groupApplicationRejected: | ||||
|   isSendMsg: false | ||||
| @ -81,9 +81,9 @@ groupApplicationRejected: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "groupApplicationRejected title" | ||||
|     desc: "groupApplicationRejected desc" | ||||
|     ext: "groupApplicationRejected ext" | ||||
|     title: groupApplicationRejected title | ||||
|     desc: groupApplicationRejected desc | ||||
|     ext: groupApplicationRejected ext | ||||
| 
 | ||||
| 
 | ||||
| groupOwnerTransferred: | ||||
| @ -92,9 +92,9 @@ groupOwnerTransferred: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "groupOwnerTransferred title" | ||||
|     desc: "groupOwnerTransferred desc" | ||||
|     ext: "groupOwnerTransferred ext" | ||||
|     title: groupOwnerTransferred title | ||||
|     desc: groupOwnerTransferred desc | ||||
|     ext: groupOwnerTransferred ext | ||||
| 
 | ||||
| memberKicked: | ||||
|   isSendMsg: true | ||||
| @ -102,9 +102,9 @@ memberKicked: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "memberKicked title" | ||||
|     desc: "memberKicked desc" | ||||
|     ext: "memberKicked ext" | ||||
|     title: memberKicked title | ||||
|     desc: memberKicked desc | ||||
|     ext: memberKicked ext | ||||
| 
 | ||||
| memberInvited: | ||||
|   isSendMsg: true | ||||
| @ -112,9 +112,9 @@ memberInvited: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "memberInvited title" | ||||
|     desc: "memberInvited desc" | ||||
|     ext: "memberInvited ext" | ||||
|     title: memberInvited title | ||||
|     desc: memberInvited desc | ||||
|     ext: memberInvited ext | ||||
| 
 | ||||
| memberEnter: | ||||
|   isSendMsg: true | ||||
| @ -122,9 +122,9 @@ memberEnter: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "memberEnter title" | ||||
|     desc: "memberEnter desc" | ||||
|     ext: "memberEnter ext" | ||||
|     title: memberEnter title | ||||
|     desc: memberEnter desc | ||||
|     ext: memberEnter ext | ||||
| 
 | ||||
| groupDismissed: | ||||
|   isSendMsg: true | ||||
| @ -132,9 +132,9 @@ groupDismissed: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "groupDismissed title" | ||||
|     desc: "groupDismissed desc" | ||||
|     ext: "groupDismissed ext" | ||||
|     title: groupDismissed title | ||||
|     desc: groupDismissed desc | ||||
|     ext: groupDismissed ext | ||||
| 
 | ||||
| groupMuted: | ||||
|   isSendMsg: true | ||||
| @ -142,9 +142,9 @@ groupMuted: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "groupMuted title" | ||||
|     desc: "groupMuted desc" | ||||
|     ext: "groupMuted ext" | ||||
|     title: groupMuted title | ||||
|     desc: groupMuted desc | ||||
|     ext: groupMuted ext | ||||
| 
 | ||||
| groupCancelMuted: | ||||
|   isSendMsg: true | ||||
| @ -152,11 +152,11 @@ groupCancelMuted: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "groupCancelMuted title" | ||||
|     desc: "groupCancelMuted desc" | ||||
|     ext: "groupCancelMuted ext" | ||||
|     title: groupCancelMuted title | ||||
|     desc: groupCancelMuted desc | ||||
|     ext: groupCancelMuted ext | ||||
|   defaultTips: | ||||
|     tips: "group Cancel Muted" | ||||
|     tips: group Cancel Muted | ||||
| 
 | ||||
| 
 | ||||
| groupMemberMuted: | ||||
| @ -165,9 +165,9 @@ groupMemberMuted: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "groupMemberMuted title" | ||||
|     desc: "groupMemberMuted desc" | ||||
|     ext: "groupMemberMuted ext" | ||||
|     title: groupMemberMuted title | ||||
|     desc: groupMemberMuted desc | ||||
|     ext: groupMemberMuted ext | ||||
| 
 | ||||
| groupMemberCancelMuted: | ||||
|   isSendMsg: true | ||||
| @ -175,9 +175,9 @@ groupMemberCancelMuted: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "groupMemberCancelMuted title" | ||||
|     desc: "groupMemberCancelMuted desc" | ||||
|     ext: "groupMemberCancelMuted ext" | ||||
|     title: groupMemberCancelMuted title | ||||
|     desc: groupMemberCancelMuted desc | ||||
|     ext: groupMemberCancelMuted ext | ||||
| 
 | ||||
| groupMemberInfoSet: | ||||
|   isSendMsg: false | ||||
| @ -185,9 +185,9 @@ groupMemberInfoSet: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "groupMemberInfoSet title" | ||||
|     desc: "groupMemberInfoSet desc" | ||||
|     ext: "groupMemberInfoSet ext" | ||||
|     title: groupMemberInfoSet title | ||||
|     desc: groupMemberInfoSet desc | ||||
|     ext: groupMemberInfoSet ext | ||||
| 
 | ||||
| groupInfoSetAnnouncement: | ||||
|   isSendMsg: true | ||||
| @ -195,9 +195,9 @@ groupInfoSetAnnouncement: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "groupInfoSetAnnouncement title" | ||||
|     desc: "groupInfoSetAnnouncement desc" | ||||
|     ext: "groupInfoSetAnnouncement ext" | ||||
|     title: groupInfoSetAnnouncement title | ||||
|     desc: groupInfoSetAnnouncement desc | ||||
|     ext: groupInfoSetAnnouncement ext | ||||
| 
 | ||||
| 
 | ||||
| groupInfoSetName: | ||||
| @ -206,9 +206,9 @@ groupInfoSetName: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "groupInfoSetName title" | ||||
|     desc: "groupInfoSetName desc" | ||||
|     ext: "groupInfoSetName ext" | ||||
|     title: groupInfoSetName title | ||||
|     desc: groupInfoSetName desc | ||||
|     ext: groupInfoSetName ext | ||||
| 
 | ||||
| 
 | ||||
| #############################friend################################# | ||||
| @ -218,9 +218,9 @@ friendApplicationAdded: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "Somebody applies to add you as a friend" | ||||
|     desc: "Somebody applies to add you as a friend" | ||||
|     ext: "Somebody applies to add you as a friend" | ||||
|     title: Somebody applies to add you as a friend | ||||
|     desc: Somebody applies to add you as a friend | ||||
|     ext: Somebody applies to add you as a friend | ||||
| 
 | ||||
| friendApplicationApproved: | ||||
|   isSendMsg: true | ||||
| @ -228,9 +228,9 @@ friendApplicationApproved: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: true | ||||
|     title: "Someone applies to add your friend application" | ||||
|     desc: "Someone applies to add your friend application" | ||||
|     ext: "Someone applies to add your friend application" | ||||
|     title: Someone applies to add your friend application | ||||
|     desc: Someone applies to add your friend application | ||||
|     ext: Someone applies to add your friend application | ||||
| 
 | ||||
| friendApplicationRejected: | ||||
|   isSendMsg: false | ||||
| @ -238,9 +238,9 @@ friendApplicationRejected: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: true | ||||
|     title: "Someone rejected your friend application" | ||||
|     desc: "Someone rejected your friend application" | ||||
|     ext: "Someone rejected your friend application" | ||||
|     title: Someone rejected your friend application | ||||
|     desc: Someone rejected your friend application | ||||
|     ext: Someone rejected your friend application | ||||
| 
 | ||||
| friendAdded: | ||||
|   isSendMsg: false | ||||
| @ -248,9 +248,9 @@ friendAdded: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: true | ||||
|     title: "We have become friends" | ||||
|     desc: "We have become friends" | ||||
|     ext: "We have become friends" | ||||
|     title: We have become friends | ||||
|     desc: We have become friends | ||||
|     ext: We have become friends | ||||
| 
 | ||||
| friendDeleted: | ||||
|   isSendMsg: false | ||||
| @ -258,9 +258,9 @@ friendDeleted: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: true | ||||
|     title: "deleted a friend" | ||||
|     desc: "deleted a friend" | ||||
|     ext: "deleted a friend" | ||||
|     title: deleted a friend | ||||
|     desc: deleted a friend | ||||
|     ext: deleted a friend | ||||
| 
 | ||||
| friendRemarkSet: | ||||
|   isSendMsg: false | ||||
| @ -268,9 +268,9 @@ friendRemarkSet: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: true | ||||
|     title: "Your friend's profile has been changed" | ||||
|     desc: "Your friend's profile has been changed" | ||||
|     ext: "Your friend's profile has been changed" | ||||
|     title: Your friend's profile has been changed | ||||
|     desc: Your friend's profile has been changed | ||||
|     ext: Your friend's profile has been changed | ||||
| 
 | ||||
| blackAdded: | ||||
|   isSendMsg: false | ||||
| @ -278,9 +278,9 @@ blackAdded: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: true | ||||
|     title: "blocked a user" | ||||
|     desc: "blocked a user" | ||||
|     ext: "blocked a user" | ||||
|     title: blocked a user | ||||
|     desc: blocked a user | ||||
|     ext: blocked a user | ||||
| 
 | ||||
| blackDeleted: | ||||
|   isSendMsg: false | ||||
| @ -288,9 +288,9 @@ blackDeleted: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: true | ||||
|     title: "Remove a blocked user" | ||||
|     desc: "Remove a blocked user" | ||||
|     ext: "Remove a blocked user" | ||||
|     title: Remove a blocked user | ||||
|     desc: Remove a blocked user | ||||
|     ext: Remove a blocked user | ||||
| 
 | ||||
| friendInfoUpdated: | ||||
|   isSendMsg: false | ||||
| @ -298,9 +298,9 @@ friendInfoUpdated: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: true | ||||
|     title: "friend info updated" | ||||
|     desc: "friend info updated" | ||||
|     ext: "friend info updated" | ||||
|     title: friend info updated | ||||
|     desc: friend info updated | ||||
|     ext: friend info updated | ||||
| 
 | ||||
| #####################user######################### | ||||
| userInfoUpdated: | ||||
| @ -309,9 +309,9 @@ userInfoUpdated: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: true | ||||
|     title: "Remove a blocked user" | ||||
|     desc: "Remove a blocked user" | ||||
|     ext: "Remove a blocked user" | ||||
|     title: Remove a blocked user | ||||
|     desc: Remove a blocked user | ||||
|     ext: Remove a blocked user | ||||
| 
 | ||||
| userStatusChanged: | ||||
|   isSendMsg: false | ||||
| @ -319,9 +319,9 @@ userStatusChanged: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: false | ||||
|     title: "user status changed" | ||||
|     desc: "user status changed" | ||||
|     ext: "user status changed" | ||||
|     title: user status changed | ||||
|     desc: user status changed | ||||
|     ext: user status changed | ||||
| 
 | ||||
| #####################conversation######################### | ||||
| conversationChanged: | ||||
| @ -330,9 +330,9 @@ conversationChanged: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: true | ||||
|     title: "conversation changed" | ||||
|     desc: "conversation changed" | ||||
|     ext: "conversation changed" | ||||
|     title: conversation changed | ||||
|     desc: conversation changed | ||||
|     ext: conversation changed | ||||
| 
 | ||||
| conversationSetPrivate: | ||||
|   isSendMsg: true | ||||
| @ -340,6 +340,6 @@ conversationSetPrivate: | ||||
|   unreadCount: false | ||||
|   offlinePush: | ||||
|     enable: true | ||||
|     title: "burn after reading" | ||||
|     desc: "burn after reading" | ||||
|     ext: "burn after reading" | ||||
|     title: burn after reading | ||||
|     desc: burn after reading | ||||
|     ext: burn after reading | ||||
|  | ||||
| @ -3,11 +3,14 @@ api: | ||||
|   listenIP: 0.0.0.0 | ||||
|   # Listening ports; if multiple are configured, multiple instances will be launched, must be consistent with the number of prometheus.ports | ||||
|   ports: [ 10002 ] | ||||
|   # API compression level; 0: default compression, 1: best compression, 2: best speed, -1: no compression | ||||
|   compressionLevel: 0 | ||||
| 
 | ||||
| 
 | ||||
| prometheus: | ||||
|   # Whether to enable prometheus | ||||
|   enable: true | ||||
|   # Prometheus listening ports, must match the number of api.ports | ||||
|   ports: [ 20113 ] | ||||
|   ports: [ 12002 ] | ||||
|   # This address can be accessed via a browser | ||||
|   grafanaURL: http://127.0.0.1:13000/ | ||||
|  | ||||
| @ -1,3 +1,3 @@ | ||||
| cronExecuteTime: "0 2 * * *" | ||||
| cronExecuteTime: 0 2 * * * | ||||
| retainChatRecords: 365 | ||||
| fileExpireTime: 90 | ||||
|  | ||||
| @ -1,14 +1,14 @@ | ||||
| rpc: | ||||
|   # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP | ||||
|   registerIP: '' | ||||
|   registerIP:  | ||||
|   # 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 | ||||
|   ports: [ 10140 ] | ||||
|   ports: [ 10140, 10141, 10142, 10143, 10144, 10145, 10146, 10147, 10148, 10149, 10150, 10151, 10152, 10153, 10154, 10155 ] | ||||
| 
 | ||||
| prometheus: | ||||
|   # Enable or disable Prometheus monitoring | ||||
|   enable: true | ||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||
|   ports: [ 20112 ] | ||||
|   ports: [ 12140, 12141, 12142, 12143, 12144, 12145, 12146, 12147, 12148, 12149, 12150, 12151, 12152, 12153, 12154, 12155 ] | ||||
| 
 | ||||
| # 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 | ||||
| @ -23,8 +23,4 @@ longConnSvr: | ||||
|   # WebSocket connection handshake timeout in seconds | ||||
|   websocketTimeout: 10 | ||||
| 
 | ||||
| # 1: For Android, iOS, Windows, Mac, and web platforms, only one instance can be online at a time | ||||
| multiLoginPolicy: 1 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  | ||||
| @ -3,4 +3,4 @@ prometheus: | ||||
|   enable: true | ||||
|   # List of ports that Prometheus listens on; each port corresponds to an instance of monitoring. Ensure these are managed accordingly | ||||
|   # Because four instances have been launched, four ports need to be specified | ||||
|   ports: [ 20108, 20109, 20110, 20111 ] | ||||
|   ports: [ 12020, 12021, 12022, 12023, 12024, 12025, 12026, 12027, 12028, 12029, 12030, 12031, 12032, 12033, 12034, 12035 ] | ||||
|  | ||||
| @ -1,46 +1,41 @@ | ||||
| rpc: | ||||
|   # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP | ||||
|   registerIP: '' | ||||
|   registerIP: | ||||
|   # 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 | ||||
|   # 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 | ||||
|   ports: [ 10170 ] | ||||
|   ports: [ 10170, 10171, 10172, 10173, 10174, 10175, 10176, 10177, 10178, 10179, 10180, 10181, 10182, 10183, 10184, 10185 ] | ||||
| 
 | ||||
| prometheus: | ||||
|   # Enable or disable Prometheus monitoring | ||||
|   enable: true | ||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||
|   ports: [ 20107 ] | ||||
|   ports: [ 12170, 12171, 12172, 12173, 12174, 12175, 12176, 12177, 12178, 12179, 12180, 12182, 12183, 12184, 12185, 12186 ] | ||||
| 
 | ||||
| maxConcurrentWorkers: 3 | ||||
| #"Use geTui for offline push notifications, or choose fcm or jpns; corresponding configuration settings must be specified." | ||||
| enable: "geTui" | ||||
| #Use geTui for offline push notifications, or choose fcm or jpns; corresponding configuration settings must be specified. | ||||
| enable: geTui | ||||
| geTui: | ||||
|   pushUrl: "https://restapi.getui.com/v2/$appId" | ||||
|   masterSecret: '' | ||||
|   appKey: '' | ||||
|   intent: '' | ||||
|   channelID: '' | ||||
|   channelName: '' | ||||
|   pushUrl: https://restapi.getui.com/v2/$appId | ||||
|   masterSecret:  | ||||
|   appKey:  | ||||
|   intent:  | ||||
|   channelID:  | ||||
|   channelName:  | ||||
| fcm: | ||||
|   # Prioritize using file paths. If the file path is empty, use URL | ||||
|   filePath: ""  # File path is concatenated with the parameters passed in through - c(`mage` default pass in `config/`) and filePath.  | ||||
|   authURL: ""  #  Must start with https or http. | ||||
|   filePath:   # File path is concatenated with the parameters passed in through - c(`mage` default pass in `config/`) and filePath.  | ||||
|   authURL:   #  Must start with https or http. | ||||
| jpns: | ||||
|   appKey: '' | ||||
|   masterSecret: '' | ||||
|   pushURL: '' | ||||
|   pushIntent: '' | ||||
|   appKey:  | ||||
|   masterSecret:  | ||||
|   pushURL:  | ||||
|   pushIntent:  | ||||
| 
 | ||||
| # iOS system push sound and badge count | ||||
| iosPush: | ||||
|       pushSound: "xxx" | ||||
|       pushSound: xxx | ||||
|       badgeCount: true | ||||
|       production: false | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| fullUserCache: true | ||||
|  | ||||
| @ -1,18 +1,17 @@ | ||||
| rpc: | ||||
|   # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP | ||||
|   registerIP: '' | ||||
|   registerIP:  | ||||
|   # 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 | ||||
|   # 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 | ||||
|   ports: [ 10160 ] | ||||
|   ports: [ 10200 ] | ||||
| 
 | ||||
| prometheus: | ||||
|   # Enable or disable Prometheus monitoring | ||||
|   enable: true | ||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||
|   ports: [ 20106 ] | ||||
|   ports: [ 12200 ] | ||||
| 
 | ||||
| tokenPolicy: | ||||
|   # Token validity period, in days | ||||
|   expire: 90 | ||||
| 
 | ||||
|  | ||||
| @ -1,13 +1,13 @@ | ||||
| rpc: | ||||
|   # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP | ||||
|   registerIP: '' | ||||
|   registerIP:  | ||||
|   # 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 | ||||
|   # 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 | ||||
|   ports: [ 10180 ] | ||||
|   ports: [ 10220 ] | ||||
| 
 | ||||
| prometheus: | ||||
|   # Enable or disable Prometheus monitoring | ||||
|   enable: true | ||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||
|   ports: [ 20105 ] | ||||
|   ports: [ 12220 ] | ||||
|  | ||||
| @ -1,13 +1,13 @@ | ||||
| rpc: | ||||
|   # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP | ||||
|   registerIP: '' | ||||
|   registerIP:  | ||||
|   # 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 | ||||
|   # 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 | ||||
|   ports: [ 10120 ] | ||||
|   ports: [ 10240 ] | ||||
| 
 | ||||
| prometheus: | ||||
|   # Enable or disable Prometheus monitoring | ||||
|   enable: true | ||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||
|   ports: [ 20104 ] | ||||
|   ports: [ 12240 ] | ||||
|  | ||||
| @ -1,13 +1,16 @@ | ||||
| rpc: | ||||
|   # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP | ||||
|   registerIP: '' | ||||
|   registerIP: | ||||
|   # 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 | ||||
|   # 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 | ||||
|   ports: [ 10150 ] | ||||
|   ports: [ 10260 ] | ||||
| 
 | ||||
| prometheus: | ||||
|   # Enable or disable Prometheus monitoring | ||||
|   enable: true | ||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||
|   ports: [ 20103 ] | ||||
|   ports: [ 12260 ] | ||||
| 
 | ||||
| 
 | ||||
| enableHistoryForNewMembers: true | ||||
|  | ||||
| @ -1,20 +1,17 @@ | ||||
| rpc: | ||||
|   # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP | ||||
|   registerIP: '' | ||||
|   registerIP:  | ||||
|   # 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 | ||||
|   # 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 | ||||
|   ports: [ 10130 ] | ||||
|   ports: [ 10280 ] | ||||
| 
 | ||||
| prometheus: | ||||
|   # Enable or disable Prometheus monitoring | ||||
|   enable: true | ||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||
|   ports: [ 20102 ] | ||||
|   ports: [ 12280 ] | ||||
| 
 | ||||
| 
 | ||||
| # Does sending messages require friend verification | ||||
| friendVerify: false | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  | ||||
| @ -1,40 +1,40 @@ | ||||
| rpc: | ||||
|   # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP | ||||
|   registerIP: '' | ||||
|   registerIP:  | ||||
|   # 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 | ||||
|   # 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 | ||||
|   ports: [ 10190 ] | ||||
|   ports: [ 10300 ] | ||||
| 
 | ||||
| prometheus: | ||||
|   # Enable or disable Prometheus monitoring | ||||
|   enable: true | ||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||
|   ports: [ 20101 ] | ||||
|   ports: [ 12300 ] | ||||
| 
 | ||||
| 
 | ||||
| object: | ||||
|   # Use MinIO as object storage, or set to "cos", "oss", "kodo", "aws", while also configuring the corresponding settings | ||||
|   enable: "minio" | ||||
|   enable: minio | ||||
|   cos: | ||||
|     bucketURL: https://temp-1252357374.cos.ap-chengdu.myqcloud.com | ||||
|     secretID: '' | ||||
|     secretKey: '' | ||||
|     sessionToken: '' | ||||
|     secretID:  | ||||
|     secretKey:  | ||||
|     sessionToken:  | ||||
|     publicRead: false | ||||
|   oss: | ||||
|     endpoint: "https://oss-cn-chengdu.aliyuncs.com" | ||||
|     bucket: "demo-9999999" | ||||
|     bucketURL: "https://demo-9999999.oss-cn-chengdu.aliyuncs.com" | ||||
|     accessKeyID: '' | ||||
|     accessKeySecret: '' | ||||
|     sessionToken: '' | ||||
|     endpoint: https://oss-cn-chengdu.aliyuncs.com | ||||
|     bucket: demo-9999999 | ||||
|     bucketURL: https://demo-9999999.oss-cn-chengdu.aliyuncs.com | ||||
|     accessKeyID:  | ||||
|     accessKeySecret:  | ||||
|     sessionToken:  | ||||
|     publicRead: false | ||||
|   kodo: | ||||
|     endpoint: "http://s3.cn-south-1.qiniucs.com" | ||||
|     bucket: "kodo-bucket-test" | ||||
|     bucketURL: "http://kodo-bucket-test-oetobfb.qiniudns.com" | ||||
|     accessKeyID: '' | ||||
|     accessKeySecret: '' | ||||
|     sessionToken: '' | ||||
|     endpoint: http://s3.cn-south-1.qiniucs.com | ||||
|     bucket: kodo-bucket-test | ||||
|     bucketURL: http://kodo-bucket-test-oetobfb.qiniudns.com | ||||
|     accessKeyID:  | ||||
|     accessKeySecret:  | ||||
|     sessionToken:  | ||||
|     publicRead: false | ||||
| @ -1,17 +1,13 @@ | ||||
| rpc: | ||||
|   # API or other RPCs can access this RPC through this IP; if left blank, the internal network IP is obtained by default | ||||
|   registerIP: '' | ||||
|   registerIP:  | ||||
|   # 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 | ||||
|   # Listening ports; if multiple are configured, multiple instances will be launched, and must be consistent with the number of prometheus.ports | ||||
|   ports: [ 10110 ] | ||||
|   ports: [ 10320 ] | ||||
| 
 | ||||
| prometheus: | ||||
|   # Whether to enable prometheus | ||||
|   enable: true | ||||
|   # Prometheus listening ports, must be consistent with the number of rpc.ports | ||||
|   ports: [ 20100 ] | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|   ports: [ 12320 ] | ||||
|  | ||||
| @ -8,76 +8,79 @@ global: | ||||
| alerting: | ||||
|   alertmanagers: | ||||
|     - static_configs: | ||||
|         - targets: ['internal_ip:19093'] | ||||
|         - targets: [internal_ip:19093] | ||||
| 
 | ||||
| # Load rules once and periodically evaluate them according to the global 'evaluation_interval'. | ||||
| # Load rules once and periodically evaluate them according to the global evaluation_interval. | ||||
| rule_files: | ||||
|   - "instance-down-rules.yml" | ||||
| # - "first_rules.yml" | ||||
| # - "second_rules.yml" | ||||
|   - instance-down-rules.yml | ||||
| # - first_rules.yml | ||||
| # - second_rules.yml | ||||
| 
 | ||||
| # A scrape configuration containing exactly one endpoint to scrape: | ||||
| # Here it's Prometheus itself. | ||||
| scrape_configs: | ||||
|   # The job name is added as a label "job='job_name'"" to any timeseries scraped from this config. | ||||
|   # The job name is added as a label "job=job_name" to any timeseries scraped from this config. | ||||
|   # Monitored information captured by prometheus | ||||
| 
 | ||||
|   # prometheus fetches application services | ||||
|   - job_name: 'node_exporter' | ||||
|   - job_name: node_exporter | ||||
|     static_configs: | ||||
|       - targets: [ 'internal_ip:20114' ] | ||||
|   - job_name: 'openimserver-openim-api' | ||||
|       - targets: [ internal_ip:20500 ] | ||||
|   - job_name: openimserver-openim-api | ||||
|     static_configs: | ||||
|       - targets: [ 'internal_ip:20113' ] | ||||
|       - targets: [ internal_ip:12002 ] | ||||
|         labels: | ||||
|           namespace: 'default' | ||||
|   - job_name: 'openimserver-openim-msggateway' | ||||
|           namespace: default | ||||
|   - job_name: openimserver-openim-msggateway | ||||
|     static_configs: | ||||
|       - targets: [ 'internal_ip:20112' ] | ||||
|       - targets: [ internal_ip:12140 ] | ||||
| #      - targets: [ internal_ip:12140, internal_ip:12141, internal_ip:12142, internal_ip:12143, internal_ip:12144, internal_ip:12145, internal_ip:12146, internal_ip:12147, internal_ip:12148, internal_ip:12149, internal_ip:12150, internal_ip:12151, internal_ip:12152, internal_ip:12153, internal_ip:12154, internal_ip:12155 ] | ||||
|         labels: | ||||
|           namespace: 'default' | ||||
|   - job_name: 'openimserver-openim-msgtransfer' | ||||
|           namespace: default | ||||
|   - job_name: openimserver-openim-msgtransfer | ||||
|     static_configs: | ||||
|       - targets: [ 'internal_ip:20111', 'internal_ip:20110', 'internal_ip:20109', 'internal_ip:20108' ] | ||||
|       - targets: [ internal_ip:12020, internal_ip:12021, internal_ip:12022, internal_ip:12023, internal_ip:12024, internal_ip:12025, internal_ip:12026, internal_ip:12027 ] | ||||
| #      - targets: [ internal_ip:12020, internal_ip:12021, internal_ip:12022, internal_ip:12023, internal_ip:12024, internal_ip:12025, internal_ip:12026, internal_ip:12027, internal_ip:12028, internal_ip:12029, internal_ip:12030, internal_ip:12031, internal_ip:12032, internal_ip:12033, internal_ip:12034, internal_ip:12035 ] | ||||
|         labels: | ||||
|           namespace: 'default' | ||||
|   - job_name: 'openimserver-openim-push' | ||||
|           namespace: default | ||||
|   - job_name: openimserver-openim-push | ||||
|     static_configs: | ||||
|       - targets: [ 'internal_ip:20107' ] | ||||
|       - targets: [ internal_ip:12170, internal_ip:12171, internal_ip:12172, internal_ip:12173, internal_ip:12174, internal_ip:12175, internal_ip:12176, internal_ip:12177 ] | ||||
| #      - targets: [ internal_ip:12170, internal_ip:12171, internal_ip:12172, internal_ip:12173, internal_ip:12174, internal_ip:12175, internal_ip:12176, internal_ip:12177, internal_ip:12178, internal_ip:12179, internal_ip:12180,  internal_ip:12182, internal_ip:12183, internal_ip:12184, internal_ip:12185, internal_ip:12186 ] | ||||
|         labels: | ||||
|           namespace: 'default' | ||||
|   - job_name: 'openimserver-openim-rpc-auth' | ||||
|           namespace: default | ||||
|   - job_name: openimserver-openim-rpc-auth | ||||
|     static_configs: | ||||
|       - targets: [ 'internal_ip:20106' ] | ||||
|       - targets: [ internal_ip:12200 ] | ||||
|         labels: | ||||
|           namespace: 'default' | ||||
|   - job_name: 'openimserver-openim-rpc-conversation' | ||||
|           namespace: default | ||||
|   - job_name: openimserver-openim-rpc-conversation | ||||
|     static_configs: | ||||
|       - targets: [ 'internal_ip:20105' ] | ||||
|       - targets: [ internal_ip:12220 ] | ||||
|         labels: | ||||
|           namespace: 'default' | ||||
|   - job_name: 'openimserver-openim-rpc-friend' | ||||
|           namespace: default | ||||
|   - job_name: openimserver-openim-rpc-friend | ||||
|     static_configs: | ||||
|       - targets: [ 'internal_ip:20104' ] | ||||
|       - targets: [ internal_ip:12240 ] | ||||
|         labels: | ||||
|           namespace: 'default' | ||||
|   - job_name: 'openimserver-openim-rpc-group' | ||||
|           namespace: default | ||||
|   - job_name: openimserver-openim-rpc-group | ||||
|     static_configs: | ||||
|       - targets: [ 'internal_ip:20103' ] | ||||
|       - targets: [ internal_ip:12260 ] | ||||
|         labels: | ||||
|           namespace: 'default' | ||||
|   - job_name: 'openimserver-openim-rpc-msg' | ||||
|           namespace: default | ||||
|   - job_name: openimserver-openim-rpc-msg | ||||
|     static_configs: | ||||
|       - targets: [ 'internal_ip:20102' ] | ||||
|       - targets: [ internal_ip:12280 ] | ||||
|         labels: | ||||
|           namespace: 'default' | ||||
|   - job_name: 'openimserver-openim-rpc-third' | ||||
|           namespace: default | ||||
|   - job_name: openimserver-openim-rpc-third | ||||
|     static_configs: | ||||
|       - targets: [ 'internal_ip:20101' ] | ||||
|       - targets: [ internal_ip:12300 ] | ||||
|         labels: | ||||
|           namespace: 'default' | ||||
|   - job_name: 'openimserver-openim-rpc-user' | ||||
|           namespace: default | ||||
|   - job_name: openimserver-openim-rpc-user | ||||
|     static_configs: | ||||
|       - targets: [ 'internal_ip:20100' ] | ||||
|       - targets: [ internal_ip:12320 ] | ||||
|         labels: | ||||
|           namespace: 'default' | ||||
|           namespace: default | ||||
| @ -1,6 +1,7 @@ | ||||
| address: [ localhost:16379 ] | ||||
| username: '' | ||||
| username:  | ||||
| password: openIM123 | ||||
| clusterMode: false | ||||
| db: 0 | ||||
| maxRetry: 10 | ||||
| poolSize: 100 | ||||
|  | ||||
| @ -10,5 +10,7 @@ rpcRegisterName: | ||||
|   conversation: conversation | ||||
|   third: third | ||||
| 
 | ||||
| imAdminUserID: [ "imAdmin" ] | ||||
| imAdminUserID: [ imAdmin ] | ||||
| 
 | ||||
| # 1: For Android, iOS, Windows, Mac, and web platforms, only one instance can be online at a time | ||||
| multiLoginPolicy: 1 | ||||
|  | ||||
| @ -1,8 +1,18 @@ | ||||
| url: "webhook://127.0.0.1:10008/callbackExample" | ||||
| url: http://127.0.0.1:10006/callbackExample | ||||
| beforeSendSingleMsg: | ||||
|   enable: false | ||||
|   timeout: 5 | ||||
|   failedContinue: true | ||||
|   # Only the contentType in allowedTypes will send the callback. | ||||
|   # Supports two formats: a single type or a range. The range is defined by the lower and upper bounds connected with a hyphen ("-"). | ||||
|   # e.g. allowedTypes: [1, 100, 200-500, 600-700] means that only contentType within the range | ||||
|   # {1, 100} ∪ [200, 500] ∪ [600, 700] will be allowed through the filter. | ||||
|   # If not set, all contentType messages will through this filter. | ||||
|   allowedTypes: [] | ||||
|   # Only the contentType not in deniedTypes will send the callback. | ||||
|   # Supports two formats, same as allowedTypes. | ||||
|   # If not set, all contentType messages will through this filter. | ||||
|   deniedTypes: [] | ||||
| beforeUpdateUserInfoEx: | ||||
|   enable:  false | ||||
|   timeout: 5 | ||||
| @ -16,17 +26,29 @@ afterSendSingleMsg: | ||||
|   # Only the senID/recvID specified in attentionIds will send the callback | ||||
|   # if not set, all user messages will be callback | ||||
|   attentionIds: [] | ||||
|   # See beforeSendSingleMsg comment. | ||||
|   allowedTypes: [] | ||||
|   deniedTypes: [] | ||||
| beforeSendGroupMsg: | ||||
|   enable: false | ||||
|   timeout: 5 | ||||
|   failedContinue: true | ||||
|   # See beforeSendSingleMsg comment. | ||||
|   allowedTypes: [] | ||||
|   deniedTypes: [] | ||||
| beforeMsgModify: | ||||
|   enable: false | ||||
|   timeout: 5 | ||||
|   failedContinue: true | ||||
|   # See beforeSendSingleMsg comment. | ||||
|   allowedTypes: [] | ||||
|   deniedTypes: [] | ||||
| afterSendGroupMsg: | ||||
|   enable: false | ||||
|   timeout: 5 | ||||
|   # See beforeSendSingleMsg comment. | ||||
|   allowedTypes: [] | ||||
|   deniedTypes: [] | ||||
| afterUserOnline: | ||||
|   enable: false | ||||
|   timeout: 5 | ||||
| @ -130,6 +152,13 @@ beforeSetGroupInfo: | ||||
|   enable: false | ||||
|   timeout: 5 | ||||
|   failedContinue: true | ||||
| afterSetGroupInfoEx: | ||||
|   enable: false | ||||
|   timeout: 5 | ||||
| beforeSetGroupInfoEx: | ||||
|   enable: false | ||||
|   timeout: 5 | ||||
|   failedContinue: true | ||||
| afterRevokeMsg: | ||||
|   enable: false | ||||
|   timeout: 5 | ||||
| @ -144,6 +173,9 @@ beforeAddFriendAgree: | ||||
|   enable: false | ||||
|   timeout: 5 | ||||
|   failedContinue: true | ||||
| afterAddFriendAgree: | ||||
|   enable: false | ||||
|   timeout: 5 | ||||
| afterDeleteFriend: | ||||
|   enable: false | ||||
|   timeout: 5 | ||||
|  | ||||
| @ -1,5 +1,3 @@ | ||||
| version: '3' | ||||
| 
 | ||||
| networks: | ||||
|   openim: | ||||
|     driver: bridge | ||||
| @ -140,50 +138,49 @@ services: | ||||
|     networks: | ||||
|       - openim | ||||
| 
 | ||||
|   prometheus: | ||||
|     image: ${PROMETHEUS_IMAGE} | ||||
|     container_name: prometheus | ||||
|     restart: always | ||||
|     volumes: | ||||
|       - ./config/prometheus.yml:/etc/prometheus/prometheus.yml | ||||
|       - ./config/instance-down-rules.yml:/etc/prometheus/instance-down-rules.yml | ||||
|       - ${DATA_DIR}/components/prometheus/data:/prometheus | ||||
|     command: | ||||
|       - '--config.file=/etc/prometheus/prometheus.yml' | ||||
|       - '--storage.tsdb.path=/prometheus' | ||||
|     ports: | ||||
|       - "19091:9090" | ||||
|     networks: | ||||
|       - openim | ||||
| 
 | ||||
|   alertmanager: | ||||
|     image: ${ALERTMANAGER_IMAGE} | ||||
|     container_name: alertmanager | ||||
|     restart: always | ||||
|     volumes: | ||||
|       - ./config/alertmanager.yml:/etc/alertmanager/alertmanager.yml | ||||
|       - ./config/email.tmpl:/etc/alertmanager/email.tmpl | ||||
|     ports: | ||||
|       - "19093:9093" | ||||
|     networks: | ||||
|       - openim | ||||
| 
 | ||||
|   grafana: | ||||
|     image: ${GRAFANA_IMAGE} | ||||
|     container_name: grafana | ||||
|     user: root | ||||
|     restart: always | ||||
|     environment: | ||||
|       - GF_SECURITY_ALLOW_EMBEDDING=true | ||||
|       - GF_SESSION_COOKIE_SAMESITE=none | ||||
|       - GF_SESSION_COOKIE_SECURE=true | ||||
|       - GF_AUTH_ANONYMOUS_ENABLED=true | ||||
|       - GF_AUTH_ANONYMOUS_ORG_ROLE=Admin | ||||
|     ports: | ||||
|       - "13000:3000" | ||||
|     volumes: | ||||
|       - ${DATA_DIR:-./}/components/grafana:/var/lib/grafana | ||||
|     networks: | ||||
|       - openim | ||||
| 
 | ||||
| #  prometheus: | ||||
| #    image: ${PROMETHEUS_IMAGE} | ||||
| #    container_name: prometheus | ||||
| #    restart: always | ||||
| #    volumes: | ||||
| #      - ./config/prometheus.yml:/etc/prometheus/prometheus.yml | ||||
| #      - ./config/instance-down-rules.yml:/etc/prometheus/instance-down-rules.yml | ||||
| #      - ${DATA_DIR}/components/prometheus/data:/prometheus | ||||
| #    command: | ||||
| #      - '--config.file=/etc/prometheus/prometheus.yml' | ||||
| #      - '--storage.tsdb.path=/prometheus' | ||||
| #    ports: | ||||
| #      - "19091:9090" | ||||
| #    networks: | ||||
| #      - openim | ||||
| # | ||||
| #  alertmanager: | ||||
| #    image: ${ALERTMANAGER_IMAGE} | ||||
| #    container_name: alertmanager | ||||
| #    restart: always | ||||
| #    volumes: | ||||
| #      - ./config/alertmanager.yml:/etc/alertmanager/alertmanager.yml | ||||
| #      - ./config/email.tmpl:/etc/alertmanager/email.tmpl | ||||
| #    ports: | ||||
| #      - "19093:9093" | ||||
| #    networks: | ||||
| #      - openim | ||||
| # | ||||
| #  grafana: | ||||
| #    image: ${GRAFANA_IMAGE} | ||||
| #    container_name: grafana | ||||
| #    user: root | ||||
| #    restart: always | ||||
| #    environment: | ||||
| #      - GF_SECURITY_ALLOW_EMBEDDING=true | ||||
| #      - GF_SESSION_COOKIE_SAMESITE=none | ||||
| #      - GF_SESSION_COOKIE_SECURE=true | ||||
| #      - GF_AUTH_ANONYMOUS_ENABLED=true | ||||
| #      - GF_AUTH_ANONYMOUS_ORG_ROLE=Admin | ||||
| #    ports: | ||||
| #      - "13000:3000" | ||||
| #    volumes: | ||||
| #      - ${DATA_DIR:-./}/components/grafana:/var/lib/grafana | ||||
| #    networks: | ||||
| #      - openim | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										82
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										82
									
								
								go.mod
									
									
									
									
									
								
							| @ -3,24 +3,24 @@ module github.com/openimsdk/open-im-server/v3 | ||||
| go 1.21.2 | ||||
| 
 | ||||
| require ( | ||||
| 	firebase.google.com/go v3.13.0+incompatible | ||||
| 	firebase.google.com/go/v4 v4.14.1 | ||||
| 	github.com/dtm-labs/rockscache v0.1.1 | ||||
| 	github.com/gin-gonic/gin v1.9.1 | ||||
| 	github.com/go-playground/validator/v10 v10.18.0 | ||||
| 	github.com/go-playground/validator/v10 v10.20.0 | ||||
| 	github.com/gogo/protobuf v1.3.2 // indirect | ||||
| 	github.com/golang-jwt/jwt/v4 v4.5.0 | ||||
| 	github.com/gorilla/websocket v1.5.1 | ||||
| 	github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 | ||||
| 	github.com/mitchellh/mapstructure v1.5.0 | ||||
| 	github.com/openimsdk/protocol v0.0.69 | ||||
| 	github.com/openimsdk/tools v0.0.49-alpha.55 | ||||
| 	github.com/openimsdk/protocol v0.0.72 | ||||
| 	github.com/openimsdk/tools v0.0.50-alpha.16 | ||||
| 	github.com/pkg/errors v0.9.1 // indirect | ||||
| 	github.com/prometheus/client_golang v1.18.0 | ||||
| 	github.com/stretchr/testify v1.9.0 | ||||
| 	go.mongodb.org/mongo-driver v1.14.0 | ||||
| 	google.golang.org/api v0.165.0 | ||||
| 	google.golang.org/grpc v1.62.1 | ||||
| 	google.golang.org/protobuf v1.33.0 | ||||
| 	google.golang.org/api v0.170.0 | ||||
| 	google.golang.org/grpc v1.66.2 | ||||
| 	google.golang.org/protobuf v1.34.2 | ||||
| 	gopkg.in/yaml.v3 v3.0.1 | ||||
| ) | ||||
| 
 | ||||
| @ -29,6 +29,7 @@ require github.com/google/uuid v1.6.0 | ||||
| require ( | ||||
| 	github.com/IBM/sarama v1.43.0 | ||||
| 	github.com/fatih/color v1.14.1 | ||||
| 	github.com/gin-contrib/gzip v1.0.1 | ||||
| 	github.com/go-redis/redis v6.15.9+incompatible | ||||
| 	github.com/go-redis/redismock/v9 v9.2.0 | ||||
| 	github.com/hashicorp/golang-lru/v2 v2.0.7 | ||||
| @ -41,17 +42,18 @@ require ( | ||||
| 	github.com/spf13/viper v1.18.2 | ||||
| 	github.com/stathat/consistent v1.0.0 | ||||
| 	go.uber.org/automaxprocs v1.5.3 | ||||
| 	golang.org/x/sync v0.6.0 | ||||
| 	golang.org/x/exp v0.0.0-20230905200255-921286631fa9 | ||||
| 	golang.org/x/sync v0.8.0 | ||||
| ) | ||||
| 
 | ||||
| require ( | ||||
| 	cloud.google.com/go v0.112.0 // indirect | ||||
| 	cloud.google.com/go/compute v1.23.3 // indirect | ||||
| 	cloud.google.com/go/compute/metadata v0.2.3 // indirect | ||||
| 	cloud.google.com/go/firestore v1.14.0 // indirect | ||||
| 	cloud.google.com/go/iam v1.1.5 // indirect | ||||
| 	cloud.google.com/go/longrunning v0.5.4 // indirect | ||||
| 	cloud.google.com/go/storage v1.36.0 // indirect | ||||
| 	cloud.google.com/go v0.112.1 // indirect | ||||
| 	cloud.google.com/go/compute/metadata v0.3.0 // indirect | ||||
| 	cloud.google.com/go/firestore v1.15.0 // indirect | ||||
| 	cloud.google.com/go/iam v1.1.7 // indirect | ||||
| 	cloud.google.com/go/longrunning v0.5.5 // indirect | ||||
| 	cloud.google.com/go/storage v1.40.0 // indirect | ||||
| 	github.com/MicahParks/keyfunc v1.9.0 // indirect | ||||
| 	github.com/aliyun/aliyun-oss-go-sdk v3.0.2+incompatible // indirect | ||||
| 	github.com/aws/aws-sdk-go-v2 v1.23.1 // indirect | ||||
| 	github.com/aws/aws-sdk-go-v2/aws/protocol/eventstream v1.5.1 // indirect | ||||
| @ -72,11 +74,12 @@ require ( | ||||
| 	github.com/aws/aws-sdk-go-v2/service/sts v1.25.4 // indirect | ||||
| 	github.com/aws/smithy-go v1.17.0 // indirect | ||||
| 	github.com/beorn7/perks v1.0.1 // indirect | ||||
| 	github.com/bytedance/sonic v1.9.1 // indirect | ||||
| 	github.com/cespare/xxhash/v2 v2.2.0 // indirect | ||||
| 	github.com/chai2010/webp v1.1.1 // indirect | ||||
| 	github.com/chenzhuoyu/base64x v0.0.0-20221115062448-fe3a3abad311 // indirect | ||||
| 	github.com/bytedance/sonic v1.11.6 // indirect | ||||
| 	github.com/bytedance/sonic/loader v0.1.1 // indirect | ||||
| 	github.com/cespare/xxhash/v2 v2.3.0 // indirect | ||||
| 	github.com/clbanning/mxj v1.8.4 // indirect | ||||
| 	github.com/cloudwego/base64x v0.1.4 // indirect | ||||
| 	github.com/cloudwego/iasm v0.2.0 // indirect | ||||
| 	github.com/coreos/go-semver v0.3.0 // indirect | ||||
| 	github.com/coreos/go-systemd/v22 v22.3.2 // indirect | ||||
| 	github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc // indirect | ||||
| @ -100,7 +103,7 @@ require ( | ||||
| 	github.com/google/go-querystring v1.1.0 // indirect | ||||
| 	github.com/google/s2a-go v0.1.7 // indirect | ||||
| 	github.com/googleapis/enterprise-certificate-proxy v0.3.2 // indirect | ||||
| 	github.com/googleapis/gax-go/v2 v2.12.0 // indirect | ||||
| 	github.com/googleapis/gax-go/v2 v2.12.3 // indirect | ||||
| 	github.com/hashicorp/errwrap v1.1.0 // indirect | ||||
| 	github.com/hashicorp/go-multierror v1.1.1 // indirect | ||||
| 	github.com/hashicorp/go-uuid v1.0.3 // indirect | ||||
| @ -117,7 +120,7 @@ require ( | ||||
| 	github.com/json-iterator/go v1.1.12 // indirect | ||||
| 	github.com/kelindar/simd v1.1.2 // indirect | ||||
| 	github.com/klauspost/compress v1.17.7 // indirect | ||||
| 	github.com/klauspost/cpuid/v2 v2.2.6 // indirect | ||||
| 	github.com/klauspost/cpuid/v2 v2.2.7 // indirect | ||||
| 	github.com/leodido/go-urn v1.4.0 // indirect | ||||
| 	github.com/lestrrat-go/strftime v1.0.6 // indirect | ||||
| 	github.com/lithammer/shortuuid v3.0.0+incompatible // indirect | ||||
| @ -132,7 +135,7 @@ require ( | ||||
| 	github.com/modern-go/reflect2 v1.0.2 // indirect | ||||
| 	github.com/montanaflynn/stats v0.0.0-20171201202039-1bf9dbcd8cbe // indirect | ||||
| 	github.com/mozillazg/go-httpheader v0.4.0 // indirect | ||||
| 	github.com/pelletier/go-toml/v2 v2.1.0 // indirect | ||||
| 	github.com/pelletier/go-toml/v2 v2.2.2 // indirect | ||||
| 	github.com/pierrec/lz4/v4 v4.1.21 // indirect | ||||
| 	github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2 // indirect | ||||
| 	github.com/prometheus/client_model v0.5.0 // indirect | ||||
| @ -162,25 +165,24 @@ require ( | ||||
| 	go.etcd.io/etcd/client/pkg/v3 v3.5.13 // indirect | ||||
| 	go.etcd.io/etcd/client/v3 v3.5.13 // indirect | ||||
| 	go.opencensus.io v0.24.0 // indirect | ||||
| 	go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.47.0 // indirect | ||||
| 	go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.47.0 // indirect | ||||
| 	go.opentelemetry.io/otel v1.23.0 // indirect | ||||
| 	go.opentelemetry.io/otel/metric v1.23.0 // indirect | ||||
| 	go.opentelemetry.io/otel/trace v1.23.0 // indirect | ||||
| 	go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.49.0 // indirect | ||||
| 	go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.49.0 // indirect | ||||
| 	go.opentelemetry.io/otel v1.24.0 // indirect | ||||
| 	go.opentelemetry.io/otel/metric v1.24.0 // indirect | ||||
| 	go.opentelemetry.io/otel/trace v1.24.0 // indirect | ||||
| 	go.uber.org/atomic v1.9.0 // indirect | ||||
| 	go.uber.org/multierr v1.11.0 // indirect | ||||
| 	golang.org/x/arch v0.3.0 // indirect | ||||
| 	golang.org/x/exp v0.0.0-20230905200255-921286631fa9 // indirect | ||||
| 	golang.org/x/arch v0.7.0 // indirect | ||||
| 	golang.org/x/image v0.15.0 // indirect | ||||
| 	golang.org/x/net v0.22.0 // indirect | ||||
| 	golang.org/x/oauth2 v0.17.0 // indirect | ||||
| 	golang.org/x/sys v0.19.0 // indirect | ||||
| 	golang.org/x/text v0.14.0 // indirect | ||||
| 	golang.org/x/net v0.29.0 // indirect | ||||
| 	golang.org/x/oauth2 v0.21.0 // indirect | ||||
| 	golang.org/x/sys v0.25.0 // indirect | ||||
| 	golang.org/x/text v0.18.0 // indirect | ||||
| 	golang.org/x/time v0.5.0 // indirect | ||||
| 	google.golang.org/appengine v1.6.8 // indirect | ||||
| 	google.golang.org/genproto v0.0.0-20240125205218-1f4bbc51befe // indirect | ||||
| 	google.golang.org/genproto/googleapis/api v0.0.0-20240123012728-ef4313101c80 // indirect | ||||
| 	google.golang.org/genproto/googleapis/rpc v0.0.0-20240318140521-94a12d6c2237 // indirect | ||||
| 	google.golang.org/appengine/v2 v2.0.2 // indirect | ||||
| 	google.golang.org/genproto v0.0.0-20240213162025-012b6fc9bca9 // indirect | ||||
| 	google.golang.org/genproto/googleapis/api v0.0.0-20240604185151-ef581f913117 // indirect | ||||
| 	google.golang.org/genproto/googleapis/rpc v0.0.0-20240903143218-8af14fe29dc1 // indirect | ||||
| 	gorm.io/gorm v1.25.8 // indirect | ||||
| 	stathat.com/c/consistent v1.0.0 // indirect | ||||
| ) | ||||
| @ -188,10 +190,10 @@ require ( | ||||
| require ( | ||||
| 	github.com/go-playground/locales v0.14.1 // indirect | ||||
| 	github.com/goccy/go-json v0.10.2 // indirect | ||||
| 	github.com/mattn/go-isatty v0.0.19 // indirect | ||||
| 	github.com/mattn/go-isatty v0.0.20 // indirect | ||||
| 	github.com/spf13/cobra v1.8.0 | ||||
| 	github.com/ugorji/go/codec v1.2.11 // indirect | ||||
| 	github.com/ugorji/go/codec v1.2.12 // indirect | ||||
| 	go.uber.org/zap v1.24.0 // indirect | ||||
| 	golang.org/x/crypto v0.21.0 // indirect | ||||
| 	golang.org/x/crypto v0.27.0 // indirect | ||||
| 	gopkg.in/ini.v1 v1.67.0 // indirect | ||||
| ) | ||||
|  | ||||
							
								
								
									
										184
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										184
									
								
								go.sum
									
									
									
									
									
								
							| @ -1,23 +1,23 @@ | ||||
| cloud.google.com/go v0.26.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw= | ||||
| cloud.google.com/go v0.112.0 h1:tpFCD7hpHFlQ8yPwT3x+QeXqc2T6+n6T+hmABHfDUSM= | ||||
| cloud.google.com/go v0.112.0/go.mod h1:3jEEVwZ/MHU4djK5t5RHuKOA/GbLddgTdVubX1qnPD4= | ||||
| cloud.google.com/go/compute v1.23.3 h1:6sVlXXBmbd7jNX0Ipq0trII3e4n1/MsADLK6a+aiVlk= | ||||
| cloud.google.com/go/compute v1.23.3/go.mod h1:VCgBUoMnIVIR0CscqQiPJLAG25E3ZRZMzcFZeQ+h8CI= | ||||
| cloud.google.com/go/compute/metadata v0.2.3 h1:mg4jlk7mCAj6xXp9UJ4fjI9VUI5rubuGBW5aJ7UnBMY= | ||||
| cloud.google.com/go/compute/metadata v0.2.3/go.mod h1:VAV5nSsACxMJvgaAuX6Pk2AawlZn8kiOGuCv6gTkwuA= | ||||
| cloud.google.com/go/firestore v1.14.0 h1:8aLcKnMPoldYU3YHgu4t2exrKhLQkqaXAGqT0ljrFVw= | ||||
| cloud.google.com/go/firestore v1.14.0/go.mod h1:96MVaHLsEhbvkBEdZgfN+AS/GIkco1LRpH9Xp9YZfzQ= | ||||
| cloud.google.com/go/iam v1.1.5 h1:1jTsCu4bcsNsE4iiqNT5SHwrDRCfRmIaaaVFhRveTJI= | ||||
| cloud.google.com/go/iam v1.1.5/go.mod h1:rB6P/Ic3mykPbFio+vo7403drjlgvoWfYpJhMXEbzv8= | ||||
| cloud.google.com/go/longrunning v0.5.4 h1:w8xEcbZodnA2BbW6sVirkkoC+1gP8wS57EUUgGS0GVg= | ||||
| cloud.google.com/go/longrunning v0.5.4/go.mod h1:zqNVncI0BOP8ST6XQD1+VcvuShMmq7+xFSzOL++V0dI= | ||||
| cloud.google.com/go/storage v1.36.0 h1:P0mOkAcaJxhCTvAkMhxMfrTKiNcub4YmmPBtlhAyTr8= | ||||
| cloud.google.com/go/storage v1.36.0/go.mod h1:M6M/3V/D3KpzMTJyPOR/HU6n2Si5QdaXYEsng2xgOs8= | ||||
| firebase.google.com/go v3.13.0+incompatible h1:3TdYC3DDi6aHn20qoRkxwGqNgdjtblwVAyRLQwGn/+4= | ||||
| firebase.google.com/go v3.13.0+incompatible/go.mod h1:xlah6XbEyW6tbfSklcfe5FHJIwjt8toICdV5Wh9ptHs= | ||||
| cloud.google.com/go v0.112.1 h1:uJSeirPke5UNZHIb4SxfZklVSiWWVqW4oXlETwZziwM= | ||||
| cloud.google.com/go v0.112.1/go.mod h1:+Vbu+Y1UU+I1rjmzeMOb/8RfkKJK2Gyxi1X6jJCZLo4= | ||||
| cloud.google.com/go/compute/metadata v0.3.0 h1:Tz+eQXMEqDIKRsmY3cHTL6FVaynIjX2QxYC4trgAKZc= | ||||
| cloud.google.com/go/compute/metadata v0.3.0/go.mod h1:zFmK7XCadkQkj6TtorcaGlCW1hT1fIilQDwofLpJ20k= | ||||
| cloud.google.com/go/firestore v1.15.0 h1:/k8ppuWOtNuDHt2tsRV42yI21uaGnKDEQnRFeBpbFF8= | ||||
| cloud.google.com/go/firestore v1.15.0/go.mod h1:GWOxFXcv8GZUtYpWHw/w6IuYNux/BtmeVTMmjrm4yhk= | ||||
| cloud.google.com/go/iam v1.1.7 h1:z4VHOhwKLF/+UYXAJDFwGtNF0b6gjsW1Pk9Ml0U/IoM= | ||||
| cloud.google.com/go/iam v1.1.7/go.mod h1:J4PMPg8TtyurAUvSmPj8FF3EDgY1SPRZxcUGrn7WXGA= | ||||
| cloud.google.com/go/longrunning v0.5.5 h1:GOE6pZFdSrTb4KAiKnXsJBtlE6mEyaW44oKyMILWnOg= | ||||
| cloud.google.com/go/longrunning v0.5.5/go.mod h1:WV2LAxD8/rg5Z1cNW6FJ/ZpX4E4VnDnoTk0yawPBB7s= | ||||
| cloud.google.com/go/storage v1.40.0 h1:VEpDQV5CJxFmJ6ueWNsKxcr1QAYOXEgxDa+sBbJahPw= | ||||
| cloud.google.com/go/storage v1.40.0/go.mod h1:Rrj7/hKlG87BLqDJYtwR0fbPld8uJPbQ2ucUMY7Ir0g= | ||||
| firebase.google.com/go/v4 v4.14.1 h1:4qiUETaFRWoFGE1XP5VbcEdtPX93Qs+8B/7KvP2825g= | ||||
| firebase.google.com/go/v4 v4.14.1/go.mod h1:fgk2XshgNDEKaioKco+AouiegSI9oTWVqRaBdTTGBoM= | ||||
| github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= | ||||
| github.com/IBM/sarama v1.43.0 h1:YFFDn8mMI2QL0wOrG0J2sFoVIAFl7hS9JQi2YZsXtJc= | ||||
| github.com/IBM/sarama v1.43.0/go.mod h1:zlE6HEbC/SMQ9mhEYaF7nNLYOUyrs0obySKCckWP9BM= | ||||
| github.com/MicahParks/keyfunc v1.9.0 h1:lhKd5xrFHLNOWrDc4Tyb/Q1AJ4LCzQ48GVJyVIID3+o= | ||||
| github.com/MicahParks/keyfunc v1.9.0/go.mod h1:IdnCilugA0O/99dW+/MkvlyrsX8+L8+x95xuVNtM5jw= | ||||
| github.com/QcloudApi/qcloud_sign_golang v0.0.0-20141224014652-e4130a326409/go.mod h1:1pk82RBxDY/JZnPQrtqHlUFfCctgdorsd9M06fMynOM= | ||||
| github.com/aliyun/aliyun-oss-go-sdk v3.0.2+incompatible h1:8psS8a+wKfiLt1iVDX79F7Y6wUM49Lcha2FMXt4UM8g= | ||||
| github.com/aliyun/aliyun-oss-go-sdk v3.0.2+incompatible/go.mod h1:T/Aws4fEfogEE9v+HPhhw+CntffsBHJ8nXQCwKr0/g8= | ||||
| @ -65,23 +65,21 @@ github.com/bsm/ginkgo/v2 v2.12.0 h1:Ny8MWAHyOepLGlLKYmXG4IEkioBysk6GpaRTLC8zwWs= | ||||
| github.com/bsm/ginkgo/v2 v2.12.0/go.mod h1:SwYbGRRDovPVboqFv0tPTcG1sN61LM1Z4ARdbAV9g4c= | ||||
| github.com/bsm/gomega v1.27.10 h1:yeMWxP2pV2fG3FgAODIY8EiRE3dy0aeFYt4l7wh6yKA= | ||||
| github.com/bsm/gomega v1.27.10/go.mod h1:JyEr/xRbxbtgWNi8tIEVPUYZ5Dzef52k01W3YH0H+O0= | ||||
| github.com/bytedance/sonic v1.5.0/go.mod h1:ED5hyg4y6t3/9Ku1R6dU/4KyJ48DZ4jPhfY1O2AihPM= | ||||
| github.com/bytedance/sonic v1.9.1 h1:6iJ6NqdoxCDr6mbY8h18oSO+cShGSMRGCEo7F2h0x8s= | ||||
| github.com/bytedance/sonic v1.9.1/go.mod h1:i736AoUSYt75HyZLoJW9ERYxcy6eaN6h4BZXU064P/U= | ||||
| github.com/bytedance/sonic v1.11.6 h1:oUp34TzMlL+OY1OUWxHqsdkgC/Zfc85zGqw9siXjrc0= | ||||
| github.com/bytedance/sonic v1.11.6/go.mod h1:LysEHSvpvDySVdC2f87zGWf6CIKJcAvqab1ZaiQtds4= | ||||
| github.com/bytedance/sonic/loader v0.1.1 h1:c+e5Pt1k/cy5wMveRDyk2X4B9hF4g7an8N3zCYjJFNM= | ||||
| github.com/bytedance/sonic/loader v0.1.1/go.mod h1:ncP89zfokxS5LZrJxl5z0UJcsk4M4yY2JpfqGeCtNLU= | ||||
| github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU= | ||||
| github.com/cespare/xxhash/v2 v2.2.0 h1:DC2CZ1Ep5Y4k3ZQ899DldepgrayRUGE6BBZ/cd9Cj44= | ||||
| github.com/cespare/xxhash/v2 v2.2.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= | ||||
| github.com/chai2010/webp v1.1.1 h1:jTRmEccAJ4MGrhFOrPMpNGIJ/eybIgwKpcACsrTEapk= | ||||
| github.com/chai2010/webp v1.1.1/go.mod h1:0XVwvZWdjjdxpUEIf7b9g9VkHFnInUSYujwqTLEuldU= | ||||
| github.com/chenzhuoyu/base64x v0.0.0-20211019084208-fb5309c8db06/go.mod h1:DH46F32mSOjUmXrMHnKwZdA8wcEefY7UVqBKYGjpdQY= | ||||
| github.com/chenzhuoyu/base64x v0.0.0-20221115062448-fe3a3abad311 h1:qSGYFH7+jGhDF8vLC+iwCD4WpbV1EBDSzWkJODFLams= | ||||
| github.com/chenzhuoyu/base64x v0.0.0-20221115062448-fe3a3abad311/go.mod h1:b583jCggY9gE99b6G5LEC39OIiVsWj+R97kbl5odCEk= | ||||
| github.com/cespare/xxhash/v2 v2.3.0 h1:UL815xU9SqsFlibzuggzjXhog7bL6oX9BbNZnL2UFvs= | ||||
| github.com/cespare/xxhash/v2 v2.3.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= | ||||
| github.com/clbanning/mxj v1.8.4 h1:HuhwZtbyvyOw+3Z1AowPkU87JkJUSv751ELWaiTpj8I= | ||||
| github.com/clbanning/mxj v1.8.4/go.mod h1:BVjHeAH+rl9rs6f+QIpeRl0tfu10SXn1pUSa5PVGJng= | ||||
| github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw= | ||||
| github.com/cloudwego/base64x v0.1.4 h1:jwCgWpFanWmN8xoIUHa2rtzmkd5J2plF/dnLS6Xd/0Y= | ||||
| github.com/cloudwego/base64x v0.1.4/go.mod h1:0zlkT4Wn5C6NdauXdJRhSKRlJvmclQ1hhJgA0rcu/8w= | ||||
| github.com/cloudwego/iasm v0.2.0 h1:1KNIy1I1H9hNNFEEH3DVnI4UujN+1zjpuk6gwHLTssg= | ||||
| github.com/cloudwego/iasm v0.2.0/go.mod h1:8rXZaNYT2n95jn+zTI1sDr+IgcD2GVs0nlbbQPiEFhY= | ||||
| github.com/cncf/udpa/go v0.0.0-20191209042840-269d4d468f6f/go.mod h1:M8M6+tZqaGXZJjfX53e64911xZQV5JYwmTeXPW+k8Sc= | ||||
| github.com/cncf/xds/go v0.0.0-20231128003011-0fa0005c9caa h1:jQCWAUqqlij9Pgj2i/PB79y4KOPYVyFYdROxgaCwdTQ= | ||||
| github.com/cncf/xds/go v0.0.0-20231128003011-0fa0005c9caa/go.mod h1:x/1Gn8zydmfq8dk6e9PdstVsDgu9RuyIIJqAaF//0IM= | ||||
| github.com/coreos/go-semver v0.3.0 h1:wkHLiw0WNATZnSG7epLsujiMCgPAc9xhjJ4tgnAxmfM= | ||||
| github.com/coreos/go-semver v0.3.0/go.mod h1:nnelYz7RCh+5ahJtPPxZlU+153eP4D4r3EedlOD2RNk= | ||||
| github.com/coreos/go-systemd/v22 v22.3.2 h1:D9/bQk5vlXQFZ6Kwuu6zaiXJ9oTPe68++AzAJc1DzSI= | ||||
| @ -109,8 +107,6 @@ github.com/envoyproxy/go-control-plane v0.9.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymF | ||||
| github.com/envoyproxy/go-control-plane v0.9.1-0.20191026205805-5f8ba28d4473/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= | ||||
| github.com/envoyproxy/go-control-plane v0.9.4/go.mod h1:6rpuAdCZL397s3pYoYcLgu1mIlRU8Am5FuJP05cCM98= | ||||
| github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c= | ||||
| github.com/envoyproxy/protoc-gen-validate v1.0.4 h1:gVPz/FMfvh57HdSJQyvBtF00j8JU4zdyUgIUNhlgg0A= | ||||
| github.com/envoyproxy/protoc-gen-validate v1.0.4/go.mod h1:qys6tmnRsYrQqIhm2bvKZH4Blx/1gTIZ2UKVY1M+Yew= | ||||
| github.com/fatih/color v1.14.1 h1:qfhVLaG5s+nCROl1zJsZRxFeYrHLqWroPOQ8BWiNb4w= | ||||
| github.com/fatih/color v1.14.1/go.mod h1:2oHN61fhTpgcxD3TSWCgKDiH1+x4OiDVVGH8WlgGZGg= | ||||
| github.com/felixge/httpsnoop v1.0.4 h1:NFTV2Zj1bL4mc9sqWACXbQFVBBg2W3GPvqp8/ESS2Wg= | ||||
| @ -123,6 +119,8 @@ github.com/fsnotify/fsnotify v1.7.0 h1:8JEhPFa5W2WU7YfeZzPNqzMP6Lwt7L2715Ggo0nos | ||||
| github.com/fsnotify/fsnotify v1.7.0/go.mod h1:40Bi/Hjc2AVfZrqy+aj+yEI+/bRxZnMJyTJwOpGvigM= | ||||
| github.com/gabriel-vasile/mimetype v1.4.3 h1:in2uUcidCuFcDKtdcBxlR0rJ1+fsokWf+uqxgUFjbI0= | ||||
| github.com/gabriel-vasile/mimetype v1.4.3/go.mod h1:d8uq/6HKRL6CGdk+aubisF/M5GcPfT7nKyLpA0lbSSk= | ||||
| github.com/gin-contrib/gzip v1.0.1 h1:HQ8ENHODeLY7a4g1Au/46Z92bdGFl74OhxcZble9WJE= | ||||
| github.com/gin-contrib/gzip v1.0.1/go.mod h1:njt428fdUNRvjuJf16tZMYZ2Yl+WQB53X5wmhDwXvC4= | ||||
| github.com/gin-contrib/sse v0.1.0 h1:Y/yl/+YNO8GZSjAhjMsSuLt29uWRFHdHYUb5lYOV9qE= | ||||
| github.com/gin-contrib/sse v0.1.0/go.mod h1:RHrZQHXnP2xjPF+u1gW/2HnVO7nvIa9PG3Gm+fLHvGI= | ||||
| github.com/gin-gonic/gin v1.9.1 h1:4idEAncQnU5cB7BeOkPtxjfCSye0AAm1R0RVIqJ+Jmg= | ||||
| @ -146,8 +144,8 @@ github.com/go-playground/universal-translator v0.18.0/go.mod h1:UvRDBj+xPUEGrFYl | ||||
| github.com/go-playground/universal-translator v0.18.1 h1:Bcnm0ZwsGyWbCzImXv+pAJnYK9S473LQFuzCbDbfSFY= | ||||
| github.com/go-playground/universal-translator v0.18.1/go.mod h1:xekY+UJKNuX9WP91TpwSH2VMlDf28Uj24BCp08ZFTUY= | ||||
| github.com/go-playground/validator/v10 v10.8.0/go.mod h1:9JhgTzTaE31GZDpH/HSvHiRJrJ3iKAgqqH0Bl/Ocjdk= | ||||
| github.com/go-playground/validator/v10 v10.18.0 h1:BvolUXjp4zuvkZ5YN5t7ebzbhlUtPsPm2S9NAZ5nl9U= | ||||
| github.com/go-playground/validator/v10 v10.18.0/go.mod h1:dbuPbCMFw/DrkbEynArYaCwl3amGuJotoKCe95atGMM= | ||||
| github.com/go-playground/validator/v10 v10.20.0 h1:K9ISHbSaI0lyB2eWMPJo+kOS/FBExVwjEviJTixqxL8= | ||||
| github.com/go-playground/validator/v10 v10.20.0/go.mod h1:dbuPbCMFw/DrkbEynArYaCwl3amGuJotoKCe95atGMM= | ||||
| github.com/go-redis/redis v6.15.9+incompatible h1:K0pv1D7EQUjfyoMql+r/jZqCLizCGKFlFgcHWWmHQjg= | ||||
| github.com/go-redis/redis v6.15.9+incompatible/go.mod h1:NAIEuMOZ/fxfXJIrKDQDz8wamY7mA7PouImQ2Jvg6kA= | ||||
| github.com/go-redis/redismock/v9 v9.2.0 h1:ZrMYQeKPECZPjOj5u9eyOjg8Nnb0BS9lkVIZ6IpsKLw= | ||||
| @ -159,6 +157,7 @@ github.com/goccy/go-json v0.10.2/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MG | ||||
| github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA= | ||||
| github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q= | ||||
| github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q= | ||||
| github.com/golang-jwt/jwt/v4 v4.4.2/go.mod h1:m21LjoU+eqJr34lmDMbreY2eSTRJ1cv77w39/MY0Ch0= | ||||
| github.com/golang-jwt/jwt/v4 v4.5.0 h1:7cYmW1XlMY7h7ii7UhUyChSgS5wUJEnm9uZVTGqOWzg= | ||||
| github.com/golang-jwt/jwt/v4 v4.5.0/go.mod h1:m21LjoU+eqJr34lmDMbreY2eSTRJ1cv77w39/MY0Ch0= | ||||
| github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q= | ||||
| @ -167,6 +166,7 @@ github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da h1:oI5xCqsCo564l | ||||
| github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= | ||||
| github.com/golang/mock v1.1.1/go.mod h1:oTYuIxOrZwtPieC+H1uAHpcLFnEyAGVDL/k47Jfbm0A= | ||||
| github.com/golang/protobuf v1.2.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= | ||||
| github.com/golang/protobuf v1.3.1/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= | ||||
| github.com/golang/protobuf v1.3.2/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= | ||||
| github.com/golang/protobuf v1.4.0-rc.1/go.mod h1:ceaxUfeHdC40wWswd/P6IGgMaK3YpKi5j83Wpe3EHw8= | ||||
| github.com/golang/protobuf v1.4.0-rc.1.0.20200221234624-67d41d38c208/go.mod h1:xKAWHe0F5eneWXFV3EuXVDTCmh+JuBKY0li0aMyXATA= | ||||
| @ -175,8 +175,6 @@ github.com/golang/protobuf v1.4.0-rc.4.0.20200313231945-b860323f09d0/go.mod h1:W | ||||
| github.com/golang/protobuf v1.4.0/go.mod h1:jodUvKwWbYaEsadDk5Fwe5c77LiNKVO9IDvqG2KuDX0= | ||||
| github.com/golang/protobuf v1.4.1/go.mod h1:U8fpvMrcmy5pZrNK1lt4xCsGvpyWQ/VVv6QDs8UjoX8= | ||||
| github.com/golang/protobuf v1.4.3/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI= | ||||
| github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk= | ||||
| github.com/golang/protobuf v1.5.2/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY= | ||||
| github.com/golang/protobuf v1.5.4 h1:i7eJL8qZTpSEXOPTxNKhASYpMn+8e5Q6AdndVa1dWek= | ||||
| github.com/golang/protobuf v1.5.4/go.mod h1:lnTiLA8Wa4RWRcIUkrtSVa5nRhsEGBg48fD6rSs7xps= | ||||
| github.com/golang/snappy v0.0.4 h1:yAGX7huGHXlcLOEtBnF4w7FQwA26wojNCwOYAEhLjQM= | ||||
| @ -188,7 +186,6 @@ github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/ | ||||
| github.com/google/go-cmp v0.5.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= | ||||
| github.com/google/go-cmp v0.5.2/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= | ||||
| github.com/google/go-cmp v0.5.3/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= | ||||
| github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= | ||||
| github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI= | ||||
| github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= | ||||
| github.com/google/go-querystring v1.0.0/go.mod h1:odCYkC5MyYFN7vkCjXpyrEuKhc/BUO6wN/zVPAxq5ck= | ||||
| @ -205,8 +202,8 @@ github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0= | ||||
| github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= | ||||
| github.com/googleapis/enterprise-certificate-proxy v0.3.2 h1:Vie5ybvEvT75RniqhfFxPRy3Bf7vr3h0cechB90XaQs= | ||||
| github.com/googleapis/enterprise-certificate-proxy v0.3.2/go.mod h1:VLSiSSBs/ksPL8kq3OBOQ6WRI2QnaFynd1DCjZ62+V0= | ||||
| github.com/googleapis/gax-go/v2 v2.12.0 h1:A+gCJKdRfqXkr+BIRGtZLibNXf0m1f9E4HG56etFpas= | ||||
| github.com/googleapis/gax-go/v2 v2.12.0/go.mod h1:y+aIqrI5eb1YGMVJfuV3185Ts/D7qKpsEkdD5+I6QGU= | ||||
| github.com/googleapis/gax-go/v2 v2.12.3 h1:5/zPPDvw8Q1SuXjrqrZslrqT7dL/uJT2CQii/cLCKqA= | ||||
| github.com/googleapis/gax-go/v2 v2.12.3/go.mod h1:AKloxT6GtNbaLm8QTNSidHUVsHYcBHwWRvkNFJUQcS4= | ||||
| github.com/gorilla/securecookie v1.1.1/go.mod h1:ra0sb63/xPlUeL+yeDciTfxMRAA+MP+HVt/4epWDjd4= | ||||
| github.com/gorilla/sessions v1.2.1/go.mod h1:dk2InVEVJ0sfLlnXv9EAgkf6ecYs/i80K/zI+bUmuGM= | ||||
| github.com/gorilla/websocket v1.5.1 h1:gmztn0JnHVt9JZquRuzLw3g4wouNVzKL15iLr/zn/QY= | ||||
| @ -259,8 +256,9 @@ github.com/klauspost/compress v1.17.7 h1:ehO88t2UGzQK66LMdE8tibEd1ErmzZjNEqWkjLA | ||||
| github.com/klauspost/compress v1.17.7/go.mod h1:Di0epgTjJY877eYKx5yC51cX2A2Vl2ibi7bDH9ttBbw= | ||||
| github.com/klauspost/cpuid/v2 v2.0.1/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa0213Md/qVLRg= | ||||
| github.com/klauspost/cpuid/v2 v2.0.9/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa0213Md/qVLRg= | ||||
| github.com/klauspost/cpuid/v2 v2.2.6 h1:ndNyv040zDGIDh8thGkXYjnFtiN02M1PVVF+JE/48xc= | ||||
| github.com/klauspost/cpuid/v2 v2.2.6/go.mod h1:Lcz8mBdAVJIBVzewtcLocK12l3Y+JytZYpaMropDUws= | ||||
| github.com/klauspost/cpuid/v2 v2.2.7 h1:ZWSB3igEs+d0qvnxR/ZBzXVmxkgt8DdzP6m9pfuVLDM= | ||||
| github.com/klauspost/cpuid/v2 v2.2.7/go.mod h1:Lcz8mBdAVJIBVzewtcLocK12l3Y+JytZYpaMropDUws= | ||||
| github.com/knz/go-libedit v1.10.1/go.mod h1:MZTVkCWyz0oBc7JOWP3wNAzd002ZbM/5hgShxwh4x8M= | ||||
| github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo= | ||||
| github.com/kr/pretty v0.2.1/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI= | ||||
| github.com/kr/pretty v0.3.0/go.mod h1:640gp4NfQd8pI5XOwp5fnNeVWj67G7CFk/SaSQn7NBk= | ||||
| @ -290,8 +288,8 @@ github.com/magiconair/properties v1.8.7/go.mod h1:Dhd985XPs7jluiymwWYZ0G4Z61jb3v | ||||
| github.com/mattn/go-colorable v0.1.13 h1:fFA4WZxdEF4tXPZVKMLwD8oUnCTTo08duU7wxecdEvA= | ||||
| github.com/mattn/go-colorable v0.1.13/go.mod h1:7S9/ev0klgBDR4GtXTXX8a3vIGJpMovkB8vQcUbaXHg= | ||||
| github.com/mattn/go-isatty v0.0.16/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM= | ||||
| github.com/mattn/go-isatty v0.0.19 h1:JITubQf0MOLdlGRuRq+jtsDlekdYPia9ZFsB8h/APPA= | ||||
| github.com/mattn/go-isatty v0.0.19/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= | ||||
| github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWEY= | ||||
| github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= | ||||
| github.com/matttproud/golang_protobuf_extensions/v2 v2.0.0 h1:jWpvCLoY8Z/e3VKvlsiIGKtc+UG6U5vzxaoagmhXfyg= | ||||
| github.com/matttproud/golang_protobuf_extensions/v2 v2.0.0/go.mod h1:QUyp042oQthUoa9bqDv0ER0wrtXnBruoNd7aNjkbP+k= | ||||
| github.com/minio/md5-simd v1.1.2 h1:Gdi1DZK69+ZVMoNHRXJyNcxrMA4dSxoYHZSQbirFg34= | ||||
| @ -321,12 +319,12 @@ github.com/onsi/gomega v1.25.0 h1:Vw7br2PCDYijJHSfBOWhov+8cAnUf8MfMaIOV323l6Y= | ||||
| github.com/onsi/gomega v1.25.0/go.mod h1:r+zV744Re+DiYCIPRlYOTxn0YkOLcAnW8k1xXdMPGhM= | ||||
| github.com/openimsdk/gomake v0.0.14-alpha.5 h1:VY9c5x515lTfmdhhPjMvR3BBRrRquAUCFsz7t7vbv7Y= | ||||
| github.com/openimsdk/gomake v0.0.14-alpha.5/go.mod h1:PndCozNc2IsQIciyn9mvEblYWZwJmAI+06z94EY+csI= | ||||
| github.com/openimsdk/protocol v0.0.69 h1:dVi8meSg8kmUzSH1XQab4MjihqKkkcCAmt1BYXPJuXo= | ||||
| github.com/openimsdk/protocol v0.0.69/go.mod h1:OZQA9FR55lseYoN2Ql1XAHYKHJGu7OMNkUbuekrKCM8= | ||||
| github.com/openimsdk/tools v0.0.49-alpha.55 h1:KPgC53oqiwZYssLKljhtXbWXifMlTj2SSQEusj4Uf4k= | ||||
| github.com/openimsdk/tools v0.0.49-alpha.55/go.mod h1:h1cYmfyaVtgFbKmb1Cfsl8XwUOMTt8ubVUQrdGtsUh4= | ||||
| github.com/pelletier/go-toml/v2 v2.1.0 h1:FnwAJ4oYMvbT/34k9zzHuZNrhlz48GB3/s6at6/MHO4= | ||||
| github.com/pelletier/go-toml/v2 v2.1.0/go.mod h1:tJU2Z3ZkXwnxa4DPO899bsyIoywizdUvyaeZurnPPDc= | ||||
| github.com/openimsdk/protocol v0.0.72 h1:K+vslwaR7lDXyBzb07UuEQITaqsgighz7NyXVIWsu6A= | ||||
| github.com/openimsdk/protocol v0.0.72/go.mod h1:OZQA9FR55lseYoN2Ql1XAHYKHJGu7OMNkUbuekrKCM8= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.16 h1:bC1AQvJMuOHtZm8LZRvN8L5mH1Ws2VYdL+TLTs1iGSc= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.16/go.mod h1:h1cYmfyaVtgFbKmb1Cfsl8XwUOMTt8ubVUQrdGtsUh4= | ||||
| github.com/pelletier/go-toml/v2 v2.2.2 h1:aYUidT7k73Pcl9nb2gScu7NSrKCSHIDE89b3+6Wq+LM= | ||||
| github.com/pelletier/go-toml/v2 v2.2.2/go.mod h1:1t835xjRzz80PqgE6HHgN2JOsmgYu/h4qDAS4n929Rs= | ||||
| github.com/pierrec/lz4/v4 v4.1.21 h1:yOVMLb6qSIDP67pl/5F7RepeKYu/VmTyEXvuMI5d9mQ= | ||||
| github.com/pierrec/lz4/v4 v4.1.21/go.mod h1:gZWDp/Ze/IJXGXf23ltt2EXimqmTUXEy0GFuRQyBid4= | ||||
| github.com/pkg/diff v0.0.0-20210226163009-20ebb0f2a09e/go.mod h1:pJLUxLENpZxwdsKMEsNbx1VGcRFpLqf3715MtcvvzbA= | ||||
| @ -410,8 +408,8 @@ github.com/tklauser/numcpus v0.7.0 h1:yjuerZP127QG9m5Zh/mSO4wqurYil27tHrqwRoRjpr | ||||
| github.com/tklauser/numcpus v0.7.0/go.mod h1:bb6dMVcj8A42tSE7i32fsIUCbQNllK5iDguyOZRUzAY= | ||||
| github.com/twitchyliquid64/golang-asm v0.15.1 h1:SU5vSMR7hnwNxj24w34ZyCi/FmDZTkS4MhqMhdFk5YI= | ||||
| github.com/twitchyliquid64/golang-asm v0.15.1/go.mod h1:a1lVb/DtPvCB8fslRZhAngC2+aY1QWCk3Cedj/Gdt08= | ||||
| github.com/ugorji/go/codec v1.2.11 h1:BMaWp1Bb6fHwEtbplGBGJ498wD+LKlNSl25MjdZY4dU= | ||||
| github.com/ugorji/go/codec v1.2.11/go.mod h1:UNopzCgEMSXjBc6AOMqYvWC1ktqTAfzJZUZgYf6w6lg= | ||||
| github.com/ugorji/go/codec v1.2.12 h1:9LC83zGrHhuUA9l16C9AHXAqEV/2wBQ4nkvumAE65EE= | ||||
| github.com/ugorji/go/codec v1.2.12/go.mod h1:UNopzCgEMSXjBc6AOMqYvWC1ktqTAfzJZUZgYf6w6lg= | ||||
| github.com/xdg-go/pbkdf2 v1.0.0 h1:Su7DPu48wXMwC3bs7MCNG+z4FhcyEuz5dlvchbq0B0c= | ||||
| github.com/xdg-go/pbkdf2 v1.0.0/go.mod h1:jrpuAogTd400dnrH08LKmI/xc1MbPOebTwRqcT5RDeI= | ||||
| github.com/xdg-go/scram v1.1.2 h1:FHX5I5B4i4hKRVRBCFRxq1iQRej7WO3hhBuJf+UUySY= | ||||
| @ -435,18 +433,18 @@ go.mongodb.org/mongo-driver v1.14.0 h1:P98w8egYRjYe3XDjxhYJagTokP/H6HzlsnojRgZRd | ||||
| go.mongodb.org/mongo-driver v1.14.0/go.mod h1:Vzb0Mk/pa7e6cWw85R4F/endUC3u0U9jGcNU603k65c= | ||||
| go.opencensus.io v0.24.0 h1:y73uSU6J157QMP2kn2r30vwW1A2W2WFwSCGnAVxeaD0= | ||||
| go.opencensus.io v0.24.0/go.mod h1:vNK8G9p7aAivkbmorf4v+7Hgx+Zs0yY+0fOtgBfjQKo= | ||||
| go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.47.0 h1:UNQQKPfTDe1J81ViolILjTKPr9WetKW6uei2hFgJmFs= | ||||
| go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.47.0/go.mod h1:r9vWsPS/3AQItv3OSlEJ/E4mbrhUbbw18meOjArPtKQ= | ||||
| go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.47.0 h1:sv9kVfal0MK0wBMCOGr+HeJm9v803BkJxGrk2au7j08= | ||||
| go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.47.0/go.mod h1:SK2UL73Zy1quvRPonmOmRDiWk1KBV3LyIeeIxcEApWw= | ||||
| go.opentelemetry.io/otel v1.23.0 h1:Df0pqjqExIywbMCMTxkAwzjLZtRf+bBKLbUcpxO2C9E= | ||||
| go.opentelemetry.io/otel v1.23.0/go.mod h1:YCycw9ZeKhcJFrb34iVSkyT0iczq/zYDtZYFufObyB0= | ||||
| go.opentelemetry.io/otel/metric v1.23.0 h1:pazkx7ss4LFVVYSxYew7L5I6qvLXHA0Ap2pwV+9Cnpo= | ||||
| go.opentelemetry.io/otel/metric v1.23.0/go.mod h1:MqUW2X2a6Q8RN96E2/nqNoT+z9BSms20Jb7Bbp+HiTo= | ||||
| go.opentelemetry.io/otel/sdk v1.21.0 h1:FTt8qirL1EysG6sTQRZ5TokkU8d0ugCj8htOgThZXQ8= | ||||
| go.opentelemetry.io/otel/sdk v1.21.0/go.mod h1:Nna6Yv7PWTdgJHVRD9hIYywQBRx7pbox6nwBnZIxl/E= | ||||
| go.opentelemetry.io/otel/trace v1.23.0 h1:37Ik5Ib7xfYVb4V1UtnT97T1jI+AoIYkJyPkuL4iJgI= | ||||
| go.opentelemetry.io/otel/trace v1.23.0/go.mod h1:GSGTbIClEsuZrGIzoEHqsVfxgn5UkggkflQwDScNUsk= | ||||
| go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.49.0 h1:4Pp6oUg3+e/6M4C0A/3kJ2VYa++dsWVTtGgLVj5xtHg= | ||||
| go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.49.0/go.mod h1:Mjt1i1INqiaoZOMGR1RIUJN+i3ChKoFRqzrRQhlkbs0= | ||||
| go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.49.0 h1:jq9TW8u3so/bN+JPT166wjOI6/vQPF6Xe7nMNIltagk= | ||||
| go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.49.0/go.mod h1:p8pYQP+m5XfbZm9fxtSKAbM6oIllS7s2AfxrChvc7iw= | ||||
| go.opentelemetry.io/otel v1.24.0 h1:0LAOdjNmQeSTzGBzduGe/rU4tZhMwL5rWgtp9Ku5Jfo= | ||||
| go.opentelemetry.io/otel v1.24.0/go.mod h1:W7b9Ozg4nkF5tWI5zsXkaKKDjdVjpD4oAt9Qi/MArHo= | ||||
| go.opentelemetry.io/otel/metric v1.24.0 h1:6EhoGWWK28x1fbpA4tYTOWBkPefTDQnb8WSGXlc88kI= | ||||
| go.opentelemetry.io/otel/metric v1.24.0/go.mod h1:VYhLe1rFfxuTXLgj4CBiyz+9WYBA8pNGJgDcSFRKBco= | ||||
| go.opentelemetry.io/otel/sdk v1.22.0 h1:6coWHw9xw7EfClIC/+O31R8IY3/+EiRFHevmHafB2Gw= | ||||
| go.opentelemetry.io/otel/sdk v1.22.0/go.mod h1:iu7luyVGYovrRpe2fmj3CVKouQNdTOkxtLzPvPz1DOc= | ||||
| go.opentelemetry.io/otel/trace v1.24.0 h1:CsKnnL4dUAr/0llH9FKuc698G04IrpWV0MQA/Y1YELI= | ||||
| go.opentelemetry.io/otel/trace v1.24.0/go.mod h1:HPc3Xr/cOApsBI154IU0OI0HJexz+aw5uPdbs3UCjNU= | ||||
| go.uber.org/atomic v1.9.0 h1:ECmE8Bn/WFTYwEW/bpKD3M8VtR/zQVbavAoalC1PYyE= | ||||
| go.uber.org/atomic v1.9.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc= | ||||
| go.uber.org/automaxprocs v1.5.3 h1:kWazyxZUrS3Gs4qUpbwo5kEIMGe/DAvi5Z4tl2NW4j8= | ||||
| @ -458,8 +456,8 @@ go.uber.org/multierr v1.11.0/go.mod h1:20+QtiLqy0Nd6FdQB9TLXag12DsQkrbs3htMFfDN8 | ||||
| go.uber.org/zap v1.24.0 h1:FiJd5l1UOLj0wCgbSE0rwwXHzEdAZS6hiiSnxJN/D60= | ||||
| go.uber.org/zap v1.24.0/go.mod h1:2kMP+WWQ8aoFoedH3T2sq6iJ2yDWpHbP0f6MQbS9Gkg= | ||||
| golang.org/x/arch v0.0.0-20210923205945-b76863e36670/go.mod h1:5om86z9Hs0C8fWVUuoMHwpExlXzs5Tkyp9hOrfG7pp8= | ||||
| golang.org/x/arch v0.3.0 h1:02VY4/ZcO/gBOH6PUaoiptASxtXU10jazRCP865E97k= | ||||
| golang.org/x/arch v0.3.0/go.mod h1:5om86z9Hs0C8fWVUuoMHwpExlXzs5Tkyp9hOrfG7pp8= | ||||
| golang.org/x/arch v0.7.0 h1:pskyeJh/3AmoQ8CPE95vxHLqp1G1GfGNXTmcl9NEKTc= | ||||
| golang.org/x/arch v0.7.0/go.mod h1:FEVrYAQjsQXMVJ1nsMoVVXPZg6p2JE2mx8psSWTDQys= | ||||
| golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= | ||||
| golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= | ||||
| golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= | ||||
| @ -467,8 +465,8 @@ golang.org/x/crypto v0.0.0-20210711020723-a769d52b0f97/go.mod h1:GvvjBRRGRdwPK5y | ||||
| golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= | ||||
| golang.org/x/crypto v0.1.0/go.mod h1:RecgLatLF4+eUMCP1PoPZQb+cVrJcOPbHkTkbkB9sbw= | ||||
| golang.org/x/crypto v0.6.0/go.mod h1:OFC/31mSvZgRz0V1QTNCzfAI1aIRzbiufJtkMIlEp58= | ||||
| golang.org/x/crypto v0.21.0 h1:X31++rzVUdKhX5sWmSOFZxx8UW/ldWx55cbf08iNAMA= | ||||
| golang.org/x/crypto v0.21.0/go.mod h1:0BP7YvVV9gBbVKyeTG0Gyn+gZm94bibOW5BjDEYAOMs= | ||||
| golang.org/x/crypto v0.27.0 h1:GXm2NjJrPaiv/h1tb2UH8QfgC/hOf/+z0p6PT8o1w7A= | ||||
| golang.org/x/crypto v0.27.0/go.mod h1:1Xngt8kV6Dvbssa53Ziq6Eqn0HqbZi5Z6R0ZpwQzt70= | ||||
| golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= | ||||
| golang.org/x/exp v0.0.0-20230905200255-921286631fa9 h1:GoHiUyI/Tp2nVkLI2mCxVkOjsbSXD66ic0XW0js0R9g= | ||||
| golang.org/x/exp v0.0.0-20230905200255-921286631fa9/go.mod h1:S2oDrQGGwySpoQPVqRShND87VCbxmc6bL1Yd2oYrm6k= | ||||
| @ -491,23 +489,24 @@ golang.org/x/net v0.0.0-20200226121028-0de0cce0169b/go.mod h1:z5CRVTTTmAJ677TzLL | ||||
| golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= | ||||
| golang.org/x/net v0.0.0-20201110031124-69a78807bb2b/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= | ||||
| golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= | ||||
| golang.org/x/net v0.0.0-20220708220712-1185a9018129/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= | ||||
| golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= | ||||
| golang.org/x/net v0.1.0/go.mod h1:Cx3nUiGt4eDBEyega/BKRp+/AlGL8hYe7U9odMt2Cco= | ||||
| golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs= | ||||
| golang.org/x/net v0.7.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs= | ||||
| golang.org/x/net v0.22.0 h1:9sGLhx7iRIHEiX0oAJ3MRZMUCElJgy7Br1nO+AMN3Tc= | ||||
| golang.org/x/net v0.22.0/go.mod h1:JKghWKKOSdJwpW2GEx0Ja7fmaKnMsbu+MWVZTokSYmg= | ||||
| golang.org/x/net v0.29.0 h1:5ORfpBpCs4HzDYoodCDBbwHzdR5UrLBZ3sOnUJmFoHo= | ||||
| golang.org/x/net v0.29.0/go.mod h1:gLkgy8jTGERgjzMic6DS9+SP0ajcu6Xu3Orq/SpETg0= | ||||
| golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= | ||||
| golang.org/x/oauth2 v0.17.0 h1:6m3ZPmLEFdVxKKWnKq4VqZ60gutO35zm+zrAHVmHyDQ= | ||||
| golang.org/x/oauth2 v0.17.0/go.mod h1:OzPDGQiuQMguemayvdylqddI7qcD9lnSDb+1FiwQ5HA= | ||||
| golang.org/x/oauth2 v0.21.0 h1:tsimM75w1tF/uws5rbeHzIWxEqElMehnc+iW793zsZs= | ||||
| golang.org/x/oauth2 v0.21.0/go.mod h1:XYTD2NtWslqkgxebSiOHnXEap4TF09sJSc7H1sXbhtI= | ||||
| golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
| golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
| golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
| golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
| golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
| golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
| golang.org/x/sync v0.6.0 h1:5BMeUDZ7vkXGfEr1x9B4bRcTH4lpkTkpdh0T/J+qjbQ= | ||||
| golang.org/x/sync v0.6.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= | ||||
| golang.org/x/sync v0.8.0 h1:3NFvSEYkUoMifnESzZl15y791HH1qU2xm6eCJU5ZPXQ= | ||||
| golang.org/x/sync v0.8.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= | ||||
| golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||
| golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||
| golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| @ -522,8 +521,8 @@ golang.org/x/sys v0.0.0-20220811171246-fbc7d0a398ab/go.mod h1:oPkhp1MJrh7nUepCBc | ||||
| golang.org/x/sys v0.1.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||
| golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||
| golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||
| golang.org/x/sys v0.19.0 h1:q5f1RH2jigJ1MoAWp2KTp3gm5zAGFUTarQZ5U386+4o= | ||||
| golang.org/x/sys v0.19.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= | ||||
| golang.org/x/sys v0.25.0 h1:r+8e+loiHxRqhXVl6ML1nO3l1+oFoWbnlu2Ehimmi34= | ||||
| golang.org/x/sys v0.25.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= | ||||
| golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= | ||||
| golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= | ||||
| golang.org/x/term v0.1.0/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= | ||||
| @ -536,8 +535,8 @@ golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ= | ||||
| golang.org/x/text v0.3.8/go.mod h1:E6s5w1FMmriuDzIBO73fBruAKo1PCIq6d2Q6DHfQ8WQ= | ||||
| golang.org/x/text v0.4.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8= | ||||
| golang.org/x/text v0.7.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8= | ||||
| golang.org/x/text v0.14.0 h1:ScX5w1eTa3QqT8oi6+ziP7dTV1S2+ALU0bI+0zXKWiQ= | ||||
| golang.org/x/text v0.14.0/go.mod h1:18ZOQIKpY8NJVqYksKHtTdi31H5itFRjB5/qKTNYzSU= | ||||
| golang.org/x/text v0.18.0 h1:XvMDiNzPAl0jr17s6W9lcaIhGUfUORdGCNsuLmPG224= | ||||
| golang.org/x/text v0.18.0/go.mod h1:BuEKDfySbSR4drPmRPG/7iBdf8hvFMuRexcpahXilzY= | ||||
| golang.org/x/time v0.5.0 h1:o7cqy6amK/52YcAKIPlM3a+Fpj35zvRj2TP+e1xFSfk= | ||||
| golang.org/x/time v0.5.0/go.mod h1:3BpzKBy/shNhVucY/MWOyx10tF3SFh9QdLuxbVysPQM= | ||||
| golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| @ -553,30 +552,30 @@ golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8T | ||||
| golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= | ||||
| golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= | ||||
| golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= | ||||
| golang.org/x/xerrors v0.0.0-20220907171357-04be3eba64a2 h1:H2TDz8ibqkAF6YGhCdN3jS9O0/s90v0rJh3X/OLHEUk= | ||||
| golang.org/x/xerrors v0.0.0-20220907171357-04be3eba64a2/go.mod h1:K8+ghG5WaK9qNqU5K3HdILfMLy1f3aNYFI/wnl100a8= | ||||
| google.golang.org/api v0.165.0 h1:zd5d4JIIIaYYsfVy1HzoXYZ9rWCSBxxAglbczzo7Bgc= | ||||
| google.golang.org/api v0.165.0/go.mod h1:2OatzO7ZDQsoS7IFf3rvsE17/TldiU3F/zxFHeqUB5o= | ||||
| golang.org/x/xerrors v0.0.0-20231012003039-104605ab7028 h1:+cNy6SZtPcJQH3LJVLOSmiC7MMxXNOb3PU/VUEz+EhU= | ||||
| golang.org/x/xerrors v0.0.0-20231012003039-104605ab7028/go.mod h1:NDW/Ps6MPRej6fsCIbMTohpP40sJ/P/vI1MoTEGwX90= | ||||
| google.golang.org/api v0.170.0 h1:zMaruDePM88zxZBG+NG8+reALO2rfLhe/JShitLyT48= | ||||
| google.golang.org/api v0.170.0/go.mod h1:/xql9M2btF85xac/VAm4PsLMTLVGUOpq4BE9R8jyNy8= | ||||
| google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM= | ||||
| google.golang.org/appengine v1.4.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= | ||||
| google.golang.org/appengine v1.6.8 h1:IhEN5q69dyKagZPYMSdIjS2HqprW324FRQZJcGqPAsM= | ||||
| google.golang.org/appengine v1.6.8/go.mod h1:1jJ3jBArFh5pcgW8gCtRJnepW8FzD1V44FJffLiz/Ds= | ||||
| google.golang.org/appengine/v2 v2.0.2 h1:MSqyWy2shDLwG7chbwBJ5uMyw6SNqJzhJHNDwYB0Akk= | ||||
| google.golang.org/appengine/v2 v2.0.2/go.mod h1:PkgRUWz4o1XOvbqtWTkBtCitEJ5Tp4HoVEdMMYQR/8E= | ||||
| google.golang.org/genproto v0.0.0-20180817151627-c66870c02cf8/go.mod h1:JiN7NxoALGmiZfu7CAH4rXhgtRTLTxftemlI0sWmxmc= | ||||
| google.golang.org/genproto v0.0.0-20190819201941-24fa4b261c55/go.mod h1:DMBHOl98Agz4BDEuKkezgsaosCRResVns1a3J2ZsMNc= | ||||
| google.golang.org/genproto v0.0.0-20200526211855-cb27e3aa2013/go.mod h1:NbSheEEYHJ7i3ixzK3sjbqSGDJWnxyFXZblF3eUsNvo= | ||||
| google.golang.org/genproto v0.0.0-20240125205218-1f4bbc51befe h1:USL2DhxfgRchafRvt/wYyyQNzwgL7ZiURcozOE/Pkvo= | ||||
| google.golang.org/genproto v0.0.0-20240125205218-1f4bbc51befe/go.mod h1:cc8bqMqtv9gMOr0zHg2Vzff5ULhhL2IXP4sbcn32Dro= | ||||
| google.golang.org/genproto/googleapis/api v0.0.0-20240123012728-ef4313101c80 h1:Lj5rbfG876hIAYFjqiJnPHfhXbv+nzTWfm04Fg/XSVU= | ||||
| google.golang.org/genproto/googleapis/api v0.0.0-20240123012728-ef4313101c80/go.mod h1:4jWUdICTdgc3Ibxmr8nAJiiLHwQBY0UI0XZcEMaFKaA= | ||||
| google.golang.org/genproto/googleapis/rpc v0.0.0-20240318140521-94a12d6c2237 h1:NnYq6UN9ReLM9/Y01KWNOWyI5xQ9kbIms5GGJVwS/Yc= | ||||
| google.golang.org/genproto/googleapis/rpc v0.0.0-20240318140521-94a12d6c2237/go.mod h1:WtryC6hu0hhx87FDGxWCDptyssuo68sk10vYjF+T9fY= | ||||
| google.golang.org/genproto v0.0.0-20240213162025-012b6fc9bca9 h1:9+tzLLstTlPTRyJTh+ah5wIMsBW5c4tQwGTN3thOW9Y= | ||||
| google.golang.org/genproto v0.0.0-20240213162025-012b6fc9bca9/go.mod h1:mqHbVIp48Muh7Ywss/AD6I5kNVKZMmAa/QEW58Gxp2s= | ||||
| google.golang.org/genproto/googleapis/api v0.0.0-20240604185151-ef581f913117 h1:+rdxYoE3E5htTEWIe15GlN6IfvbURM//Jt0mmkmm6ZU= | ||||
| google.golang.org/genproto/googleapis/api v0.0.0-20240604185151-ef581f913117/go.mod h1:OimBR/bc1wPO9iV4NC2bpyjy3VnAwZh5EBPQdtaE5oo= | ||||
| google.golang.org/genproto/googleapis/rpc v0.0.0-20240903143218-8af14fe29dc1 h1:pPJltXNxVzT4pK9yD8vR9X75DaWYYmLGMsEvBfFQZzQ= | ||||
| google.golang.org/genproto/googleapis/rpc v0.0.0-20240903143218-8af14fe29dc1/go.mod h1:UqMtugtsSgubUsoxbuAoiCXvqvErP7Gf0so0mK9tHxU= | ||||
| google.golang.org/grpc v1.19.0/go.mod h1:mqu4LbDTu4XGKhr4mRzUsmM4RtVoemTSY81AxZiDr8c= | ||||
| google.golang.org/grpc v1.23.0/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg= | ||||
| google.golang.org/grpc v1.25.1/go.mod h1:c3i+UQWmh7LiEpx4sFZnkU36qjEYZ0imhYfXVyQciAY= | ||||
| google.golang.org/grpc v1.27.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk= | ||||
| google.golang.org/grpc v1.33.2/go.mod h1:JMHMWHQWaTccqQQlmk3MJZS+GWXOdAesneDmEnv2fbc= | ||||
| google.golang.org/grpc v1.62.1 h1:B4n+nfKzOICUXMgyrNd19h/I9oH0L1pizfk1d4zSgTk= | ||||
| google.golang.org/grpc v1.62.1/go.mod h1:IWTG0VlJLCh1SkC58F7np9ka9mx/WNkjl4PGJaiq+QE= | ||||
| google.golang.org/grpc v1.66.2 h1:3QdXkuq3Bkh7w+ywLdLvM56cmGvQHUMZpiCzt6Rqaoo= | ||||
| google.golang.org/grpc v1.66.2/go.mod h1:s3/l6xSSCURdVfAnL+TqCNMyTDAGN6+lZeVxnZR128Y= | ||||
| google.golang.org/protobuf v0.0.0-20200109180630-ec00e32a8dfd/go.mod h1:DFci5gLYBciE7Vtevhsrf46CRTquxDuWsQurQQe4oz8= | ||||
| google.golang.org/protobuf v0.0.0-20200221191635-4d8936d0db64/go.mod h1:kwYJMbMJ01Woi6D6+Kah6886xMZcty6N08ah7+eCXa0= | ||||
| google.golang.org/protobuf v0.0.0-20200228230310-ab0ca4ff8a60/go.mod h1:cfTl7dwQJ+fmap5saPgwCLgHXTUD7jkjRqWcaiX5VyM= | ||||
| @ -586,10 +585,8 @@ google.golang.org/protobuf v1.22.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2 | ||||
| google.golang.org/protobuf v1.23.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU= | ||||
| google.golang.org/protobuf v1.23.1-0.20200526195155-81db48ad09cc/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU= | ||||
| google.golang.org/protobuf v1.25.0/go.mod h1:9JNX74DMeImyA3h4bdi1ymwjUzf21/xIlbajtzgsN7c= | ||||
| google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw= | ||||
| google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc= | ||||
| google.golang.org/protobuf v1.33.0 h1:uNO2rsAINq/JlFpSdYEKIZ0uKD/R9cpdv0T+yoGwGmI= | ||||
| google.golang.org/protobuf v1.33.0/go.mod h1:c6P6GXX6sHbq/GpV6MGZEdwhWPcYBgnhAHhKbcUYpos= | ||||
| google.golang.org/protobuf v1.34.2 h1:6xV6lTsCfpGD21XK49h7MhtcApnLqkfYgPcdHftf6hg= | ||||
| google.golang.org/protobuf v1.34.2/go.mod h1:qYOHts0dSfpeUzUFpOMr/WGzszTmLH+DiWniOlNbLDw= | ||||
| gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= | ||||
| gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= | ||||
| gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk= | ||||
| @ -610,6 +607,7 @@ gorm.io/gorm v1.25.8 h1:WAGEZ/aEcznN4D03laj8DKnehe1e9gYQAjW8xyPRdeo= | ||||
| gorm.io/gorm v1.25.8/go.mod h1:hbnx/Oo0ChWMn1BIhpy1oYozzpM15i4YPuHDmfYtwg8= | ||||
| honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= | ||||
| honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= | ||||
| nullprogram.com/x/optparse v1.0.0/go.mod h1:KdyPE+Igbe0jQUrVfMqDMeJQIJZEuyV7pjYmp6pbG50= | ||||
| rsc.io/pdf v0.1.1/go.mod h1:n8OzWcQ6Sp37PL01nO98y4iUCRdTGarVfzxY20ICaU4= | ||||
| stathat.com/c/consistent v1.0.0 h1:ezyc51EGcRPJUxfHGSgJjWzJdj3NiMU9pNfLNGiXV0c= | ||||
| stathat.com/c/consistent v1.0.0/go.mod h1:QkzMWzcbB+yQBL2AttO6sgsQS/JSTapcDISJalmCDS0= | ||||
|  | ||||
| @ -27,8 +27,8 @@ func NewAuthApi(client rpcclient.Auth) AuthApi { | ||||
| 	return AuthApi(client) | ||||
| } | ||||
| 
 | ||||
| func (o *AuthApi) UserToken(c *gin.Context) { | ||||
| 	a2r.Call(auth.AuthClient.UserToken, o.Client, c) | ||||
| func (o *AuthApi) GetAdminToken(c *gin.Context) { | ||||
| 	a2r.Call(auth.AuthClient.GetAdminToken, o.Client, c) | ||||
| } | ||||
| 
 | ||||
| func (o *AuthApi) GetUserToken(c *gin.Context) { | ||||
|  | ||||
| @ -62,3 +62,11 @@ func (o *ConversationApi) GetIncrementalConversation(c *gin.Context) { | ||||
| func (o *ConversationApi) GetOwnerConversation(c *gin.Context) { | ||||
| 	a2r.Call(conversation.ConversationClient.GetOwnerConversation, o.Client, c) | ||||
| } | ||||
| 
 | ||||
| func (o *ConversationApi) GetNotNotifyConversationIDs(c *gin.Context) { | ||||
| 	a2r.Call(conversation.ConversationClient.GetNotNotifyConversationIDs, o.Client, c) | ||||
| } | ||||
| 
 | ||||
| func (o *ConversationApi) GetPinnedConversationIDs(c *gin.Context) { | ||||
| 	a2r.Call(conversation.ConversationClient.GetPinnedConversationIDs, o.Client, c) | ||||
| } | ||||
|  | ||||
| @ -72,6 +72,10 @@ func (o *FriendApi) GetPaginationBlacks(c *gin.Context) { | ||||
| 	a2r.Call(relation.FriendClient.GetPaginationBlacks, o.Client, c) | ||||
| } | ||||
| 
 | ||||
| func (o *FriendApi) GetSpecifiedBlacks(c *gin.Context) { | ||||
| 	a2r.Call(relation.FriendClient.GetSpecifiedBlacks, o.Client, c) | ||||
| } | ||||
| 
 | ||||
| func (o *FriendApi) RemoveBlack(c *gin.Context) { | ||||
| 	a2r.Call(relation.FriendClient.RemoveBlack, o.Client, c) | ||||
| } | ||||
|  | ||||
| @ -35,6 +35,10 @@ func (o *GroupApi) SetGroupInfo(c *gin.Context) { | ||||
| 	a2r.Call(group.GroupClient.SetGroupInfo, o.Client, c) | ||||
| } | ||||
| 
 | ||||
| func (o *GroupApi) SetGroupInfoEx(c *gin.Context) { | ||||
| 	a2r.Call(group.GroupClient.SetGroupInfoEx, o.Client, c) | ||||
| } | ||||
| 
 | ||||
| func (o *GroupApi) JoinGroup(c *gin.Context) { | ||||
| 	a2r.Call(group.GroupClient.JoinGroup, o.Client, c) | ||||
| } | ||||
| @ -63,6 +67,10 @@ func (o *GroupApi) GetGroupUsersReqApplicationList(c *gin.Context) { | ||||
| 	a2r.Call(group.GroupClient.GetGroupUsersReqApplicationList, o.Client, c) | ||||
| } | ||||
| 
 | ||||
| func (o *GroupApi) GetSpecifiedUserGroupRequestInfo(c *gin.Context) { | ||||
| 	a2r.Call(group.GroupClient.GetSpecifiedUserGroupRequestInfo, o.Client, c) | ||||
| } | ||||
| 
 | ||||
| func (o *GroupApi) GetGroupsInfo(c *gin.Context) { | ||||
| 	a2r.Call(group.GroupClient.GetGroupsInfo, o.Client, c) | ||||
| 	//a2r.Call(group.GroupClient.GetGroupsInfo, o.Client, c, a2r.NewNilReplaceOption(group.GroupClient.GetGroupsInfo)) | ||||
|  | ||||
							
								
								
									
										204
									
								
								internal/api/jssdk/jssdk.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										204
									
								
								internal/api/jssdk/jssdk.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,204 @@ | ||||
| package jssdk | ||||
| 
 | ||||
| import ( | ||||
| 	"github.com/gin-gonic/gin" | ||||
| 	"github.com/openimsdk/protocol/conversation" | ||||
| 	"github.com/openimsdk/protocol/msg" | ||||
| 	"github.com/openimsdk/protocol/sdkws" | ||||
| 	"github.com/openimsdk/tools/a2r" | ||||
| 	"github.com/openimsdk/tools/mcontext" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 	"sort" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
| 	maxGetActiveConversation     = 500 | ||||
| 	defaultGetActiveConversation = 100 | ||||
| ) | ||||
| 
 | ||||
| func NewJSSdkApi(msg msg.MsgClient, conv conversation.ConversationClient) *JSSdk { | ||||
| 	return &JSSdk{ | ||||
| 		msg:  msg, | ||||
| 		conv: conv, | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| type JSSdk struct { | ||||
| 	msg  msg.MsgClient | ||||
| 	conv conversation.ConversationClient | ||||
| } | ||||
| 
 | ||||
| func (x *JSSdk) GetActiveConversations(c *gin.Context) { | ||||
| 	call(c, x.getActiveConversations) | ||||
| } | ||||
| 
 | ||||
| func (x *JSSdk) GetConversations(c *gin.Context) { | ||||
| 	call(c, x.getConversations) | ||||
| } | ||||
| 
 | ||||
| func (x *JSSdk) getActiveConversations(ctx *gin.Context) (*ConversationsResp, error) { | ||||
| 	req, err := a2r.ParseRequest[ActiveConversationsReq](ctx) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	if req.Count <= 0 || req.Count > maxGetActiveConversation { | ||||
| 		req.Count = defaultGetActiveConversation | ||||
| 	} | ||||
| 	opUserID := mcontext.GetOpUserID(ctx) | ||||
| 	conversationIDs, err := field(ctx, x.conv.GetConversationIDs, | ||||
| 		&conversation.GetConversationIDsReq{UserID: opUserID}, (*conversation.GetConversationIDsResp).GetConversationIDs) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	if len(conversationIDs) == 0 { | ||||
| 		return &ConversationsResp{}, nil | ||||
| 	} | ||||
| 	readSeq, err := field(ctx, x.msg.GetHasReadSeqs, | ||||
| 		&msg.GetHasReadSeqsReq{UserID: opUserID, ConversationIDs: conversationIDs}, (*msg.SeqsInfoResp).GetMaxSeqs) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	activeConversation, err := field(ctx, x.msg.GetActiveConversation, | ||||
| 		&msg.GetActiveConversationReq{ConversationIDs: conversationIDs}, (*msg.GetActiveConversationResp).GetConversations) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	if len(activeConversation) == 0 { | ||||
| 		return &ConversationsResp{}, nil | ||||
| 	} | ||||
| 	sortConversations := sortActiveConversations{ | ||||
| 		Conversation: activeConversation, | ||||
| 	} | ||||
| 	if len(activeConversation) > 1 { | ||||
| 		pinnedConversationIDs, err := field(ctx, x.conv.GetPinnedConversationIDs, | ||||
| 			&conversation.GetPinnedConversationIDsReq{UserID: opUserID}, (*conversation.GetPinnedConversationIDsResp).GetConversationIDs) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 		sortConversations.PinnedConversationIDs = datautil.SliceSet(pinnedConversationIDs) | ||||
| 	} | ||||
| 	sort.Sort(&sortConversations) | ||||
| 	sortList := sortConversations.Top(req.Count) | ||||
| 	conversations, err := field(ctx, x.conv.GetConversations, | ||||
| 		&conversation.GetConversationsReq{ | ||||
| 			OwnerUserID: opUserID, | ||||
| 			ConversationIDs: datautil.Slice(sortList, func(c *msg.ActiveConversation) string { | ||||
| 				return c.ConversationID | ||||
| 			})}, (*conversation.GetConversationsResp).GetConversations) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	msgs, err := field(ctx, x.msg.GetSeqMessage, | ||||
| 		&msg.GetSeqMessageReq{ | ||||
| 			UserID: opUserID, | ||||
| 			Conversations: datautil.Slice(sortList, func(c *msg.ActiveConversation) *msg.ConversationSeqs { | ||||
| 				return &msg.ConversationSeqs{ | ||||
| 					ConversationID: c.ConversationID, | ||||
| 					Seqs:           []int64{c.MaxSeq}, | ||||
| 				} | ||||
| 			}), | ||||
| 		}, (*msg.GetSeqMessageResp).GetMsgs) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	conversationMap := datautil.SliceToMap(conversations, func(c *conversation.Conversation) string { | ||||
| 		return c.ConversationID | ||||
| 	}) | ||||
| 	resp := make([]ConversationMsg, 0, len(sortList)) | ||||
| 	for _, c := range sortList { | ||||
| 		conv, ok := conversationMap[c.ConversationID] | ||||
| 		if !ok { | ||||
| 			continue | ||||
| 		} | ||||
| 		var lastMsg *sdkws.MsgData | ||||
| 		if msgList, ok := msgs[c.ConversationID]; ok && len(msgList.Msgs) > 0 { | ||||
| 			lastMsg = msgList.Msgs[0] | ||||
| 		} | ||||
| 		resp = append(resp, ConversationMsg{ | ||||
| 			Conversation: conv, | ||||
| 			LastMsg:      lastMsg, | ||||
| 			MaxSeq:       c.MaxSeq, | ||||
| 			ReadSeq:      readSeq[c.ConversationID], | ||||
| 		}) | ||||
| 	} | ||||
| 	var unreadCount int64 | ||||
| 	for _, c := range activeConversation { | ||||
| 		count := c.MaxSeq - readSeq[c.ConversationID] | ||||
| 		if count > 0 { | ||||
| 			unreadCount += count | ||||
| 		} | ||||
| 	} | ||||
| 	return &ConversationsResp{ | ||||
| 		Conversations: resp, | ||||
| 		UnreadCount:   unreadCount, | ||||
| 	}, nil | ||||
| } | ||||
| 
 | ||||
| func (x *JSSdk) getConversations(ctx *gin.Context) (*ConversationsResp, error) { | ||||
| 	req, err := a2r.ParseRequest[conversation.GetConversationsReq](ctx) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	req.OwnerUserID = mcontext.GetOpUserID(ctx) | ||||
| 	conversations, err := field(ctx, x.conv.GetConversations, req, (*conversation.GetConversationsResp).GetConversations) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	if len(conversations) == 0 { | ||||
| 		return &ConversationsResp{}, nil | ||||
| 	} | ||||
| 	req.ConversationIDs = datautil.Slice(conversations, func(c *conversation.Conversation) string { | ||||
| 		return c.ConversationID | ||||
| 	}) | ||||
| 	maxSeqs, err := field(ctx, x.msg.GetMaxSeqs, | ||||
| 		&msg.GetMaxSeqsReq{ConversationIDs: req.ConversationIDs}, (*msg.SeqsInfoResp).GetMaxSeqs) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	readSeqs, err := field(ctx, x.msg.GetHasReadSeqs, | ||||
| 		&msg.GetHasReadSeqsReq{UserID: req.OwnerUserID, ConversationIDs: req.ConversationIDs}, (*msg.SeqsInfoResp).GetMaxSeqs) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	conversationSeqs := make([]*msg.ConversationSeqs, 0, len(conversations)) | ||||
| 	for _, c := range conversations { | ||||
| 		if seq := maxSeqs[c.ConversationID]; seq > 0 { | ||||
| 			conversationSeqs = append(conversationSeqs, &msg.ConversationSeqs{ | ||||
| 				ConversationID: c.ConversationID, | ||||
| 				Seqs:           []int64{seq}, | ||||
| 			}) | ||||
| 		} | ||||
| 	} | ||||
| 	var msgs map[string]*sdkws.PullMsgs | ||||
| 	if len(conversationSeqs) > 0 { | ||||
| 		msgs, err = field(ctx, x.msg.GetSeqMessage, | ||||
| 			&msg.GetSeqMessageReq{UserID: req.OwnerUserID, Conversations: conversationSeqs}, (*msg.GetSeqMessageResp).GetMsgs) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 	} | ||||
| 	resp := make([]ConversationMsg, 0, len(conversations)) | ||||
| 	for _, c := range conversations { | ||||
| 		var lastMsg *sdkws.MsgData | ||||
| 		if msgList, ok := msgs[c.ConversationID]; ok && len(msgList.Msgs) > 0 { | ||||
| 			lastMsg = msgList.Msgs[0] | ||||
| 		} | ||||
| 		resp = append(resp, ConversationMsg{ | ||||
| 			Conversation: c, | ||||
| 			LastMsg:      lastMsg, | ||||
| 			MaxSeq:       maxSeqs[c.ConversationID], | ||||
| 			ReadSeq:      readSeqs[c.ConversationID], | ||||
| 		}) | ||||
| 	} | ||||
| 	var unreadCount int64 | ||||
| 	for conversationID, maxSeq := range maxSeqs { | ||||
| 		count := maxSeq - readSeqs[conversationID] | ||||
| 		if count > 0 { | ||||
| 			unreadCount += count | ||||
| 		} | ||||
| 	} | ||||
| 	return &ConversationsResp{ | ||||
| 		Conversations: resp, | ||||
| 		UnreadCount:   unreadCount, | ||||
| 	}, nil | ||||
| } | ||||
							
								
								
									
										33
									
								
								internal/api/jssdk/sort.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								internal/api/jssdk/sort.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,33 @@ | ||||
| package jssdk | ||||
| 
 | ||||
| import "github.com/openimsdk/protocol/msg" | ||||
| 
 | ||||
| type sortActiveConversations struct { | ||||
| 	Conversation          []*msg.ActiveConversation | ||||
| 	PinnedConversationIDs map[string]struct{} | ||||
| } | ||||
| 
 | ||||
| func (s sortActiveConversations) Top(limit int) []*msg.ActiveConversation { | ||||
| 	if limit > 0 && len(s.Conversation) > limit { | ||||
| 		return s.Conversation[:limit] | ||||
| 	} | ||||
| 	return s.Conversation | ||||
| } | ||||
| 
 | ||||
| func (s sortActiveConversations) Len() int { | ||||
| 	return len(s.Conversation) | ||||
| } | ||||
| 
 | ||||
| func (s sortActiveConversations) Less(i, j int) bool { | ||||
| 	iv, jv := s.Conversation[i], s.Conversation[j] | ||||
| 	_, ip := s.PinnedConversationIDs[iv.ConversationID] | ||||
| 	_, jp := s.PinnedConversationIDs[jv.ConversationID] | ||||
| 	if ip != jp { | ||||
| 		return ip | ||||
| 	} | ||||
| 	return iv.LastTime > jv.LastTime | ||||
| } | ||||
| 
 | ||||
| func (s sortActiveConversations) Swap(i, j int) { | ||||
| 	s.Conversation[i], s.Conversation[j] = s.Conversation[j], s.Conversation[i] | ||||
| } | ||||
							
								
								
									
										22
									
								
								internal/api/jssdk/stu.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								internal/api/jssdk/stu.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| package jssdk | ||||
| 
 | ||||
| import ( | ||||
| 	"github.com/openimsdk/protocol/conversation" | ||||
| 	"github.com/openimsdk/protocol/sdkws" | ||||
| ) | ||||
| 
 | ||||
| type ActiveConversationsReq struct { | ||||
| 	Count int `json:"count"` | ||||
| } | ||||
| 
 | ||||
| type ConversationMsg struct { | ||||
| 	Conversation *conversation.Conversation `json:"conversation"` | ||||
| 	LastMsg      *sdkws.MsgData             `json:"lastMsg"` | ||||
| 	MaxSeq       int64                      `json:"maxSeq"` | ||||
| 	ReadSeq      int64                      `json:"readSeq"` | ||||
| } | ||||
| 
 | ||||
| type ConversationsResp struct { | ||||
| 	UnreadCount   int64             `json:"unreadCount"` | ||||
| 	Conversations []ConversationMsg `json:"conversations"` | ||||
| } | ||||
							
								
								
									
										26
									
								
								internal/api/jssdk/tools.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								internal/api/jssdk/tools.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,26 @@ | ||||
| package jssdk | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"github.com/gin-gonic/gin" | ||||
| 	"github.com/openimsdk/tools/apiresp" | ||||
| 	"google.golang.org/grpc" | ||||
| ) | ||||
| 
 | ||||
| func field[A, B, C any](ctx context.Context, fn func(ctx context.Context, req *A, opts ...grpc.CallOption) (*B, error), req *A, get func(*B) C) (C, error) { | ||||
| 	resp, err := fn(ctx, req) | ||||
| 	if err != nil { | ||||
| 		var c C | ||||
| 		return c, err | ||||
| 	} | ||||
| 	return get(resp), nil | ||||
| } | ||||
| 
 | ||||
| func call[R any](c *gin.Context, fn func(ctx *gin.Context) (R, error)) { | ||||
| 	resp, err := fn(c) | ||||
| 	if err != nil { | ||||
| 		apiresp.GinError(c, err) | ||||
| 		return | ||||
| 	} | ||||
| 	apiresp.GinSuccess(c, resp) | ||||
| } | ||||
							
								
								
									
										37
									
								
								internal/api/jssdk_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								internal/api/jssdk_test.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,37 @@ | ||||
| package api | ||||
| 
 | ||||
| import ( | ||||
| 	"github.com/openimsdk/protocol/msg" | ||||
| 	"sort" | ||||
| 	"testing" | ||||
| ) | ||||
| 
 | ||||
| func TestName(t *testing.T) { | ||||
| 	val := sortActiveConversations{ | ||||
| 		Conversation: []*msg.ActiveConversation{ | ||||
| 			{ | ||||
| 				ConversationID: "100", | ||||
| 				LastTime:       100, | ||||
| 			}, | ||||
| 			{ | ||||
| 				ConversationID: "200", | ||||
| 				LastTime:       200, | ||||
| 			}, | ||||
| 			{ | ||||
| 				ConversationID: "300", | ||||
| 				LastTime:       300, | ||||
| 			}, | ||||
| 			{ | ||||
| 				ConversationID: "400", | ||||
| 				LastTime:       400, | ||||
| 			}, | ||||
| 		}, | ||||
| 		//PinnedConversationIDs: map[string]struct{}{ | ||||
| 		//	"100": {}, | ||||
| 		//	"300": {}, | ||||
| 		//}, | ||||
| 	} | ||||
| 	sort.Sort(&val) | ||||
| 	t.Log(val) | ||||
| 
 | ||||
| } | ||||
| @ -49,14 +49,14 @@ func NewMessageApi(msgRpcClient *rpcclient.Message, userRpcClient *rpcclient.Use | ||||
| 		userRpcClient: rpcclient.NewUserRpcClientByUser(userRpcClient), imAdminUserID: imAdminUserID} | ||||
| } | ||||
| 
 | ||||
| func (MessageApi) SetOptions(options map[string]bool, value bool) { | ||||
| func (*MessageApi) SetOptions(options map[string]bool, value bool) { | ||||
| 	datautil.SetSwitchFromOptions(options, constant.IsHistory, value) | ||||
| 	datautil.SetSwitchFromOptions(options, constant.IsPersistent, value) | ||||
| 	datautil.SetSwitchFromOptions(options, constant.IsSenderSync, value) | ||||
| 	datautil.SetSwitchFromOptions(options, constant.IsConversationUpdate, value) | ||||
| } | ||||
| 
 | ||||
| func (m MessageApi) newUserSendMsgReq(_ *gin.Context, params *apistruct.SendMsg) *msg.SendMsgReq { | ||||
| func (m *MessageApi) newUserSendMsgReq(_ *gin.Context, params *apistruct.SendMsg) *msg.SendMsgReq { | ||||
| 	var newContent string | ||||
| 	options := make(map[string]bool, 5) | ||||
| 	switch params.ContentType { | ||||
| @ -231,7 +231,7 @@ func (m *MessageApi) SendMessage(c *gin.Context) { | ||||
| 	} | ||||
| 
 | ||||
| 	// Set the status to successful if the message is sent. | ||||
| 	var status int = constant.MsgSendSuccessed | ||||
| 	var status = constant.MsgSendSuccessed | ||||
| 
 | ||||
| 	// Attempt to update the message sending status in the system. | ||||
| 	_, err = m.Client.SetSendMsgStatus(c, &msg.SetSendMsgStatusReq{ | ||||
|  | ||||
| @ -2,12 +2,20 @@ package api | ||||
| 
 | ||||
| import ( | ||||
| 	"fmt" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/internal/api/jssdk" | ||||
| 
 | ||||
| 	"github.com/gin-contrib/gzip" | ||||
| 
 | ||||
| 	"github.com/gin-gonic/gin" | ||||
| 	"github.com/gin-gonic/gin/binding" | ||||
| 	"github.com/go-playground/validator/v10" | ||||
| 	"google.golang.org/grpc" | ||||
| 	"google.golang.org/grpc/credentials/insecure" | ||||
| 
 | ||||
| 	"net/http" | ||||
| 	"strings" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/prommetrics" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/servererrs" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/rpcclient" | ||||
| @ -16,8 +24,13 @@ import ( | ||||
| 	"github.com/openimsdk/tools/discovery" | ||||
| 	"github.com/openimsdk/tools/log" | ||||
| 	"github.com/openimsdk/tools/mw" | ||||
| 	"net/http" | ||||
| 	"strings" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
| 	NoCompression      = -1 | ||||
| 	DefaultCompression = 0 | ||||
| 	BestCompression    = 1 | ||||
| 	BestSpeed          = 2 | ||||
| ) | ||||
| 
 | ||||
| func prommetricsGin() gin.HandlerFunc { | ||||
| @ -52,10 +65,19 @@ func newGinRouter(disCov discovery.SvcDiscoveryRegistry, config *Config) *gin.En | ||||
| 	conversationRpc := rpcclient.NewConversation(disCov, config.Share.RpcRegisterName.Conversation) | ||||
| 	authRpc := rpcclient.NewAuth(disCov, config.Share.RpcRegisterName.Auth) | ||||
| 	thirdRpc := rpcclient.NewThird(disCov, config.Share.RpcRegisterName.Third, config.API.Prometheus.GrafanaURL) | ||||
| 
 | ||||
| 	switch config.API.Api.CompressionLevel { | ||||
| 	case NoCompression: | ||||
| 	case DefaultCompression: | ||||
| 		r.Use(gzip.Gzip(gzip.DefaultCompression)) | ||||
| 	case BestCompression: | ||||
| 		r.Use(gzip.Gzip(gzip.BestCompression)) | ||||
| 	case BestSpeed: | ||||
| 		r.Use(gzip.Gzip(gzip.BestSpeed)) | ||||
| 	} | ||||
| 	r.Use(prommetricsGin(), gin.Recovery(), mw.CorsHandler(), mw.GinParseOperationID(), GinParseToken(authRpc)) | ||||
| 	u := NewUserApi(*userRpc) | ||||
| 	m := NewMessageApi(messageRpc, userRpc, config.Share.IMAdminUserID) | ||||
| 	j := jssdk.NewJSSdkApi(messageRpc.Client, conversationRpc.Client) | ||||
| 	userRouterGroup := r.Group("/user") | ||||
| 	{ | ||||
| 		userRouterGroup.POST("/user_register", u.UserRegister) | ||||
| @ -97,6 +119,7 @@ func newGinRouter(disCov discovery.SvcDiscoveryRegistry, config *Config) *gin.En | ||||
| 		friendRouterGroup.POST("/set_friend_remark", f.SetFriendRemark) | ||||
| 		friendRouterGroup.POST("/add_black", f.AddBlack) | ||||
| 		friendRouterGroup.POST("/get_black_list", f.GetPaginationBlacks) | ||||
| 		friendRouterGroup.POST("/get_specified_blacks", f.GetSpecifiedBlacks) | ||||
| 		friendRouterGroup.POST("/remove_black", f.RemoveBlack) | ||||
| 		friendRouterGroup.POST("/get_incremental_blacks", f.GetIncrementalBlacks) | ||||
| 		friendRouterGroup.POST("/import_friend", f.ImportFriends) | ||||
| @ -112,6 +135,7 @@ func newGinRouter(disCov discovery.SvcDiscoveryRegistry, config *Config) *gin.En | ||||
| 	{ | ||||
| 		groupRouterGroup.POST("/create_group", g.CreateGroup) | ||||
| 		groupRouterGroup.POST("/set_group_info", g.SetGroupInfo) | ||||
| 		groupRouterGroup.POST("/set_group_info_ex", g.SetGroupInfoEx) | ||||
| 		groupRouterGroup.POST("/join_group", g.JoinGroup) | ||||
| 		groupRouterGroup.POST("/quit_group", g.QuitGroup) | ||||
| 		groupRouterGroup.POST("/group_application_response", g.ApplicationGroupResponse) | ||||
| @ -119,6 +143,7 @@ func newGinRouter(disCov discovery.SvcDiscoveryRegistry, config *Config) *gin.En | ||||
| 		groupRouterGroup.POST("/get_recv_group_applicationList", g.GetRecvGroupApplicationList) | ||||
| 		groupRouterGroup.POST("/get_user_req_group_applicationList", g.GetUserReqGroupApplicationList) | ||||
| 		groupRouterGroup.POST("/get_group_users_req_application_list", g.GetGroupUsersReqApplicationList) | ||||
| 		groupRouterGroup.POST("/get_specified_user_group_request_info", g.GetSpecifiedUserGroupRequestInfo) | ||||
| 		groupRouterGroup.POST("/get_groups_info", g.GetGroupsInfo) | ||||
| 		groupRouterGroup.POST("/kick_group", g.KickGroupMember) | ||||
| 		groupRouterGroup.POST("/get_group_members_info", g.GetGroupMembersInfo) | ||||
| @ -144,7 +169,7 @@ func newGinRouter(disCov discovery.SvcDiscoveryRegistry, config *Config) *gin.En | ||||
| 	authRouterGroup := r.Group("/auth") | ||||
| 	{ | ||||
| 		a := NewAuthApi(*authRpc) | ||||
| 		authRouterGroup.POST("/user_token", a.UserToken) | ||||
| 		authRouterGroup.POST("/get_admin_token", a.GetAdminToken) | ||||
| 		authRouterGroup.POST("/get_user_token", a.GetUserToken) | ||||
| 		authRouterGroup.POST("/parse_token", a.ParseToken) | ||||
| 		authRouterGroup.POST("/force_logout", a.ForceLogout) | ||||
| @ -211,6 +236,8 @@ func newGinRouter(disCov discovery.SvcDiscoveryRegistry, config *Config) *gin.En | ||||
| 		conversationGroup.POST("/get_full_conversation_ids", c.GetFullOwnerConversationIDs) | ||||
| 		conversationGroup.POST("/get_incremental_conversations", c.GetIncrementalConversation) | ||||
| 		conversationGroup.POST("/get_owner_conversation", c.GetOwnerConversation) | ||||
| 		conversationGroup.POST("/get_not_notify_conversation_ids", c.GetNotNotifyConversationIDs) | ||||
| 		conversationGroup.POST("/get_pinned_conversation_ids", c.GetPinnedConversationIDs) | ||||
| 	} | ||||
| 
 | ||||
| 	statisticsGroup := r.Group("/statistics") | ||||
| @ -220,6 +247,11 @@ func newGinRouter(disCov discovery.SvcDiscoveryRegistry, config *Config) *gin.En | ||||
| 		statisticsGroup.POST("/group/create", g.GroupCreateCount) | ||||
| 		statisticsGroup.POST("/group/active", m.GetActiveGroup) | ||||
| 	} | ||||
| 
 | ||||
| 	jssdk := r.Group("/jssdk") | ||||
| 	jssdk.POST("/get_conversations", j.GetConversations) | ||||
| 	jssdk.POST("/get_active_conversations", j.GetActiveConversations) | ||||
| 
 | ||||
| 	return r | ||||
| } | ||||
| 
 | ||||
| @ -256,7 +288,6 @@ func GinParseToken(authRPC *rpcclient.Auth) gin.HandlerFunc { | ||||
| 
 | ||||
| // Whitelist api not parse token | ||||
| var Whitelist = []string{ | ||||
| 	"/user/user_register", | ||||
| 	"/auth/user_token", | ||||
| 	"/auth/get_admin_token", | ||||
| 	"/auth/parse_token", | ||||
| } | ||||
|  | ||||
| @ -36,9 +36,11 @@ func (u *UserApi) UserRegister(c *gin.Context) { | ||||
| 	a2r.Call(user.UserClient.UserRegister, u.Client, c) | ||||
| } | ||||
| 
 | ||||
| // UpdateUserInfo is deprecated. Use UpdateUserInfoEx | ||||
| func (u *UserApi) UpdateUserInfo(c *gin.Context) { | ||||
| 	a2r.Call(user.UserClient.UpdateUserInfo, u.Client, c) | ||||
| } | ||||
| 
 | ||||
| func (u *UserApi) UpdateUserInfoEx(c *gin.Context) { | ||||
| 	a2r.Call(user.UserClient.UpdateUserInfoEx, u.Client, c) | ||||
| } | ||||
| @ -105,14 +107,14 @@ func (u *UserApi) GetUsersOnlineStatus(c *gin.Context) { | ||||
| 			if v2.UserID == v1 { | ||||
| 				flag = true | ||||
| 				res.UserID = v1 | ||||
| 				res.Status = constant.OnlineStatus | ||||
| 				res.Status = constant.Online | ||||
| 				res.DetailPlatformStatus = append(res.DetailPlatformStatus, v2.DetailPlatformStatus...) | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 		if !flag { | ||||
| 			res.UserID = v1 | ||||
| 			res.Status = constant.OfflineStatus | ||||
| 			res.Status = constant.Offline | ||||
| 		} | ||||
| 		respResult = append(respResult, res) | ||||
| 	} | ||||
| @ -151,26 +153,26 @@ func (u *UserApi) GetUsersOnlineTokenDetail(c *gin.Context) { | ||||
| 	} | ||||
| 
 | ||||
| 	for _, v1 := range req.UserIDs { | ||||
| 		m := make(map[string][]string, 10) | ||||
| 		m := make(map[int32][]string, 10) | ||||
| 		flag = false | ||||
| 		temp := new(msggateway.SingleDetail) | ||||
| 		for _, v2 := range wsResult { | ||||
| 			if v2.UserID == v1 { | ||||
| 				flag = true | ||||
| 				temp.UserID = v1 | ||||
| 				temp.Status = constant.OnlineStatus | ||||
| 				temp.Status = constant.Online | ||||
| 				for _, status := range v2.DetailPlatformStatus { | ||||
| 					if v, ok := m[status.Platform]; ok { | ||||
| 						m[status.Platform] = append(v, status.Token) | ||||
| 					if v, ok := m[status.PlatformID]; ok { | ||||
| 						m[status.PlatformID] = append(v, status.Token) | ||||
| 					} else { | ||||
| 						m[status.Platform] = []string{status.Token} | ||||
| 						m[status.PlatformID] = []string{status.Token} | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		for p, tokens := range m { | ||||
| 			t := new(msggateway.SinglePlatformToken) | ||||
| 			t.Platform = p | ||||
| 			t.PlatformID = p | ||||
| 			t.Token = tokens | ||||
| 			t.Total = int32(len(tokens)) | ||||
| 			temp.SinglePlatformToken = append(temp.SinglePlatformToken, t) | ||||
|  | ||||
| @ -22,6 +22,8 @@ import ( | ||||
| 	"sync/atomic" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"google.golang.org/protobuf/proto" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/msgprocessor" | ||||
| 	"github.com/openimsdk/protocol/constant" | ||||
| 	"github.com/openimsdk/protocol/sdkws" | ||||
| @ -30,7 +32,6 @@ import ( | ||||
| 	"github.com/openimsdk/tools/log" | ||||
| 	"github.com/openimsdk/tools/mcontext" | ||||
| 	"github.com/openimsdk/tools/utils/stringutil" | ||||
| 	"google.golang.org/protobuf/proto" | ||||
| ) | ||||
| 
 | ||||
| var ( | ||||
| @ -220,6 +221,10 @@ func (c *Client) handleMessage(message []byte) error { | ||||
| 		resp, messageErr = c.longConnServer.SendSignalMessage(ctx, binaryReq) | ||||
| 	case WSPullMsgBySeqList: | ||||
| 		resp, messageErr = c.longConnServer.PullMessageBySeqList(ctx, binaryReq) | ||||
| 	case WSPullMsg: | ||||
| 		resp, messageErr = c.longConnServer.GetSeqMessage(ctx, binaryReq) | ||||
| 	case WSGetConvMaxReadSeq: | ||||
| 		resp, messageErr = c.longConnServer.GetConversationsHasReadAndMaxSeq(ctx, binaryReq) | ||||
| 	case WsLogoutMsg: | ||||
| 		resp, messageErr = c.longConnServer.UserLogout(ctx, binaryReq) | ||||
| 	case WsSetBackgroundStatus: | ||||
| @ -271,11 +276,13 @@ func (c *Client) replyMessage(ctx context.Context, binaryReq *Req, err error, re | ||||
| 		ErrMsg:        errResp.ErrMsg, | ||||
| 		Data:          resp, | ||||
| 	} | ||||
| 	t := time.Now() | ||||
| 	log.ZDebug(ctx, "gateway reply message", "resp", mReply.String()) | ||||
| 	err = c.writeBinaryMsg(mReply) | ||||
| 	if err != nil { | ||||
| 		log.ZWarn(ctx, "wireBinaryMsg replyMessage", err, "resp", mReply.String()) | ||||
| 	} | ||||
| 	log.ZDebug(ctx, "wireBinaryMsg end", "time cost", time.Since(t)) | ||||
| 
 | ||||
| 	if binaryReq.ReqIdentifier == WsLogoutMsg { | ||||
| 		return errs.New("user logout", "operationID", binaryReq.OperationID).Wrap() | ||||
|  | ||||
| @ -39,6 +39,8 @@ const ( | ||||
| 	WSPullMsgBySeqList    = 1002 | ||||
| 	WSSendMsg             = 1003 | ||||
| 	WSSendSignalMsg       = 1004 | ||||
| 	WSPullMsg             = 1005 | ||||
| 	WSGetConvMaxReadSeq   = 1006 | ||||
| 	WSPushMsg             = 2001 | ||||
| 	WSKickOnlineMsg       = 2002 | ||||
| 	WsLogoutMsg           = 2003 | ||||
|  | ||||
| @ -66,12 +66,16 @@ func (c *UserConnContext) Value(key any) any { | ||||
| } | ||||
| 
 | ||||
| func newContext(respWriter http.ResponseWriter, req *http.Request) *UserConnContext { | ||||
| 	remoteAddr := req.RemoteAddr | ||||
| 	if forwarded := req.Header.Get("X-Forwarded-For"); forwarded != "" { | ||||
| 		remoteAddr += "_" + forwarded | ||||
| 	} | ||||
| 	return &UserConnContext{ | ||||
| 		RespWriter: respWriter, | ||||
| 		Req:        req, | ||||
| 		Path:       req.URL.Path, | ||||
| 		Method:     req.Method, | ||||
| 		RemoteAddr: req.RemoteAddr, | ||||
| 		RemoteAddr: remoteAddr, | ||||
| 		ConnID:     encrypt.Md5(req.RemoteAddr + "_" + strconv.Itoa(int(timeutil.GetCurrentTimestampByMill()))), | ||||
| 	} | ||||
| } | ||||
|  | ||||
| @ -16,6 +16,8 @@ package msggateway | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"sync/atomic" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/authverify" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/servererrs" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/startrpc" | ||||
| @ -30,7 +32,6 @@ import ( | ||||
| 	"github.com/openimsdk/tools/mq/memamq" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 	"google.golang.org/grpc" | ||||
| 	"sync/atomic" | ||||
| ) | ||||
| 
 | ||||
| func (s *Server) InitServer(ctx context.Context, config *Config, disCov discovery.SvcDiscoveryRegistry, server *grpc.Server) error { | ||||
| @ -111,15 +112,14 @@ func (s *Server) GetUsersOnlineStatus( | ||||
| 			} | ||||
| 
 | ||||
| 			ps := new(msggateway.GetUsersOnlineStatusResp_SuccessDetail) | ||||
| 			ps.Platform = constant.PlatformIDToName(client.PlatformID) | ||||
| 			ps.Status = constant.OnlineStatus | ||||
| 			ps.PlatformID = int32(client.PlatformID) | ||||
| 			ps.ConnID = client.ctx.GetConnID() | ||||
| 			ps.Token = client.token | ||||
| 			ps.IsBackground = client.IsBackground | ||||
| 			uresp.Status = constant.OnlineStatus | ||||
| 			uresp.Status = constant.Online | ||||
| 			uresp.DetailPlatformStatus = append(uresp.DetailPlatformStatus, ps) | ||||
| 		} | ||||
| 		if uresp.Status == constant.OnlineStatus { | ||||
| 		if uresp.Status == constant.Online { | ||||
| 			resp.SuccessResult = append(resp.SuccessResult, uresp) | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @ -58,7 +58,7 @@ func Start(ctx context.Context, index int, conf *Config) error { | ||||
| 	) | ||||
| 
 | ||||
| 	hubServer := NewServer(rpcPort, longServer, conf, func(srv *Server) error { | ||||
| 		longServer.online = rpccache.NewOnlineCache(srv.userRcp, nil, rdb, longServer.subscriberUserOnlineStatusChanges) | ||||
| 		longServer.online, _ = rpccache.NewOnlineCache(srv.userRcp, nil, rdb, false, longServer.subscriberUserOnlineStatusChanges) | ||||
| 		return nil | ||||
| 	}) | ||||
| 
 | ||||
|  | ||||
| @ -19,6 +19,8 @@ import ( | ||||
| 	"sync" | ||||
| 
 | ||||
| 	"github.com/go-playground/validator/v10" | ||||
| 	"google.golang.org/protobuf/proto" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/rpcclient" | ||||
| 	"github.com/openimsdk/protocol/msg" | ||||
| @ -27,7 +29,6 @@ import ( | ||||
| 	"github.com/openimsdk/tools/discovery" | ||||
| 	"github.com/openimsdk/tools/errs" | ||||
| 	"github.com/openimsdk/tools/utils/jsonutil" | ||||
| 	"google.golang.org/protobuf/proto" | ||||
| ) | ||||
| 
 | ||||
| type Req struct { | ||||
| @ -94,6 +95,8 @@ type MessageHandler interface { | ||||
| 	SendMessage(context context.Context, data *Req) ([]byte, error) | ||||
| 	SendSignalMessage(context context.Context, data *Req) ([]byte, error) | ||||
| 	PullMessageBySeqList(context context.Context, data *Req) ([]byte, error) | ||||
| 	GetConversationsHasReadAndMaxSeq(context context.Context, data *Req) ([]byte, error) | ||||
| 	GetSeqMessage(context context.Context, data *Req) ([]byte, error) | ||||
| 	UserLogout(context context.Context, data *Req) ([]byte, error) | ||||
| 	SetUserDeviceBackground(context context.Context, data *Req) ([]byte, bool, error) | ||||
| } | ||||
| @ -175,7 +178,7 @@ func (g GrpcHandler) SendSignalMessage(context context.Context, data *Req) ([]by | ||||
| func (g GrpcHandler) PullMessageBySeqList(context context.Context, data *Req) ([]byte, error) { | ||||
| 	req := sdkws.PullMessageBySeqsReq{} | ||||
| 	if err := proto.Unmarshal(data.Data, &req); err != nil { | ||||
| 		return nil, errs.WrapMsg(err, "error unmarshaling request", "action", "unmarshal", "dataType", "PullMessageBySeqsReq") | ||||
| 		return nil, errs.WrapMsg(err, "err proto unmarshal", "action", "unmarshal", "dataType", "PullMessageBySeqsReq") | ||||
| 	} | ||||
| 	if err := g.validate.Struct(data); err != nil { | ||||
| 		return nil, errs.WrapMsg(err, "validation failed", "action", "validate", "dataType", "PullMessageBySeqsReq") | ||||
| @ -191,6 +194,44 @@ func (g GrpcHandler) PullMessageBySeqList(context context.Context, data *Req) ([ | ||||
| 	return c, nil | ||||
| } | ||||
| 
 | ||||
| func (g GrpcHandler) GetConversationsHasReadAndMaxSeq(context context.Context, data *Req) ([]byte, error) { | ||||
| 	req := msg.GetConversationsHasReadAndMaxSeqReq{} | ||||
| 	if err := proto.Unmarshal(data.Data, &req); err != nil { | ||||
| 		return nil, errs.WrapMsg(err, "err proto unmarshal", "action", "unmarshal", "dataType", "GetConversationsHasReadAndMaxSeq") | ||||
| 	} | ||||
| 	if err := g.validate.Struct(data); err != nil { | ||||
| 		return nil, errs.WrapMsg(err, "validation failed", "action", "validate", "dataType", "GetConversationsHasReadAndMaxSeq") | ||||
| 	} | ||||
| 	resp, err := g.msgRpcClient.GetConversationsHasReadAndMaxSeq(context, &req) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	c, err := proto.Marshal(resp) | ||||
| 	if err != nil { | ||||
| 		return nil, errs.WrapMsg(err, "error marshaling response", "action", "marshal", "dataType", "GetConversationsHasReadAndMaxSeq") | ||||
| 	} | ||||
| 	return c, nil | ||||
| } | ||||
| 
 | ||||
| func (g GrpcHandler) GetSeqMessage(context context.Context, data *Req) ([]byte, error) { | ||||
| 	req := msg.GetSeqMessageReq{} | ||||
| 	if err := proto.Unmarshal(data.Data, &req); err != nil { | ||||
| 		return nil, errs.WrapMsg(err, "error unmarshaling request", "action", "unmarshal", "dataType", "GetSeqMessage") | ||||
| 	} | ||||
| 	if err := g.validate.Struct(data); err != nil { | ||||
| 		return nil, errs.WrapMsg(err, "validation failed", "action", "validate", "dataType", "GetSeqMessage") | ||||
| 	} | ||||
| 	resp, err := g.msgRpcClient.GetSeqMessage(context, &req) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	c, err := proto.Marshal(resp) | ||||
| 	if err != nil { | ||||
| 		return nil, errs.WrapMsg(err, "error marshaling response", "action", "marshal", "dataType", "GetSeqMessage") | ||||
| 	} | ||||
| 	return c, nil | ||||
| } | ||||
| 
 | ||||
| func (g GrpcHandler) UserLogout(context context.Context, data *Req) ([]byte, error) { | ||||
| 	req := push.DelUserPushTokenReq{} | ||||
| 	if err := proto.Unmarshal(data.Data, &req); err != nil { | ||||
|  | ||||
| @ -265,7 +265,7 @@ func (ws *WsServer) registerClient(client *Client) { | ||||
| 		if clientOK { | ||||
| 			ws.clients.Set(client.UserID, client) | ||||
| 			// There is already a connection to the platform | ||||
| 			log.ZInfo(client.ctx, "repeat login", "userID", client.UserID, "platformID", | ||||
| 			log.ZDebug(client.ctx, "repeat login", "userID", client.UserID, "platformID", | ||||
| 				client.PlatformID, "old remote addr", getRemoteAdders(oldClients)) | ||||
| 			ws.onlineUserConnNum.Add(1) | ||||
| 		} else { | ||||
| @ -275,7 +275,7 @@ func (ws *WsServer) registerClient(client *Client) { | ||||
| 	} | ||||
| 
 | ||||
| 	wg := sync.WaitGroup{} | ||||
| 	log.ZDebug(client.ctx, "ws.msgGatewayConfig.Discovery.Enable", ws.msgGatewayConfig.Discovery.Enable) | ||||
| 	log.ZDebug(client.ctx, "ws.msgGatewayConfig.Discovery.Enable", "discoveryEnable", ws.msgGatewayConfig.Discovery.Enable) | ||||
| 
 | ||||
| 	if ws.msgGatewayConfig.Discovery.Enable != "k8s" { | ||||
| 		wg.Add(1) | ||||
| @ -293,7 +293,7 @@ func (ws *WsServer) registerClient(client *Client) { | ||||
| 
 | ||||
| 	wg.Wait() | ||||
| 
 | ||||
| 	log.ZInfo( | ||||
| 	log.ZDebug( | ||||
| 		client.ctx, | ||||
| 		"user online", | ||||
| 		"online user Num", | ||||
| @ -321,7 +321,7 @@ func (ws *WsServer) KickUserConn(client *Client) error { | ||||
| } | ||||
| 
 | ||||
| func (ws *WsServer) multiTerminalLoginChecker(clientOK bool, oldClients []*Client, newClient *Client) { | ||||
| 	switch ws.msgGatewayConfig.MsgGateway.MultiLoginPolicy { | ||||
| 	switch ws.msgGatewayConfig.Share.MultiLoginPolicy { | ||||
| 	case constant.DefalutNotKick: | ||||
| 	case constant.PCAndOther: | ||||
| 		if constant.PlatformIDToClass(newClient.PlatformID) == constant.TerminalPC { | ||||
| @ -360,7 +360,7 @@ func (ws *WsServer) unregisterClient(client *Client) { | ||||
| 	ws.onlineUserConnNum.Add(-1) | ||||
| 	ws.subscription.DelClient(client) | ||||
| 	//ws.SetUserOnlineStatus(client.ctx, client, constant.Offline) | ||||
| 	log.ZInfo(client.ctx, "user offline", "close reason", client.closedErr, "online user Num", | ||||
| 	log.ZDebug(client.ctx, "user offline", "close reason", client.closedErr, "online user Num", | ||||
| 		ws.onlineUserNum.Load(), "online user conn Num", | ||||
| 		ws.onlineUserConnNum.Load(), | ||||
| 	) | ||||
| @ -425,6 +425,7 @@ func (ws *WsServer) wsHandler(w http.ResponseWriter, r *http.Request) { | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	log.ZDebug(connContext, "new conn", "token", connContext.GetToken()) | ||||
| 	// Create a WebSocket long connection object | ||||
| 	wsLongConn := newGWebSocket(WebSocket, ws.handshakeTimeout, ws.writeBufferSize) | ||||
| 	if err := wsLongConn.GenerateLongConn(w, r); err != nil { | ||||
|  | ||||
| @ -16,20 +16,22 @@ package msgtransfer | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	"net/http" | ||||
| 	"os" | ||||
| 	"os/signal" | ||||
| 	"syscall" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/prommetrics" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache/redis" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/database/mgo" | ||||
| 	"github.com/openimsdk/tools/db/mongoutil" | ||||
| 	"github.com/openimsdk/tools/db/redisutil" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 	"net/http" | ||||
| 	"os" | ||||
| 	"os/signal" | ||||
| 	"syscall" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||
| 	kdisc "github.com/openimsdk/open-im-server/v3/pkg/common/discoveryregister" | ||||
| 	discRegister "github.com/openimsdk/open-im-server/v3/pkg/common/discoveryregister" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/controller" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/rpcclient" | ||||
| 	"github.com/openimsdk/tools/errs" | ||||
| @ -64,6 +66,7 @@ type Config struct { | ||||
| func Start(ctx context.Context, index int, config *Config) error { | ||||
| 	log.CInfo(ctx, "MSG-TRANSFER server is initializing", "prometheusPorts", | ||||
| 		config.MsgTransfer.Prometheus.Ports, "index", index) | ||||
| 
 | ||||
| 	mgocli, err := mongoutil.NewMongoDB(ctx, config.MongodbConfig.Build()) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| @ -72,12 +75,13 @@ func Start(ctx context.Context, index int, config *Config) error { | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	client, err := kdisc.NewDiscoveryRegister(&config.Discovery, &config.Share) | ||||
| 	client, err := discRegister.NewDiscoveryRegister(&config.Discovery, &config.Share) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	client.AddOption(mw.GrpcClient(), grpc.WithTransportCredentials(insecure.NewCredentials()), | ||||
| 		grpc.WithDefaultServiceConfig(fmt.Sprintf(`{"LoadBalancingPolicy": "%s"}`, "round_robin"))) | ||||
| 
 | ||||
| 	msgModel := redis.NewMsgCache(rdb) | ||||
| 	msgDocModel, err := mgo.NewMsgMongo(mgocli.GetDB()) | ||||
| 	if err != nil { | ||||
| @ -93,20 +97,21 @@ func Start(ctx context.Context, index int, config *Config) error { | ||||
| 		return err | ||||
| 	} | ||||
| 	seqUserCache := redis.NewSeqUserCacheRedis(rdb, seqUser) | ||||
| 	msgDatabase, err := controller.NewCommonMsgDatabase(msgDocModel, msgModel, seqUserCache, seqConversationCache, &config.KafkaConfig) | ||||
| 	msgTransferDatabase, err := controller.NewMsgTransferDatabase(msgDocModel, msgModel, seqUserCache, seqConversationCache, &config.KafkaConfig) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	conversationRpcClient := rpcclient.NewConversationRpcClient(client, config.Share.RpcRegisterName.Conversation) | ||||
| 	groupRpcClient := rpcclient.NewGroupRpcClient(client, config.Share.RpcRegisterName.Group) | ||||
| 	historyCH, err := NewOnlineHistoryRedisConsumerHandler(&config.KafkaConfig, msgDatabase, &conversationRpcClient, &groupRpcClient) | ||||
| 	historyCH, err := NewOnlineHistoryRedisConsumerHandler(&config.KafkaConfig, msgTransferDatabase, &conversationRpcClient, &groupRpcClient) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	historyMongoCH, err := NewOnlineHistoryMongoConsumerHandler(&config.KafkaConfig, msgDatabase) | ||||
| 	historyMongoCH, err := NewOnlineHistoryMongoConsumerHandler(&config.KafkaConfig, msgTransferDatabase) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	msgTransfer := &MsgTransfer{ | ||||
| 		historyCH:      historyCH, | ||||
| 		historyMongoCH: historyMongoCH, | ||||
| @ -137,7 +142,7 @@ func (m *MsgTransfer) Start(index int, config *Config) error { | ||||
| 				return | ||||
| 			} | ||||
| 
 | ||||
| 			if err := prommetrics.TransferInit(prometheusPort); err != nil && err != http.ErrServerClosed { | ||||
| 			if err := prommetrics.TransferInit(prometheusPort); err != nil && !errors.Is(err, http.ErrServerClosed) { | ||||
| 				netErr = errs.WrapMsg(err, "prometheus start error", "prometheusPort", prometheusPort) | ||||
| 				netDone <- struct{}{} | ||||
| 			} | ||||
|  | ||||
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