diff --git a/.gitattributes b/.gitattributes new file mode 100644 index 0000000..dfdb8b7 --- /dev/null +++ b/.gitattributes @@ -0,0 +1 @@ +*.sh text eol=lf diff --git a/docker-compose.yml b/docker-compose.yml index 48506ab..5adb983 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -34,7 +34,7 @@ services: environment: - VITE_TENANT=default - VITE_TENANT_CLIENT_ID=e9fdb985-9173-4e01-9d73-ac2d60d1dc8e - - VITE_TENANT_LOGO= + - VITE_TENANT_LOGO=/default-logo.png - VITE_TENANT_BACKGROUNDCOLOR=#FFFFFF - VITE_BACKEND_URL=http://localhost/api frontend-adac: @@ -44,8 +44,8 @@ services: - "5174:3000" environment: - VITE_TENANT=adac - - VITE_TENANT_CLIENT_ID=b2cd30ad-bcb9-472b-91d6-effae14db013 - - VITE_TENANT_LOGO= + - VITE_TENANT_CLIENT_ID=e9fdb985-9173-4e01-9d73-ac2d60d1dc8e + - VITE_TENANT_LOGO=/adac-logo.png - VITE_TENANT_BACKGROUNDCOLOR=#FFFF00 - VITE_BACKEND_URL=http://localhost/api pin-service: diff --git a/frontend/public/adac-logo.png b/frontend/public/adac-logo.png new file mode 100644 index 0000000..2613333 Binary files /dev/null and b/frontend/public/adac-logo.png differ diff --git a/frontend/public/default-logo.png b/frontend/public/default-logo.png new file mode 100644 index 0000000..731d94a Binary files /dev/null and b/frontend/public/default-logo.png differ diff --git a/frontend/src/App.vue b/frontend/src/App.vue index d3cb002..1a7b5ce 100644 --- a/frontend/src/App.vue +++ b/frontend/src/App.vue @@ -3,7 +3,7 @@ logo-black { let tenantBackgroundColor = ref(TENANT_BACKGROUNDCOLOR || '#ffffff') -console.log('TENANT: ' + TENANT + ' PATH: ' + PATH, 'TENANT_BACKGROUNDCOLOR: ' + TENANT_BACKGROUNDCOLOR) +console.log('TENANT: ' + TENANT + ' PATH: ' + PATH, 'TENANT_BACKGROUNDCOLOR: ' + TENANT_BACKGROUNDCOLOR, 'TENANT_LOGO: ' + TENANT_LOGO) console.log(document.cookie) diff --git a/frontend/src/js/config.js b/frontend/src/js/config.js index bf29551..9367c58 100644 --- a/frontend/src/js/config.js +++ b/frontend/src/js/config.js @@ -3,7 +3,7 @@ const BACKEND_URL = import.meta.env.VITE_BACKEND_URL; const TENANT = import.meta.env.VITE_TENANT || 'default'; const TENANT_CLIENT_ID = import.meta.env.VITE_TENANT_CLIENT_ID; -const TENANT_LOGO = import.meta.env.VITE_TENANT_LOGO; +const TENANT_LOGO = import.meta.env.VITE_TENANT_LOGO || '/default-logo.png'; const TENANT_BACKGROUNDCOLOR = import.meta.env.VITE_TENANT_BACKGROUNDCOLOR; const PATH = TENANT == 'default' ? '' : `/${TENANT}`; diff --git a/frontend/src/js/requests.js b/frontend/src/js/requests.js index 94e8e22..4ebf325 100644 --- a/frontend/src/js/requests.js +++ b/frontend/src/js/requests.js @@ -49,6 +49,8 @@ export async function createPin(pin) { "tenant": TENANT } }); + + console.log(response); if (!response.ok) throw new Error(`HTTP error! status: ${response.status}, ${response.statusText}`); const createdPin = await response.json(); @@ -65,7 +67,7 @@ export async function createPin(pin) { */ export async function getHeatmapData() { try { - const response = await fetch(`${BACKEND_URL}/heatmap`, { + const response = await fetch(`${BACKEND_URL}/heatmap/`, { method: 'GET', headers: { 'Content-Type': 'application/json', diff --git a/frontend/src/views/HeatmapView.vue b/frontend/src/views/HeatmapView.vue index 265a637..7501412 100644 --- a/frontend/src/views/HeatmapView.vue +++ b/frontend/src/views/HeatmapView.vue @@ -9,11 +9,11 @@ style="cursor: crosshair" > { console.log(...args); }; + const MONDODB_URI = process.env.MONGODB_URI || "mongodb://localhost:27017"; +debug("heatmap-service: connecting to MongoDB: ", MONDODB_URI); + // connect to MongoDB const client = new MongoClient(MONDODB_URI); await client.connect(); @@ -21,66 +25,47 @@ const polygonCollection = database.collection("polygon"); // heatRegionsState = { timestamp: string, heatRegions: [{ polygonname: string, density: number (0-1), count: number }] } const heatRegionStateCollection = database.collection("heatRegionState"); -// create a view that joins the heatRegion and polygon collections -await database.command({ drop: "heatRegionStateWithPolygonView" }); -// polygon: {polygonname: string, polygon: []} -// heatRegionWithPolygonView: { timestamp: string, heatRegions: [{ polygonname: string, density: number (0-1), count: number, polygon: [] }] } -await database.command({ - create: "heatRegionStateWithPolygonView", - viewOn: "heatRegionState", - pipeline: [ - { - $lookup: { - from: "polygon", - localField: "heatRegions.polygonname", - foreignField: "polygonname", - as: "polygondata", - }, - }, - { - $project: { - _id: 0, - timestamp: 1, - heatRegions: { - polygonname: 1, - density: 1, - count: 1, - polygon: "$polygondata.polygon", - }, - }, - }, - { - $unwind: "$heatRegions.polygon" - } - ], -}); -const heatRegionStateWithPolygonView = database.collection("heatRegionStateWithPolygonView"); - // start express server const app = express(); const port = 3003; app.use(express.json()); app.use(cookieParser()); -app.use(auth); +// app.use(auth); + // define routes app.get("/", async (req, res) => { + debug("heatmap-service: GET /"); + // get the current heat region state - const heatRegionState = await heatRegionStateCollection.find({}).sort({ timestamp: -1 }).limit(1).next(); + const heatRegionState = await heatRegionStateCollection.find({}).sort({ "timestamp": -1 }).limit(1).next(); if (!heatRegionState) { + debug("heatmap-service: no heat region state found"); res.status(400).send("No heat region state found"); return; } - // TEMP: add polygon data to the heat region state (later this should be done in the view) - for (let i = 0; i < heatRegionState.heatRegions.length; i++) { - const heatRegion = heatRegionState.heatRegions[i]; - const polygon = await polygonCollection.findOne({ polygonname: heatRegion.polygonname }); - if (polygon) { - heatRegion.polygon = polygon.polygon; + debug("heatmap-service: heat region state: ", heatRegionState); + + const polygonNames = heatRegionState.heatRegions.map(heatRegion => heatRegion.polygonname); + + debug("heatmap-service: polygon names: ", polygonNames); + + const polygons = await polygonCollection.find({ polygonname: { $in: polygonNames } }).toArray(); + + debug("heatmap-service: polygons: ", polygons); + + heatRegionState.heatRegions.forEach(heatRegion => { + const polygon = polygons.find(polygon => polygon.polygonname === heatRegion.polygonname); + if (!polygon) { + console.error(`Could not find polygon ${heatRegion.polygonname}`); + return; } - } + heatRegion.polygon = polygon.polygon; + }); + + debug("heatmap-service: sending heat region state: ", heatRegionState); // send the heat region state res.status(200).send(heatRegionState); diff --git a/services/heatmap-service/version.txt b/services/heatmap-service/version.txt index 6a2b0ac..13637f4 100644 --- a/services/heatmap-service/version.txt +++ b/services/heatmap-service/version.txt @@ -1 +1 @@ -v1.0.1 \ No newline at end of file +v1.0.3 \ No newline at end of file diff --git a/services/pin-service/index.js b/services/pin-service/index.js index 8a1841b..7c4a1ec 100644 --- a/services/pin-service/index.js +++ b/services/pin-service/index.js @@ -21,59 +21,23 @@ const pinCollection = database.collection("pin"); const polygonCollection = database.collection("polygon"); const heatRegionCollection = database.collection("heatRegion"); -// create a view that joins the pin and polygon collections -await database.command({ drop: "pinWithPolygonView" }); -await database.command({ - create: "pinWithPolygonView", - viewOn: "pin", - pipeline: [ - { - $lookup: { - from: "polygon", - localField: "polygonname", - foreignField: "polygonname", - as: "polygondata", - }, - }, - { - $project: { - _id: 0, - id: 1, - username: 1, - longitude: 1, - latitude: 1, - name: 1, - description: 1, - date: 1, - companions: 1, - duration: 1, - budget: 1, - polygon: "$polygondata.polygon", - polygonname: 1, - }, - }, - { - $unwind: { - path: "$polygon", - preserveNullAndEmptyArrays: true, - }, - }, - ], -}); -const pinWithPolygonView = database.collection("pinWithPolygonView"); - // start express server const app = express(); const port = 3002; app.use(express.json()); app.use(cookieParser()); app.use(auth); - +const debug = (...args) => { console.log(...args); }; app.post("/", async (req, res) => { let pin = req.body; + + debug("pin-service: received pin: ", pin); + pin.username = req.user.username; + debug("pin-service: username in request: ", req.user.username); + const { polygon, polygonname } = await getPolygonAndName(pin.latitude, pin.longitude); if (!polygon) { res.status(400).send("Could not find polygon"); @@ -96,36 +60,26 @@ app.post("/", async (req, res) => { app.get("/", async (req, res) => { const user = req.user; - const pins = await pinWithPolygonView.find({ username: user.username }).toArray(); - res.send(pins); -}); -app.post("/region", async (req, res) => { + debug("pin-service: username in get request: ", req.user.username); - // takes in a lat and lng and returns a polygon that is the region around that point - // it also stores the polygon in the database so that it does not have to be fetched again - // it replaces the getPolygonAndName function (but uses it) - - const { lat, lng } = req.body; - - // fetch the polygon outline from nominatim - const { polygon, polygonname } = await getPolygonAndName(lat, lng); - if (!polygon) { - res.status(400).send("Could not find polygon"); - return; - } + const pins = await pinCollection.find({ "username": req.user.username }).toArray(); - // save the polygon outline to the database to not have to fetch it again if it is not already there - const existingPolygon = await polygonCollection.findOne({ polygonname }); - if (!existingPolygon) { - await polygonCollection.insertOne({ polygonname, polygon }); - } + // add the polygon outlines to the pins + const polygonnames = pins.map(pin => pin.polygonname); + const polygons = await polygonCollection.find({ polygonname: { $in: polygonnames } }).toArray(); + const pinsWithPolygons = pins.map(pin => { + const polygon = polygons.find(polygon => polygon.polygonname === pin.polygonname); + if (!polygon) return pin; + pin.polygon = polygon.polygon; + return pin; + }); - res.send({ polygonname, polygon }); + debug("pin-service: received pins from database: ", pinsWithPolygons); + res.send(pinsWithPolygons); }); - app.listen(port, () => console.log(`Example app listening on http://localhost:${port}`)); @@ -167,7 +121,7 @@ const getPolygonAndName = async (lat, lng) => { let maxZoom = 10; let minZoom = 5; - for (let tryIndex = 0; tryIndex < 10; tryIndex++) { + for (let tryIndex = 0; tryIndex < 5; tryIndex++) { // prepare the reverse geocoding request options let reverseRequestOptions = { diff --git a/services/pin-service/version.txt b/services/pin-service/version.txt index 6a2b0ac..c1757a8 100644 --- a/services/pin-service/version.txt +++ b/services/pin-service/version.txt @@ -1 +1 @@ -v1.0.1 \ No newline at end of file +v1.0.5 \ No newline at end of file diff --git a/services/update-service/index.js b/services/update-service/index.js index 44cd84a..89a0089 100644 --- a/services/update-service/index.js +++ b/services/update-service/index.js @@ -28,7 +28,7 @@ const app = express(); const port = 3005; app.use(express.json()); app.use(cookieParser()); -app.use(auth); +// app.use(auth); // define routes app.get("/", (req, res) => { diff --git a/services/update-service/version.txt b/services/update-service/version.txt index 6a2b0ac..b482243 100644 --- a/services/update-service/version.txt +++ b/services/update-service/version.txt @@ -1 +1 @@ -v1.0.1 \ No newline at end of file +v1.0.2 \ No newline at end of file