Перейти к основному содержимому

Эндпоинты Giving

Модуль Giving управляет пожертвованиями, фондами, обработкой платежей, подписками и связанными финансовыми операциями. Он поддерживает несколько платёжных шлюзов (Stripe, PayPal), обрабатывает разовые и периодические пожертвования, отслеживает пакеты пожертвований и обеспечивает обработку вебхуков для асинхронных платёжных событий.

Базовый путь: /giving

Пожертвования

Базовый путь: /giving/donations

МетодПутьАутентификацияРазрешениеОписание
GET/JWTDonations.View или собственный personIdСписок всех пожертвований. Фильтр по ?batchId= или ?personId=
GET/:idJWTDonations.ViewПолучить пожертвование по ID
GET/myJWTПолучить пожертвования текущего пользователя
GET/summaryJWTDonations.ViewSummaryПолучить сводку пожертвований. Фильтр по ?startDate=&endDate=&type=. Используйте type=person для разбивки по людям
GET/testEmailPublicОтправить тестовое письмо (разработка/отладка)
POST/JWTDonations.EditСоздать или обновить пожертвования (пакетно)
DELETE/:idJWTDonations.EditУдалить пожертвование

Пример: Список пожертвований по пакету

GET /giving/donations?batchId=abc-123
Authorization: Bearer <token>
[
{
"id": "don-456",
"batchId": "abc-123",
"personId": "per-789",
"donationDate": "2025-03-15T00:00:00.000Z",
"amount": 100.00,
"method": "card"
}
]

Пример: Получение сводки пожертвований

GET /giving/donations/summary?startDate=2025-01-01&endDate=2025-12-31
Authorization: Bearer <token>
[
{
"week": "2025-01-06",
"fund": "General Fund",
"totalAmount": 2500.00,
"count": 15
}
]

Пакеты пожертвований

Базовый путь: /giving/donationbatches

Наследует GenericCrudController с CRUD-маршрутами: getById, getAll, post, delete. Операция удаления также удаляет все пожертвования в пакете.

МетодПутьАутентификацияРазрешениеОписание
GET/JWTDonations.ViewSummaryСписок всех пакетов пожертвований
GET/:idJWTDonations.ViewSummaryПолучить пакет пожертвований по ID
POST/JWTDonations.EditСоздать или обновить пакеты пожертвований
DELETE/:idJWTDonations.EditУдалить пакет и все его пожертвования

Пожертвование

Базовый путь: /giving/donate

Обрабатывает публичный процесс пожертвования, включая списания, подписки, вебхуки и расчёт комиссий. Базовые CRUD-маршруты не активированы; все эндпоинты пользовательские.

МетодПутьАутентификацияРазрешениеОписание
GET/gateways/:churchIdPublicПолучить доступные платёжные шлюзы для церкви (только публичные ключи)
POST/client-tokenJWTСгенерировать клиентский токен для инициализации шлюза
POST/create-orderJWTСоздать платёжный ордер (процесс оплаты в стиле PayPal)
POST/chargeJWTОбработать разовое списание пожертвования
POST/subscribeJWTСоздать подписку на периодическое пожертвование
POST/logPublicЗаписать пожертвование. Тело: { donation, fundData }
POST/webhook/:providerPublicПолучить событие вебхука платёжной системы (Stripe, PayPal). Требуется ?churchId=
POST/replay-stripe-eventsJWTDonations.EditПовторить события Stripe за период. Тело: { startDate, endDate, dryRun }
POST/feePublicРассчитать комиссию транзакции. Тело: { type, provider, gatewayId, amount, currency }. Требуется ?churchId=
POST/captcha-verifyPublicПроверить токен reCAPTCHA. Тело: { token }

Пример: Обработка пожертвования

POST /giving/donate/charge
Authorization: Bearer <token>

{
"provider": "stripe",
"amount": 50.00,
"currency": "usd",
"person": { "id": "per-123", "email": "donor@example.com" },
"funds": [{ "id": "fund-001", "name": "General Fund", "amount": 50.00 }],
"church": { "name": "First Church", "subDomain": "firstchurch" }
}
{
"id": "ch_abc123",
"status": "succeeded",
"provider": "stripe"
}

Пример: Создание периодической подписки

POST /giving/donate/subscribe
Authorization: Bearer <token>

{
"provider": "stripe",
"amount": 100.00,
"customerId": "cus_abc123",
"interval": { "interval_count": 1, "interval": "month" },
"billing_cycle_anchor": 1710460800,
"person": { "id": "per-123", "email": "donor@example.com" },
"funds": [{ "id": "fund-001", "name": "General Fund", "amount": 100.00 }],
"church": { "name": "First Church", "subDomain": "firstchurch" }
}
{
"id": "sub_xyz789",
"status": "active",
"provider": "stripe"
}

Фонды

Базовый путь: /giving/funds

Наследует GenericCrudController с CRUD-маршрутами: getById, getAll, post, delete. Разрешение view равно null (для просмотра фондов разрешение не требуется).

МетодПутьАутентификацияРазрешениеОписание
GET/JWTСписок всех фондов
GET/:idJWTПолучить фонд по ID
GET/churchId/:churchIdPublicПолучить все фонды для конкретной церкви (публичный)
POST/JWTDonations.EditСоздать или обновить фонды
DELETE/:idJWTDonations.EditУдалить фонд

Пожертвования в фонды

Базовый путь: /giving/funddonations

Отслеживает распределение отдельных пожертвований по фондам. Базовые CRUD-маршруты не активированы; все эндпоинты пользовательские.

