当前位置: 首页 > article >正文

通过脚本,发起分支合并请求和打tag

#!/bin/bash

# Set GitLab API URL and access token
GITLAB_API_URL="http://IP/api/v4"
ACCESS_TOKEN="Token秘钥"

# Define repository IDs
declare -A repo_ids=(
    ["git@IP:kingmq/client.git"]="123"
    ["git@IP:kingmq/server.git"]="456"
)

# Function: Create a merge request
create_merge_request() {
    local repo=$1
    local src_branch=$2
    local dest_branch=$3
    local title=$4
    local description=$5
    local repo_id=${repo_ids[$repo]}

    echo "Creating a merge request from $src_branch to $dest_branch for repository $repo"

    # Make API request to create a merge request
    response=$(curl -s --request POST --header "PRIVATE-TOKEN: $ACCESS_TOKEN" --data "source_branch=$src_branch&target_branch=$dest_branch&title=$title&description=$description" "$GITLAB_API_URL/projects/$repo_id/merge_requests")

    # Parse the response to get the merge request URL
    merge_request_url=$(echo "$response" | python -c 'import sys, json; print(json.load(sys.stdin)["web_url"])')

    echo "Merge request created: $merge_request_url"
}

create_tag() {
    local repo=$1
    local branch=$2
    local tag_name=$3
    local tag_message=$4
    local repo_id=${repo_ids[$repo]}

    echo "Creating tag $tag_name on branch $branch for repository $repo"

    # 获取分支的提交 SHA
    commit_sha=$(curl -s --header "PRIVATE-TOKEN: $ACCESS_TOKEN" "$GITLAB_API_URL/projects/$repo_id/repository/branches/$branch" | python -c 'import sys, json; print(json.load(sys.stdin)["commit"]["id"])')

    # 创建标签
    response=$(curl -s --request POST --header "PRIVATE-TOKEN: $ACCESS_TOKEN" --data "tag_name=$tag_name&ref=$commit_sha&message=$tag_message" "$GITLAB_API_URL/projects/$repo_id/repository/tags")
    
    echo "Tag created: $response"
}
# Interactive repository selection
select_repo() {
    PS3="Select a repository: "
    select repo in "kingmq-client" "kingmq-common" "kingmq-kmf" "kingmq-server" "Exit"; do
        case $repo in
            "Exit")
                exit 0
                ;;
            *)
                break
                ;;
        esac
    done
    repo_url="git@IP:XXX/$repo.git"
}


main(){
    echo -e "输入 \n\
    1: Merge from release to main \n\
    4: release分支打标签 \n\
    其他:取消"
    read -p "请输入 " args
    case $args in 
        1)
            title="合并release到main"
            description="合并release到main"
            select_repo
            create_merge_request "$repo_url" "release" "main" "$title" "$description"
            ;;
        2)
            echo "请输入tag编号:"
            read version
            title="$version"
            description="baseline-$version"
            select_repo
            create_tag "$repo_url" "release" "$title" "$description"
            ;;
   
        *)
            echo "Invalid option: $1"
            echo "Usage: $0 {1|2}"
            exit 1
            ;;
    esac
}

#开始执行
main $*


http://www.kler.cn/a/395062.html

相关文章:

  • Vue 92 ,Element 15 ,Vue + el-upload 实现图片上传与管理
  • 基于Springboot + vue实现的汽车资讯网站
  • Leetcode 3393. Count Paths With the Given XOR Value
  • 【XSSed】攻防实战全记录
  • Day13 用Excel表体验梯度下降法
  • Go web 开发框架 Iris
  • 【贪心算法】贪心算法三
  • 【HAProxy07】企业级反向代理HAProxy高级功能之Cookie 会话保持与HAProxy 状态页
  • 计算机网络——路由选择算法
  • 校园二手交易网站毕业设计基于SpringBootSSM框架
  • Invar-RAG:基于不变性对齐的LLM检索方法提升生成质量
  • 初识Linux · 信号产生
  • 通过Python 调整Excel行高、列宽
  • 技术栈1:nginx基础入门
  • 计算机网络——1.1计算机网络概述
  • Bugku CTF_Web——点login咋没反应
  • 技术前沿:从强化学习到Prompt Engineering,业务流程管理的创新之路
  • 第十九周:机器学习
  • 在Linux中使用Nginx和Docker进行项目部署
  • 【mysql】explain执行计划的各个参数
  • C# Winform--SerialPort串口通讯(ASCII码发送)
  • linux 能显式修改文件的最后一次访问时间和文件内容最后被修改的时间,不能显式修改文件状态最后被改变的时间,为什么
  • Leetcode 3352. Count K-Reducible Numbers Less Than N
  • vue el-upload js 上传文件只有uid
  • Linux自定义终端提示符
  • 基于Spider异步爬虫框架+JS动态参数逆向+隧道代理+自定义中间件的猎聘招聘数据爬取