Ejemplo n.º 1
0
 private void Start()
 {
     MigrateFrom1To2();
     MixpanelTracking();
     CheckForMixpanelImplemented();
     Mixpanel.Log($"Mixpanel Component Started");
     StartCoroutine(WaitAndFlush());
 }
Ejemplo n.º 2
0
        private static void DispatchOperations()
        {
            ThreadOperation operation = _ops.Dequeue();

            if (operation == null)
            {
                return;
            }
            Mixpanel.Log($"Dispatching new operation: {operation.GetAction()}");
            Value data = operation.GetWhat();

            switch (operation.GetAction())
            {
            case ThreadOperation.ThreadOperationAction.ENQUEUE_EVENTS:
                MixpanelStorage.TrackPersistentQueue.Enqueue(data);
                break;

            case ThreadOperation.ThreadOperationAction.ENQUEUE_PEOPLE:
                MixpanelStorage.EngagePersistentQueue.Enqueue(data);
                break;

            case ThreadOperation.ThreadOperationAction.FLUSH:
                if (_isBgThreadRunning)
                {
                    IEnumerator trackEnum  = SendData(MixpanelStorage.TrackPersistentQueue, Config.TrackUrl);
                    IEnumerator engageEnum = SendData(MixpanelStorage.EngagePersistentQueue, Config.EngageUrl);
                    while (trackEnum.MoveNext())
                    {
                    }
                    ;
                    while (engageEnum.MoveNext())
                    {
                    }
                    ;
                }
                else
                {
                    Controller.GetInstance().StartCoroutine(SendData(MixpanelStorage.TrackPersistentQueue, Config.TrackUrl));
                    Controller.GetInstance().StartCoroutine(SendData(MixpanelStorage.EngagePersistentQueue, Config.EngageUrl));
                }

                break;

            case ThreadOperation.ThreadOperationAction.CLEAR_QUEUE:
                MixpanelStorage.TrackPersistentQueue.Clear();
                MixpanelStorage.EngagePersistentQueue.Clear();
                break;

            case ThreadOperation.ThreadOperationAction.KILL_THREAD:
                _isBgThreadRunning = false;
                _bgThread.Abort();     // Will throw an exception
                break;

            default:
                break;
            }
        }
Ejemplo n.º 3
0
        /// <summary>
        /// Checks whether Mixpanel is initialized or not. If it is not, every API will be no-op.
        /// </summary>
        public static bool IsInitialized()
        {
            bool initialized = Controller.IsInitialized();

            if (!initialized)
            {
                Mixpanel.Log("Mixpanel is not initialized");
            }
            return(initialized);
        }
Ejemplo n.º 4
0
 private static void InitializeBeforeSceneLoad()
 {
     MixpanelSettings.LoadSettings();
     if (Config.ManualInitialization)
     {
         return;
     }
     Initialize();
     Mixpanel.Log($"Track Queue Depth: {MixpanelStorage.TrackPersistentQueue.CurrentCountOfItemsInQueue}");
     Mixpanel.Log($"Engage Queue Depth: {MixpanelStorage.EngagePersistentQueue.CurrentCountOfItemsInQueue}");
 }
Ejemplo n.º 5
0
        private IEnumerator Start()
        {
            MigrateFrom1To2();
            DontDestroyOnLoad(this);
            //Worker.StartWorkerThread();
            TrackIntegrationEvent();
            Mixpanel.Log($"Mixpanel Component Started");
            while (true)
            {
                yield return(new WaitForSecondsRealtime(Config.FlushInterval));

                DoFlush();
            }
        }
Ejemplo n.º 6
0
        private IEnumerator SendData(MixpanelStorage.FlushType flushType)
        {
            if (_retryTime > DateTime.Now && _retryCount > 0)
            {
                yield break;
            }

            string url   = (flushType == MixpanelStorage.FlushType.EVENTS) ? Config.TrackUrl : Config.EngageUrl;
            Value  batch = MixpanelStorage.DequeueBatchTrackingData(flushType, Config.BatchSize);

            while (batch.Count > 0)
            {
                WWWForm form    = new WWWForm();
                String  payload = batch.ToString();
                form.AddField("data", payload);
                Mixpanel.Log("Sending batch of data: " + payload);
                using (UnityWebRequest request = UnityWebRequest.Post(url, form))
                {
                    yield return(request.SendWebRequest());

                    #if UNITY_2020_1_OR_NEWER
                    if (request.result != UnityWebRequest.Result.Success)
                    #else
                    if (request.isHttpError || request.isNetworkError)
                    #endif
                    {
                        Mixpanel.Log("API request to " + url + "has failed with reason " + request.error);
                        _retryCount += 1;
                        double retryIn = Math.Pow(2, _retryCount - 1) * 60;
                        retryIn    = Math.Min(retryIn, 10 * 60); // limit 10 min
                        _retryTime = DateTime.Now;
                        _retryTime = _retryTime.AddSeconds(retryIn);
                        Mixpanel.Log("Retrying request in " + retryIn + " seconds (retryCount=" + _retryCount + ")");
                        yield break;
                    }
                    else
                    {
                        _retryCount = 0;
                        MixpanelStorage.DeleteBatchTrackingData(batch);
                        batch = MixpanelStorage.DequeueBatchTrackingData(flushType, Config.BatchSize);
                        Mixpanel.Log("Successfully posted to " + url);
                    }
                }
            }
        }
