Skip to content

Bulk Operations

Bulk operations let you create and distribute large numbers of gift cards in one job — without issuing them one at a time.

Bulk operations hub

Three types of bulk jobs

Job type What it does Best for
Generate Creates codes with a set balance, no recipient Export to CSV, physical card programs, internal use
Send Creates codes and emails each one to a recipient Corporate gifting, loyalty rewards, promotions
Update Adjusts the balance on a set of existing cards Adding bonus credit, correcting balances

Bulk Generate

Use this to create a batch of gift card codes that you'll distribute yourself (e.g., export and print, add to packaging, hand to a partner).

Bulk generate

Settings

Field Description
Quantity Number of cards to generate (up to 10,000 per job)
Amount per card Fixed balance loaded on each card
Expiry Optional expiry date
Gift card type Which design/settings template to use
Export format CSV with code, balance, expiry, and status

Generate without import

Use the Generate without import option for physical printed cards. This generates codes without activating them in Shopify — codes remain inactive until sold. Configure a prefix (up to 4 characters) and code length (8-16 characters).

After generation

When the job completes, you can download a CSV with all generated codes and their details. The codes are also live in Shopify as active gift cards (unless you used "Generate without import").

Bulk Send

Use this to send gift cards to a list of named recipients. Each person gets their own card and a personalized email.

Bulk send

Preparing your recipient list

Upload a CSV with the following columns:

Column Required Description
initial_value Yes Amount in your store's currency
email Yes Recipient's email address
name Optional Recipient name, used in email greeting
message Optional Per-recipient personal message
expires_on Optional Expiry date in YYYY-MM-DD format

Example CSV:

initial_value,email,name,message,expires_on
50,jane@example.com,Jane Smith,Thank you for your loyalty!,2027-03-15
100,bob@example.com,Bob Jones,Happy birthday Bob!,

Settings

  • Default amount — used for rows that don't specify an amount
  • Gift card type — design and settings template
  • Sender name — shown in the email as "A gift from..."
  • Default message — used when a row doesn't have a message column
  • Schedule — send all at once or spread over time (e.g., 500/hour to avoid email throttling)

Sending throttle

For large lists (1,000+), GiftCard Hero spreads the sends over time to avoid hitting Shopify's email rate limits. You can set the rate in the advanced options.

Bulk Update

Adjust balances on a set of existing cards. Use cases:

  • Add $10 bonus credit to all cards issued in a specific month
  • Zero out cards that are past expiry
  • Correct an incorrect balance after a system issue

Upload a CSV with the following columns:

Column Required Description
code Yes The gift card code to update
new_balance Optional New balance value. Use + or - prefix for relative adjustments (e.g., +10.00 adds $10, -5.00 subtracts $5)
disabled Optional Set to TRUE to disable the card (irreversible)
recipient_email Optional Update the recipient email
customer_email Optional Update the customer email
notify_customer Optional Send notification to customer
notify_recipient Optional Send notification to recipient
code,new_balance
ABCD-1234-EFGH-5678,75.00
IJKL-9012-MNOP-3456,+10.00
QRST-7890-UVWX-1234,-5.00

Note: Bulk Update sets the balance to the value you provide — it doesn't add or subtract — unless you use the + or - prefix for relative adjustments. To add $10 to a card with $40, either set new_balance to 50.00 or use +10.00.

Bulk Import

Import existing gift cards from other systems into GiftCard Hero.

Upload a CSV with the following columns:

Column Required Description
initial_value Yes Amount in your store's currency
code Optional Gift card code (auto-generated if omitted)
customer_id Optional Shopify customer ID to associate
expires_on Optional Expiry date in YYYY-MM-DD format
recipient_email Optional Recipient's email address
customer_email Optional Customer's email address
notify_customer Optional Send notification to customer
notify_recipient Optional Send notification to recipient

Steps

  1. Navigate to the Import tab
  2. Prepare your CSV file with the columns above
  3. Upload the CSV file
  4. Click Start Import

Tracking results

After starting any bulk job, you can monitor progress in Bulk → Results.

The results page shows:

  • Job status (queued, running, completed, failed)
  • Progress (e.g., 847 / 1000 sent)
  • Per-row errors (e.g., invalid email, duplicate code)
  • Download links for the results CSV

Results CSV

The results CSV includes all input columns plus:

  • status — success / failed / skipped
  • error — error message if failed
  • helpscout_url — public URL of the gift card (for Generate jobs)
  • code_last4 — last 4 digits of the gift card code

Limits and performance

Limit Value
Max cards per Generate job 10,000
Max rows per Send job 10,000
Max rows per Update job 50,000
Estimated speed (Generate) ~500 cards/minute
Estimated speed (Send) ~200 emails/minute

Large jobs run in the background — you don't need to keep the browser open. You'll receive a summary email when the job completes.