REST API resources

Learn how the Fundraise Up API works.

This article will show you how to integrate our fundraising platform with your systems through the Fundraise Up API. For detailed information on obtaining your API key, handling errors, understanding rate limits, and other essential topics, please refer to the API overview article.

The Fundraise Up API allows you to interact with the following resources:

  • Donations
  • Recurring plans
  • Supporters
  • Events
  • Donor Portal access links
  • Donor Portal recurring plan access links

You can access and export data for the first four of these resources. The API also allows you to create and update Donations and their associated Recurring plans, but updates are only allowed within 24 hours of creation and only for API-created donations.

Donor Portal access link and Donor Portal recurring plan access link resources handle automatic supporter authentication in the Donor Portal.

Currently, the only payment method supported by the API is credit card.

Base URL: https://api.fundraiseup.com

The Fundraise Up API does not support bulk updates. You can only create or update one object per request.

Donations

 
Link copied

The Donation object represents a single donation. It can be either a one-time donation or an installment as part of a recurring plan.

You can create donations, update donations and associated recurring plans sourced from the API, and read donations from your account.

Endpoints:

Create a donation

 
Link copied

Endpoint: POST /v1/donations

This request allows you to create either a one-time donation or a recurring plan.

To create a recurring plan, you must include a recurring_plan object with the frequency parameter. If the object is not provided, a one-time donation will be created.

All fields and values must meet the requirements of your campaign. Otherwise, an error will be returned.

We do not format or verify addresses and emails that were sent through the API.

A Stripe payment method ID is required. For more details on how to create a payment method, refer to the Stripe Payment Methods documentation.

Prerequisites

Make sure you have:

  • A Stripe account that is connected to your Fundraise Up account and activated.
  • An active campaign with a money-based payment method.
  • An API key with permission to create new donations.
  • Access to the Stripe API for the same Stripe account used as the Fundraise Up payment method, with the ability to create Payment Methods.

Nonprofit organizations must meet PCI compliance requirements to ensure the secure processing of payment card data. Fundraise Up complies with these standards, but if an organization or its vendor uses direct API integration with Stripe to send raw card data (such as card numbers, expiration dates, and CVV codes), that organization or vendor is responsible for meeting broader PCI DSS requirements, such as SAQ D for merchants or higher.

If using Stripe Elements, the responsibility for card data security shifts to Stripe, requiring only minimal PCI compliance validation from the organization. Vendors working with face-to-face or direct mail solutions should use Stripe Elements or maintain their own PCI compliance certification.

Parameters

All string parameters will be trimmed first, then all empty strings will be converted to null.

Parameters that are not required can be omitted. Omitted parameters will contain default values where applicable. Fields that accept null values are marked as nullable.

campaign string required

Campaign ID. Must belong to the account that owns the API key, otherwise an error will occur. Must be active and accept money-based donations, otherwise an error will occur.

payment_method dictionary required

Payment method information.

Child parameters

payment_method.stripe dictionary required

Child parameters

payment_method.stripe.id string required

The PaymentMethod ID within the organization’s Stripe account. Card payments are the only accepted payment method.

When writing test code, use a payment_method.stripe.id such as pm_card_visa from the list of Stripe test cards. For more information on using test cards, see the Stripe documentation.

currency enum required

Three-letter ISO currency code, in lowercase.

Must be one of the following. Note that the list of currencies for your organization may be more limited. You can check the available currencies in your campaign settings.
Name Code
US Dollar usd
Canadian Dollar cad
Euro eur
Afghan Afghani afn
Albanian Lek all
Algerian Dinar dzd
Angolan Kwanza aoa
Argentine Peso ars
Armenian Dram amd
Aruban Florin awg
Australian Dollar aud
Azerbaijani Manat azn
Bahraini Dinar bhd
Bangladeshi Taka bdt
Barbadian Dollar bbd
Belarusian Ruble byn
Belize Dollar bzd
Bermudan Dollar bmd
Bhutanese Ngultrum btn
Bolivian Boliviano bob
Bosnia-Herzegovina Convertible Mark bam
Botswanan Pula bwp
Brazilian Real brl
British Pound gbp
Brunei Dollar bnd
Bulgarian Lev bgn
Burundian Franc bif
Cape Verdean Escudo cve
CFP Franc xpf
Central African CFA Franc xaf
Chilean Peso clp
Chinese Yuan cny
Colombian Peso cop
Comorian Franc kmf
Congolese Franc cdf
Costa Rican Colón crc
Croatian Kuna hrk
Czech Koruna czk
Danish Krone dkk
Djiboutian Franc djf
Dominican Peso dop
East Caribbean Dollar xcd
Egyptian Pound egp
Ethiopian Birr etb
Falkland Islands Pound fkp
Fijian Dollar fjd
Gambian Dalasi gmd
Georgian Lari gel
Ghanaian Cedi ghs
Gibraltar Pound gip
Guatemalan Quetzal gtq
Guinean Franc gnf
Guyanaese Dollar gyd
Haitian Gourde htg
Honduran Lempira hnl
Hong Kong Dollar hkd
Hungarian Forint huf
Icelandic Króna isk
Indian Rupee inr
Indonesian Rupiah idr
Israeli New Shekel ils
Jamaican Dollar jmd
Japanese Yen jpy
Jordanian Dinar jod
Kazakhstani Tenge kzt
Kenyan Shilling kes
Kyrgystani Som kgs
Laotian Kip lak
Lebanese Pound lbp
Lesotho Loti lsl
Liberian Dollar lrd
Macedonian Denar mkd
Malagasy Ariary mga
Malawian Kwacha mwk
Malaysian Ringgit myr
Maldivian Rufiyaa mvr
Mauritian Rupee mur
Mexican Peso mxn
Moldovan Leu mdl
Mongolian Tugrik mnt
Moroccan Dirham mad
Mozambican Metical mzn
Myanmar Kyat mmk
Namibian Dollar nad
Nepalese Rupee npr
Netherlands Antillean Guilder ang
New Zealand Dollar nzd
Nicaraguan Córdoba nio
Nigerian Naira ngn
Norwegian Krone nok
Omani Rial omr
Pakistani Rupee pkr
Panamanian Balboa pab
Papua New Guinean Kina pgk
Paraguayan Guarani pyg
Peruvian Sol pen
Philippine Peso php
Polish Zloty pln
Qatari Riyal qar
Romanian Leu ron
Russian Ruble rub
Rwandan Franc rwf
Saudi Riyal sar
Serbian Dinar rsd
Seychellois Rupee scr
Sierra Leonean Leone (1964–2022) sll
Singapore Dollar sgd
Solomon Islands Dollar sbd
South African Rand zar
South Korean Won krw
Sri Lankan Rupee lkr
St. Helena Pound shp
Sudanese Pound sdg
Surinamese Dollar srd
Swedish Krona sek
Swiss Franc chf
Syrian Pound syp
Tajikistani Somoni tjs
Tanzanian Shilling tzs
Thai Baht thb
Tongan Paʻanga top
Trinidad and Tobago Dollar ttd
Tunisian Dinar tnd
Turkish Lira try
Turkmenistani Manat tmt
Ugandan Shilling ugx
Ukrainian Hryvnia uah
United Arab Emirates Dirham aed
Uruguayan Peso uyu
Uzbekistani Som uzs
Vanuatu Vatu vuv
Venezuelan Bolívar vef
Vietnamese Dong vnd
West African CFA Franc xof
Yemeni Rial yer
Zambian Kwacha zmw

