Spend & Expense API redesign
We are excited to announce a customer-focused redesign for the Spend & Expense API endpoints. The core of the changes are about further simplifying the /v3/spend/budgets API endpoints. In addition, we have introduced many quality of life updates and simplifications in other Spend & Expense API endpoints.
Our expectations with the redesign are that the terminology and experience will now be closer for customers who are familiar with the web app experience.
Budgets operation updates
New endpoints
| Endpoint | Description | 
|---|---|
| PUT /v3/spend/budgets/{budgetId}/members/bulk | Update a list of budget members in a budget. For more than 5 users, the request will be processed asynchronously. | 
| GET /v3/spend/budgets/{budgetId}/members/{userId} | Get a member in a budget | 
| PUT /v3/spend/budgets/{budgetId}/members/{userId} | Update a member in a budget | 
| DELETE /v3/spend/budgets/{budgetId}/members/{userId} | Delete a member from a budget | 
Deleted endpoints
| Endpoint | 
|---|
| PATCH /v3/spend/budgets/{budgetId}/userAllocations/{userAllocationId} | 
| GET /v3/spend/budgets/{budgetId}/userAllocations/{userAllocationId} | 
| PATCH /v3/spend/budgets/{budgetId}/users | 
General updates
| Change | Description | 
|---|---|
| Renamed | The  | 
| Added | 
 | 
| Removed | The  | 
GET /v3/spend/budgets
| Change | Description | 
|---|---|
| Added | Sorting and filtering operations are now consistent with other BILL v3 API list operations | 
| Removed | The typefield is removed. You can continue filtering with this field. | 
GET /v3/spend/budgets/{budgetId}/members
| Change | Description | 
|---|---|
| Renamed | The GET /v3/spend/budgets/{budgetId}/userAllocationsendpoint is renamed toGET /v3/spend/budgets/{budgetId}/members | 
| Added | Sorting and filtering operations are now consistent with other BILL v3 API list operations | 
| Removed | The retiredfield is removed. You can continue filtering with this field. | 
Cards operation updates
New endpoint
| Endpoint | Description | 
|---|---|
| 
 | Get a JWT token for retrieving a card's PAN (full account number). The JWT token contains all the information required for retrieving details about a virtual card (16-digit PAN, CVV, and expiration date). The JWT token lifespan is 5 minutes. | 
Deleted endpoint
| Endpoint | 
|---|
| GET /v3/spend/cards/getPanToken/{token}(SeeGET /v3/spend/cards/{cardId}/pan-jwt) | 
General updates
| Change | Description | 
|---|---|
| Renamed | The  | 
| Added | The  | 
| Removed | The  | 
GET /v3/spend/cards
| Change | Description | 
|---|---|
| Added | Sorting and filtering operations are now consistent with other BILL v3 API list operations | 
| Removed | The userIdsfield is removed as a body parameter. You can continue filtering with this field. | 
PATCH /v3/spend/cards/{cardId}
| Change | Description | 
|---|---|
| Added | The user allocation update logic is now a part of PATCH /v3/spend/cards/{cardId} | 
Transactions operation updates
General updates
| Change | Description | 
|---|---|
| Renamed | The  | 
| Removed | The  | 
Other updates
All date-time fields are consistent across all BILL v3 API endpoints. For example, deletedAt is renamed to deletedTime.
