Skip to content

feat(imports): add CSV import preview endpoint with validation#375

Open
ryzen-xp wants to merge 1 commit into
CredenceOrg:mainfrom
ryzen-xp:feature/import-upload-limits
Open

feat(imports): add CSV import preview endpoint with validation#375
ryzen-xp wants to merge 1 commit into
CredenceOrg:mainfrom
ryzen-xp:feature/import-upload-limits

Conversation

@ryzen-xp
Copy link
Copy Markdown
Contributor

  • Add POST /api/imports/preview endpoint for validating Stellar address CSV files
  • Implement CSV parsing with configurable limits (512 KB file size, 10k rows, 1 KB cells)
  • Validate file type by MIME type and extension; reject non-CSV files with 415 response
  • Enforce Enterprise API scope requirement for endpoint access
  • Add per-row validation with detailed error reporting (missing/invalid addresses)
  • Sanitize formula-injection characters (=, +, -, @) in preview output
  • Return summary statistics (valid/invalid row counts, truncation status)
  • Include comprehensive test suite covering auth, file limits, CSV parsing, and error cases
  • Add detailed API documentation with request/response examples and error reference
  • Close [Backend] Imports: enforce file-size/row limits and content-type validation on CSV upload path #339

- Add POST /api/imports/preview endpoint for validating Stellar address CSV files
- Implement CSV parsing with configurable limits (512 KB file size, 10k rows, 1 KB cells)
- Validate file type by MIME type and extension; reject non-CSV files with 415 response
- Enforce Enterprise API scope requirement for endpoint access
- Add per-row validation with detailed error reporting (missing/invalid addresses)
- Sanitize formula-injection characters (=, +, -, @) in preview output
- Return summary statistics (valid/invalid row counts, truncation status)
- Include comprehensive test suite covering auth, file limits, CSV parsing, and error cases
- Add detailed API documentation with request/response examples and error reference
@drips-wave
Copy link
Copy Markdown

drips-wave Bot commented May 30, 2026

@ryzen-xp Great news! 🎉 Based on an automated assessment of this PR, the linked Wave issue(s) no longer count against your application limits.

You can now already apply to more issues while waiting for a review of this PR. Keep up the great work! 🚀

Learn more about application limits

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

[Backend] Imports: enforce file-size/row limits and content-type validation on CSV upload path

1 participant