amount string required

Donation amount in the selected currency. Must be a decimal string in the format {NNN}[.nn]. Examples: 9.99 (for USD), 200 (for JPY).

The amount must be greater than $1 or the equivalent in other currencies. If a minimum amount is set for the campaign, the donation must meet or exceed that value.

supporter dictionary required

Supporter's personal data.

Child parameters

supporter.first_name string required

Up to 256 characters.

supporter.last_name string required

Up to 256 characters.

supporter.phone nullable string

Up to 20 characters.

Required if the campaign is configured to require the supporter to provide their phone number.

supporter.address nullable dictionary

Required if the campaign is configured to require the supporter to provide their mailing address. Also affected by the minimum amount required.

Child parameters

supporter.address.country string required

Two-letter country code, lowercase.

supporter.address.region nullable string required for some countries

Up to 64 characters.

Required for all countries except gb (United Kingdom), il (Israel), nl (Netherlands), fr (France), de (Germany). Can be: region, state, or province.

supporter.address.city string required

Up to 64 characters.

supporter.address.line1 string required

Up to 256 characters.

supporter.address.line2 nullable string

Up to 256 characters.

supporter.address.postal_code string required

Up to 10 characters.

supporter.title nullable enum

Supporter’s title, in lowercase. Available options depend on the campaign settings. Available for the following countries:

  • United Kingdom: mr, mrs, miss, ms, mx, sir, dr, rev, dcn, fr, br, sr, prof
  • France: m, mme, mlle, autre
  • Germany: herr, frau, prof, dr
  • Austria: herr, frau
  • Canada (French): m, mme, mlle, autre

supporter.email nullable string

Up to 254 characters.

supporter.employer nullable dictionary

Only allowed if employer matching is enabled for the campaign.

Child parameters

supporter.employer.name string required

Up to 64 characters.

comment nullable string

Up to 256 characters.

recurring_plan dictionary

Recurring plan parameters.

This must be specified if the campaign settings in the Frequency section do not include “Once” as an option for either Default Frequency or Second Frequency.

Child parameters

recurring_plan.frequency enum required

Can be: daily, weekly, biweekly, every4weeks, monthly, bimonthly, quarterly, semiannual, or annual.

Must match campaign settings for default or additional frequency.

skip_thank_you_email boolean

false (default) will send a donation receipt email for the first installment.

true will prevent the donation receipt email from being sent for the first installment.

Available for recurring plans only.

To use this parameter, you must also include the email parameter.

Sending this parameter for a one-time donation will return an error.

questions array of dictionaries

Required if there are required questions in the campaign settings.

Child parameters

Each item must include an id and, depending on the question type, one of the following fields: text, options, or checked.

questions.id string required

Question ID located in Settings > Questions.

questions.text string

Up to 256 characters.

Required for questions with types “Text box,” “Text line,” “Select one option,” or “Dropdown menu.”

questions.options array of strings

Required for questions with the type “Multiple checkboxes.”

questions.checked boolean

Required for questions with the type “Single checkbox.”

designation nullable string

Designation ID located in Settings > Designations.

If a default designation exists in the campaign settings and no value is provided, the default designation will be applied.

custom_fields array of dictionaries

Missing fields will be populated with default non-blank values from the campaign settings.

Child parameters

custom_fields.name string required

Up to 256 characters.

custom_fields.value string required

Up to 256 characters.

One-time donation example (minimum number of required fields)

1{
2  "campaign": "FUNBRRPPNWQ",
3  "payment_method": {
4    "stripe": {
5      "id": "pm_card_visa"
6    }
7  },
8  "currency": "usd",
9  "amount": "9.99",
10  "supporter": {
11    "first_name": "John",
12    "last_name": "Doe"
13  }
14}

This example only works if the campaign does not have any additional required fields set up. Depending on your campaign configuration, you may also need to provide required fields such as address, title, designation, and questions. Please check your campaign settings to ensure that all required fields are included.

Recurring donation example (minimum number of required fields)

To create a recurring plan, include the recurring_plan object with the required frequency parameter.

1{
2  "campaign": "FUNBRRPPNWQ",
3  "payment_method": {
4    "stripe": {
5      "id": "pm_card_visa"
6    }
7  },
8  "currency": "usd",
9  "amount": "9.99",
10  "supporter": {
11    "first_name": "John",
12    "last_name": "Doe"
13  },
14  "recurring_plan": {
15    "frequency": "monthly"
16  }
17}

This example only works if the campaign does not have any additional required fields set up. Depending on your campaign configuration, you may also need to provide required fields such as address, title, designation, and questions. Please check your campaign settings to ensure that all required fields are included.

Full request example

This example shows a request for a campaign that includes all available parameters, such as supporter details, comment, designation, questions, and custom fields.

1{
2  "campaign": "FUNBRRPPNWQ",
3  "payment_method": {
4    "stripe": {
5      "id": "pm_card_visa"
6    }
7  },
8  "currency": "usd",
9  "amount": "9.99",
10  "recurring_plan": {
11    "frequency": "daily"
12  },
13  "supporter": {
14    "first_name": "John",
15    "last_name": "Doe",
16    "title": "mr",
17    "email": "john.doe@example.com",
18    "phone": "7056789834",
19    "address": {
20      "line1": "Street",
21      "line2": "House",
22      "city": "City",
23      "region": "CA",
24      "postal_code": "100100",
25      "country": "us"
26    },
27    "employer": {
28      "name": "Fundraise Up"
29    }
30  },
31  "comment": "Comment",
32  "designation": "ESTPTE7U",
33  "questions": [
34    {
35      "id": "Q1",
36      "text": "Text"
37    },
38    {
39      "id": "Q2",
40      "options": [
41        "Checkbox 1",
42        "Checkbox 2"
43      ]
44    },
45    {
46      "id": "Q3",
47      "checked": false
48    }
49  ],
50  "custom_fields": [
51    {
52      "name": "a",
53      "value": "A"
54    },
55    {
56      "name": "b",
57      "value": "B"
58    }
59  ]
60}

Response

On success, the API returns the donation object. If the parameters are invalid, the call will return an error.

