node实现对git仓库的管理

一、项目背景

一份代码,发布多个小程序。想让技术支持部通过脚本自己获取代码,并通过脚本自动提交到客户的小程序后台。他们自行发布。

现已注册第三方平台,开发人员通过"开发小程序"上传模板。开发人员把代码上传到模板,支持人员选择模板进行发布小程序。好像git代码管理也不需要了。

二、主要代码

app.js

c 复制代码
const express = require('express');
const fs = require('fs');
const simpleGit = require('simple-git');
const cors = require('cors'); // 引入 cors 模块

const app = express();

const gitUrl = 'xxx'; //配置
const branch = '5.0.1';
const codePath = 'unpackage/dist/build/mp-weixin';

// 本地临时文件夹
const tempFolder = 'temp';

// 使用 cors 中间件
app.use(cors());

//clone项目
app.get('/api/gitClone', (req, res) => {
    simpleGit().clone(gitUrl, tempFolder, ['-b', branch], (err, data) => {
        if (err) {
            console.error('Clone failed:', err);
        } else {
            console.log('Clone success');
            res.json({
                message: 'clone成功'
            });

            // 2. 复制代码到指定路径
            // 这里可能需要根据你的实际需求使用适当的文件复制方法
            // 例如使用 fs-extra 库的 copy 方法

            // 3. 执行特定文件
            const filePath = `${tempFolder}/${codePath}/your-executable-file.js`;

            try {
                // execSync(`node ${filePath}`, {
                //     stdio: 'inherit'
                // });
                console.log('Execution success');
            } catch (error) {
                console.error('Execution failed:', error);

            }
        }
    });
});


//git 获取所有分支
app.get('/api/gitBranches', (req, res) => {
    // 获取所有分支
    simpleGit(tempFolder).branch((err, branchSummary) => {
        console.log('branchSummary: ', branchSummary);
        if (err) {
            console.error('Error:', err);
            res.status(500).json({
                error: 'Failed to fetch branches'
            });
        } else {
            // 将分支信息转换为 JSON 格式并返回
            const branchesJson = {
                branches: branchSummary.all
            };

            // current: '5.0.1',  返回的字段为当前分支
            //{"branches":["5.0.1","remotes/origin/1.0.0","remotes/origin/2.0.0","remotes/origin/2.0.1","remotes/origin/2.0.2","remotes/origin/3.0.0","remotes/origin/4.0.0","remotes/origin/4.1.0","remotes/origin/4.2.0","remotes/origin/4.2.1","remotes/origin/5.0.1","remotes/origin/6.0.0","remotes/origin/master"]}
            res.json(branchesJson);
        }
    });
});

//git 切换分支
app.get('/api/checkoutBranch', (req, res) => {
    // 获取所有分支
    simpleGit(tempFolder).checkout('6.0.0', (err) => {
        if (err) {
            console.error('Error:', err);
        } else {
            console.log('Switched to branch 6.0.0');
            res.json({
                message: '切换成功'
            });
        }
    });
});

const branchToPull = '6.0.0'; // 要拉取的分支名称

//git 拉取指定分支代码
app.get('/api/pull', (req, res) => {
    // 获取所有分支
    // 拉取分支代码
    simpleGit(tempFolder).pull('origin', branchToPull, (err, update) => {
        if (err) {
            console.error('Error:', err);
            res.json({
                message: '拉取错误'
            });
        } else if (update && update.summary.changes) {
            console.log(`Pulled ${update.summary.changes} changes from branch ${branchToPull}`);
            res.json({
                message: '最新成功'
            });
        } else {
            console.log('Already up to date');
            res.json({
                message: '已经是最新'
            });
        }
    });
});

app.listen(8000, () => {
    console.log(`Server is running on port 8000`);
});
相关推荐
知识即是力量ol15 小时前
Git 快速入门 (实习生视角)
git·gitee·github
Dontla15 小时前
Git撤销上一次提交(撤销提交,Git回退提交)git reset、git revert
git
wdfk_prog16 小时前
解决 `git cherry-pick` 引入大量新文件的问题
大数据·git·elasticsearch
西门吹-禅16 小时前
prisma
node.js
怪兽毕设17 小时前
基于SpringBoot的选课调查系统
java·vue.js·spring boot·后端·node.js·选课调查系统
fu的博客18 小时前
Git从删库到跑路
git·gitee·github
要加油哦~18 小时前
git 报错 | husky - pre-commit hook exited with code 1 解决
git
知识即是力量ol18 小时前
Git 实战指南:从分支管理到冲突解决
git·github·源代码管理
心.c19 小时前
Vue3+Node.js实现文件上传分片上传和断点续传【详细教程】
前端·javascript·vue.js·算法·node.js·哈希算法
roamingcode20 小时前
我是如何 Vibe Coding,将 AI CLI 工具从 Node.js 迁移到 Rust 并成功发布的
人工智能·rust·node.js·github·claude·github copilot