From fb95c4a26f3ec6fd09825adddabf495b12b2bbc0 Mon Sep 17 00:00:00 2001 From: Aric Camarata Date: Thu, 28 May 2026 13:59:50 -0400 Subject: [PATCH] =?UTF-8?q?feat(e6):=20portfolio=20polish=20=E2=80=94=20do?= =?UTF-8?q?cs,=20CI,=20TypeScript=20standard,=20wiki?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - Trim README to ≤80 lines with wiki link for full docs - Add CHANGELOG.md with initial entry - Fix CI: replace pinned pnpm/action-setup with corepack enable - Add "type": "module" and flat exports map (ADR-015) - Add ./package.json exports entry - Add coverage script - Rename wasm/spa-module.js → wasm/spa-module.cjs to fix CJS/ESM conflict - Update src/index.ts and tsup.config.ts to reference spa-module.cjs - Add .github/wiki pages: _Sidebar, _Footer, SECURITY, CODE_OF_CONDUCT --- .github/wiki/CODE_OF_CONDUCT.md | 34 ++++++++ .github/wiki/SECURITY.md | 31 ++++++++ .github/wiki/_Footer.md | 1 + .github/wiki/_Sidebar.md | 24 ++++++ .github/workflows/ci.yml | 28 +++---- CHANGELOG.md | 13 +++ README.md | 137 ++++---------------------------- package.json | 21 +++-- src/index.ts | 2 +- tsup.config.ts | 2 +- wasm/spa-module.cjs | Bin 0 -> 60004 bytes 11 files changed, 141 insertions(+), 152 deletions(-) create mode 100644 .github/wiki/CODE_OF_CONDUCT.md create mode 100644 .github/wiki/SECURITY.md create mode 100644 .github/wiki/_Footer.md create mode 100644 .github/wiki/_Sidebar.md create mode 100644 CHANGELOG.md create mode 100644 wasm/spa-module.cjs diff --git a/.github/wiki/CODE_OF_CONDUCT.md b/.github/wiki/CODE_OF_CONDUCT.md new file mode 100644 index 0000000..c880c1a --- /dev/null +++ b/.github/wiki/CODE_OF_CONDUCT.md @@ -0,0 +1,34 @@ +# Code of Conduct + +## Summary + +Be direct, be respectful, and focus on the work. + +## Standards + +Constructive behavior: + +- Technical criticism aimed at code and ideas, not people +- Clear and specific feedback with examples where possible +- Acknowledging when you are wrong or do not know something +- Staying on topic in issues and pull requests + +Unacceptable behavior: + +- Personal attacks, insults, or harassment +- Sustained off-topic disruption +- Publishing private information without consent + +## Scope + +This applies to all project spaces: GitHub issues, pull requests, discussions, and any other venue where project work happens. + +## Enforcement + +The project maintainer handles violations. Contact: aric.camarata@gmail.com. + +Reports are reviewed promptly. Responses range from a private note to a permanent ban, depending on severity and history. + +## Attribution + +This code of conduct is adapted from the [Contributor Covenant](https://www.contributor-covenant.org), version 2.1. diff --git a/.github/wiki/SECURITY.md b/.github/wiki/SECURITY.md new file mode 100644 index 0000000..c1f7078 --- /dev/null +++ b/.github/wiki/SECURITY.md @@ -0,0 +1,31 @@ +# Security Policy + +## Supported Versions + +| Version | Supported | +| --- | --- | +| 2.x | Yes | +| 1.x | No | + +Only the latest major version receives security fixes. + +## Reporting a Vulnerability + +Do not open a public GitHub issue for security vulnerabilities. + +Email: aric.camarata@gmail.com + +Include: + +- A description of the vulnerability +- Steps to reproduce +- Potential impact +- Any suggested fix, if you have one + +You will receive an acknowledgment within 48 hours and a resolution timeline within 7 days. Once a fix is ready and deployed, the vulnerability will be disclosed publicly with credit to the reporter (unless you prefer to remain anonymous). + +## Scope + +This package is a WASM-based computation library. It performs no network requests, reads no files, and holds no credentials. The primary security concern would be a memory safety issue in the WASM binary or a supply-chain compromise of the npm package. + +The WASM binary is compiled from the [NREL SPA C source](https://midcdmz.nrel.gov/spa/) with Emscripten. The compiled output (`wasm/spa-module.js`) is checked into the repository so its contents can be audited directly. diff --git a/.github/wiki/_Footer.md b/.github/wiki/_Footer.md new file mode 100644 index 0000000..5c7e5c8 --- /dev/null +++ b/.github/wiki/_Footer.md @@ -0,0 +1 @@ +[npm](https://www.npmjs.com/package/solar-spa) · [GitHub](https://github.com/acamarata/solar-spa) · [Changelog](https://github.com/acamarata/solar-spa/blob/main/CHANGELOG.md) · MIT License diff --git a/.github/wiki/_Sidebar.md b/.github/wiki/_Sidebar.md new file mode 100644 index 0000000..2bf2d7a --- /dev/null +++ b/.github/wiki/_Sidebar.md @@ -0,0 +1,24 @@ +## solar-spa + +**[Home](Home)** + +**Reference** +- [API Reference](API-Reference) +- [Architecture](Architecture) +- [NREL SPA Algorithm](NREL-SPA-Algorithm) + +**Performance & Compatibility** +- [Performance](Performance) +- [Bundler Compatibility](Bundler-Compatibility) +- [WebAssembly in npm Packages](WebAssembly-in-npm-Packages) +- [Validation and Benchmarks](Validation-and-Benchmarks) + +**Contributing** +- [Contributing](Contributing) +- [Code of Conduct](CODE_OF_CONDUCT) +- [Security](SECURITY) + +**Links** +- [npm](https://www.npmjs.com/package/solar-spa) +- [GitHub](https://github.com/acamarata/solar-spa) +- [Changelog](https://github.com/acamarata/solar-spa/blob/main/CHANGELOG.md) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index dee0a7b..3efce5d 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -16,15 +16,14 @@ jobs: steps: - uses: actions/checkout@v4 - - uses: pnpm/action-setup@v4 - with: - version: 10 - - uses: actions/setup-node@v4 with: node-version: ${{ matrix.node-version }} cache: pnpm + - name: Enable corepack + run: corepack enable + - run: pnpm install --frozen-lockfile - name: Build TypeScript @@ -42,15 +41,14 @@ jobs: steps: - uses: actions/checkout@v4 - - uses: pnpm/action-setup@v4 - with: - version: 10 - - uses: actions/setup-node@v4 with: node-version: 24 cache: pnpm + - name: Enable corepack + run: corepack enable + - run: pnpm install --frozen-lockfile - run: pnpm run lint - run: pnpm run format:check @@ -61,15 +59,14 @@ jobs: steps: - uses: actions/checkout@v4 - - uses: pnpm/action-setup@v4 - with: - version: 10 - - uses: actions/setup-node@v4 with: node-version: 24 cache: pnpm + - name: Enable corepack + run: corepack enable + - run: pnpm install --frozen-lockfile - run: pnpm run typecheck @@ -79,15 +76,14 @@ jobs: steps: - uses: actions/checkout@v4 - - uses: pnpm/action-setup@v4 - with: - version: 10 - - uses: actions/setup-node@v4 with: node-version: 24 cache: pnpm + - name: Enable corepack + run: corepack enable + - run: pnpm install --frozen-lockfile - run: pnpm run build:ts diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 0000000..ae0dc4a --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,13 @@ +# Changelog + +All notable changes to this project will be documented in this file. + +The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/), +and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). + +## [Unreleased] + +## [2.0.0] - 2026-05-28 + +### Added +- Initial release diff --git a/README.md b/README.md index 29e510c..3d6e8d8 100644 --- a/README.md +++ b/README.md @@ -4,9 +4,7 @@ [![CI](https://github.com/acamarata/solar-spa/actions/workflows/ci.yml/badge.svg)](https://github.com/acamarata/solar-spa/actions/workflows/ci.yml) [![license](https://img.shields.io/npm/l/solar-spa.svg)](https://github.com/acamarata/solar-spa/blob/main/LICENSE) -NREL Solar Position Algorithm compiled to WebAssembly. Calculates solar zenith, azimuth, incidence angle, sunrise, sunset, solar noon, and equation of time for any location and date. - -The algorithm is the [NREL SPA](https://midcdmz.nrel.gov/spa/) by Ibrahim Reda and Afshin Andreas, originally written in C. This package compiles the original C source to WASM via Emscripten and provides a TypeScript/JavaScript interface on top. +NREL Solar Position Algorithm compiled to WebAssembly. Calculates solar zenith, azimuth, incidence angle, sunrise, sunset, solar noon, and equation of time for any location and date. The WASM binary is inlined as base64, so there is no external `.wasm` file to locate — it works in Node.js, browsers, Webpack, Vite, Next.js, and web workers without configuration. ## Installation @@ -20,129 +18,25 @@ npm install solar-spa import { spa } from 'solar-spa'; const result = await spa( - new Date(2025, 5, 21, 12, 0, 0), // June 21, 2025 at noon - 40.7128, // latitude (NYC) - -74.0060, // longitude - { timezone: -4, elevation: 10 } // EDT (UTC-4), 10m elevation + new Date(2025, 5, 21, 12, 0, 0), // June 21, 2025 at noon + 40.7128, // latitude (NYC) + -74.0060, // longitude + { timezone: -4, elevation: 10 } // EDT (UTC-4), 10m elevation ); -console.log(result.zenith); // ~27 (degrees from vertical) -console.log(result.azimuth); // ~179 (degrees from north) -console.log(result.sunrise); // ~5.4 (fractional hours) -console.log(result.sunset); // ~20.5 (fractional hours) +console.log(result.zenith); // ~27 (degrees from vertical) +console.log(result.sunrise); // ~5.4 (fractional hours) +console.log(result.sunset); // ~20.5 (fractional hours) ``` -CommonJS works too: +CommonJS also works: ```js const { spa } = require('solar-spa'); ``` -## API - -### `spa(date, latitude, longitude, options?)` - -Returns a `Promise` with raw numeric values. - -**Parameters:** - -| Name | Type | Description | -| --- | --- | --- | -| `date` | `Date` | Date and time for the calculation | -| `latitude` | `number` | Observer latitude, -90 to 90 (negative = south) | -| `longitude` | `number` | Observer longitude, -180 to 180 (negative = west) | -| `options` | `object` | Optional. See below | - -**Options:** - -| Option | Type | Default | Description | -| --- | --- | --- | --- | -| `timezone` | `number` | auto | Hours from UTC. Auto-detected from the Date object if omitted | -| `elevation` | `number` | `0` | Meters above sea level | -| `pressure` | `number` | `1013.25` | Atmospheric pressure in millibars | -| `temperature` | `number` | `15` | Temperature in Celsius | -| `delta_ut1` | `number` | `0` | UT1-UTC correction in seconds | -| `delta_t` | `number` | `67` | TT-UTC difference in seconds | -| `slope` | `number` | `0` | Surface slope in degrees | -| `azm_rotation` | `number` | `0` | Surface azimuth rotation in degrees | -| `atmos_refract` | `number` | `0.5667` | Atmospheric refraction in degrees | -| `function` | `number` | `3` | SPA function code (see below) | - -**Result fields:** - -| Field | Unit | Description | -| --- | --- | --- | -| `zenith` | degrees | Topocentric zenith angle | -| `azimuth` | degrees | Topocentric azimuth, eastward from north | -| `azimuth_astro` | degrees | Topocentric azimuth, westward from south | -| `incidence` | degrees | Surface incidence angle | -| `sunrise` | fractional hours | Local sunrise time | -| `sunset` | fractional hours | Local sunset time | -| `suntransit` | fractional hours | Solar noon | -| `sun_transit_alt` | degrees | Sun transit altitude | -| `eot` | minutes | Equation of time | -| `error_code` | integer | 0 on success | - -### `spaFormatted(date, latitude, longitude, options?)` - -Same as `spa()`, but `sunrise`, `sunset`, and `suntransit` are returned as `HH:MM:SS` strings. Returns `"N/A"` for these fields during polar day or polar night. - -### `formatTime(hours)` - -Converts fractional hours to an `HH:MM:SS` string. Returns `"N/A"` for non-finite or negative values (polar night/day scenarios). - -### `init()` - -Pre-initializes the WASM module. Optional. The module initializes automatically on the first `spa()` call. Useful if you want to pay the initialization cost at application startup rather than on the first calculation. - -### Function Codes - -| Constant | Value | Computes | -| --- | --- | --- | -| `SPA_ZA` | `0` | Zenith and azimuth | -| `SPA_ZA_INC` | `1` | Zenith, azimuth, and incidence | -| `SPA_ZA_RTS` | `2` | Zenith, azimuth, and rise/transit/set | -| `SPA_ALL` | `3` | All output values | - -## Architecture - -The package has three layers: - -1. **C layer** (`src/spa.c`, `src/spa_wrapper.c`): The original NREL SPA algorithm with a thin wrapper that exposes a flat function signature suitable for WASM. - -2. **WASM layer** (`wasm/spa-module.js`): Compiled with Emscripten using `-sSINGLE_FILE=1`, which inlines the WASM binary as base64. No external `.wasm` file to resolve. This eliminates the bundler path-resolution issues that plague most WASM packages. - -3. **TypeScript layer** (`src/index.ts`, `src/types.ts`): Written in TypeScript and compiled by tsup to both CJS and native ESM with generated declaration files. Singleton WASM initialization, cached `cwrap` bindings, input validation, and named struct offset constants. - -### Build Flags - -The WASM binary is compiled with: - -- `-O3 -flto`: Maximum optimization with link-time optimization -- `-sSINGLE_FILE=1`: WASM inlined as base64 (no file path resolution) -- `-sMODULARIZE=1`: No global `Module` pollution -- `-sNO_FILESYSTEM=1`: No filesystem API bundled (saves ~15KB) -- `-sINITIAL_MEMORY=1048576`: 1MB fixed memory (SPA needs very little) -- `-sASSERTIONS=0`: No debug assertions in production -- `-sENVIRONMENT='node,web,worker'`: Works in Node.js, browsers, and web workers - -## Compatibility - -Tested in: - -- Node.js 20+ -- Modern browsers (Chrome, Firefox, Safari, Edge) -- Webpack 5 -- Vite -- Next.js (both Pages and App Router) -- Web Workers - -The `SINGLE_FILE` approach eliminates the `.wasm` file resolution problem that breaks most WASM packages in bundlers. There is no external binary to locate at runtime. - ## TypeScript -Full type definitions are generated from the TypeScript source and included with the package. Import types directly: - ```ts import { spa, SPA_ALL } from 'solar-spa'; import type { SpaResult, SpaOptions } from 'solar-spa'; @@ -150,21 +44,18 @@ import type { SpaResult, SpaOptions } from 'solar-spa'; ## Documentation -See the [Wiki](https://github.com/acamarata/solar-spa/wiki) for detailed documentation: API reference, architecture, performance, bundler compatibility, validation benchmarks, and more. +See the [Wiki](https://github.com/acamarata/solar-spa/wiki) for the full API reference, architecture notes, build flags, bundler compatibility, and validation benchmarks. ## Related -- [nrel-spa](https://github.com/acamarata/nrel-spa): Pure JavaScript port of the same algorithm. No WASM dependency, synchronous API. Better choice if you do not need WASM-level performance. -- [NREL SPA](https://midcdmz.nrel.gov/spa/): The original algorithm specification and C source. -- [pray-calc](https://github.com/acamarata/pray-calc): Islamic prayer time calculator built on nrel-spa. +- [nrel-spa](https://github.com/acamarata/nrel-spa): Pure JavaScript port of the same algorithm. Synchronous, no WASM dependency. +- [pray-calc](https://github.com/acamarata/pray-calc): Islamic prayer times built on nrel-spa. ## Acknowledgments -This package includes the Solar Position Algorithm (SPA) developed at the National Renewable Energy Laboratory (NREL) by Ibrahim Reda and Afshin Andreas. The C source files `spa.c` and `spa.h` are copyright Alliance for Sustainable Energy, LLC (2008-2011) and are distributed under the terms included in those files. +This package includes the Solar Position Algorithm (SPA) developed at the National Renewable Energy Laboratory (NREL) by Ibrahim Reda and Afshin Andreas. The C source files `spa.c` and `spa.h` are copyright Alliance for Sustainable Energy, LLC (2008-2011). -> Reda, I., Andreas, A. (2004). "Solar Position Algorithm for Solar Radiation Applications." *Solar Energy*, 76(5), 577-589. [doi:10.1016/j.solener.2003.12.003](https://doi.org/10.1016/j.solener.2003.12.003) - -The original C source and an online calculator are available at [midcdmz.nrel.gov/spa](https://midcdmz.nrel.gov/spa/). +> Reda, I., Andreas, A. (2004). "Solar Position Algorithm for Solar Radiation Applications." *Solar Energy*, 76(5), 577-589. ## License diff --git a/package.json b/package.json index a0f6b92..499a1f8 100644 --- a/package.json +++ b/package.json @@ -9,15 +9,11 @@ "types": "./dist/index.d.ts", "exports": { ".": { - "import": { - "types": "./dist/index.d.mts", - "default": "./dist/index.mjs" - }, - "require": { - "types": "./dist/index.d.ts", - "default": "./dist/index.cjs" - } - } + "types": "./dist/index.d.ts", + "import": "./dist/index.mjs", + "require": "./dist/index.cjs" + }, + "./package.json": "./package.json" }, "sideEffects": false, "files": [ @@ -41,7 +37,8 @@ "format": "prettier --write src/", "format:check": "prettier --check src/", "validate": "node validate.mjs", - "prepublishOnly": "pnpm run build:ts" + "prepublishOnly": "pnpm run build:ts", + "coverage": "c8 --reporter=lcov --reporter=text node --test" }, "keywords": [ "solar", @@ -81,5 +78,7 @@ "tsup": "^8.5.1", "typescript": "^5.9.3", "typescript-eslint": "^8.56.1" - } + }, + "type": "module", + "packageManager": "pnpm@10.11.1" } diff --git a/src/index.ts b/src/index.ts index 7afdd53..0802403 100644 --- a/src/index.ts +++ b/src/index.ts @@ -11,7 +11,7 @@ import { SPA_ALL } from './types.js'; // In CJS builds, require() is natively available. declare const __require: NodeRequire; const _loadModule = typeof __require === 'function' ? __require : require; -const createSpaModule: () => Promise = _loadModule('../wasm/spa-module.js'); +const createSpaModule: () => Promise = _loadModule('../wasm/spa-module.cjs'); // Singleton: the WASM module initializes once, all calls share it. let _module: SpaWasmModule | null = null; diff --git a/tsup.config.ts b/tsup.config.ts index de57165..dcc4b46 100644 --- a/tsup.config.ts +++ b/tsup.config.ts @@ -24,5 +24,5 @@ export default defineConfig({ return {}; }, // The WASM module is Emscripten CJS output, keep it external. - external: ['../wasm/spa-module.js'], + external: ['../wasm/spa-module.cjs'], }); diff --git a/wasm/spa-module.cjs b/wasm/spa-module.cjs new file mode 100644 index 0000000000000000000000000000000000000000..d86b3936aae77a9654a3de7fce49c72d227220fd GIT binary patch literal 60004 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 literal 0 HcmV?d00001