Удалить документ Firebase через 30 минут

Я хочу удалить некоторые документы в Firebase через 30 минут после создания. Я пытаюсь использовать для этого функции Firebase. Почему-то всегда удаляет документы без проверки дат. Вот мой код. Это работает, но я не понимаю, почему я не могу проверить даты.

exports.scheduledFunction = functions.pubsub.schedule('every 1 minutes').onRun((context) => {
  const now = new Date();
  const queryTime = new Date(now - 30 * 60000);

  const trips = admin.firestore().collection('trips');
  const allTrips = trips.get().then(snapshot => {
    snapshot.forEach(trip => {
      if (trip.data().date < queryTime) {
        admin.firestore().collection('trips').doc(trip.id).delete();
      }
    });
  });

  return allTrips;
});
Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
Четыре эффективных способа центрирования блочных элементов в CSS
Четыре эффективных способа центрирования блочных элементов в CSS
У каждого из нас бывали случаи, когда нам нужно отцентрировать блочный элемент, но мы не знаем, как это сделать. Даже если мы реализуем какой-то...
1
0
24
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Переменная now — это Дата, а не число. Вместо этого попробуйте использовать Date.now() для получения текущей метки времени:

const queryTime = new Date(Date.now() - 30 * 60000);

Затем вы можете использовать предложение where() для получения документов, в которых поле date старше 30 минут, вместо того, чтобы извлекать все документы и отфильтровывать их самостоятельно. Это сократит расходы на чтение, поскольку вы извлекаете только совпадающие документы, а не всю коллекцию.

export const scheduledFunction = functions.pubsub
  .schedule("every 1 minutes")
  .onRun(async (context) => {
    // async fn ^^
    const queryTime = new Date(Date.now() - 30 * 60 * 1000);

    // Alternatively:
    // const queryTime = admin.firestore.Timestamp.fromMillis(Date.now() - 30 * 60 * 1000);

    // Query to fetch documents where date is less than queryTime
    const tripsQuery = admin
      .firestore()
      .collection("trips")
      .where("date", "<", queryTime);

    const allTrips = await tripsQuery.get();
 
    // Mapping an array of delete promises
    await Promise.all(allTrips.docs.map((d) => d.ref.delete()));

    return allTrips;
  });

В качестве альтернативы вы также можете использовать пакетная запись для одновременного удаления до 500 документов.

@ArnavThorat Да, вы можете admin.firestore.Timestamp.fromDate(queryTime), но это не обязательно, iirc.

Dharmaraj 09.04.2022 10:30

Прекрасно работает. Думаю, я сделал несколько очевидных ошибок. Цените свое время

Emre 09.04.2022 11:48

Другие вопросы по теме