The cloud portion of Nidus
Find a file
2026-03-18 19:59:42 +00:00
api Fix tracking report type through the system 2026-03-18 19:25:52 +00:00
arcgis-go@f5ec5c75c1 Bump to latest arcgis-go 2026-03-11 14:30:01 +00:00
auth Wire up events for creating new public reports 2026-03-13 17:56:24 +00:00
cmd/passwordgen Remove unused query-test 2026-03-04 03:47:40 +00:00
comms Handle disabled IP address from Voip.ms 2026-02-18 22:11:30 +00:00
config Rework publicreport addressing 2026-03-09 18:02:22 +00:00
db Remove report_location view, add lat lng to report table 2026-03-18 18:55:50 +00:00
debug Begin work on debugging user behavior in early setup 2026-01-06 14:46:31 +00:00
go-geojson2h3@c2ff1a96ab Add mocks for data entry 2025-12-10 17:06:27 +00:00
h3utils Finish green pool report submission 2026-01-09 19:43:19 +00:00
html Fix display of types on comms page 2026-03-18 19:26:49 +00:00
http Move handler objects to common location to share with RMO 2026-03-03 17:08:58 +00:00
label-studio WIP migration of API from fieldseeker-sync 2025-12-16 16:37:53 +00:00
llm Return logs on comms public reports 2026-03-18 18:56:51 +00:00
minio WIP migration of API from fieldseeker-sync 2025-12-16 16:37:53 +00:00
platform Fix build for staging 2026-03-18 19:59:42 +00:00
rmo Fix references to report organization ID 2026-03-18 19:00:40 +00:00
scss Fix map display on RMO status-by-id page 2026-03-11 14:59:04 +00:00
stadia Fix build for staging 2026-03-18 19:59:42 +00:00
sync Allow sudo to send structured SSEs 2026-03-13 18:31:43 +00:00
tomtom Add tomtom routing test 2026-02-25 16:13:28 +00:00
tools Massive rework of platform layer user/organization 2026-03-12 23:49:16 +00:00
.air.toml Don't stop the server if there is a build error 2026-02-13 19:18:48 +00:00
.gitattributes Add a basic main page with login 2025-11-03 22:13:19 +00:00
.gitignore Add better support for extracting address from reverse geocode results 2026-03-14 01:51:02 +00:00
.gitmodules Build custom SCSS as part of nix package 2026-01-29 02:11:04 +00:00
.prettierrc Format JavaScript files with prettier 2026-02-06 17:07:06 +00:00
default.nix Fix build for staging 2026-03-18 19:59:42 +00:00
flake.lock Update go.mod to try harder to build on nix 2026-03-04 02:53:18 +00:00
flake.nix Get proj build to work 2026-03-04 03:41:41 +00:00
go.mod Fix build for staging 2026-03-18 19:59:42 +00:00
go.sum Fix build for staging 2026-03-18 19:59:42 +00:00
lefthook.yml Format JavaScript files with prettier 2026-02-06 17:07:06 +00:00
LICENSE Initial commit 2025-11-03 05:12:02 -07:00
main.go Create generic backend process, fix background interdependencies 2026-03-16 19:52:29 +00:00
query.go Add ability to make LLM agent forget the conversation history 2026-01-27 18:44:02 +00:00
README.md Update scss tooling readme 2026-02-16 01:10:13 +00:00
start-air.sh Read secrets when running air 2026-01-06 14:46:54 +00:00
start-flogo.sh Enable verbose logging by default 2026-03-11 23:20:58 +00:00
start-nidus-sync.sh Add debugging around staging environment not acting like prod 2026-03-05 19:17:16 +00:00

Nidus Sync

This is the software that powers Nidus Cloud Sync.

Building from source

First, you'll need Nix.

Then:

nix develop
go build .

Building Custom Theme

We're using a customized Bootstrap theme for this site. You'll need to build the SCSS into CSS:

nix develop
sass --style=compressed --trace "$SASS_SRC_DIR/custom.scss":"$CSS_OUTPUT_DIR/bootstrap.css"

Running

You'll need a number of environment variables for configuring things;

  • ARCGIS_CLIENT_ID - The client ID for ArcGIS oauth, configured with esri.
  • ARCGIS_CLIENT_SECRET - The client secret for ArcGIS oauth, configured with esri.
  • BASE_URL - The URL the site is hosted at, used for forming callback URLs. Should be complete like 'https://foo.bar'
  • BIND - The address and port to bind to. Use ':9001' for 'any address, port 9001'
  • ENVIRONMENT - either 'PRODUCTION' or 'DEVELOPMENT'. It's used to set things like oauth token length.
  • MAPBOX_TOKEN - The token to use with mapbox which is important for rendering maps.
  • POSTGRES_DSN - The DSN for connecting to the postgres database.
  • FIELDSEEKER_SCHEMA_DIRECTORY - The directory to write fieldseeker schema files for debugging.
  • USER_FILES_DIRECTORY - The directory for writing uploaded user data files (audio, images).
> BASE_URL=https://sync.nidus.cloud ARCGIS_CLIENT_ID=foo ARCGIS_CLIENT_SECRET=bar POSTGRES_DSN='postgresql://?host=/var/run/postgresql&dbname=nidus-sync' ./nidus-sync

Districts

There's a table containing district information in the database, import.district. It was created with:

psql
CREATE SCHEMA import;
shp2pgsql -s 3857 -c -D -I CA_districts.shp import.district | psql -d nidus-sync
psql
ALTER TABLE import.district ADD COLUMN geom_4326 geometry(MultiPolygon,4326) GENERATED ALWAYS AS (ST_Transform(geom, 4326)) STORED;

Hacking

air

This project uses air for fast compile-and-test loops. You can run it with:

> BASE_URL=https://sync.nidus.cloud ARCGIS_CLIENT_ID=foo ARCGIS_CLIENT_SECRET=bar POSTGRES_DSN='postgresql://?host=/var/run/postgresql&dbname=nidus-sync' air

bob

This uses the bob query framework. You can regenerate the models for bob with:

PSQL_DSN="postgresql://dbname?host=/var/run/postgresql&sslmode=disable" go run github.com/stephenafamo/bob/gen/bobgen-psql@latest"
PSQL_DSN="postgresql://?host=/var/run/postgresql&sslmode=disable&dbname=nidus-sync" go run github.com/stephenafamo/bob/gen/bobgen-psql@latest

This will generate a bunch of files. They're already committed, you only need this if you change the database schema in some way.

goose

This uses goose. You can use the goose command line to check status and make changes

> cd migrations
> GOOSE_DRIVER=postgres GOOSE_DBSTRING="dbname=nidus-sync sslmode=disable" goose status
> GOOSE_DRIVER=postgres GOOSE_DBSTRING="dbname=nidus-sync sslmode=disable" goose down
> GOOSE_DRIVER=postgres GOOSE_DBSTRING="dbname=nidus-sync sslmode=disable" goose up

watchexec

For iterating on styles

watchexec -e *.scss sass scss/custom.scss:html/static/css/bootstrap.css