1{
2  "id": "DFQLCFEP",
3  "created_at": "2024-11-10T15:49:12.667Z",
4  "account": {
5    "id": "HRMEIGNS",
6    "code": "123423",
7    "name": "Helping Hands"
8  },
9  "livemode": true,
10  "amount": "9.99",
11  "amount_in_default_currency": "9.99",
12  "amount_before_fees_covered": "9.99",
13  "amount_before_fees_covered_in_default_currency": "9.99",
14  "anonymous": false,
15  "campaign": {
16    "id": "FUNBRRPPNWQ",
17    "code": "GENERAL",
18    "name": "Campaign Name"
19  },
20  "comment": "Comment",
21  "currency": "usd",
22  "custom_fields": [
23    {
24      "name": "a",
25      "value": "A"
26    },
27    {
28      "name": "b",
29      "value": "B"
30    }
31  ],
32  "device": {
33    "type": "desktop",
34    "browser": null,
35    "os": null,
36    "ip": {
37      "address": "127.0.0.1",
38      "country_name": "Spain",
39      "region": "Catalonia",
40      "city": "Barcelona"
41    }
42  },
43  "element": null,
44  "designation": {
45    "id": "ESTPTE7U",
46    "code": "DESIGNATION",
47    "name": "Designation Name"
48  },
49  "status": "succeeded",
50  "failed_at": null,
51  "succeeded_at": "2024-10-11T14:11:01.089Z",
52  "refunded_at": null,
53  "source": "api",
54  "installment": 1,
55  "recurring_plan": null,
56  "on_behalf_of": null,
57  "payment": {
58    "id": "ch_3Q8jYTKL8VnB2RtS0gQZUqoe",
59    "credit_card": {
60      "exp_month": "10",
61      "exp_year": "2025",
62      "last4": "4242"
63    },
64    "email": null,
65    "error_message": null,
66    "method": "credit_card",
67    "processor": "stripe"
68  },
69  "payout": {
70    "amount": "9.20",
71    "amount_in_default_currency": "9.20",
72    "currency": "usd"
73  },
74  "platform_fee": {
75    "amount": "0.20",
76    "amount_in_default_currency": "0.20",
77    "currency": "usd"
78  },
79  "processing_fee": {
80    "amount": "0.59",
81    "amount_in_default_currency": "0.59",
82    "currency": "usd"
83  },
84  "supporter": {
85    "id": "SWYRPXNQ",
86    "email": "john.doe@example.com",
87    "first_name": "John",
88    "last_name": "Doe",
89    "title": "mr",
90    "phone": "7056789834",
91    "employer": {
92      "name": "Fundraise Up"
93    },
94    "address": {
95      "line1": "Street",
96      "line2": "House",
97      "city": "City",
98      "region": "CA",
99      "postal_code": "100100",
100      "country": "us"
101    }
102  },
103  "supporter_covered_fee": "0.00",
104  "tribute": null,
105  "fundraiser": null,
106  "questions": [
107    {
108      "id": "Q1",
109      "code": "CODE1",
110      "text": "Text"
111    },
112    {
113      "id": "Q2",
114      "code": "CODE2",
115      "options": [
116        "Checkbox 1",
117        "Checkbox 2"
118      ]
119    },
120    {
121      "id": "Q3",
122      "code": "CODE3",
123      "checked": false
124    }
125  ],
126  "utm": {
127    "source": null,
128    "campaign": null,
129    "medium": null,
130    "content": null,
131    "term": null
132  },
133  "url": null
134}

In case of an error on the Stripe side, the response will contain an error.stripe_error object with the status and nullable error payload returned by Stripe.

Update a donation and associated recurring plan

 
Link copied

Endpoint: POST v1/donations/:id

This request allows you to update the details of a donation that was made through an API call.

You can make updates to:

  • Enrich data.
  • Modify parameter values.
  • Remove parameter values.
This action is only available within 24 hours of the donation being created.

Donations created outside of the API, such as through the Checkout modal, Campaign Page, or Virtual Terminal, cannot be edited through the API.

The donation ID must belong to the account associated with the API key. Donations from subaccounts cannot be updated using the API key of the parent account. Attempting to do so will result in an error. To update a donation in a subaccount, you must use the API key of that subaccount.

For the update to be successful, the donation object must match the current campaign settings, otherwise the operation will fail with a validation error.

Parallel requests to update one object are not allowed and will result in an error.

Any parameters or child parameters that are not provided will remain unchanged.

A successful update will modify the donation receipt, but no emails will be sent as a result.

If you update recurring plan, the changes will apply to both the specific installment and all future installments.

Parameters

All string parameters will be trimmed first, then all empty strings will be converted to null.

Parameters that are not required may be omitted or set to undefined. If a value is not provided or is undefined, it will not be updated. Fields that accept null values are marked as nullable.

If the campaign is changed, all attributes will be validated to ensure they match the parameters of the target campaign. If the campaign is not changed, only the parameters specified in the request will be validated against the current campaign settings.

campaign string

Campaign ID. Must belong to the account that owns the API key, otherwise an error will occur. Must be active and accept money-based donations, otherwise an error will occur.

supporter dictionary

Supporter's personal data. Only the specified parameters are updated, the others remain unchanged. This means that you can send an object with only some fields, because all parameters are optional.

Child parameters

supporter.first_name string

Up to 256 characters.

supporter.last_name string

Up to 256 characters.

supporter.phone nullable string

Up to 20 characters.

It can only be sent if the campaign setting “Ask for phone number” is enabled.

Required if the campaign is configured to require the supporter to provide their phone number.

supporter.address nullable dictionary

It can only be sent if the campaign setting “Ask for mailing address” is enabled, taking into account the amount specified in the campaign settings that triggers the address request.

Required if the campaign is configured to require the supporter to provide their mailing address. Also affected by the minimum amount required.

To remove the address, pass null for supporter.address.

Child parameters

supporter.address.country string

Two-letter country code, lowercase.

supporter.address.region nullable string required for some countries

Up to 64 characters.

Required for all countries except gb (United Kingdom), il (Israel), nl (Netherlands), fr (France), de (Germany). Can be: region, state, or province.

supporter.address.city string

Up to 64 characters.

supporter.address.line1 string

Up to 256 characters.

supporter.address.line2 string

Up to 256 characters.

supporter.address.postal_code string

Up to 10 characters.

supporter.title nullable enum

Supporter’s title, in lowercase. Available options depend on the campaign settings. Available for the following countries:

United Kingdom France Germany Austria Canada (French)
mr m herr herr m
mrs mme frau frau mme
miss mlle prof mlle
ms autre dr autre
mx
sir
dr
rev
dcn
fr
br
sr
prof

supporter.email nullable string

Up to 254 characters.

supporter.employer nullable dictionary

Child parameters

supporter.employer.name string

Up to 64 characters.

comment nullable string

Up to 256 characters.

questions array of dictionaries

Required if there are required questions in the campaign settings.

Erases all previous answers to all questions and sets the answers to the current values.

Child parameters

questions.id string required

Question ID located in Settings > Questions.

questions.text string

Up to 256 characters.

Required for questions with types “Text box,” “Text line,” “Select one option,” or “Dropdown menu.”

questions.options array of strings

Required for questions with the type “Multiple checkboxes.”

questions.checked boolean

Required for questions with the type “Single checkbox.”

designation nullable string

Designation ID located in Settings > Designations.

If a default designation exists in the campaign settings and no value is provided, the default designation will be applied.

custom_fields array of dictionaries

Erases all previous values for all fields and sets the values for the provided keys.

Missing fields will be populated with default non-blank values from the campaign settings.

Child parameters

custom_fields.name string required

Up to 256 characters.

custom_fields.value string required

Up to 256 characters.

Example

1{
2  "campaign": "FUNBRRPPNWQ",
3  "supporter": {
4    "first_name": "John",
5    "last_name": "Doe",
6    "title": "mr",
7    "email": "john.doe@example.com",
8    "phone": "7056789834",
9    "address": {
10      "line1": "Street",
11      "line2": "House",
12      "city": "City",
13      "region": "Region",
14      "postal_code": "100100",
15      "country": "us"
16    },
17    "employer": {
18      "name": "Fundraise Up"
19    }
20  },
21  "comment": "Comment",
22  "designation": "ESTPTE7U",
23  "questions": [
24    {
25      "id": "Q1",
26      "text": "Text"
27    },
28    {
29      "id": "Q2",
30      "options": [
31        "Checkbox 1",
32        "Checkbox 2"
33      ]
34    },
35    {
36      "id": "Q3",
37      "checked": false
38    }
39  ],
40  "custom_fields": [
41    {
42      "name": "a",
43      "value": "A"
44    },
45    {
46      "name": "b",
47      "value": "B"
48    }
49  ]
50}

Response

Returns the donation if the update was successful. If the update parameters are invalid, the call returns an error.

