aboutsummaryrefslogtreecommitdiff
path: root/src/app.js
diff options
context:
space:
mode:
authorHampusM <hampus@hampusmat.com>2021-05-27 21:46:44 +0200
committerHampusM <hampus@hampusmat.com>2021-05-27 21:46:44 +0200
commitbdfc5d2d092fdce8fb4149ae8acb86b63c14c642 (patch)
tree64fd18534f7f6cfb0f204065c2d40b9bf6146d85 /src/app.js
parentdf806dda764ff722742301042ab88b3d91f472c5 (diff)
Implemented cloning in backend
Diffstat (limited to 'src/app.js')
-rw-r--r--src/app.js47
1 files changed, 40 insertions, 7 deletions
diff --git a/src/app.js b/src/app.js
index 14b8188..57f0ca1 100644
--- a/src/app.js
+++ b/src/app.js
@@ -6,6 +6,7 @@ const fs = require('fs');
const { exit } = require("process");
const path = require("path");
const util = require("./api/util");
+const git = require("./api/git");
const settings = yaml.load(fs.readFileSync(__dirname + "/../settings.yml", 'utf8'));
const settings_keys = Object.keys(settings);
@@ -44,12 +45,9 @@ fastify.setNotFoundHandler({
reply.send("404: Not found");
});
-fastify.route({
- method: "GET",
- path: "/app.html",
- handler: (req, reply) => reply.redirect("/")
-});
+fastify.addContentTypeParser("application/x-git-upload-pack-request", (req, payload, done) => done(null, payload));
+
fastify.register(fastify_static, { root: dist_dir })
fastify.register(api, { prefix: "/api/v1", config: { settings: settings } });
@@ -64,6 +62,12 @@ fastify.route({
}
});
+fastify.route({
+ method: "GET",
+ path: "/app.html",
+ handler: (req, reply) => reply.redirect("/")
+});
+
fastify.register((fastify_repo, opts, done) =>
{
fastify_repo.setNotFoundHandler({
@@ -79,10 +83,10 @@ fastify.register((fastify_repo, opts, done) =>
const repo_verification = await util.verifyRepoName(req.params.repo, settings.base_dir);
if(repo_verification !== true) {
if(repo_verification === "ERR_REPO_REGEX") {
- reply.code(400).send("Error: Unacceptable git repository name!");
+ reply.code(400).send("Unacceptable git repository name!\n");
}
else if(repo_verification === "ERR_REPO_NOT_FOUND") {
- reply.code(404).send("Error: Git repository not found!");
+ reply.code(404).send("Git repository not found!\n");
}
}
});
@@ -113,6 +117,35 @@ fastify.register((fastify_repo, opts, done) =>
}
});
+ fastify_repo.route({
+ method: "GET",
+ path: "/info/refs",
+ handler: (req, reply) =>
+ {
+ if(!req.query.service) {
+ reply.code(403).send("Missing service query parameter\n");
+ return
+ }
+ else if(req.query.service !== "git-upload-pack") {
+ reply.code(403).send("Access denied!\n");
+ return;
+ }
+ else if(Object.keys(req.query).length !== 1) {
+ reply.header("Content-Type", "application/x-git-upload-pack-advertisement");
+ reply.code(403).send("Too many query parameters!\n");
+ return;
+ }
+
+ git.connectToGitHTTPBackend(settings["base_dir"], req, reply);
+ }
+ });
+
+ fastify_repo.route({
+ method: "POST",
+ path: "/git-upload-pack",
+ handler: (req, reply) => git.connectToGitHTTPBackend(settings["base_dir"], req, reply)
+ });
+
done();
}, { prefix: "/:repo" });