CSV Upload
Issue points to multiple users at once by uploading a CSV file
CSV Upload Points
The CSV Upload feature allows you to issue points to multiple users at once by uploading a CSV file containing user identities and point values.
CSV Format Requirements
Your CSV file must include:
- A header row with column names
- A column for user identities (addresses, emails, etc.)
- A column for point values
Example CSV format:
You can include additional columns for your own reference, but you’ll need to specify which columns contain the identity and points values during the upload process.
CSV Validation Rules
When uploading a CSV file, the system will validate your data according to these rules:
-
Identity values must match the specified identity type format:
- EVM addresses must be valid Ethereum addresses (0x followed by 40 hex characters)
- Solana addresses must be valid base58 strings (32-44 characters)
- Bitcoin addresses must follow BTC address format
- Email addresses must be in valid email format
- Discord IDs must be 17-19 digits
- X/Twitter handles must be 1-15 alphanumeric characters or underscores
- GitHub usernames must follow GitHub username format
-
Point values must be:
- Valid numbers
- Greater than or equal to zero (no negative points)
- Finite numbers
-
Duplicate identities will be flagged as warnings but will still be processed
-
Empty or invalid entries will be flagged as errors and must be corrected before processing
Identity Types
When uploading a CSV, you’ll need to specify which type of identity is in your identity column:
Identity Type | Description |
---|---|
EVM_ADDRESS | Ethereum addresses (e.g., “0xB58621209Dc0b0c514E52a6D9A165a16ae95e4f7”) |
SOLANA_ADDRESS | Solana addresses (e.g., “8ZUkk8pTyEAjyHbmBBXdrDNiNZ9D9Gcn5HgqxEjD8aHn”) |
BTC_ADDRESS | Bitcoin addresses (e.g., “1A1zP1eP5QGefi2DMPTfTL5SLmv7DivfNa”) |
Email addresses (e.g., “user@example.com”) | |
DISCORD_PROVIDER_ID | Discord numeric IDs (not usernames) |
X_PROVIDER_ID | X/Twitter numeric IDs (not usernames) |
GITHUB_PROVIDER_ID | GitHub numeric IDs (not usernames) |
Using the Dashboard
The easiest way to upload a CSV is through the Absinthe dashboard:
- Navigate to your season in the app.absinthe.network dashboard
- Go to the “Points” section and select “CSV Upload”
- Create a new CSV upload source
- Upload your CSV file
- Map the identity column and points column
- Select the identity type
- Validate the CSV
- Publish the source to issue points
Best Practices
- Keep your CSV files organized: Use clear column headers and consistent formatting
- Validate before publishing: Always validate your CSV data before publishing to catch any errors
- Use appropriate identity types: Make sure you select the correct identity type for your data
- Limit file size: For optimal performance, keep CSV files under 10,000 rows
- Include metadata: Consider adding additional columns for your own reference and tracking
For large CSV files, consider breaking them into smaller batches to improve processing speed and reduce the chance of timeouts.
FAQ
The CSV upload feature is designed for one-time or periodic bulk point issuances. For real-time or event-triggered point issuances, consider using our GraphQL API or integrations with platforms like Zapier.