1{
2  "id": "DFQLCFEP",
3  "created_at": "2024-11-10T15:49:12.667Z",
4  "account": {
5    "id": "HRMEIGNS",
6    "code": "911",
7    "name": "Helping Hands"
8  },
9  "livemode": true,
10  "amount": "9.99",
11  "amount_in_default_currency": "9.99",
12  "amount_before_fees_covered": "8.99",
13  "amount_before_fees_covered_in_default_currency": "8.99",
14  "anonymous": false,
15  "campaign": {
16    "id": "FUNUMQTSTYD",
17    "code": "GENERAL",
18    "name": "Campaign Name"
19  },
20  "comment": "Comment",
21  "currency": "usd",
22  "custom_fields": [
23    {
24      "name": "a",
25      "value": "A"
26    },
27    {
28      "name": "b",
29      "value": "B"
30    }
31  ],
32  "device": {
33    "type": "desktop",
34    "browser": null,
35    "os": null,
36    "ip": {
37      "address": "127.0.0.1",
38      "country_name": "Spain",
39      "region": "Catalonia",
40      "city": "Barcelona"
41    }
42  },
43  "element": {
44    "id": "XXCKSMLL",
45    "type": "donation_form",
46    "name": "Element Name"
47  },
48  "designation": [
49    {
50      "id": "EW83VF95",
51      "code": "DESIGNATION",
52      "name": "Designation Name"
53    }
54  ],
55  "status": "refunded",
56  "failed_at": null,
57  "succeeded_at": "2024-11-11T15:49:12.667Z",
58  "refunded_at": "2024-11-11T15:49:12.667Z",
59  "source": "api",
60  "installment": 1,
61  "recurring_plan": {
62    "id": "RVSHJNPJ",
63    "status": "active",
64    "frequency": "monthly"
65  },
66  "on_behalf_of": "Humanity",
67  "payment": {
68    "id": "ch_12345678910abcdefghijk",
69    "credit_card": {
70      "exp_month": "01",
71      "exp_year": "2024",
72      "last4": "1111"
73    },
74    "email": "paypalemail@example.com",
75    "error_message": null,
76    "method": "credit_card",
77    "processor": "stripe"
78  },
79  "payout": {
80    "amount": "1.01",
81    "amount_in_default_currency": "1.01",
82    "currency": "usd"
83  },
84  "platform_fee": {
85    "amount": "1.01",
86    "amount_in_default_currency": "1.01",
87    "currency": "usd"
88  },
89  "processing_fee": {
90    "amount": "1.01",
91    "amount_in_default_currency": "1.01",
92    "currency": "usd"
93  },
94  "supporter": {
95    "id": "SWYRPXNQ",
96    "email": null,
97    "first_name": "John",
98    "last_name": "Doe",
99    "title": null,
100    "phone": null,
101    "employer": {
102      "name": "Fundraise Up"
103    },
104    "address": {
105      "country": "us",
106      "line1": "Street",
107      "line2": "House",
108      "city": "City",
109      "region": "CA",
110      "postal_code": "100100"
111    }
112  },
113  "supporter_covered_fee": "1.01",
114  "tribute": {
115    "type": "in_honor",
116    "honoree": "Fundraise Up",
117    "from": "Grateful supporter",
118    "message": "All the best!",
119    "sharing": {
120      "type": "address",
121      "recipient": {
122        "address": {
123          "country": "us",
124          "line1": "Street",
125          "line2": "House",
126          "city": "City",
127          "region": "Region",
128          "postal_code": "100100"
129        },
130        "title": "mr",
131        "first_name": "John",
132        "last_name": "Doe"
133      }
134    }
135  },
136  "fundraiser": {
137    "id": "FUNUMQTSTYD",
138    "name": "Awesome Fundraiser"
139  },
140  "questions": [
141    {
142      "id": "Q1",
143      "code": "CODE1",
144      "checked": true
145    },
146    {
147      "id": "Q2",
148      "code": "CODE2",
149      "text": "answer"
150    },
151    {
152      "id": "Q3",
153      "code": "CODE3",
154      "options": [
155        "answer1",
156        "answer2"
157      ]
158    }
159  ],
160  "utm": {
161    "source": "web",
162    "campaign": "summer",
163    "medium": "email",
164    "content": null,
165    "term": null
166  },
167  "url": "https://fundraiseup.com"
168}

Read donations

 
Link copied

Endpoints:

  • GET /v1/donations
  • GET /v1/donations/:id

These requests let you access donation records in your Fundraise Up account. Note that we do not support webhooks.

The supporter data will be displayed as it appears on the Donation page in your Dashboard.

Attributes

id string

Unique identifier for the object.

created_at timestamp

The time at which the object was created.

comment nullable string

account dictionary

Organization that created the donation.

Child attributes

account.id string

Unique organization ID.

account.code nullable string

Organization code.

account.name string

Organization name.

anonymous boolean

Anonymous donation.

livemode boolean

Test mode indicator. true for live mode donations, false for test mode donations.

status enum

Can be: succeeded, scheduled, pending, retrying, refunded, or failed.

amount string

Amount in donation’s currency.

amount_in_default_currency string

Amount in the organization’s default currency at the time of the donation.

amount_before_fees_covered string

Amount before fees covered by supporter.

amount_before_fees_covered_in_default_currency string

Amount before fees covered by supporter in organization’s default currency at the time of the donation.

campaign dictionary

Campaign to which the donation belongs.

Child attributes

campaign.id string

Unique campaign identifier.

campaign.code nullable string

campaign.name string

designation nullable dictionary

Designation to which the donation belongs.

Child attributes

designation.id string

Unique designation identifier.

designation.code nullable string

designation.name nullable string

element nullable dictionary

Element through which the donation was made.

Child attributes

element.id string

Unique element identifier.

element.type enum

element.name string

currency enum

Three-letter ISO currency code, lowercase.

custom_fields array of dictionaries

Populated custom fields listed in the campaign settings.

Child attributes

custom_fields.name string

custom_fields.value string

device dictionary

Device details.

Child attributes

device.type nullable enum

Can be: desktop, mobile, tablet, or null.

device.browser nullable string

device.os nullable string

device.ip dictionary

Child attributes

device.ip.address nullable string

device.ip.country_name nullable string

device.ip.region nullable string

device.ip.city nullable string

installment nullable string

null for one-time donations. 1+ for donations with recurring plan.

recurring_plan nullable dictionary

Recurring plan attributes, if any.

Child attributes

recurring_plan.id string

Unique recurring identifier.

recurring_plan.status enum

Can be: active, scheduled, paused, retrying, completed, failed, or canceled

recurring_plan.frequency enum

Can be: daily, weekly, biweekly, every4weeks, monthly, bimonthly, quarterly, semiannual, or annual.

refunded_at nullable timestamp

The time at which the donation was refunded.

succeeded_at nullable timestamp

The time at which the donation succeeded.

failed_at nullable timestamp

The time at which the donation failed.

fundraiser nullable dictionary

Fundraiser, if any.

Child attributes

fundraiser.id string

Unique fundraiser ID.

fundraiser.name string

on_behalf_of nullable string

payment dictionary

Child attributes

payment.id nullable string

For PayPal: Capture ID.

For Stripe: Charge ID or Payment Intent ID.

For other processors: payment ID.

payment.email nullable string

Email from payment method. Example: PayPal email.

payment.credit_card nullable dictionary

Credit card details.

Child attributes

payment.credit_card.exp_month nullable string

