Ejemplo n.º 1
0
        public void PollForCallParsing()
        {
            try
            {
                _logger.Info("Entering In Vici Dialer Parsing...");
                var timeOfDay = DateTime.Now;
                if (_isDevEnvironment || (timeOfDay.TimeOfDay < new TimeSpan(1, 0, 0)) || (timeOfDay.TimeOfDay > new TimeSpan(2, 0, 0)))
                {
                    //Check for file

                    var listModel = Get <IEnumerable <ViciDialerCallModel> >(_settings.ViciDialerApiUrl);

                    _logger.Info("Getting data from API.");

                    if (listModel.IsNullOrEmpty())
                    {
                        _logger.Info("No data found to parse.");
                        return;
                    }

                    long orgRoleUserId = 1;

                    var ViciUser = _userLoginRepository.GetByUserName(_settings.ViciDialerUserName);
                    if (ViciUser != null)
                    {
                        var organizationRoleUser = _organizationRoleUserRepository.GetOrganizationRoleUsermodel(ViciUser.Id, (long)Roles.CallCenterRep);
                        if (organizationRoleUser != null)
                        {
                            orgRoleUserId = organizationRoleUser.OrganizationRoleUserId;
                        }
                    }

                    foreach (var model in listModel)
                    {
                        try
                        {
                            _callUploadService.SaveViciDialerCall(model, orgRoleUserId);
                        }
                        catch (Exception ex)
                        {
                            _logger.Error(string.Format("Error for Customer Id: {0}. Message: {2}. \n Stack Trace{3}", model.CustomerId, ex.Message, ex.StackTrace));
                        }
                    }
                }
            }
            catch (Exception ex)
            {
                _logger.Error("Vici Dialer Parsing Exception Message: " + ex.Message + "\n Stack Trace:" + ex.StackTrace);
            }
        }