anvil/striker-ui
2024-06-12 13:14:36 -04:00
..
.husky chore: commit husky changes to .gitignore file 2021-06-09 10:33:46 -04:00
components fix(striker-ui): prevent provision server form from crashing the whole UI 2024-06-12 12:36:55 -04:00
hooks fix(striker-ui): expose cookie jar builder 2024-06-12 12:36:55 -04:00
lib fix(striker-ui): yup: reduce restrictions on UUID checks, move IPv4 checks 2024-06-12 12:36:55 -04:00
out build(striker-ui): rebuild 2024-06-12 13:14:36 -04:00
pages fix(striker-ui): apply new manage host to replace old prepare host form 2024-03-07 11:53:54 -05:00
public chore(striker-ui): add symlink to image assets 2021-06-04 12:11:48 -04:00
styles refactor: remove unused css classes 2021-06-04 12:11:49 -04:00
theme fix(striker-ui): add font source code pro to theme 2022-03-18 22:50:41 -04:00
types fix(striker-ui): remove MTU from manifest forms 2024-06-12 12:36:55 -04:00
.env fix(striker-ui): migrate /cgi-bin->/api 2023-07-03 04:46:06 -04:00
.eslintignore build(striker-ui): ignore out/ when linting 2021-08-25 11:43:53 -04:00
.eslintrc.json chore(striker-ui): allow skip props in object destructure 2022-11-28 14:37:19 -05:00
.gitignore chore: rebuild web UI 2022-03-18 22:50:41 -04:00
.lintstagedrc.json chore(striker-ui): revise scripts for lint and quick-fix 2022-03-18 22:50:41 -04:00
.prettierrc.json feat(striker-ui): add minimal demo 2021-06-04 12:11:48 -04:00
commitlint.config.js feat(striker-ui): add minimal demo 2021-06-04 12:11:48 -04:00
lsxdist chore(striker-ui): patch find command in lsxdist 2024-03-18 17:07:33 -04:00
Makefile.am build(striker-ui): distribute /mail-config page 2024-03-18 17:19:41 -04:00
next-env.d.ts chore(striker-ui): regenerate next-env.d.ts 2022-02-24 00:04:04 -05:00
next.config.js build(striker-ui): remove deprecated 'next export' and use recommended 'output: export' 2024-01-29 13:13:52 -05:00
package-lock.json build(striker-ui): bump braces 3.0.2->3.0.3 2024-06-12 12:42:40 -04:00
package.json build(striker-ui): rebuild 2024-06-11 16:02:54 -04:00
README.md docs(striker-ui): add minimal README to web UI 2023-10-10 22:32:53 -04:00
tsconfig.json chore(striker-ui): enable 'incremental' in tsconfig 2022-02-23 17:42:21 -05:00

Anvil system striker web interface

Notes

  • All NPM commands must be executed at the root folder of this UI module, where the package.json is located.
  • For those unfamiliar with git and/or the web technologies involved, it's highly recommended to clone a fresh repo as a test workspace.

Development prerequisites

  • NodeJS LTS is recommended, version >= 14 is required.
  • NPM latest is recommended, version >= 6 is required.

"required" means this project was started with roughly the specified version; earlier version may work.

For Fedora, NPM is included as a dependency of NodeJS; running sudo dnf install nodejs should be enough.

Installation

Run npm install to download all production and development dependencies. The NPM packages will be collectively placed into a folder named node_modules in the root of this project.

Live development

Run npm run dev to start a local development server that listens on port 3000. Any source code changes after the dev server has started will trigger a quick partial rebuild, the changes will be reflected shortly in the browser.

However, it's highly recommended to perform a clear-cache reload, which is usually CTRL + F5, because changes may not always reflect correctly.

Production build

Run rm -rf out && npm run build to remove the existing build output and generate a new one. It's highly recommended to remove the old build before building a new one because the some of the generated files won't replace the old files, thus old files will remain when the whole output directory gets committed/copied.

The build is expected to be placed into the /var/www/html/ directory on a striker.

At the time of writing, the build is committed to the repository to keep the whole project's building process offline. NPM requires network to fetch dependencies before building. Ideally, the build shouldn't be included, but we cannot remove the it from repo until there's a reliable way to separate the download and build tasks.

Logs

At the time of writing, no logging library has been added due to other priorities. The recommended debug logging is to temporarily add any appropriate console functions to suspicious areas, i.e. before and after the location where an exception was thrown.

Test with striker API

Most of the API requires authentication to access. At the time of writing, the striker API can only produce cookies with its domain (including port) after successfully authenticating a user. Therefore, the striker UI must be accessed from the same location to allow the browser to read the session cookies.

There are 2 tested methods to achive same-domain:

  1. Make changes to the source and produce a production build. Copy the new build to the striker and access the UI by connecting to the striker.
  2. Install a proxy/load balance server, forward <domain>/ (root) to the server hosting the web UI, and forward <domain>/api/ to the API. When accessing the UI, the browser only accesses the proxy and will consider the two locations to be under the same domain. thus it will see the cookies produced by authentication. A recommended server with easy-to-understand configuration is nginx; it's available via dnf.