Two-symbol string. Examples: 01, 12.

payment.credit_card.exp_year nullable string

Four-symbol string. Example: 2024.

payment.credit_card.last4 nullable string

Last four digits of the credit card number.

payment.credit_card.type nullable string

The type of credit card used for the payment.

error_message nullable string

Returns the latest payment error message only if the status is failed or retrying. Otherwise, returns null.

method enum

Payment method, in lowercase underscore. Examples: ach, apple_pay, google_pay, click_to_pay, paypal, venmo, becs_direct_debit, bacs_direct_debit, credit_card, pad, sepa_direct_debit, ideal, crypto, stock.

processor enum

Payment processor, in lowercase. Examples: stripe, paypal, gemini, manual_brokerage, coinbase_commerce (deprecated).

payout dictionary

Payout details.

Child attributes

payout.amount string

Amount in donation’s currency.

payout.amount_in_default_currency string

Amount in organization’s default currency, at donation time.

payout.currency enum

Three-letter ISO currency code, lowercase.

platform_fee dictionary

Fundraise Up fee details.

Child attributes

platform_fee.amount string

Amount in donation’s currency.

platform_fee.amount_in_default_currency string

Amount in organization’s default currency, at donation time.

platform_fee.currency enum

Three-letter ISO currency code, lowercase.

processing_fee dictionary

Child attributes

processing_fee.amount string

Amount in donation’s currency.

processing_fee.amount_in_default_currency string

Amount in organization’s default currency, at the time of the donation.

processing_fee.currency enum

Three-letter ISO currency code, lowercase.

receipt_id string

Unique identifier for donation receipt.

supporter dictionary

Supporter data, as it displayed on the Donation page in your Dashboard.

Child attributes

supporter.id string

Unique supporter ID.

supporter.email nullable string

supporter.first_name nullable string

supporter.last_name nullable string

supporter.title nullable enum

Returns null if the title is empty. Title options include values like mr, mrs, etc.

supporter.phone nullable string

supporter.employer nullable dictionary

Child attributes

supporter.employer.name string

supporter.address nullable dictionary

Mailing address.

Child attributes

supporter.address.country enum

Two-letter country code, lowercase.

supporter.address.region nullable string

Can refer to a region, state, or province.

supporter.address.city nullable string

supporter.address.line1 nullable string

supporter.address.line2 nullable string

supporter.address.postal_code nullable string

Postal/ZIP code.

supporter.language string

Supporter’s locale. Can be: ar, da, de, en-CA, en-GB, en-US, es, es-US, fi, fr-CA, fr-FR, hu, it, ja, ko, nl, no, pl, pt-BR, pt-PT, ru, sv, zh-CN, zh-TW.

supporter_covered_fee string

Fees covered by supporter. Decimal string.

source enum

Donation source.

Can be: website, campaign_page, virtual_terminal, recurring_migration, api.

tribute nullable dictionary

Child attributes

tribute.id string

tribute.type nullable enum

Can be: in_honor or in_memory.

tribute.honoree string

tribute.sharing nullable dictionary

Sharing options.

Child attributes

tribute.sharing.type enum

Sharing destination field name.

Can be: email or address

tribute.sharing.from string

tribute.sharing.message nullable string

tribute.sharing.recipient dictionary

Child attributes

tribute.sharing.recipient.email nullable string

Email address for the email sharing type.

tribute.sharing.recipient.address nullable dictionary

Postal address for the address sharing type.

Child attributes

tribute.sharing.recipient.address.country enum

Two-letter country code, lowercase.

tribute.sharing.recipient.address.region nullable string

Region/state/province.

tribute.sharing.recipient.address.city string

tribute.sharing.recipient.address.line1 string

tribute.sharing.recipient.address.line2 nullable string

tribute.sharing.recipient.address.postal_code nullable string

Postal/ZIP code.

tribute.sharing.recipient.title nullable enum

tribute.sharing.recipient.first_name string

tribute.sharing.recipient.last_name string

utm dictionary

UTM tags.

Child attributes

utm.source nullable string

utm.campaign nullable string

utm.content nullable string

utm.medium nullable string

utm.term nullable string

url nullable string

URL, from which the donation was made.

questions array of dictionaries

Child attributes

questions.question dictionary

The object contains the fields id, code, and one of the following fields: text, options, or checked, depending on the question type.

Child attributes

questions.question.id string

Unique question identifier.

questions.question.code nullable string

questions.question.text string

Up to 256 characters.

Answer for the question. This field is returned only for question types “Text box,” “Text line,” “Select one option,” and “Dropdown menu.”

questions.question.options array of strings

Selected options. This field is returned only for question types “Multiple checkboxes.”

questions.question.checked boolean

Checkbox state. This field is returned for question types “Single checkbox.”

gift_aid nullable dictionary

An optional dictionary containing details about Gift Aid. This field is available only for organizations based in Great Britain.

Child attributes

gift_aid.claimed boolean

Indicates whether the Gift Aid has been claimed (true) or not (false).

gift_aid.legal_text string

The legal text associated with Gift Aid.

consent dictionary

Stores the supporter’s communication consent type associated with a donation.

Child attributes

consent.general enum

Reflects overall communication consent.

'opted_in' if the supporter has agreed to receive communications.

'opted_out' if the supporter has declined communications.

'not_submitted' if no consent data is available.

consent.customized dictionary

Specifies consent values for individual communication channels.

Child attributes

consent.customized.email enum

'opted_in' if the supporter has agreed to email communication.

'opted_out' if the supporter has declined email communication.

'not_submitted' if no email consent data is available.

consent.customized.phone_calls enum

'opted_in' if the supporter has agreed to phone call communication.

'opted_out' if the supporter has declined phone call communication.

'not_submitted' if no phone call consent data is available.

consent.customized.sms enum

'opted_in' if the supporter has agreed to SMS communication.

'opted_out' if the supporter has declined SMS communication.

'not_submitted' if no SMS consent data is available.

consent.customized.postal_mail enum

'opted_in' if the supporter has agreed to postal mail communication.

'opted_out' if the supporter has declined postal mail communication.

'not_submitted' if no postal mail consent data is available.

consent.customized.social_media enum

'opted_in' if the supporter has agreed to social media communication.

'opted_out' if the supporter has declined social media communication.

'not_submitted' if no social media consent data is available.

Example

