Added container routes to backend and Dashboard.jsx to frontend.
This commit is contained in:
parent
d0e1db5439
commit
81431c61b3
4
admin-api/docker.js
Normal file
4
admin-api/docker.js
Normal file
|
|
@ -0,0 +1,4 @@
|
||||||
|
const Docker = require('dockerode');
|
||||||
|
const docker = new Docker();
|
||||||
|
|
||||||
|
module.exports = docker;
|
||||||
15
admin-api/routes/containerRoutes.js
Normal file
15
admin-api/routes/containerRoutes.js
Normal file
|
|
@ -0,0 +1,15 @@
|
||||||
|
const express = require('express');
|
||||||
|
const docker = require('../docker');
|
||||||
|
|
||||||
|
const router = express.Router();
|
||||||
|
|
||||||
|
router.get('/', async (req, res) => {
|
||||||
|
try {
|
||||||
|
const containers = await docker.listContainers();
|
||||||
|
res.json(containers);
|
||||||
|
} catch (error) {
|
||||||
|
res.status(500).send({ error: error.message });
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
module.exports = router;
|
||||||
|
|
@ -3,6 +3,7 @@ const express = require('express');
|
||||||
const session = require('express-session');
|
const session = require('express-session');
|
||||||
const passport = require('passport');
|
const passport = require('passport');
|
||||||
const authRoutes = require('./routes/authRoutes');
|
const authRoutes = require('./routes/authRoutes');
|
||||||
|
const containerRoutes = require('./routes/containerRoutes');
|
||||||
|
|
||||||
const app = express();
|
const app = express();
|
||||||
app.use(express.json());
|
app.use(express.json());
|
||||||
|
|
@ -11,6 +12,7 @@ app.use(passport.initialize());
|
||||||
app.use(passport.session());
|
app.use(passport.session());
|
||||||
|
|
||||||
app.use('/api/auth', authRoutes);
|
app.use('/api/auth', authRoutes);
|
||||||
|
app.use('/api/containers', containerRoutes);
|
||||||
|
|
||||||
app.listen(3001, () => {
|
app.listen(3001, () => {
|
||||||
console.log('Backend server running on port 3001');
|
console.log('Backend server running on port 3001');
|
||||||
|
|
|
||||||
27
admin-app/src/components/Dashboard.jsx
Normal file
27
admin-app/src/components/Dashboard.jsx
Normal file
|
|
@ -0,0 +1,27 @@
|
||||||
|
import React, { useState, useEffect } from 'react';
|
||||||
|
import axios from 'axios';
|
||||||
|
|
||||||
|
const Dashboard = () => {
|
||||||
|
const [containers, setContainers] = useState([]);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
const fetchContainers = async () => {
|
||||||
|
const response = await axios.get('/api/containers');
|
||||||
|
setContainers(response.data);
|
||||||
|
};
|
||||||
|
fetchContainers();
|
||||||
|
}, []);
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div>
|
||||||
|
<h2>Docker Containers</h2>
|
||||||
|
<ul>
|
||||||
|
{containers.map(container => (
|
||||||
|
<li key={container.Id}>{container.Names[0]}</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
export default Dashboard;
|
||||||
Loading…
Reference in New Issue
Block a user