МетодПутьАутентификацияРазрешениеОписание
GET/JWTDonations.ViewСписок пожертвований в фонды. Фильтр по ?donationId=, ?personId=, ?fundId= или ?fundName=. Необязательно ?startDate=&endDate= для фильтрации по дате
GET/:idJWTDonations.ViewПолучить пожертвование в фонд по ID
GET/myJWTПолучить пожертвования в фонды текущего пользователя
POST/JWTDonations.EditСоздать или обновить пожертвования в фонды (пакетно)
DELETE/:idJWTDonations.EditУдалить пожертвование в фонд

Шлюзы

Базовый путь: /giving/gateways

Управляет конфигурациями платёжных шлюзов (Stripe, PayPal и др.). Базовые CRUD-маршруты не активированы; все эндпоинты пользовательские. Секреты шлюзов шифруются при хранении.

МетодПутьАутентификацияРазрешениеОписание
GET/JWTСписок всех шлюзов церкви
GET/:idJWTSettings.EditПолучить шлюз по ID
GET/churchId/:churchIdPublicПолучить шлюзы для церкви (только публичные ключи)
GET/configured/:churchIdPublicПроверить, настроен ли платёжный шлюз у церкви
POST/JWTSettings.EditСоздать или обновить шлюзы (шифрует ключи, настраивает вебхуки и продукты)
PATCH/:idJWTSettings.EditЧастично обновить шлюз
DELETE/:idJWTSettings.EditУдалить шлюз (также удаляет его вебхуки)

Пример: Проверка конфигурации шлюза

GET /giving/gateways/configured/church-123
{
"configured": true
}

Клиенты

Базовый путь: /giving/customers

Наследует GenericCrudController с CRUD-маршрутами: getAll, delete. Связывает людей с их записями клиентов в платёжных шлюзах.

МетодПутьАутентификацияРазрешениеОписание
GET/JWTDonations.ViewSummaryСписок всех клиентов
GET/:idJWTDonations.ViewSummary или собственная записьПолучить клиента по ID
GET/:id/subscriptionsJWTDonations.ViewSummary или собственная записьПолучить подписки шлюза для клиента
DELETE/:idJWTDonations.EditУдалить клиента

Подписки

Базовый путь: /giving/subscriptions

Управляет подписками на периодические пожертвования. Базовые CRUD-маршруты не активированы; все эндпоинты пользовательские.

МетодПутьАутентификацияРазрешениеОписание
GET/JWTDonations.ViewSummaryСписок всех подписок
GET/:idJWTDonations.ViewSummaryПолучить подписку по ID
POST/JWTDonations.Edit или собственная подпискаОбновить подписки через платёжный шлюз
DELETE/:idJWTDonations.Edit или собственная подпискаОтменить подписку и удалить из базы данных. Тело: { provider, reason }

Фонды подписок

Базовый путь: /giving/subscriptionfunds

Отслеживает распределение по фондам для периодических подписок. Базовые CRUD-маршруты не активированы; все эндпоинты пользовательские.

МетодПутьАутентификацияРазрешениеОписание
GET/JWTDonations.View или собственная подпискаСписок фондов подписок. Фильтр по ?subscriptionId=
GET/:idJWTDonations.ViewSummaryПолучить фонд подписки по ID
DELETE/:idJWTDonations.EditУдалить фонд подписки
DELETE/subscription/:idJWTDonations.Edit или собственная подпискаУдалить все фонды для подписки

Способы оплаты

Базовый путь: /giving/paymentmethods

Управляет сохранёнными способами оплаты (карты, банковские счета) через API платёжных шлюзов. Базовые CRUD-маршруты не активированы; все эндпоинты пользовательские.

МетодПутьАутентификацияРазрешениеОписание
GET/personid/:idJWTDonations.View или собственный personIdПолучить все сохранённые способы оплаты для человека (карты, банковские счета)
POST/addcardJWTПривязать карточный способ оплаты. Тело: { id, personId, customerId, email, name, churchId, provider }
POST/updatecardJWTDonations.Edit или собственный personIdОбновить данные карты. Тело: { personId, paymentMethodId, cardData, provider }
POST/ach-setup-intentJWTDonations.Edit или собственный personIdСоздать Stripe ACH SetupIntent для привязки банковского счёта. Тело: { personId, customerId, email, name, churchId }
POST/ach-setup-intent-anonPublicСоздать анонимный ACH SetupIntent для гостевых пожертвований. Тело: { email, name, churchId, gatewayId }
POST/addbankaccountJWTDonations.Edit или собственный personIdДобавить банковский счёт через токен (устаревший; используйте ach-setup-intent). Тело: { id, personId, customerId, email, name }
POST/updatebankJWTDonations.Edit или собственный personIdОбновить данные банковского счёта. Тело: { paymentMethodId, personId, bankData, customerId }
POST/verifybankJWTDonations.Edit или собственный клиентПодтвердить банковский счёт микроплатежами. Тело: { paymentMethodId, customerId, amountData }
DELETE/:id/:customeridJWTDonations.Edit или собственный клиентУдалить способ оплаты (карту или банковский счёт)

Журнал событий

Базовый путь: /giving/eventLog

Наследует GenericCrudController с CRUD-маршрутами: getById, getAll, post, delete. Отслеживает события вебхуков платёжных шлюзов для аудита и дедупликации.

МетодПутьАутентификацияРазрешениеОписание
GET/JWTDonations.ViewSummaryСписок всех записей журнала событий
GET/:idJWTDonations.ViewSummaryПолучить запись журнала событий по ID
GET/type/:typeJWTDonations.ViewSummaryПолучить записи журнала событий с фильтром по типу
POST/JWTDonations.EditСоздать или обновить записи журнала событий
DELETE/:idJWTDonations.EditУдалить запись журнала событий

Связанные страницы