mirror of
https://github.com/openimsdk/open-im-server.git
synced 2025-04-05 20:11:14 +08:00
feat: Introduce Language-Specific Comment Detection Tool and Standardize Log Filename Convention (#1992)
* feat: optimize openim reset code * feat: optimize openim reset code * feat: optimize openim reset code * feat: optimize openim reset code * feat: optimize openim reset code * feat: optimize openim reset code * feat: optimize openim reset code * feat: optimize openim reset code
This commit is contained in:
parent
853ac47e42
commit
02a3cfb021
@ -66,6 +66,7 @@ run:
|
|||||||
- "mocks/"
|
- "mocks/"
|
||||||
- ".github/"
|
- ".github/"
|
||||||
- "logs/"
|
- "logs/"
|
||||||
|
- "_output/"
|
||||||
- "components/"
|
- "components/"
|
||||||
|
|
||||||
# by default isn't set. If set we pass it to "go list -mod={option}". From "go help modules":
|
# by default isn't set. If set we pass it to "go list -mod={option}". From "go help modules":
|
||||||
|
@ -53,7 +53,7 @@
|
|||||||
},
|
},
|
||||||
"id": 16,
|
"id": 16,
|
||||||
"panels": [],
|
"panels": [],
|
||||||
"title": "openim自定义指标",
|
"title": "openim Custom Metrics",
|
||||||
"type": "row"
|
"type": "row"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -144,7 +144,7 @@
|
|||||||
"refId": "A"
|
"refId": "A"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"title": "在线人数",
|
"title": "Online population",
|
||||||
"type": "timeseries"
|
"type": "timeseries"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -235,7 +235,7 @@
|
|||||||
"refId": "A"
|
"refId": "A"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"title": "登入/注册人数",
|
"title": "Login/registration numbers",
|
||||||
"type": "timeseries"
|
"type": "timeseries"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -1345,7 +1345,7 @@
|
|||||||
"type": "timeseries"
|
"type": "timeseries"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"title": "应用服务器流量指标",
|
"title": "Traffic indicators of the application server",
|
||||||
"type": "row"
|
"type": "row"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
@ -449,7 +449,7 @@ This section involves configuring the log settings, including storage location,
|
|||||||
|
|
||||||
| Parameter | Example Value | Description |
|
| Parameter | Example Value | Description |
|
||||||
| ------------------------- | ------------------------ | --------------------------------- |
|
| ------------------------- | ------------------------ | --------------------------------- |
|
||||||
| LOG_STORAGE_LOCATION | "${OPENIM_ROOT}/logs/" | Location for storing logs |
|
| LOG_STORAGE_LOCATION | "${OPENIM_ROOT}/_output/logs/" | Location for storing logs |
|
||||||
| LOG_ROTATION_TIME | "24" | Log rotation time (in hours) |
|
| LOG_ROTATION_TIME | "24" | Log rotation time (in hours) |
|
||||||
| LOG_REMAIN_ROTATION_COUNT | "2" | Number of log rotations to retain |
|
| LOG_REMAIN_ROTATION_COUNT | "2" | Number of log rotations to retain |
|
||||||
| LOG_REMAIN_LOG_LEVEL | "6" | Log level to retain |
|
| LOG_REMAIN_LOG_LEVEL | "6" | Log level to retain |
|
||||||
|
1
go.work
1
go.work
@ -3,6 +3,7 @@ go 1.19
|
|||||||
use (
|
use (
|
||||||
.
|
.
|
||||||
./test/typecheck
|
./test/typecheck
|
||||||
|
./tools/codescan
|
||||||
./tools/changelog
|
./tools/changelog
|
||||||
./tools/component
|
./tools/component
|
||||||
./tools/data-conversion
|
./tools/data-conversion
|
||||||
|
@ -183,7 +183,7 @@ func (g GrpcHandler) PullMessageBySeqList(context context.Context, data *Req) ([
|
|||||||
return nil, errs.Wrap(err, "error unmarshaling request")
|
return nil, errs.Wrap(err, "error unmarshaling request")
|
||||||
}
|
}
|
||||||
if err := g.validate.Struct(data); err != nil {
|
if err := g.validate.Struct(data); err != nil {
|
||||||
return nil, err
|
return nil, errs.Wrap(err, "validation failed")
|
||||||
}
|
}
|
||||||
resp, err := g.msgRpcClient.PullMessageBySeqList(context, &req)
|
resp, err := g.msgRpcClient.PullMessageBySeqList(context, &req)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -191,7 +191,7 @@ func (g GrpcHandler) PullMessageBySeqList(context context.Context, data *Req) ([
|
|||||||
}
|
}
|
||||||
c, err := proto.Marshal(resp)
|
c, err := proto.Marshal(resp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, errs.Wrap(err, "error marshaling response")
|
||||||
}
|
}
|
||||||
return c, nil
|
return c, nil
|
||||||
}
|
}
|
||||||
@ -199,7 +199,7 @@ func (g GrpcHandler) PullMessageBySeqList(context context.Context, data *Req) ([
|
|||||||
func (g GrpcHandler) UserLogout(context context.Context, data *Req) ([]byte, error) {
|
func (g GrpcHandler) UserLogout(context context.Context, data *Req) ([]byte, error) {
|
||||||
req := push.DelUserPushTokenReq{}
|
req := push.DelUserPushTokenReq{}
|
||||||
if err := proto.Unmarshal(data.Data, &req); err != nil {
|
if err := proto.Unmarshal(data.Data, &req); err != nil {
|
||||||
return nil, err
|
return nil, errs.Wrap(err, "error unmarshaling request")
|
||||||
}
|
}
|
||||||
resp, err := g.pushClient.DelUserPushToken(context, &req)
|
resp, err := g.pushClient.DelUserPushToken(context, &req)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -207,7 +207,7 @@ func (g GrpcHandler) UserLogout(context context.Context, data *Req) ([]byte, err
|
|||||||
}
|
}
|
||||||
c, err := proto.Marshal(resp)
|
c, err := proto.Marshal(resp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, errs.Wrap(err, "error marshaling response")
|
||||||
}
|
}
|
||||||
return c, nil
|
return c, nil
|
||||||
}
|
}
|
||||||
@ -215,10 +215,10 @@ func (g GrpcHandler) UserLogout(context context.Context, data *Req) ([]byte, err
|
|||||||
func (g GrpcHandler) SetUserDeviceBackground(_ context.Context, data *Req) ([]byte, bool, error) {
|
func (g GrpcHandler) SetUserDeviceBackground(_ context.Context, data *Req) ([]byte, bool, error) {
|
||||||
req := sdkws.SetAppBackgroundStatusReq{}
|
req := sdkws.SetAppBackgroundStatusReq{}
|
||||||
if err := proto.Unmarshal(data.Data, &req); err != nil {
|
if err := proto.Unmarshal(data.Data, &req); err != nil {
|
||||||
return nil, false, err
|
return nil, false, errs.Wrap(err, "error unmarshaling request")
|
||||||
}
|
}
|
||||||
if err := g.validate.Struct(data); err != nil {
|
if err := g.validate.Struct(data); err != nil {
|
||||||
return nil, false, err
|
return nil, false, errs.Wrap(err, "validation failed")
|
||||||
}
|
}
|
||||||
return nil, req.IsBackground, nil
|
return nil, req.IsBackground, nil
|
||||||
}
|
}
|
||||||
|
@ -974,7 +974,7 @@ func (s *groupServer) SetGroupInfo(ctx context.Context, req *pbgroup.SetGroupInf
|
|||||||
if len(update) == 0 {
|
if len(update) == 0 {
|
||||||
return resp, nil
|
return resp, nil
|
||||||
}
|
}
|
||||||
if updateErr := s.db.UpdateGroup(ctx, group.GroupID, update); updateErr != nil {
|
if err := s.db.UpdateGroup(ctx, group.GroupID, update); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
group, err = s.db.TakeGroup(ctx, req.GroupInfoForSet.GroupID)
|
group, err = s.db.TakeGroup(ctx, req.GroupInfoForSet.GroupID)
|
||||||
|
@ -47,7 +47,7 @@ type CmdOpts struct {
|
|||||||
|
|
||||||
func WithCronTaskLogName() func(*CmdOpts) {
|
func WithCronTaskLogName() func(*CmdOpts) {
|
||||||
return func(opts *CmdOpts) {
|
return func(opts *CmdOpts) {
|
||||||
opts.loggerPrefixName = "openim.crontask.log.all"
|
opts.loggerPrefixName = "openim-crontask"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -117,7 +117,7 @@ func (rc *RootCmd) initializeLogger(cmdOpts *CmdOpts) error {
|
|||||||
|
|
||||||
func defaultCmdOpts() *CmdOpts {
|
func defaultCmdOpts() *CmdOpts {
|
||||||
return &CmdOpts{
|
return &CmdOpts{
|
||||||
loggerPrefixName: "OpenIM.log.all",
|
loggerPrefixName: "openim-all",
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -23,9 +23,6 @@
|
|||||||
# Example: `scripts/build-go.sh WHAT=cmd/kubelet`.
|
# Example: `scripts/build-go.sh WHAT=cmd/kubelet`.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
OPENIM_ROOT=$(dirname "${BASH_SOURCE[0]}")/..
|
OPENIM_ROOT=$(dirname "${BASH_SOURCE[0]}")/..
|
||||||
source "${OPENIM_ROOT}/scripts/lib/init.sh"
|
source "${OPENIM_ROOT}/scripts/lib/init.sh"
|
||||||
|
|
||||||
|
@ -19,9 +19,6 @@
|
|||||||
|
|
||||||
# Common utilities, variables and checks for all build scripts.
|
# Common utilities, variables and checks for all build scripts.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Unset CDPATH, having it set messes up with script import paths
|
# Unset CDPATH, having it set messes up with script import paths
|
||||||
unset CDPATH
|
unset CDPATH
|
||||||
|
|
||||||
|
@ -332,7 +332,7 @@ def "OPENIM_CONVERSATION_NAME" "Conversation" # OpenIM对话服务名称
|
|||||||
def "OPENIM_THIRD_NAME" "Third" # OpenIM第三方服务名称
|
def "OPENIM_THIRD_NAME" "Third" # OpenIM第三方服务名称
|
||||||
|
|
||||||
###################### Log Configuration Variables ######################
|
###################### Log Configuration Variables ######################
|
||||||
def "LOG_STORAGE_LOCATION" "${OPENIM_ROOT}/logs/" # 日志存储位置
|
def "LOG_STORAGE_LOCATION" "${OPENIM_ROOT}/_output/logs/" # 日志存储位置
|
||||||
def "LOG_ROTATION_TIME" "24" # 日志轮替时间
|
def "LOG_ROTATION_TIME" "24" # 日志轮替时间
|
||||||
def "LOG_REMAIN_ROTATION_COUNT" "2" # 保留的日志轮替数量
|
def "LOG_REMAIN_ROTATION_COUNT" "2" # 保留的日志轮替数量
|
||||||
def "LOG_REMAIN_LOG_LEVEL" "6" # 保留的日志级别
|
def "LOG_REMAIN_LOG_LEVEL" "6" # 保留的日志级别
|
||||||
|
@ -38,10 +38,6 @@
|
|||||||
# Note: Before executing this script, ensure that the necessary permissions are granted and relevant environmental variables are set.
|
# Note: Before executing this script, ensure that the necessary permissions are granted and relevant environmental variables are set.
|
||||||
#
|
#
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
OPENIM_ROOT=$(cd "$(dirname "${BASH_SOURCE[0]}")"/../.. && pwd -P)
|
OPENIM_ROOT=$(cd "$(dirname "${BASH_SOURCE[0]}")"/../.. && pwd -P)
|
||||||
[[ -z ${COMMON_SOURCED} ]] && source "${OPENIM_ROOT}"/scripts/install/common.sh
|
[[ -z ${COMMON_SOURCED} ]] && source "${OPENIM_ROOT}"/scripts/install/common.sh
|
||||||
|
|
||||||
|
@ -39,9 +39,6 @@
|
|||||||
#
|
#
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
OPENIM_ROOT=$(cd "$(dirname "${BASH_SOURCE[0]}")"/../.. && pwd -P)
|
OPENIM_ROOT=$(cd "$(dirname "${BASH_SOURCE[0]}")"/../.. && pwd -P)
|
||||||
[[ -z ${COMMON_SOURCED} ]] && source "${OPENIM_ROOT}"/scripts/install/common.sh
|
[[ -z ${COMMON_SOURCED} ]] && source "${OPENIM_ROOT}"/scripts/install/common.sh
|
||||||
|
|
||||||
|
@ -14,9 +14,6 @@
|
|||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Short-circuit if init.sh has already been sourced
|
# Short-circuit if init.sh has already been sourced
|
||||||
[[ $(type -t openim::init::loaded) == function ]] && return 0
|
[[ $(type -t openim::init::loaded) == function ]] && return 0
|
||||||
|
|
||||||
|
@ -25,9 +25,9 @@ if [ -z "${OPENIM_OUTPUT+x}" ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Set the log file path
|
# Set the log file path
|
||||||
LOG_FILE="${OPENIM_OUTPUT}/logs/openim_$(date '+%Y%m%d').log"
|
LOG_FILE="${OPENIM_OUTPUT}/logs/openim-$(date '+%Y%m%d').log"
|
||||||
STDERR_LOG_FILE="${OPENIM_OUTPUT}/logs/openim_error_$(date '+%Y%m%d').log"
|
STDERR_LOG_FILE="${OPENIM_OUTPUT}/logs/openim-error-$(date '+%Y%m%d').log"
|
||||||
TMP_LOG_FILE="${OPENIM_OUTPUT}/logs/openim_tmp_$(date '+%Y%m%d').log"
|
TMP_LOG_FILE="${OPENIM_OUTPUT}/logs/openim-tmp-$(date '+%Y%m%d').log"
|
||||||
|
|
||||||
if [[ ! -d "${OPENIM_OUTPUT}/logs" ]]; then
|
if [[ ! -d "${OPENIM_OUTPUT}/logs" ]]; then
|
||||||
mkdir -p "${OPENIM_OUTPUT}/logs"
|
mkdir -p "${OPENIM_OUTPUT}/logs"
|
||||||
|
@ -152,6 +152,7 @@ function openim::release::package_src_tarball() {
|
|||||||
-path "${OPENIM_ROOT}"/.github\* -o \
|
-path "${OPENIM_ROOT}"/.github\* -o \
|
||||||
-path "${OPENIM_ROOT}"/components\* -o \
|
-path "${OPENIM_ROOT}"/components\* -o \
|
||||||
-path "${OPENIM_ROOT}"/logs\* -o \
|
-path "${OPENIM_ROOT}"/logs\* -o \
|
||||||
|
-path "${OPENIM_ROOT}"/_output\* -o \
|
||||||
-path "${OPENIM_ROOT}"/.gitignore\* -o \
|
-path "${OPENIM_ROOT}"/.gitignore\* -o \
|
||||||
-path "${OPENIM_ROOT}"/.gsemver.yml\* -o \
|
-path "${OPENIM_ROOT}"/.gsemver.yml\* -o \
|
||||||
-path "${OPENIM_ROOT}"/.config\* -o \
|
-path "${OPENIM_ROOT}"/.config\* -o \
|
||||||
|
46
scripts/verify-annotation-language.sh
Executable file
46
scripts/verify-annotation-language.sh
Executable file
@ -0,0 +1,46 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# 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.
|
||||||
|
|
||||||
|
|
||||||
|
# This script verifies whether codes follow golang convention.
|
||||||
|
# Usage: `scripts/verify-pkg-names.sh`.
|
||||||
|
|
||||||
|
set -o errexit
|
||||||
|
|
||||||
|
OPENIM_ROOT=$(dirname "${BASH_SOURCE[0]}")/..
|
||||||
|
source "${OPENIM_ROOT}/scripts/lib/init.sh"
|
||||||
|
|
||||||
|
openim::golang::verify_go_version
|
||||||
|
|
||||||
|
openim::golang::verify_go_version
|
||||||
|
|
||||||
|
OPENIM_OUTPUT_HOSTBIN_TOOLS="${OPENIM_ROOT}/_output/bin/tools/linux/amd64"
|
||||||
|
CODESCAN_BINARY="${OPENIM_OUTPUT_HOSTBIN_TOOLS}/codescan"
|
||||||
|
|
||||||
|
if [[ ! -f "${CODESCAN_BINARY}" ]]; then
|
||||||
|
echo "codescan binary not found, building..."
|
||||||
|
pushd "${OPENIM_ROOT}" >/dev/null
|
||||||
|
make build BINS="codescan"
|
||||||
|
popd >/dev/null
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ ! -f "${CODESCAN_BINARY}" ]]; then
|
||||||
|
echo "Failed to build codescan binary."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
CONFIG_PATH="${OPENIM_ROOT}/tools/codescan/config.yaml"
|
||||||
|
|
||||||
|
"${CODESCAN_BINARY}" -config "${CONFIG_PATH}"
|
@ -18,9 +18,6 @@
|
|||||||
# Usage: `scripts/verify-pkg-names.sh`.
|
# Usage: `scripts/verify-pkg-names.sh`.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
OPENIM_ROOT=$(dirname "${BASH_SOURCE[0]}")/..
|
OPENIM_ROOT=$(dirname "${BASH_SOURCE[0]}")/..
|
||||||
source "${OPENIM_ROOT}/scripts/lib/init.sh"
|
source "${OPENIM_ROOT}/scripts/lib/init.sh"
|
||||||
|
|
||||||
|
@ -1 +0,0 @@
|
|||||||
package main
|
|
90
tools/codescan/checker/checker.go
Normal file
90
tools/codescan/checker/checker.go
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
package checker
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bufio"
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
"regexp"
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"github.com/openimsdk/open-im-server/tools/codescan/config"
|
||||||
|
)
|
||||||
|
|
||||||
|
type CheckResult struct {
|
||||||
|
FilePath string
|
||||||
|
Lines []int
|
||||||
|
}
|
||||||
|
|
||||||
|
func checkFileForChineseComments(filePath string) ([]CheckResult, error) {
|
||||||
|
file, err := os.Open(filePath)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
defer file.Close()
|
||||||
|
|
||||||
|
var results []CheckResult
|
||||||
|
scanner := bufio.NewScanner(file)
|
||||||
|
reg := regexp.MustCompile(`[\p{Han}]+`)
|
||||||
|
lineNumber := 0
|
||||||
|
|
||||||
|
var linesWithChinese []int
|
||||||
|
for scanner.Scan() {
|
||||||
|
lineNumber++
|
||||||
|
if reg.FindString(scanner.Text()) != "" {
|
||||||
|
linesWithChinese = append(linesWithChinese, lineNumber)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(linesWithChinese) > 0 {
|
||||||
|
results = append(results, CheckResult{
|
||||||
|
FilePath: filePath,
|
||||||
|
Lines: linesWithChinese,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := scanner.Err(); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return results, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func WalkDirAndCheckComments(cfg config.Config) error {
|
||||||
|
var allResults []CheckResult
|
||||||
|
err := filepath.Walk(cfg.Directory, func(path string, info os.FileInfo, err error) error {
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if info.IsDir() {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
for _, fileType := range cfg.FileTypes {
|
||||||
|
if filepath.Ext(path) == fileType {
|
||||||
|
results, err := checkFileForChineseComments(path)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if len(results) > 0 {
|
||||||
|
allResults = append(allResults, results...)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
})
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(allResults) > 0 {
|
||||||
|
var errMsg strings.Builder
|
||||||
|
errMsg.WriteString("Files containing Chinese comments:\n")
|
||||||
|
for _, result := range allResults {
|
||||||
|
errMsg.WriteString(fmt.Sprintf("%s: Lines %v\n", result.FilePath, result.Lines))
|
||||||
|
}
|
||||||
|
return fmt.Errorf(errMsg.String())
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
20
tools/codescan/codescan.go
Normal file
20
tools/codescan/codescan.go
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"log"
|
||||||
|
|
||||||
|
"github.com/openimsdk/open-im-server/tools/codescan/checker"
|
||||||
|
"github.com/openimsdk/open-im-server/tools/codescan/config"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
cfg, err := config.ParseConfig()
|
||||||
|
if err != nil {
|
||||||
|
log.Fatalf("Error parsing config: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
err = checker.WalkDirAndCheckComments(cfg)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
}
|
7
tools/codescan/config.yaml
Normal file
7
tools/codescan/config.yaml
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
directory: ./
|
||||||
|
file_types:
|
||||||
|
- .go
|
||||||
|
- .yaml
|
||||||
|
- .yml
|
||||||
|
languages:
|
||||||
|
- Chinese
|
35
tools/codescan/config/config.go
Normal file
35
tools/codescan/config/config.go
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
package config
|
||||||
|
|
||||||
|
import (
|
||||||
|
"flag"
|
||||||
|
"log"
|
||||||
|
"os"
|
||||||
|
|
||||||
|
"gopkg.in/yaml.v2"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Config struct {
|
||||||
|
Directory string `yaml:"directory"`
|
||||||
|
FileTypes []string `yaml:"file_types"`
|
||||||
|
Languages []string `yaml:"languages"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func ParseConfig() (Config, error) {
|
||||||
|
var configPath string
|
||||||
|
flag.StringVar(&configPath, "config", "./", "Path to config file")
|
||||||
|
flag.Parse()
|
||||||
|
|
||||||
|
var config Config
|
||||||
|
if configPath != "" {
|
||||||
|
configFile, err := os.ReadFile(configPath)
|
||||||
|
if err != nil {
|
||||||
|
return Config{}, err
|
||||||
|
}
|
||||||
|
if err := yaml.Unmarshal(configFile, &config); err != nil {
|
||||||
|
return Config{}, err
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
log.Fatal("Config file must be provided")
|
||||||
|
}
|
||||||
|
return config, nil
|
||||||
|
}
|
3
tools/codescan/go.mod
Normal file
3
tools/codescan/go.mod
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
module github.com/openimsdk/open-im-server/tools/codescan
|
||||||
|
|
||||||
|
go 1.19
|
Loading…
x
Reference in New Issue
Block a user