public int import_contacts(string filename) { var dialer_configuration = new DialerConfigurationManager(Application.ICSession); var data = new CSVDataSet(filename); var fields = data.Fields; var columns = configuration.GetColumns(); var mapping = new Dictionary <DBColumn, DBColumn>(); foreach (var field in fields) { var column = fields.First(item => string.Compare(item.Name, field.Name) == 0); if (column != null) { mapping.Add(field, column); } } if (mapping.Keys.Count <= 0) { throw new ArgumentException(string.Format("No mapping available between Contact List {0} and CSV filename {1}", DisplayName, filename), filename); } return(configuration.BulkImport(dialer_configuration.GetHttpRequestKey(configuration.ConfigurationId), data, mapping)); }
public int ScheduleCall(string column, string key, Campaign campaign, string agent_id, string site_id, DateTime when) { var dialer_configuration = new DialerConfigurationManager(Application.ICSession); var select = new SelectCommand(configuration); select.Where = new BinaryExpression(new ColumnExpression(configuration.ColumnMap[column]), new ConstantExpression(key, configuration.ColumnMap[column]), BinaryOperationType.Equal); Collection <Dictionary <string, object> > contacts = configuration.GetContacts(dialer_configuration.GetHttpRequestKey(configuration.ConfigurationId), select); var calls = new List <ScheduledCall>(); foreach (var ic_contact in contacts) { calls.Add(new ScheduledCall(ic_contact[ContactListConfiguration.I3_Identity.Name].ToString(), campaign.id, "", agent_id, site_id, when)); } return(configuration.AddScheduledCalls(calls)); }
public int ScheduleCall(string column, string key, Campaign campaign, string agent_id, string site_id, DateTime when) { var dialer_configuration = new DialerConfigurationManager(Application.ICSession); var select = new SelectCommand(configuration); select.Where = new BinaryExpression(new ColumnExpression(configuration.ColumnMap[column]), new ConstantExpression(key, configuration.ColumnMap[column]), BinaryOperationType.Equal); Collection<Dictionary<string, object>> contacts = configuration.GetContacts(dialer_configuration.GetHttpRequestKey(configuration.ConfigurationId), select); var calls = new List<ScheduledCall>(); foreach(var ic_contact in contacts) { calls.Add(new ScheduledCall(ic_contact[ContactListConfiguration.I3_Identity.Name].ToString(), campaign.id, "", agent_id, site_id, when)); } return configuration.AddScheduledCalls(calls); }
public int import_contacts(string filename) { var dialer_configuration = new DialerConfigurationManager(Application.ICSession); var data = new CSVDataSet(filename); var fields = data.Fields; var columns = configuration.GetColumns(); var mapping = new Dictionary<DBColumn, DBColumn>(); foreach(var field in fields) { var column = fields.First(item => string.Compare(item.Name, field.Name) == 0); if (column != null) { mapping.Add(field, column); } } if (mapping.Keys.Count <= 0) throw new ArgumentException(string.Format("No mapping available between Contact List {0} and CSV filename {1}", DisplayName, filename), filename); return configuration.BulkImport(dialer_configuration.GetHttpRequestKey(configuration.ConfigurationId), data, mapping); }