В лунных APNS, какова логика получения действительных токенов в методе GetFeedBack?

Я пытался выяснить список допустимых токенов для моего приложения Apple, используя библиотеку MoonAPNS. При использовании GetFeedBack() количество полученных токенов резко меняется через несколько минут. В первой попытке это было около 8000. Затем это было 0, в третьей попытке это было 1 и снова это было 0.

Я использую его с действующим сертификатом производства. & Успешно отправили уведомления с использованием того же сертификата на выбранные устройства.

Я не понимаю логику кода и на каком основании он предоставляет полученные токены. Код, загруженный с Moon APNS, показан ниже.

public List<Feedback> GetFeedBack()
{
  try
  {
    var feedbacks = new List<Feedback>();
    Logger.Info("Connecting to feedback service.");

    if (!_conected)
        Connect(_feedbackHost, FeedbackPort, _certificates);

    if (_conected)
    {
        //Set up
        byte[] buffer = new byte[38];
        int recd = 0;
        DateTime minTimestamp = DateTime.Now.AddYears(-1);

        //Get the first feedback
        recd = _apnsStream.Read(buffer, 0, buffer.Length);
        Logger.Info("Feedback response received.");

        if (recd == 0)
            Logger.Info("Feedback response is empty.");

        //Continue while we have results and are not disposing
        while (recd > 0)
        {
            Logger.Info("processing feedback response");
            var fb = new Feedback();

            //Get our seconds since 1970 ?
            byte[] bSeconds = new byte[4];
            byte[] bDeviceToken = new byte[32];

            Array.Copy(buffer, 0, bSeconds, 0, 4);

            //Check endianness
            if (BitConverter.IsLittleEndian)
                Array.Reverse(bSeconds);

            int tSeconds = BitConverter.ToInt32(bSeconds, 0);

            //Add seconds since 1970 to that date, in UTC and then get it locally
            fb.Timestamp = new DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc).AddSeconds(tSeconds).ToLocalTime();


            //Now copy out the device token
            Array.Copy(buffer, 6, bDeviceToken, 0, 32);

            fb.DeviceToken = BitConverter.ToString(bDeviceToken).Replace("-", "").ToLower().Trim();

            //Make sure we have a good feedback tuple
            if (fb.DeviceToken.Length == 64 && fb.Timestamp > minTimestamp)
            {
                //Raise event
                //this.Feedback(this, fb);
                feedbacks.Add(fb);
            }

            //Clear our array to reuse it
            Array.Clear(buffer, 0, buffer.Length);

            //Read the next feedback
            recd = _apnsStream.Read(buffer, 0, buffer.Length);
        }
        //clode the connection here !
        Disconnect();
        if (feedbacks.Count > 0)
            Logger.Info("Total {0} feedbacks received.", feedbacks.Count);
        return feedbacks;
    }
  }
  catch (Exception ex)
  {
    Logger.Error("Error occurred on receiving feed back. - " + ex.Message);
    return null;
  }
  return null;
}

}

1 ответ

Решение

Лично я не использовал Moon APNS, но служба обратной связи APNS работает так, что каждый раз, когда вы вызываете ее, она возвращает неактивные токены с момента последнего обращения в службу обратной связи. И это объясняет шаблон, который вы видите здесь.

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