diff --git a/alfalfa_web/alfalfa.svg b/alfalfa_web/alfalfa.svg
deleted file mode 100644
index 04a1a8ad..00000000
--- a/alfalfa_web/alfalfa.svg
+++ /dev/null
@@ -1 +0,0 @@
-
diff --git a/alfalfa_web/components/App/App.js b/alfalfa_web/components/App/App.js
index c27b4091..0b7ac16b 100644
--- a/alfalfa_web/components/App/App.js
+++ b/alfalfa_web/components/App/App.js
@@ -17,7 +17,7 @@ export const App = () => {
-
+
diff --git a/alfalfa_web/app.js b/alfalfa_web/components/app.js
similarity index 76%
rename from alfalfa_web/app.js
rename to alfalfa_web/components/app.js
index f21a59d2..0602f038 100644
--- a/alfalfa_web/app.js
+++ b/alfalfa_web/components/app.js
@@ -4,11 +4,13 @@ import "@fontsource/roboto";
import "normalize.css/normalize.css";
import ReactDOM from "react-dom";
import { BrowserRouter } from "react-router-dom";
-import { App } from "./components/App/App.js";
+import { App } from "./App/App.js";
ReactDOM.render(
-
+
+
+
,
document.getElementById("root")
);
diff --git a/alfalfa_web/generate-docs.js b/alfalfa_web/generate-docs.js
index f0bb8fe8..293f6000 100644
--- a/alfalfa_web/generate-docs.js
+++ b/alfalfa_web/generate-docs.js
@@ -17,7 +17,7 @@ const openapiSpecification = swaggerJsdoc({
description:
"Alfalfa transforms Building Energy Models (BEMs) into virtual buildings by providing industry standard building control interfaces for interacting with models as they run",
"x-logo": {
- url: "/assets/alfalfa.svg"
+ url: ""
}
},
servers: [
@@ -203,6 +203,3 @@ mkdirp.sync("build/app/assets");
fs.writeFileSync("build/app/openapi.json", JSON.stringify(openapiSpecification));
npmRun.execSync("redoc-cli build openapi.json -t ../../docs.hbs", { cwd: __dirname + "/build/app" });
-
-fs.copyFileSync("alfalfa.svg", "build/app/assets/alfalfa.svg");
-fs.renameSync("build/app/redoc-static.html", "build/app/docs.html");
diff --git a/alfalfa_web/package.json b/alfalfa_web/package.json
index af9a9c18..910cc083 100644
--- a/alfalfa_web/package.json
+++ b/alfalfa_web/package.json
@@ -9,8 +9,10 @@
"build-server": "babel -d ./build ./server",
"clean": "npx rimraf build",
"start": "node ./build/index.js",
- "start-dev": "npm run build-server && env-cmd -f ../.env npm start",
- "watch": "nodemon -e js,html --ignore build/ --exec \"npm run build-app && npm run build-server && npm start\""
+ "watch": "run-p watch-app watch-docs watch-server",
+ "watch-app": "webpack --watch",
+ "watch-docs": "nodemon --watch generate-docs.js --watch server/api-v2.js --watch server/api-haystack.js generate-docs.js",
+ "watch-server": "nodemon --watch server --exec \"npm run build-server && env-cmd -f ../.env npm start\""
},
"author": "",
"license": "ISC",
diff --git a/alfalfa_web/server/api.js b/alfalfa_web/server/api.js
index 02a2b98e..ec721908 100644
--- a/alfalfa_web/server/api.js
+++ b/alfalfa_web/server/api.js
@@ -32,6 +32,7 @@ class AlfalfaAPI {
this.s3 = new S3Client({
credentials,
endpoint: process.env.S3_URL_EXTERNAL || process.env.S3_URL,
+ forcePathStyle: true,
region
});
}
diff --git a/alfalfa_web/server/index.js b/alfalfa_web/server/index.js
index 4e1b2a19..077b4874 100644
--- a/alfalfa_web/server/index.js
+++ b/alfalfa_web/server/index.js
@@ -11,6 +11,7 @@ import { createClient } from "redis";
import alfalfaServer from "./alfalfa-server";
import apiv2 from "./api-v2";
+const isProd = process.env.NODE_ENV === "production";
const redis = createClient({ host: process.env.REDIS_HOST });
MongoClient.connect(process.env.MONGO_URL, { useUnifiedTopology: true })
@@ -35,13 +36,21 @@ MongoClient.connect(process.env.MONGO_URL, { useUnifiedTopology: true })
});
});
- app.get("/redoc", (req, res) => {
- const docsPath = path.join(__dirname, "/app/docs.html");
+ let cachedDocs;
+ app.get("/redoc", async (req, res) => {
+ if (isProd && cachedDocs) {
+ return res.type("html").send(cachedDocs);
+ }
+
+ const docsPath = path.join(__dirname, "app/redoc-static.html");
- fsp
- .access(docsPath, fsp.constants.F_OK)
- .then(() => res.sendFile(docsPath))
- .catch(() => res.status(404).type("txt").send("Documentation has not been generated"));
+ try {
+ await fsp.access(docsPath, fsp.constants.F_OK);
+ res.sendFile(docsPath);
+ if (isProd) cachedDocs = await fsp.readFile(docsPath, "utf-8");
+ } catch (e) {
+ res.status(404).type("txt").send("Documentation has not been generated");
+ }
});
app.use("/api/v2/", apiv2({ api: app.locals.alfalfaServer.api }));
diff --git a/alfalfa_web/webpack.config.js b/alfalfa_web/webpack.config.js
index 077bb323..2ee4659d 100644
--- a/alfalfa_web/webpack.config.js
+++ b/alfalfa_web/webpack.config.js
@@ -25,20 +25,10 @@ const getSha = () => {
module.exports = {
mode: isProd ? "production" : "development",
devtool: isProd ? false : "source-map",
- entry: "./app.js",
+ entry: "./components/app.js",
cache: {
type: "filesystem"
},
- devServer: {
- static: {
- directory: path.join(__dirname, "public")
- },
- compress: true,
- port: 80
- },
- watchOptions: {
- ignored: ["**/node_modules", "**/scripts", "**/server"]
- },
output: {
path: path.resolve(__dirname, "build/app"),
filename: "app.bundle.js"
@@ -53,6 +43,9 @@ module.exports = {
})
]
},
+ performance: {
+ hints: false
+ },
module: {
rules: [
{