169 похожих чатов

Добрый вечер! Такой вопрос: нужно сделать регулярные (ежеминутные) платежи. Сейчас

это реализовано так: запись, куда и кому платить, сохраняется в firestore. Есть cron функция (* * * * *), которая каждую минуту пробегается по записям в БД (активным контрактам) и совершает платеж. Проблема в том, что если контракт начался, например в 14:30:59 а закончился в 14:31:01 - то деньги за минуты спишутся, хотя прошла лишь секунда (короче крон запускается ровно в 00 секунд, поэтому будут накладки, кто списалось больше/меньше денег, в зависимости от того, когда добавлена транзакция.)

Как поступить? Можно ли навесить какую-нибудь функцию конкретно на запись в БД, чтобы списывалось ровно столько, сколько нужно?

3 ответов

8 просмотров

Да, можно слушать onCreate https://firebase.google.com/docs/reference/functions/providers_firestore_.documentbuilder.html#oncreate

Игнат-Егоров Автор вопроса

OnCreate это понятно, а дальше то что? SetInterval навесить? Но ведь firebase убьёт такую фоновую функцию. Мне надо, чтобы пока запись есть в базе, каждую минуту с момента добавления списывались деньги. Платежи отменяются только удалением записи из базы

Игнат-Егоров Автор вопроса

После create нужно каждую минуту совершать платёж по api, используя данные, сохранённые create. Это шеринговое приложение, поэтому каждую минуту должна списываться арендная плата. Платёжные данные арендовавшего клиента сохранены в базе

Похожие вопросы

Обсуждают сегодня

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Карта сайта