{"id":49751306,"url":"https://github.com/esquetta/open-local-audit","last_synced_at":"2026-06-11T09:00:19.317Z","repository":{"id":356561402,"uuid":"1232936088","full_name":"Esquetta/open-local-audit","owner":"Esquetta","description":"Open-source website and local presence auditor for small businesses","archived":false,"fork":false,"pushed_at":"2026-05-31T08:38:32.000Z","size":267,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"master","last_synced_at":"2026-05-31T10:14:44.843Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/Esquetta.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":"CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":"CODE_OF_CONDUCT.md","threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":"SECURITY.md","support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2026-05-08T12:27:55.000Z","updated_at":"2026-05-31T08:37:45.000Z","dependencies_parsed_at":null,"dependency_job_id":null,"html_url":"https://github.com/Esquetta/open-local-audit","commit_stats":null,"previous_names":["esquetta/open-local-audit"],"tags_count":23,"template":false,"template_full_name":null,"purl":"pkg:github/Esquetta/open-local-audit","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Esquetta%2Fopen-local-audit","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Esquetta%2Fopen-local-audit/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Esquetta%2Fopen-local-audit/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Esquetta%2Fopen-local-audit/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/Esquetta","download_url":"https://codeload.github.com/Esquetta/open-local-audit/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Esquetta%2Fopen-local-audit/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":34190585,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-26T15:22:16.424Z","status":"online","status_checked_at":"2026-06-11T02:00:06.485Z","response_time":57,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2026-05-10T10:56:45.198Z","updated_at":"2026-06-11T09:00:19.284Z","avatar_url":"https://github.com/Esquetta.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Open Local Audit\n\nOpen Local Audit is an open-source website and local presence auditor for small businesses. It turns public website signals into practical reports for outreach, customer education, and implementation work.\n\n## Current stage\n\nPublished CLI. The project can run a single URL audit, an opt-in Playwright-rendered audit with screenshot evidence, optional Lighthouse category scoring, branded customer-facing reports, public contact readiness extraction, a plain-text batch URL list, or a profile-aware CSV batch file, optionally check same-origin links, and produce JSON, Markdown, HTML, PDF, or all standard report formats. Batch runs can use controlled concurrency, write per-site reports, add aggregate insight sections and contact/outreach rollups to the top-level index, and optionally export prospect CSV data for triage. Discovery runs can control Google Places result counts, cap website audits, write summary JSON, merge local review CSVs, explain opportunity scores, enrich outreach and public-contact columns, select a preferred manual outreach channel, and report exact duplicate lead groups plus advisory fuzzy duplicate review candidates. CRM-ready CSV exports can be validated locally before import, lead CSVs can be ranked into local shortlist reports with optional local review-state suppression, and single-site report folders can be packaged for local customer sharing.\n\n## Business purpose\n\nOpen Local Audit produces evidence-backed mini audits for local businesses. The tool should be useful as open-source software while keeping paid value in implementation, redesign, maintenance, and custom reporting.\n\n## Product principles\n\n- Evidence first: every recommendation should point to a concrete finding.\n- Ethical scanning: only scan user-provided public URLs and avoid Google Maps scraping.\n- Small-business language: reports should be readable by non-technical owners.\n- Developer quality: deterministic checks, clear CLI output, tests, and release notes.\n- Commercial clarity: the open-source scanner is useful; paid work is execution and support.\n\n## Proposed first stack\n\n- Runtime: Node.js with TypeScript.\n- CLI framework: `commander` or `cac`.\n- Validation: `zod`.\n- HTML parsing: `cheerio`.\n- Browser rendering: Playwright where static parsing is not enough.\n- Storage: no persistence by default; optional JSON/Markdown outputs.\n- Test runner: Vitest.\n- Package manager: npm unless implementation chooses pnpm before first commit.\n\n## Documents\n\n- [Product brief](./docs/product-brief.md)\n- [Technical architecture](./docs/technical-architecture.md)\n- [MVP roadmap](./docs/mvp-roadmap.md)\n- [Security and ethics](./docs/security-and-ethics.md)\n- [Go-to-market plan](./docs/go-to-market.md)\n- [Audit checklist](./docs/research/audit-checklist.md)\n- [Release readiness](./docs/release/release-readiness.md)\n- [npm publishing plan](./docs/release/npm-publishing.md)\n- [Project operating standard](./docs/operations/project-standard.md)\n- [Decision log](./docs/operations/decision-log.md)\n\n## Local development\n\nInstall dependencies and run the checks:\n\n```bash\nnpm install\nnpm test\nnpm run lint\nnpm run build\nnpm run release-check\n```\n\nRun the CLI locally:\n\n```bash\nnpm start -- https://example.com --format markdown\n```\n\nAfter building, run the compiled CLI:\n\n```bash\nnode dist/cli.js https://example.com --format json --pretty\n```\n\nRun the published package:\n\n```bash\nnpx open-local-audit https://example.com --format markdown\n```\n\nRun with an industry profile:\n\n```bash\nopen-local-audit https://example.com --profile dental --format markdown\n```\n\nSupported profiles are `generic`, `dental`, `beauty`, `restaurant`, `contractor`, `lawyer`, `clinic`, `gym`, `hotel`, and `auto-service`.\n\nRender the page before auditing when static HTML is not enough:\n\n```bash\nopen-local-audit https://example.com --render --format markdown\n```\n\nCapture a rendered homepage screenshot and add it as visual evidence:\n\n```bash\nopen-local-audit https://example.com --screenshot --format all --out-dir reports\n```\n\n`--render` loads Playwright from the current project. Install it alongside the CLI when needed:\n\n```bash\nnpm install -D playwright\n```\n\nRun Lighthouse category scoring:\n\n```bash\nopen-local-audit https://example.com --lighthouse --format html --out report.html\n```\n\n`--lighthouse` runs Chrome through Lighthouse and adds performance, accessibility, best-practices, and SEO category scores to the report. It requires a local Chrome or Chromium runtime that Lighthouse can launch.\n\nWrite standard report formats to a directory:\n\n```bash\nopen-local-audit https://example.com --format all --out-dir reports\n```\n\nWrite an HTML report:\n\n```bash\nopen-local-audit https://example.com --format html --out report.html\n```\n\nWrite a branded PDF report:\n\n```bash\nopen-local-audit https://example.com --format pdf --out report.pdf\n```\n\nApply report branding:\n\n```bash\nopen-local-audit https://example.com --brand-config brand.json --format pdf --out report.pdf\n```\n\nMinimal `brand.json`:\n\n```json\n{\n  \"name\": \"Example Audit Studio\",\n  \"primaryColor\": \"#123456\",\n  \"accentColor\": \"#2f7d5f\",\n  \"footerText\": \"Prepared for outreach review\",\n  \"contact\": \"hello@example.com\"\n}\n```\n\nBrand colors must use six-digit hex values. Branding applies to Markdown, HTML, and PDF reports.\n\nRun a batch audit from a text file:\n\n```bash\nopen-local-audit --input sites.txt --format all --out-dir reports\n```\n\nRun a labeled CSV batch audit:\n\n```bash\nopen-local-audit --input sites.csv --format all --out-dir reports\n```\n\nRun a profile-aware batch audit and write a prospect CSV export:\n\n```bash\nopen-local-audit --input sites.csv --profile dental --export-csv prospects.csv --format all --out-dir reports\n```\n\nRun a focused batch triage index:\n\n```bash\nopen-local-audit --input sites.csv --format all --out-dir reports --segment dental --sort score-asc --top 25\n```\n\nRun a controlled parallel batch audit:\n\n```bash\nopen-local-audit --input sites.csv --format all --out-dir reports --concurrency 3\n```\n\nCapture screenshots during batch audits:\n\n```bash\nopen-local-audit --input sites.csv --screenshot --format all --out-dir reports\n```\n\nBatch triage supports `--segment \u003csegment\u003e`, `--min-score \u003cscore\u003e`, `--top \u003ccount\u003e`, `--sort score-asc|severity-desc`, and `--concurrency \u003ccount\u003e`. Batch runs can also write `--export-csv \u003cpath\u003e` for prospect triage. Batch index reports include aggregate average score, profile breakdown, segment breakdown, frequent finding sections, contact rollups, and advisory outreach channel rollups. Batch CSV exports include contact confidence, preferred contact channel, and contactability reason when reports were audited successfully. Use `--export-preset crm` with `--export-csv` to write a CRM-ready local import CSV instead of the standard operator CSV.\n\nSupported CSV columns:\n\n```csv\nurl,label,segment,profile\nexample.com,Example Clinic,dental,dental\nhttps://example.org/path,Example Salon,beauty,beauty\n```\n\nManual CSV lead discovery:\n\n```bash\nopen-local-audit discover --input places.csv --provider manual-csv --profile dental --out-dir reports/dental --export-csv leads.csv\n```\n\nThe `manual-csv` provider reads an operator-prepared CSV, resolves supplied website URLs, audits website-present rows through the existing batch pipeline, and writes `leads.csv` with `hasWebsite`, `websiteUrl`, `priority`, and `nextAction`. Use `--dry-run` to create the prospect CSV without auditing websites.\n\nGoogle Places lead discovery:\n\n```bash\nGOOGLE_MAPS_API_KEY=your-key open-local-audit discover \"guzellik salonu Umraniye\" --provider google-places --profile beauty --out-dir reports/umraniye-beauty --export-csv leads.csv\n```\n\nControl discovery cost and audit volume:\n\n```bash\nGOOGLE_MAPS_API_KEY=your-key open-local-audit discover \"dis klinigi Kadikoy\" --provider google-places --limit 20 --max-audits 5 --summary-json discovery-summary.json --out-dir reports/kadikoy-dental --export-csv leads.csv\n```\n\nSkip previously reviewed leads and keep only stronger opportunities:\n\n```bash\nopen-local-audit discover --input places.csv --provider manual-csv --suppression-list reviewed-leads.csv --min-opportunity-score 90 --dry-run --export-csv leads.csv\n```\n\nMaintain a review queue and duplicate review report across reruns:\n\n```bash\nopen-local-audit discover --input places.csv --provider manual-csv --review-csv review.csv --duplicates-json duplicates.json --dry-run --export-csv leads.csv\n```\n\nWrite a CRM-ready local import CSV:\n\n```bash\nopen-local-audit discover --input places.csv --provider manual-csv --dry-run --export-csv crm-leads.csv --export-preset crm\n```\n\nValidate a CRM-ready local import CSV:\n\n```bash\nopen-local-audit validate-export --input crm-leads.csv --preset crm\nopen-local-audit validate-export --input crm-leads.csv --preset crm --format json\n```\n\n`validate-export` checks the local CSV shape before a manual import. It reports missing CRM columns, missing `companyName`, missing `website`, missing `leadKey`, duplicate `leadKey` values, low or empty contact confidence, and rows that still need manual contact review. Markdown output is the default; JSON is available for automation. Any issue returns exit code `1`, while a clean file returns exit code `0`.\n\nCreate a local lead shortlist from a discovery or CRM CSV export:\n\n```bash\nopen-local-audit shortlist --input leads.csv --out shortlist.md --top 20\nopen-local-audit shortlist --input leads.csv --out shortlist.md --min-opportunity-score 80\nopen-local-audit shortlist --input leads.csv --sort score-desc --out shortlist.md\nopen-local-audit shortlist --input leads.csv --out shortlist.md --summary-json shortlist-summary.json\nopen-local-audit shortlist --input leads.csv --segment dental --priority high --contact-confidence High --out shortlist.csv --format csv\nopen-local-audit shortlist --input leads.csv --exclude-review-status deferred --out shortlist.json --format json\nopen-local-audit shortlist --input leads.csv --require-website --out shortlist.json --format json\nopen-local-audit shortlist --input leads.csv --review-csv review.csv --review-status pending --out shortlist.json --format json\nopen-local-audit shortlist --input crm-leads.csv --out shortlist.json --format json\nopen-local-audit shortlist --input crm-leads.csv --out shortlist.csv --format csv\nopen-local-audit shortlist --input leads.csv --review-csv review.csv --out shortlist.md\n```\n\n`shortlist` ranks local CSV rows by `opportunityScore`, `priority`, `contactConfidence`, `score`, and company name. Use `--sort opportunity-desc|score-desc|company-asc|last-reviewed-asc` to change the ranking mode before top-N selection. Use `--summary-json` to write a separate automation summary with counts and selected lead identifiers. Use `--require-website` to keep only rows with a website. Use `--min-opportunity-score` to keep only stronger local opportunities. Use `--segment`, `--profile`, `--priority`, and `--contact-confidence` for case-insensitive exact focus filters; supplied filters are combined with `AND` semantics. Use `--review-status` to keep only active leads with a matching review status after completed or suppressed review rows have been removed, or `--exclude-review-status` to remove a matching active review status from the local report. Filtering runs after review-state suppression and before top-N ranking. With `--review-csv`, the command matches review rows by `leadKey`, normalized website, or company label; skips rows marked `rejected`, `contacted`, `not-fit`, `not_a_fit`, `do-not-contact`, or `suppressed`; and carries active `reviewStatus`, `reviewReason`, and `lastReviewedAt` values into Markdown, JSON, and CSV reports. Markdown output is the default; JSON is available for automation; CSV is available for spreadsheet review. The command only reads local CSV files and writes a local report. It does not mutate source files, call APIs, send outreach, or sync to a CRM.\n\nPackage an existing single-site report folder for local customer sharing:\n\n```bash\nopen-local-audit package-report --input reports/example-com --out packages/example-com\n```\n\n`package-report` reads `open-local-audit-report.json` from the input folder, copies available JSON, Markdown, HTML, and PDF report artifacts into `reports/`, and writes `README.md`, `next-actions.md`, and `manifest.json`. It is local file packaging only; it does not upload reports, send outreach, or sync to a CRM.\n\nThe `google-places` provider is opt-in and requires `GOOGLE_MAPS_API_KEY`. It uses the official Places Text Search API and requests only `places.id`, `places.displayName`, and `places.websiteUri`. It does not scrape Google Maps, collect reviews/photos/ratings, send outreach, or store raw Places responses. Google Maps Platform billing and quota limits apply to API use, and the CLI prints a billing warning when this provider is selected.\n\nDiscovery CSV exports include `leadKey`, `opportunityScore`, `opportunityReasons`, `pitchAngle`, `recommendedOffer`, `estimatedNeed`, `outreachPriorityReason`, website-derived public contact columns, manual outreach handoff columns, and review columns for local triage. Contact columns are populated only from audited public website HTML and include `publicEmail`, `publicPhone`, `whatsappUrl`, `contactPageUrl`, `socialProfiles`, `contactConfidence`, and `contactSource`. Handoff columns include `preferredContactChannel`, `outreachAction`, and `contactabilityReason`; they are advisory only and do not send outreach. Duplicate review JSON includes exact `duplicateGroups` and advisory `fuzzyDuplicateGroups` with confidence and matching reasons for local operator review. Fuzzy duplicate candidates do not auto-suppress leads, change review status, send outreach, or sync to a CRM. The CRM export preset writes `companyName`, `website`, `segment`, `profile`, `priority`, `score`, `opportunityScore`, `topFinding`, `contactConfidence`, `preferredContactChannel`, `contactabilityReason`, `publicEmail`, `publicPhone`, `contactPageUrl`, `source`, `leadKey`, and `reportPath`; it is a local import file only and does not call CRM APIs. A suppression list can reuse a prior discovery CSV or a smaller CSV with `leadKey`, `sourceId`, `websiteUrl`, or `label` plus optional `reviewStatus`, `reviewReason`, and `lastReviewedAt` columns. Rows marked `rejected`, `contacted`, `not-fit`, `do-not-contact`, or `suppressed` are skipped before audits run. `--review-csv` preserves prior operator decisions and adds new leads as `pending`. Spreadsheet formula-like cell values are neutralized before export, so values such as phone numbers starting with `+` may be prefixed for spreadsheet safety.\n\nSee [Google Maps API key setup](./docs/operations/google-maps-api-key.md) for local environment setup.\n\nCheck same-origin links and fail CI when high-severity issues are found:\n\n```bash\nopen-local-audit https://example.com --check-links --max-pages 10 --fail-on high --format all --out-dir reports\n```\n\n## First implementation milestone\n\nThe first implementation milestone is a CLI that accepts one URL and outputs:\n\n- JSON report.\n- Markdown report.\n- HTML report.\n- PDF report.\n- Executive Summary section in customer-facing reports.\n- Contact Readiness section in customer-facing reports.\n- Optional report branding with `--brand-config`.\n- Combined JSON, Markdown, and HTML report output with `--format all --out-dir`.\n- Batch input files with per-site report folders.\n- CSV batch input with optional labels and segments.\n- Aggregate batch index reports for prospect triage.\n- Batch index filtering, sorting, and top-N triage controls.\n- Controlled parallel batch audits with `--concurrency`.\n- Batch index insights for average score, profile breakdown, segment breakdown, and frequent findings.\n- Batch contact and outreach rollups for audited public website contact readiness.\n- CRM-ready local CSV export preset for batch and discovery exports.\n- Local CRM export validation with Markdown and JSON issue reports.\n- Local lead shortlist reports from discovery and CRM CSV exports.\n- Local shortlist sort modes with `--sort`.\n- Local shortlist automation summaries with `--summary-json`.\n- Local shortlist website-present filtering with `--require-website`.\n- Local shortlist review-state suppression with `--review-csv`.\n- Local shortlist opportunity-score filtering with `--min-opportunity-score`.\n- Local shortlist focus filtering by segment, profile, priority, and contact confidence.\n- Local shortlist active review-status filtering with `--review-status`.\n- Local shortlist active review-status exclusion with `--exclude-review-status`.\n- Spreadsheet-ready local shortlist CSV output with `--format csv`.\n- Local report packaging with shareable summaries and copied report artifacts.\n- Industry profiles for generic, dental, beauty, restaurant, contractor, lawyer, clinic, gym, hotel, and auto-service audits.\n- Profile-specific findings for dental, beauty, restaurant, and contractor conversion/trust signals.\n- Prospect CSV export with profile, score, top finding, contact handoff, report path, and error columns.\n- Discovery CSV contact enrichment from audited public website HTML.\n- Discovery CSV outreach handoff fields for manual next-channel selection.\n- Advisory fuzzy duplicate lead review candidates for discovery reruns.\n- Duplicate review output remains local operator guidance and does not auto-suppress, send outreach, or sync to CRM systems.\n- Optional rendered DOM audits with `--render`.\n- Optional rendered screenshot evidence with `--screenshot`.\n- Optional Lighthouse category scoring with `--lighthouse`.\n- Score summary.\n- Evidence table.\n- Optional same-origin link checks.\n- Terminal summary when reports are written to files.\n- CI-friendly exit codes with `--fail-on`.\n- Clear owner-readable recommendations.\n- Structured-data quality, address, opening-hours, service-location, CTA, and placeholder-copy checks.\n- Trust and conversion checks for current date signals, review cues, service detail depth, brand icons, and placeholder social links.\n\nExample target command:\n\n```bash\nopen-local-audit https://example.com --format markdown --out report.md\n```\n\nExample report artifacts are available under [`examples/reports`](./examples/reports).\n\n## Known limits\n\n- `--render` requires Playwright in the calling project and a working browser runtime.\n- `--screenshot` uses the rendered audit path, requires `--out-dir`, and also requires Playwright.\n- `--lighthouse` requires a local Chrome or Chromium runtime that Lighthouse can launch.\n- `--format pdf` is supported for single URL audits and requires `--out` or `--out-dir`.\n- `--brand-config` reads local JSON only; it does not fetch remote assets or upload report data.\n- Batch triage options apply to the aggregate batch index, not individual per-site report contents.\n- Batch contact and outreach rollups are advisory local triage metadata; they do not send outreach or sync to a CRM.\n- `--export-preset crm` changes CSV columns only; it does not create, update, or sync CRM records.\n- `validate-export` checks local CSV files only; it does not create, update, or sync CRM records.\n- `shortlist` ranks local CSV files only; it does not call APIs, send outreach, or sync CRM records.\n- `shortlist --sort` changes local report ordering only; it does not update source or review CSV files.\n- `shortlist --summary-json` writes local automation metadata only; it does not update source or review CSV files.\n- `shortlist --require-website` filters local report output only; it does not update source or review CSV files.\n- `shortlist --review-csv` reads review state for suppression and report context only; it does not mutate the review CSV.\n- `shortlist --min-opportunity-score` filters local report output only; it does not update source lead files.\n- Shortlist focus filters use case-insensitive exact matching and do not update source lead files.\n- `shortlist --review-status` filters local report output only; it does not update source or review CSV files.\n- `shortlist --exclude-review-status` filters local report output only; it does not update source or review CSV files.\n- `shortlist --format csv` writes a local spreadsheet review file only; it does not import or sync records.\n- `package-report` packages local files only; it does not upload reports, send outreach, or sync CRM records.\n- `--export-csv` is supported for batch audits and discovery exports.\n- `discover --provider google-places` requires `GOOGLE_MAPS_API_KEY` and may incur Google Maps Platform billing.\n- `--limit` caps Google Places candidates at 50; it does not paginate beyond one Text Search request.\n- `--max-audits` limits website audits only; all discovered candidates still appear in `leads.csv`.\n- `--suppression-list` uses exact lead identity matching; source IDs are preferred, then normalized website URLs, then normalized labels.\n- `--review-csv` is local operator state only; it does not send outreach or sync to a CRM.\n- `--duplicates-json` reports exact duplicate lead groups and advisory fuzzy duplicate candidates for manual review; it does not auto-suppress rows or update review decisions.\n- Batch input requires `--out-dir` and cannot be combined with a positional URL.\n- Industry profiles are deterministic vertical heuristics, not a replacement for a human review of each business model.\n- Higher `--concurrency` values can increase network load against audited sites; use conservative values for prospect batches.\n- Rule checks are deterministic heuristics, so they can miss or over-flag site-specific markup.\n\n## GitHub and npm release intent\n\nThe project should be prepared for:\n\n- Public GitHub repository.\n- Clear README and examples.\n- MIT license, unless maintainers choose a different license before the first public release.\n- GitHub Actions for lint, tests, build, and release checks.\n- npm package after the CLI has real tests and example reports.\n\nRelease work should follow the checklist in `docs/release/release-readiness.md`.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fesquetta%2Fopen-local-audit","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fesquetta%2Fopen-local-audit","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fesquetta%2Fopen-local-audit/lists"}