Ejemplo n.º 7
0
        internal static IEnumerator SendData(Queue <Value> queue, string url)
        {
            if (queue.Count == 0)
            {
                yield break;
            }

            int depth      = queue.Count;
            int numBatches = (depth / Config.BatchSize) + (depth % Config.BatchSize != 0 ? 1 : 0);

            for (int i = 0; i < numBatches; i++)
            {
                if (_stopThread)
                {
                    yield break;
                }
                Value batch = Value.Array;
                int   count = 0;
                while (count < Config.BatchSize && queue.Count > 0)
                {
                    Value data = queue.Dequeue();
                    if (data == null)
                    {
                        break;
                    }
                    try {
                        batch.Add(data);
                    }
                    catch (Exception e) {
                        Mixpanel.LogError($"There was an error processing event [{count}] from the internal object pool: " + e);
                    }
                    ++count;
                }
                if (count == 0)
                {
                    yield break;
                }
                string payload = Convert.ToBase64String(Encoding.UTF8.GetBytes(batch.ToString()));
                Mixpanel.Log($"Sending Request - '{url}' with payload '{payload}'");
                bool   successful   = false;
                int    responseCode = -1;
                string response     = null;

                if (_isBgThreadRunning)
                {
                    try
                    {
                        var content         = new StringContent("data=" + payload, Encoding.UTF8, "application/json");
                        var responseRequest = _client.PostAsync(url, content).Result;
                        responseCode = (int)responseRequest.StatusCode;
                        response     = responseRequest.Content.ReadAsStringAsync().Result;
                    }
                    catch (Exception e)
                    {
                        Mixpanel.LogError("There was an error sending the request: " + e);
                    }
                }
                else
                {
                    WWWForm form = new WWWForm();
                    form.AddField("data", payload);
                    UnityWebRequest request = UnityWebRequest.Post(url, form);
                    yield return(request.SendWebRequest());

                    while (!request.isDone)
                    {
                        yield return(new WaitForEndOfFrame());
                    }
                    responseCode = (int)request.responseCode;
                    response     = request.downloadHandler.text;
                }

                Mixpanel.Log($"Response - '{url}' was '{response}'");

                successful = responseCode == (int)HttpStatusCode.OK;

                if (successful)
                {
                    _retryCount = 0;
                }
                else
                {
                    _retryCount += 1;
                    double retryIn = Math.Pow(2, _retryCount) * 60000;
                    retryIn = Math.Min(retryIn, 10 * 60 * 1000);     // limit 10 min
                    Mixpanel.Log("Retrying request in " + retryIn / 1000 + " seconds (retryCount=" + _retryCount + ")");
                    _retryTimer = new System.Threading.Timer((obj) =>
                    {
                        ForceFlushOp();
                        _retryTimer.Dispose();
                    }, null, (int)retryIn, System.Threading.Timeout.Infinite);
                    yield break;
                }
            }
        }
Ejemplo n.º 8
0
 void OnDestroy()
 {
     Mixpanel.Log($"Mixpanel Component Destroyed");
 }
Ejemplo n.º 9
0
 private static void InitializeBeforeSceneLoad()
 {
     GetInstance();
     Mixpanel.Log($"Track Queue Depth: {MixpanelStorage.TrackPersistentQueue.CurrentCountOfItemsInQueue}");
     Mixpanel.Log($"Engage Queue Depth: {MixpanelStorage.EngagePersistentQueue.CurrentCountOfItemsInQueue}");
 }
Ejemplo n.º 10
0
 void OnDestroy()
 {
     Mixpanel.Log($"Mixpanel Component Destroyed");
     //Worker.StopWorkerThread();
 }