forked from Pythagora-io/codebase-chat
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathroutes.js
95 lines (86 loc) · 4.67 KB
/
routes.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
const express = require('express');
const router = express.Router();
const axios = require('axios');
const Repository = require('./repository');
const { processRepository } = require('./processRepository');
const { interactWithRepository } = require('./chatService');
console.log('Router middleware is set up.');
router.get('/', (req, res) => {
console.log('GET request made to /, rendering index page.'); // gpt_pilot_debugging_log
res.render('index');
});
router.post('/submit', async (req, res) => {
console.log('POST request made to /submit'); // gpt_pilot_debugging_log
const { githubUrl, email } = req.body;
if (!githubUrl || !email) {
return res.status(400).render('submit', { message: 'Repository URL and email are both required.' });
}
try {
const repoResponse = await axios.get(githubUrl.replace('https://github.com', 'https://api.github.com/repos'));
if (repoResponse.data.private) {
console.error('Repository is private:', githubUrl); // gpt_pilot_debugging_log
return res.status(400).render('submit', { message: 'Repository is private or does not exist.' });
} else if (repoResponse.data.size === 0) {
console.log(`Repository ${githubUrl} is empty and cannot be processed.`); // gpt_pilot_debugging_log
return res.status(400).render('submit', { message: 'The repository is empty and cannot be processed.' });
} else if (repoResponse.data.size > 500) {
console.error('Repository has more than 500 files:', githubUrl); // gpt_pilot_debugging_log
return res.status(400).render('submit', { message: 'Repository has more than 500 files and cannot be processed.' });
}
const existingRepo = await Repository.findOne({ githubUrl });
if (existingRepo) {
if (existingRepo.isProcessed) {
console.log(`Redirecting to existing processed repository: ${existingRepo.uuid}`); // gpt_pilot_debugging_log
return res.redirect(`/explain/${existingRepo.uuid}`);
} else {
console.log(`Repository is currently being processed: ${githubUrl}`); // gpt_pilot_debugging_log
return res.status(200).render('submit', { message: 'Repository is currently being processed.' }); // gpt_pilot_debugging_log
}
}
const newRepo = new Repository({ githubUrl, email });
await newRepo.save();
console.log(`New repository saved with URL: ${githubUrl}`); // gpt_pilot_debugging_log
await processRepository(newRepo.githubUrl, newRepo.email);
console.log(`Processing started for repository: ${newRepo.githubUrl}`); // gpt_pilot_debugging_log
res.status(201).render('submit', { message: 'Repository processing started. You will receive an email when it is complete.' });
} catch (error) {
console.error('Error handling POST /submit:', error.message, error.stack); // gpt_pilot_debugging_log
res.status(400).render('submit', { message: 'Error checking repository. Make sure the URL is correct and the repository is public.' });
}
});
router.get('/explain/:uuid', async (req, res) => {
const uuid = req.params.uuid;
console.log(`GET request made to /explain/${uuid}`); // gpt_pilot_debugging_log
try {
const repository = await Repository.findOne({ uuid: uuid });
console.log(`Repository search result for UUID: ${uuid}:`, repository); // gpt_pilot_debugging_log
if (!repository) {
console.error(`No repository found with UUID: ${uuid}`); // gpt_pilot_debugging_log
return res.status(404).send('Repository not found');
}
if (repository.isProcessed) {
console.log(`Found and serving processed repository with UUID: ${uuid}`); // gpt_pilot_debugging_log
res.render('explain', { summary: repository.summary, uuid: uuid, githubUrl: repository.githubUrl });
} else {
console.log(`Repository with UUID: ${uuid} is not processed yet`); // gpt_pilot_debugging_log
res.status(200).send('Processing is not yet complete. Please wait for an email notification.');
}
} catch (error) {
console.error(`Error retrieving repository with UUID: ${uuid}: ${error.message}`, error.stack); // gpt_pilot_debugging_log
res.status(500).send('Error fetching repository');
}
});
router.post('/interact/:uuid', async (req, res) => {
const uuid = req.params.uuid;
const userMessage = req.body.question;
console.log(`POST request made to /interact/${uuid} with question: ${userMessage}`);
try {
const answer = await interactWithRepository(uuid, userMessage);
console.log(`Answer retrieved from interactWithRepository for UUID: ${uuid}`);
res.json({ answer });
} catch (error) {
console.error('Error in POST /interact/:uuid:', error.message, error.stack);
res.status(500).json({ error: 'Error processing your question.' });
}
});
module.exports = router;