1{
2  "id": "DFQLCFEP",
3  "created_at": "2024-11-10T15:49:12.667Z",
4  "account": {
5    "id": "HRMEIGNS",
6    "code": "911",
7    "name": "Helping Hands"
8  },
9  "livemode": true,
10  "amount": "9.99",
11  "amount_in_default_currency": "9.99",
12  "amount_before_fees_covered": "8.99",
13  "amount_before_fees_covered_in_default_currency": "8.99",
14  "anonymous": false,
15  "campaign": {
16    "id": "FUNUMQTSTYD",
17    "code": "GENERAL",
18    "name": "Campaign Name"
19  },
20  "comment": "Comment",
21  "currency": "usd",
22  "custom_fields": [
23    {
24      "name": "a",
25      "value": "A"
26    },
27    {
28      "name": "b",
29      "value": "B"
30    }
31  ],
32  "device": {
33    "type": "desktop",
34    "browser": null,
35    "os": null,
36    "ip": {
37      "address": "127.0.0.1",
38      "country_name": "Spain",
39      "region": "Catalonia",
40      "city": "Barcelona"
41    }
42  },
43  "element": {
44    "id": "XXCKSMLL",
45    "type": "donation_form",
46    "name": "Element Name"
47  },
48  "designation": [
49    {
50      "id": "EW83VF95",
51      "code": "DESIGNATION",
52      "name": "Designation Name"
53    }
54  ],
55  "status": "refunded",
56  "failed_at": null,
57  "succeeded_at": "2024-11-11T15:49:12.667Z",
58  "refunded_at": "2024-11-11T15:49:12.667Z",
59  "source": "api",
60  "installment": 1,
61  "recurring_plan": {
62    "id": "RVSHJNPJ",
63    "status": "active",
64    "frequency": "monthly"
65  },
66  "on_behalf_of": "Humanity",
67  "payment": {
68    "id": "ch_12345678910abcdefghijk",
69    "credit_card": {
70      "exp_month": "01",
71      "exp_year": "2024",
72      "last4": "1111",
73      "type": "Visa"
74    },
75    "email": "paypalemail@example.com",
76    "error_message": null,
77    "method": "credit_card",
78    "processor": "stripe"
79  },
80  "payout": {
81    "amount": "1.01",
82    "amount_in_default_currency": "1.01",
83    "currency": "usd"
84  },
85  "platform_fee": {
86    "amount": "1.01",
87    "amount_in_default_currency": "1.01",
88    "currency": "usd"
89  },
90  "receipt_id": "string",
91  "processing_fee": {
92    "amount": "1.01",
93    "amount_in_default_currency": "1.01",
94    "currency": "usd"
95  },
96  "supporter": {
97    "id": "SWYRPXNQ",
98    "email": null,
99    "first_name": "John",
100    "last_name": "Doe",
101    "title": null,
102    "phone": null,
103    "employer": {
104      "name": "Fundraise Up"
105    },
106   "address": {
107      "country": "us",
108      "line1": "Street",
109      "line2": "House",
110      "city": "City",
111      "region": "CA",
112      "postal_code": "100100"
113    }
114  },
115  "language": "en-CA",
116  "supporter_covered_fee": "1.01",
117  "tribute": {
118    "type": "in_honor",
119    "honoree": "Fundraise Up",
120    "from": "Grateful supporter",
121    "message": "All the best!",
122    "sharing": {
123      "type": "address",
124      "recipient": {
125        "address": {
126          "country": "us",
127          "line1": "Street",
128          "line2": "House",
129          "city": "City",
130          "region": "Region",
131          "postal_code": "100100"
132        },
133        "title": "mr",
134        "first_name": "John",
135        "last_name": "Doe"
136      }
137    }
138  },
139  "fundraiser": {
140    "id": "FUNUMQTSTYD",
141    "name": "Awesome Fundraiser"
142  },
143  "questions": [
144    {
145      "id": "Q1",
146      "code": "CODE1",
147      "checked": true
148    },
149    {
150      "id": "Q2",
151      "code": "CODE2",
152      "text": "answer"
153    },
154    {
155      "id": "Q3",
156      "code": "CODE3",
157      "options": [
158        "answer1",
159        "answer2"
160      ]
161    }
162  ],
163  "utm": {
164    "source": "web",
165    "campaign": "summer",
166    "medium": "email",
167    "content": null,
168    "term": null
169  },
170  "url": "https://fundraiseup.com",
171  "gift_aid": {
172    "claimed": true,
173    "legal_text": "string"
174  },
175"consent": {
176    "customized": {
177      "email": "opted_in",
178      "phone_calls": "opted_out",
179      "sms": "opted_out",
180      "postal_mail": "not_submitted",
181      "social_media": "not_submitted"
182    }
183  }
184}

Recurring plans

 
Link copied

Endpoints:

  • GET /v1/recurring_plans
  • GET /v1/recurring_plans/:id

These requests allow you to read your Fundraise Up recurring plan records. The supporter data will be displayed as it appears on the Recurring plan page in your Dashboard.

Attributes

id string

Unique recurring plan ID.

created_at timestamp

The time at which the object was created.

anonymous boolean

amount string

Amount in donation’s currency.

currency enum

Three-letter ISO currency code, lowercase.

amount_in_default_currency string

Amount in organization’s default currency, at the time of the donation.

amount_before_fees_covered string

Amount before fees covered by supporter.

amount_before_fees_covered_in_default_currency string

Amount before fees covered by supporter in organization’s default currency, at the time of the donation.

supporter_covered_fee string

Fees covered by supporter. Decimal string.

livemode boolean

Test mode indicator. true for live mode donations, false for test mode donations.

account dictionary

Organization that created the donation.

Child attributes

account.id string

Unique organization ID.

account.code nullable string

Organization code.

account.name string

Organization name.

campaign dictionary

Campaign to which the donation belongs.

Child attributes

campaign.id string

Unique campaign ID.

campaign.code nullable string

campaign.name string

designation nullable dictionary

Designation to which the donation belongs.

Child attributes

designation.id string

Unique designation identifier.

designation.code nullable string

designation.name nullable string

element nullable dictionary

Element through which the donation was made.

Child attributes

element.id string

Unique element ID.

element.type enum

element.name string

comment nullable string

custom_fields array of dictionaries

Populated custom fields listed in the campaign settings.

Child parameters

custom_fields.name string

custom_fields.value string

device dictionary

Device details.

Child attributes

device.ip dictionary

Child attributes

device.ip.address nullable string

device.ip.country_name nullable string

device.ip.region nullable string

device.ip.city nullable string

fundraiser nullable dictionary

Fundraiser, if any.

Child attributes

fundraiser.id string

Unique fundraiser ID.

fundraiser.name string

questions array of dictionaries

Child attributes

questions.question dictionary

The object contains the fields id, code, and one of the following fields: text, options, or checked, depending on the question type.

Child attributes

questions.question.id string

Unique question identifier.

questions.question.code nullable string

questions.question.text string

Up to 256 characters.

Answer for the question. This field is returned only for question types “Text box,” “Text line,” “Select one option,” and “Dropdown menu.”

questions.question.options array of strings

Selected options. This field is returned only for question types “Multiple checkboxes.”

questions.question.checked boolean

Checkbox state. This field is returned for question types “Single checkbox.”

status enum

Can be: active, scheduled, paused, retrying, completed, failed, or canceled.

source enum

Donation source.

Can be: website, campaign_page, virtual_terminal, recurring_migration, api.

tribute nullable dictionary

Child attributes

tribute.id string

tribute.type nullable enum

Can be: in_honor or in_memory.

tribute.honoree string

tribute.sharing nullable dictionary

Sharing options.

Child attributes

tribute.sharing.type enum

Sharing destination field name.

Can be: email or address.

tribute.sharing.from string

tribute.sharing.message nullable string

tribute.sharing.recipient dictionary

Child attributes

tribute.sharing.recipient.email nullable string

Email address for the email sharing type.

tribute.sharing.recipient.address nullable dictionary

Postal address for the address sharing type.

Child attributes

tribute.sharing.recipient.address.country enum

Two-letter country code, lowercase.

tribute.sharing.recipient.address.region nullable string

Region/state/province.

tribute.sharing.recipient.address.city string

tribute.sharing.recipient.address.line1 string

tribute.sharing.recipient.address.line2 nullable string

tribute.sharing.recipient.address.postal_code nullable string

Postal/ZIP code.

tribute.sharing.recipient.title nullable enum

tribute.sharing.recipient.first_name string

tribute.sharing.recipient.last_name string

ended_at nullable timestamp

Date on which the recurring plan ended.

next_installment_at nullable timestamp

