abstract class CRM_Import_Parser

Constants

MAX_WARNINGS

Settings

DEFAULT_TIMEOUT

Settings

VALID

Return codes

WARNING

Return codes

ERROR

Return codes

CONFLICT

Return codes

STOP

Return codes

DUPLICATE

Return codes

MULTIPLE_DUPE

Return codes

NO_MATCH

Return codes

UNPARSED_ADDRESS_WARNING

Return codes

MODE_MAPFIELD

Parser modes

MODE_PREVIEW

Parser modes

MODE_SUMMARY

Parser modes

MODE_IMPORT

Parser modes

DUPLICATE_SKIP

Codes for duplicate record handling

DUPLICATE_REPLACE

Codes for duplicate record handling

DUPLICATE_UPDATE

Codes for duplicate record handling

DUPLICATE_FILL

Codes for duplicate record handling

DUPLICATE_NOCHECK

Codes for duplicate record handling

CONTACT_INDIVIDUAL

Contact types

CONTACT_HOUSEHOLD

Contact types

CONTACT_ORGANIZATION

Contact types

Properties

protected int $_totalCount Total number of non empty lines
protected int $_validCount Running total number of valid lines
protected int $_invalidRowCount Running total number of invalid rows
protected int $_maxLinesToProcess Maximum number of non-empty/comment lines to process
protected array $_errors Array of error lines, bounded by MAX_ERROR
protected int $_conflictCount Total number of conflict lines
protected array $_conflicts Array of conflict lines
protected int $_duplicateCount Total number of duplicate (from database) lines
protected array $_duplicates Array of duplicate lines
protected int $_warningCount Running total number of warnings
protected int $_maxWarningCount Maximum number of warnings to store
protected array $_warnings Array of warning lines, bounded by MAX_WARNING
protected array $_fields Array of all the fields that could potentially be part of this import process
protected array $importableFieldsMetadata Metadata for all available fields, keyed by unique name.
protected array $_activeFields Array of the fields that are actually part of the import process the position in the array also dictates their position in the import file
protected int $_activeFieldCount Cache the count of active fields
protected array $_rows Cache of preview rows
protected string $_errorFileName Filename of error data
protected string $_conflictFileName Filename of conflict data
protected string $_duplicateFileName Filename of duplicate data
int $_contactType Contact type
int $_contactSubType Contact sub-type

Methods

array
getImportableFieldsMetadata()

Get metadata for all importable fields in std getfields style format.

setImportableFieldsMetadata(array $importableFieldsMetadata)

Set metadata for all importable fields in std getfields style format.

__construct()

Class constructor.

init()

Abstract function definitions.

mixed
fini()

No description

mixed
mapField(array $values)

Map field.

mixed
preview(array $values)

Preview.

mixed
summary($values)

No description

mixed
import($onDuplicate, $values)

No description

int
setActiveFieldValues(array $elements, $erroneousField)

Set and validate field values.

array
getActiveFieldParams()

Format the field values for input to the api.

NULL|$currTimestamp
progressImport($statusID, bool $startImport = TRUE, $startTimestamp = NULL, $prevTimestamp = NULL, $totalRowCount = NULL)

Add progress bar to the import process. Calculates time remaining, status etc.

array
getSelectValues()

No description

array
getSelectTypes()

No description

array
getHeaderPatterns()

No description

array
getDataPatterns()

No description

static void
encloseScrub(array $values, string $enclosure = "'")

Remove single-quote enclosures from a value array (row).

void
setMaxLinesToProcess(int $max)

Setter function.

static string
errorFileName($type)

Determines the file extension based on error code.

static string
saveFileName($type)

Determines the file name based on error code.

array
checkContactDuplicate(array $formatValues)

Check if contact is a duplicate .

mixed
parsePseudoConstantField(string|int|null $submittedValue, array $fieldSpec)

Parse a field which could be represented by a label or name value rather than the DB value.

Details

at line 155
array getImportableFieldsMetadata()

Get metadata for all importable fields in std getfields style format.

Return Value

array

at line 163
setImportableFieldsMetadata(array $importableFieldsMetadata)

Set metadata for all importable fields in std getfields style format.

Parameters

array $importableFieldsMetadata

at line 226
__construct()

Class constructor.

at line 233
abstract protected init()

Abstract function definitions.

at line 238
abstract protected mixed fini()

Return Value

mixed

at line 247
abstract protected mixed mapField(array $values)

Map field.

Parameters

array $values

Return Value

mixed

at line 256
abstract protected mixed preview(array $values)

Preview.

Parameters

array $values

Return Value

mixed

at line 263
abstract protected mixed summary($values)

Parameters

$values

Return Value

mixed

at line 271
abstract protected mixed import($onDuplicate, $values)

Parameters

$onDuplicate
$values

Return Value

mixed

at line 283
int setActiveFieldValues(array $elements, $erroneousField)

Set and validate field values.

Parameters

array $elements array.
$erroneousField reference.

Return Value

int

at line 313
array getActiveFieldParams()

Format the field values for input to the api.

Return Value

array (reference) associative array of name/value pairs

at line 343
NULL|$currTimestamp progressImport($statusID, bool $startImport = TRUE, $startTimestamp = NULL, $prevTimestamp = NULL, $totalRowCount = NULL)

Add progress bar to the import process. Calculates time remaining, status etc.

Parameters

$statusID status id of the import process saved in $config->uploadDir.
bool $startImport True when progress bar is to be initiated.
$startTimestamp Initial timstamp when the import was started.
$prevTimestamp Previous timestamp when this function was last called.
$totalRowCount Total number of rows in the import file.

Return Value

NULL|$currTimestamp

at line 385
array getSelectValues()

Return Value

array

at line 396
array getSelectTypes()

Return Value

array

at line 409
array getHeaderPatterns()

Return Value

array

at line 422
array getDataPatterns()

Return Value

array

at line 438
static void encloseScrub(array $values, string $enclosure = "'")

Remove single-quote enclosures from a value array (row).

Parameters

array $values
string $enclosure

Return Value

void

at line 455
void setMaxLinesToProcess(int $max)

Setter function.

Parameters

int $max

Return Value

void

at line 465
static string errorFileName($type)

Determines the file extension based on error code.

Parameters

$type

Return Value

string

at line 504
static string saveFileName($type)

Determines the file name based on error code.

Parameters

$type

Return Value

string

at line 541
protected array checkContactDuplicate(array $formatValues)

Check if contact is a duplicate .

Parameters

array $formatValues

Return Value

array

at line 563
protected mixed parsePseudoConstantField(string|int|null $submittedValue, array $fieldSpec)

Parse a field which could be represented by a label or name value rather than the DB value.

We will try to match name first or (per https://lab.civicrm.org/dev/core/issues/1285 if we have an id.

but if not available then see if we have a label that can be converted to a name.

Parameters

string|int|null $submittedValue
array $fieldSpec Metadata for the field

Return Value

mixed