The cloud portion of Nidus
Find a file
2026-01-21 15:15:52 +00:00
api Overhaul system for handling text messaging 2026-01-21 03:30:03 +00:00
arcgis-go@af786fabcc Initially made it through full update with new fieldseeker schema 2025-12-05 23:11:57 +00:00
auth Creat signout logic, make links use it. 2026-01-15 00:20:19 +00:00
background Overhaul system for handling text messaging 2026-01-21 03:30:03 +00:00
cmd/query-test Fix query test to not reference defunct enums 2025-12-11 01:33:24 +00:00
comms Overhaul system for handling text messaging 2026-01-21 03:30:03 +00:00
config Overhaul system for handling text messaging 2026-01-21 03:30:03 +00:00
db Overhaul system for handling text messaging 2026-01-21 03:30:03 +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
htmlpage Get search map overlay working again. 2026-01-21 15:15:52 +00:00
label-studio WIP migration of API from fieldseeker-sync 2025-12-16 16:37:53 +00:00
minio WIP migration of API from fieldseeker-sync 2025-12-16 16:37:53 +00:00
notification Rip apart several new packages for inter-dependence 2026-01-07 16:07:51 +00:00
platform Move imported districts to its own schema, add ref from organization 2026-01-16 14:43:26 +00:00
public-report Get search map overlay working again. 2026-01-21 15:15:52 +00:00
sync Show full district details on location search 2026-01-15 23:19:31 +00:00
tools Actually delete the organization in delete-org.sql 2026-01-15 04:11:19 +00:00
userfile Extract EXIF data from images 2026-01-16 20:16:58 +00:00
.air.toml Shorten the time waiting for air to kill my webserver 2025-11-07 08:46:26 +00:00
.gitattributes Add a basic main page with login 2025-11-03 22:13:19 +00:00
.gitignore Ignore air's temp building directory 2025-11-05 17:17:21 +00:00
.gitmodules Remove bob submodule, add arcgis.user 2026-01-15 19:20:39 +00:00
default.nix Bump vendor hash 2026-01-09 20:11:57 +00:00
flake.lock Move to nixos pkg 25.11 base 2026-01-06 14:27:19 +00:00
flake.nix Move to nixos pkg 25.11 base 2026-01-06 14:27:19 +00:00
go.mod Overhaul system for handling text messaging 2026-01-21 03:30:03 +00:00
go.sum Overhaul system for handling text messaging 2026-01-21 03:30:03 +00:00
lefthook.yml Add lefthook configuration for formatting 2025-11-06 22:31:29 +00:00
LICENSE Initial commit 2025-11-03 05:12:02 -07:00
main.go Overhaul system for handling text messaging 2026-01-21 03:30:03 +00:00
query.go Add missing query source file 2025-11-24 18:09:28 +00:00
README.md Update readme with how I created the working district table 2026-01-13 23:36:09 +00:00
start-air.sh Read secrets when running air 2026-01-06 14:46:54 +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 .

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, public.district. It was created with:

shp2pgsql -s 3857 -c -D -I CA_districts.shp public.district | psql -d nidus-sync
psql
ALTER TABLE 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