Timestamp of the next installment.

on_behalf_of nullable string

frequency enum

Can be: daily, weekly, biweekly, every4weeks, monthly, bimonthly, quarterly, semiannual, or annual.

payment dictionary

Child attributes

payment.email nullable string

Email from payment method. Example: PayPal email.

payment.credit_card nullable dictionary

Credit card details.

Child attributes

payment.credit_card.exp_month nullable string

Two-symbol string. Examples: 01, 12.

payment.credit_card.exp_year nullable string

Four-symbol string. Example: 2024.

payment.credit_card.last4 nullable string

Last four digits of the credit card number.

payment.credit_card.type nullable string

The type of credit card used for the payment.

payment.error_message nullable string

Returns the latest payment error message only if the status is failed or retrying. Otherwise, returns null.

payment.method enum

Payment method, in lowercase underscore. Examples: ach, plaid, apple_pay, google_pay, click_to_pay, paypal, venmo, becs_direct_debit, bacs_direct_debit, credit_card, pad, sepa_direct_debit, ideal, crypto, stock.

The value of us_bank_account maps to ach. The value of plaid also maps to ach.

payment.processor enum

Payment processor, in lowercase. Examples: stripe, paypal, gemini, manual_brokerage, coinbase_commerce (deprecated).

supporter dictionary

Supporter data, as it displayed on the Recurring plan in your Dashboard.

Child attributes

supporter.id string

Unique supporter ID.

supporter.email nullable string

supporter.first_name nullable string

supporter.last_name nullable string

supporter.title nullable enum

Returns null if the title is empty. Title options include values like mr, mrs, etc.

supporter.phone nullable string

supporter.employer nullable dictionary

Child attributes

supporter.employer.name string

supporter.address nullable dictionary

Mailing address.

Child attributes

supporter.address.country enum

Two-letter country code, lowercase.

supporter.address.region nullable string

Can refer to a region, state, or province.

supporter.address.city string

supporter.address.line1 string

supporter.address.line2 nullable string

supporter.address.postal string

Postal/ZIP code.

supporter.language string

Supporter’s locale. Can be: ar, da, de, en-CA, en-GB, en-US, es, es-US, fi, fr-CA, fr-FR, hu, it, ja, ko, nl, no, pl, pt-BR, pt-PT, ru, sv, zh-CN, zh-TW.

url nullable string

URL, from which the donation was made.

utm dictionary

UTM tags.

Child attributes

utm.source nullable string

utm.campaign nullable string

utm.content nullable string

utm.medium nullable string

utm.term nullable string

gift_aid nullable dictionary

An optional dictionary containing details about Gift Aid. This field is available only for organizations based in Great Britain.

Child attributes

gift_aid.claimed boolean

Indicates whether the Gift Aid has been claimed (true) or not (false).

gift_aid.legal_text string

The legal text associated with Gift Aid.

consent dictionary

Stores the supporter’s communication consent type associated with a recurring plan.

Child attributes

consent.general enum

Reflects overall communication consent.

'opted_in' if the supporter has agreed to receive communications.

'opted_out' if the supporter has declined communications.

'not_submitted' if no consent data is available.

consent.customized dictionary

Specifies consent values for individual communication channels.

Child attributes

consent.customized.email enum

'opted_in' if the supporter has agreed to email communication.

'opted_out' if the supporter has declined email communication.

'not_submitted' if no email consent data is available.

consent.customized.phone_calls enum

'opted_in' if the supporter has agreed to phone call communication.

'opted_out' if the supporter has declined phone call communication.

'not_submitted' if no phone call consent data is available.

consent.customized.sms enum

'opted_in' if the supporter has agreed to SMS communication.

'opted_out' if the supporter has declined SMS communication.

'not_submitted' if no SMS consent data is available.

consent.customized.postal_mail enum

'opted_in' if the supporter has agreed to postal mail communication.

'opted_out' if the supporter has declined postal mail communication.

'not_submitted' if no postal mail consent data is available.

consent.customized.social_media enum

'opted_in' if the supporter has agreed to social media communication.

'opted_out' if the supporter has declined social media communication.

'not_submitted' if no social media consent data is available.

Example

1{
2  "id": "RVSHJNPJ",
3  "created_at": "2024-11-10T15:49:12.667Z",
4  "account": {
5    "id": "HRMEIGNS",
6    "code": "911",
7    "name": "Helping Hands"
8  },
9  "amount": "9.99",
10  "amount_in_default_currency": "9.99",
11  "amount_before_fees_covered": "8.99",
12  "amount_before_fees_covered_in_default_currency": "8.99",
13  "livemode": true,
14  "currency": "usd",
15  "comment": "comment",
16  "campaign": {
17    "id": "FUNUMQTSTYD",
18    "code": "GENERAL",
19    "name": "Campaign Name"
20  },
21  "ended_at": "2024-12-10T15:49:12.667Z",
22  "frequency": "monthly",
23  "element": {
24    "id": "XXCKSMLL",
25    "type": "donation_form",
26    "name": "Element Name"
27  },
28  "next_installment_at": "2024-11-10T15:49:12.667Z",
29  "designation": [
30    {
31      "id": "EW83VF95",
32      "code": "DESIGNATION",
33      "name": "Designation Name"
34    }
35  ],
36  "device": {
37    "ip": {
38      "address": "127.0.0.1",
39      "country_name": "Spain",
40      "region": "Catalonia",
41      "city": "Barcelona"
42    }
43  },
44  "on_behalf_of": "Humanity",
45  "payment": {
46    "credit_card": {
47      "exp_month": "01",
48      "exp_year": "2024",
49      "last4": "1111",
50      "type": "Visa"
51    },
52    "email": "paypalemail@example.com",
53    "error_message": null,
54    "method": "credit_card",
55    "processor": "stripe"
56  },
57  "status": "active",
58  "supporter": {
59    "id": "SBSWERQY",
60    "created_at": "2024-11-10T15:49:12.667Z",
61    "email": null,
62    "first_name": "John",
63    "last_name": "Doe",
64    "title": null,
65    "phone": null,
66    "employer": {
67      "name": "Fundraise Up"
68    },
69   "address": {
70      "country": "us",
71      "line1": "Street",
72      "line2": "House",
73      "city": "City",
74      "region": "CA",
75      "postal_code": "100100"
76    }
77  },
78  "language": "en-CA",
79  "tribute": {
80    "type": "in_memory",
81    "honoree": "Fundraise Up",
82    "sharing": {
83      "type": "address",
84      "address": {
85        "country": "us",
86        "line1": "Street",
87        "line2": "House",
88        "city": "City",
89        "region": "CA",
90        "postal_code": "100100"
91      }
92    }
93  },
94  "fundraiser": {
95    "id": "FUNUMQTSTYD",
96    "name": "Awesome Fundraiser"
97  },
98  "source": "checkout",
99  "supporter_covered_fee": "1.01",
100  "utm": {
101    "source": "web",
102    "campaign": "summer",
103    "medium": "email",
104    "content": null,
105    "term": null
106  },
107  "questions": [
108    {
109      "id": "Q1",
110      "text": "Text"
111    },
112    {
113      "id": "Q2",
114      "options": [
115        "Checkbox 1",
116        "Checkbox 2"
117      ]
118    },
119    {
120      "id": "Q3",
121      "checked": false
122    }
123  ],
124  "custom_fields": [
125    {
126      "name": "a",
127      "value": "A"
128    },
129    {
130      "name": "b",
131      "value": "B"
132    }
133  ],
134  "url": "https://fundraiseup.com",
135  "gift_aid": {
136    "claimed": true,
137    "legal_text": "string"
138  },
139"consent": {
140    "customized": {
141      "email": "opted_in",
142      "phone_calls": "opted_out",
143      "sms": "opted_out",
144      "postal_mail": "not_submitted",
145      "social_media": "not_submitted"
146    }
147  }
148}

