Skip to main content

Import Historical Points or Credits Transactions

Import past points or credits activity with CSV so balances are rebuilt from your imported transaction history.

Written by Stuart Chaney

Introduction

Use the Points Logs CSV importer when you want to backfill historical loyalty activity into Rivo. This creates transaction history rows (not just a one-time balance adjustment), then recalculates each affected customer’s points or credits balance from that imported history.

This is useful for migrations, historical corrections, and bringing older activity into your current program records.

In migration projects, a backfill means importing older transaction history so customers’ past earning and spending activity appears in Rivo (with historical dates, if provided), instead of starting everyone from today.





Before You Import

  1. Go to Settings > CSV Imports.

  2. Set Data Type to Points Logs.

  3. Click Download Template.

  4. Prepare your CSV using the required format below.





CSV Format

Your file must include:

  • A customer identifier column: customer_id or email

  • A transaction amount column: points_amount or credits_amount

Optional columns:

  • source

  • points_amount

  • credits_amount

  • internal_note

  • external_note

  • applied_at

  • approved_at

  • revoked_at

  • expires_at

  • order_id

  • custom_action_name

  • earning_rule_id

  • points_purchases_id


Header aliases accepted

The importer accepts common header variants, including:

  • customer_id, Customer ID, CustomerID, Shopify Customer ID

  • email, Email, customer_email, Customer Email, Shopify Customer Email

  • points_amount, Points Amount

  • credits_amount, Credits Amount

  • source, Source

  • internal_note, Internal Note

  • external_note, External Note

  • applied_at, Applied At

  • approved_at, Approved At

  • revoked_at, Revoked At

  • expires_at, Expires At

  • order_id, Order ID, points_order_id

  • custom_action_name, Custom Action Name

  • earning_rule_id, Earning Rule ID

  • points_purchases_id, Points Purchases ID


Amount behavior

  • Positive values add points or credits.

  • Negative values deduct points or credits.

  • Rows where both amounts are zero are skipped.

  • A row can include both points_amount and credits_amount.


Date behavior

If applied_at is missing or invalid, Rivo uses the current timestamp.
If approved_at is missing or invalid, it defaults to the final applied_at value.
Invalid revoked_at or expires_at values are ignored.





Matching and Processing Rules

Use one matching method per file

Do not mix lookup methods in one CSV.

  • During processing, if a batch includes rows with customer_id, that batch uses customer ID matching.

  • In those batches, rows without a valid customer_id can be skipped even if they include an email.

Best practice: use either customer IDs for all rows, or emails for all rows, so matching behavior stays predictable.

Existing customers only

Rows are imported only when the customer already exists in your store’s Rivo customer records.
Unknown customers are skipped.

Duplicate protection

If you import the same transaction row again (including across separate import runs), duplicate rows are ignored.

To count as the same row, key values must match (customer, source, amounts, notes, action/rule fields, and applied timestamp). If you change any of those values, Rivo treats it as a new transaction.





Upload and Monitor Progress

  1. In Settings > CSV Imports , upload your file in the dropzone.

  2. Rivo queues processing in the background.

  3. Open CSV Import Progress and click View CSV Imports to monitor status.

Possible statuses include Pending , Processing , Completed , Failed , Reverting , Reverted , and Cancelled.

For large files, processing time scales with row count. Typical timing guidance:

  • Up to 100 rows: a few seconds

  • 101 to 1,000 rows: a few minutes

  • 1,001 to 10,000 rows: up to 20 minutes

  • 10,001 to 100,000 rows: up to an hour

  • Over 100,000 rows: a few hours

If an import sits in Pending, it is waiting in the background queue before processing starts.





What Happens After Import

After rows are imported:

  • Transaction history entries are created for matched customers.

  • Customer balances are recalculated for the affected balance type (points and/or credits).

  • Imported rows are tagged for traceability so they can be reverted later from CSV Imports history.

Customer-facing message records are not generated by this importer.

What customers and admins will see

  • In admin, imported transactions appear in customer points/credits history and in the CSV Imports history.

  • In customer-facing activity history, the customer-facing note uses external_note when you provide one.

  • internal_note is for internal reference and traceability.

  • Some stores have per-entry visibility controls enabled for points logs. If available in your account, you can hide specific entries from customer view after import.





Revert an Imported File

If you need to roll back a completed import:

  1. Go to Settings > CSV Imports.

  2. Click View CSV Imports.

  3. Find the completed import and click Revert.

This queues a rollback for that import and moves it through Reverting to Reverted status.

If you don’t see a Revert button for an older import, contact support for help.





Common Questions About Actions and Expiry

Can I tie uploaded transactions to a specific earning action?

Yes. In a Points Logs import, you can map transactions to specific activity using the source column, and optionally add custom_action_name and earning_rule_id when needed.

If you only need to change balances (not record a specific action history), use manual balance adjustments instead.

Can monthly uploads use different point or credit amounts per customer?

Yes. Every row can use a different value, including positive and negative amounts.

This works well for partner reports, offline campaigns, and one-off corrections where each customer’s amount is different.

How does expiry work for uploaded transactions vs manual adjustments?

  • For Points Logs imports, use expires_at if you want a specific expiry date on each imported row.

  • If expires_at is blank in a Points Logs import, Rivo does not add an expiry date for that imported row.

  • For manual balance adjustments (single-customer or bulk balance updates), expiry follows your points or credits expiry settings.

  • For earning-rule activity (like order, birthday, or other configured ways to earn), expiry follows your earning setup and program expiry configuration.





FAQ

Can I import points and credits in one file?
Yes. A row can contain both points_amount and credits_amount.

Will this create new customers from email addresses in my CSV?
No. Only customers that already exist in your Rivo customer records are updated.

What if my source value is blank or not recognized?
Rivo assigns a default import source automatically.

Can I safely retry an import file?
Yes, if the key row values are unchanged.
To avoid accidental duplicates, keep applied_at, amounts, notes, and source values identical when retrying.

Can I upload historical timestamps?
Yes. Use applied_at and approved_at in your CSV when you want historical dates preserved.

Did this answer your question?