Supporters

 
Link copied

Endpoints:

  • GET /v1/supporters
  • GET /v1/supporters/:id

These requests allow you to read the supporter records in your Fundraise Up account, as shown on the Supporter page in your Dashboard.

Attributes

id string

Unique supporter ID.

created_at timestamp

The time at which the object was created.

account dictionary

Organization that created the supporter.

Child attributes

account.id string

Unique organization ID.

account.code nullable string

Organization code.

account.name string

Organization name.

livemode boolean

Test mode indicator. true for live mode donations, false for test mode donations.

email nullable string

first_name nullable string

last_name nullable string

title nullable enum

phone nullable string

employer nullable dictionary

Child attributes

employer.name string

address nullable dictionary

Mailing address.

Child attributes

address.country string

Two-letter country code, lowercase.

address.region nullable string

Can refer to a region, state, or province.

address.city string

address.line1 string

address.line2 nullable string

address.postal_code string

Postal/ZIP code.

language string

Supporter’s locale. Can be: ar, da, de, en-CA, en-GB, en-US, es, es-US, fi, fr-CA, fr-FR, hu, it, ja, ko, nl, no, pl, pt-BR, pt-PT, ru, sv, zh-CN, zh-TW.

Example

1{
2  "id": "SWFGMTJA",
3  "created_at": "2024-11-10T15:49:12.667Z",
4  "account": {
5    "id": "HRMEIGNS",
6    "code": "911",
7    "name": "Helping Hands"
8  },
9  "livemode": true,
10  "email": null,
11  "first_name": "John",
12  "last_name": "Doe",
13  "title": null,
14  "phone": null,
15  "employer": {
16    "name": "Fundraise Up"
17  },
18  "address": {
19    "country": "us",
20    "line1": "Street",
21    "line2": "House",
22    "city": "City",
23    "region": "CA",
24    "postal_code": "100100"
25  },
26  "language": "en-CA"
27}

Events

 
Link copied

Endpoint: GET /v1/events

This request allows you to read the events from your Audit Log, helping you monitor changes in your account.

Parameters

types array of strings

An array of up to 10 strings containing specific event types (see below for available types). The list will be filtered to include only events with a matching event type property. Passing more than 10 values will result in an error.

Attributes

id string

Unique ID for the event.

created_at timestamp

Time at which the object was created.

account dictionary

Organization that created the donation.

Child attributes

account.id string

Unique organization identifier.

account.code nullable string

Organization code.

account.name string

Organization name.

livemode boolean

Test mode indicator. true for live mode donations, false for test mode donations.

type enum

Event types
Event Type Explanation
donation.created Donation created
donation.success Donation successful
donation.pending Donation pending
donation.failed Donation failed
donation.updated Donation updated
donation.refunded Donation refunded
donation.success_early_fraud_warning Donation early fraud warning
donation.pending_ach_verification_required Donation pending (verification required)
donation.pending_incomplete Donation pending (waiting for the payment provider's response)
donation.pending_scheduled Donation scheduled
donation.pending_waiting_for_transfer Donation pending (waiting for transfer)
donation.pending_paypal_action_required Donation pending (PayPal action required)
donation.pending_retrying Donation retrying
donation.personal_data_deleted Donation personal information deleted
donation.success_dispute_created Donation dispute created
donation.success_dispute_lost Donation dispute lost
donation.success_dispute_won Donation dispute won
donation.success_dispute_in_review Donation dispute in review
recurring_plan.activated Recurring plan activated
recurring_plan.scheduled Recurring plan scheduled
recurring_plan.failed Recurring plan failed
recurring_plan.completed Recurring plan completed
recurring_plan.canceled Recurring plan canceled
recurring_plan.terms_updated Recurring plan payment terms updated
recurring_plan.paused Recurring plan paused
recurring_plan.retrying Recurring plan retrying
recurring_plan.details_updated Recurring plan supporter preferences updated
recurring_plan.personal_data_deleted Recurring plan personal information deleted
supporter.created Supporter created
supporter.personal_data_deleted Supporter details deleted
supporter.updated Supporter updated
transaction_attempt.pending Transaction attempt pending
transaction_attempt.success Transaction attempt successful
transaction_attempt.failed Transaction attempt failed
tribute.created Tribute created
tribute.updated Tribute updated
tribute.shared Tribute card sent

donation nullable string

Unique ID of the related donation. Example event: donation.created.

recurring_plan nullable string

Unique ID of the related recurring plan. Example event: recurring_plan.created.

supporter nullable string

Unique ID of the related supporter. Example event: donation.personal_data_deleted.

Example

1{
2  "id": "66911bb67616b5001045cc6b",
3  "created_at": "2023-11-10T15:49:12.667Z",
4  "account": {
5    "id": "HRMEIGNS",
6    "code": "911",
7    "name": "Helping Hands"
8  },
9  "livemode": true,
10  "type": "donation.created",
11  "donation": "DVTZLHEF",
12  "recurring_plan": null,
13  "supporter": "SWYRPXNQ"
14}

Response

1{
2	"url": "https://ropsi.org/login/?auth=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJkYXRhIjp7ImlkIjoiNjRiMGJhOWQ5YTE5ZWEwMDFmYTM1MTZhIiwiaWRlbXBvdGVuY3lLZXkiOiIwMDg0YzJkZGZhMGNhZGJhODAwOWI2M2M0MTVhZWZhOGQ0YWYxMjJjZjg3ZmE3ODNmN2ZlNWE5YmVjMzQxNGQzIiwicGF0aCI6Ii9yZWN1cnJpbmdzL1JWRUJXSkJMIn0sImlhdCI6MTcyOTA4MTg2M30.7QTIc9Qvbql642MMvsnrAgVLG3Bj77bCY4yirPAUNXU"
3}

Parameter

back_url string optional

Must be a valid URL starting with http:// or https://. If invalid, returns 400 Bad Request error.

If provided, this URL will appear as the “← Back to home” link in the Fundraise Up Donor Portal. The supporter can click this link or the portal logo to return to your organization's portal.

If not provided, the “← Back to home“ button will not be displayed and the portal logo will not be clickable.

We recommend including a return URL to provide consistent navigation between portals.

Response

1{
2	"url": "https://ropsi.org/login/?auth=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJkYXRhIjp7ImlkIjoiNjRiMGJhOWQ5YTE5ZWEwMDFmYTM1MTZhIiwiaWRlbXBvdGVuY3lLZXkiOiIwMDg0YzJkZGZhMGNhZGJhODAwOWI2M2M0MTVhZWZhOGQ0YWYxMjJjZjg3ZmE3ODNmN2ZlNWE5YmVjMzQxNGQzIiwicGF0aCI6Ii9yZWN1cnJpbmdzL1JWRUJXSkJMIn0sImlhdCI6MTcyOTA4MTg2M30.7QTIc9Qvbql642MMvsnrAgVLG3Bj77bCY4yirPAUNXU"
3}

Parent accounts cannot use their API keys to create Donor Portal access links for subaccounts. To create access links for a subaccount, generate an API key within that specific subaccount and use it.

 

In this article