ImportModel

Model used for importing data

abstract class Backend\Models\ImportModel
extends Model

Extends

Class Description
Model

Traits

Trait Description
Validation

Properties

public $attachOne : mixed

Relations

protected $guarded : array

The attributes that aren't mass assignable.

protected $resultStats : array

Import statistics store.

inherited protected $validationDefaultAttrNames : array

Inherited from Validation

Default custom attribute names.

inherited protected $validationErrors : Illuminate\Support\MessageBag

Inherited from Validation

The message bag instance containing validation error messages

Methods

public getFormatEncodingOptions () : array

Returns all available encodings values from the localization config

Returns
array

public getImportFilePath ($sessionKey = null) : string

Returns an attached imported file local path, if available.

Parameters
Property Description
$sessionKey
mixed
Returns
string

public getResultStats ()

Returns
mixed

public import ($matches, array $options = [])

Import data based on column names matching header indexes in the CSV.

The $matches array should be in the format of:

[ 0 => [db_name1, db_name2], 1 => [db_name3], ... ]

The key (0, 1) is the column index in the CSV and the value is another array of target database column names.

Parameters
Property Description
$matches
mixed
$options
array
Returns
mixed

public importData ($results, $sessionKey = null)

Called when data is being imported.

The $results array should be in the format of:

[ 'db_name1' => 'Some value', 'db_name2' => 'Another value' ], [...]

Parameters
Property Description
$results
mixed
$sessionKey
mixed
Returns
mixed

protected decodeArrayValue ($value, string $delimeter = "|") : array

Explodes a string using pipes (|) to a single dimension array

Parameters
Property Description
$value
mixed
$delimeter
string
Returns
array

protected logCreated ()

Returns
mixed

protected logError ($rowIndex, $message)

Parameters
Property Description
$rowIndex
mixed
$message
mixed
Returns
mixed

protected logSkipped ($rowIndex, $message)

Parameters
Property Description
$rowIndex
mixed
$message
mixed
Returns
mixed

protected logUpdated ()

Returns
mixed

protected logWarning ($rowIndex, $message)

Parameters
Property Description
$rowIndex
mixed
$message
mixed
Returns
mixed

protected processImportData ($filePath, $matches, $options) : array

Converts column index to database column map to an array containing database column names and values pulled from the CSV file. Eg:

[0 => [first_name], 1 => [last_name]]

Will return:

[first_name => Joe, last_name => Blogs], [first_name => Harry, last_name => Potter], [...]

Parameters
Property Description
$filePath
mixed
$matches
mixed
$options
mixed
Returns
array

protected processImportRow ($rowData, $matches) : array

Converts a single row of CSV data to the column map.

Parameters
Property Description
$rowData
mixed
$matches
mixed
Returns
array

inherited public static bootValidation () : void

Inherited from Validation

Boot the validation trait for this model.

Returns
void

inherited public errors () : Illuminate\Support\MessageBag

Inherited from Validation

Get validation error message collection for the Model

Returns
Illuminate\Support\MessageBag

inherited public forceSave ($options = null, $sessionKey = null) : bool

Inherited from Validation

Force save the model even if validation fails.

Parameters
Property Description
$options
mixed
$sessionKey
mixed
Returns
bool

inherited public isAttributeRequired (string $attribute, boolean $checkDependencies = true) : bool

Inherited from Validation

Determines if an attribute is required based on the validation rules.

Parameters
Property Description
$attribute
string
$checkDependencies
boolean

Checks the attribute dependencies (for required_if & required_with rules). Note that it will only be checked up to the next level, if another dependent rule is found then it will just assume the field is required

Returns
bool

inherited public setValidationAttributeName (string $attr, string $name) : void

Inherited from Validation

Programatically sets the validation attribute names, will take lower priority to model defined attribute names found in $attributeNames.

Parameters
Property Description
$attr
string
$name
string
Returns
void

inherited public setValidationAttributeNames (array $attributeNames) : void

Inherited from Validation

Programatically sets multiple validation attribute names.

Parameters
Property Description
$attributeNames
array
Returns
void

inherited public validate ($rules = null, $customMessages = null, $attributeNames = null) : bool

Inherited from Validation

Validate the model instance

Parameters
Property Description
$rules
mixed
$customMessages
mixed
$attributeNames
mixed
Returns
bool

inherited public static validated (Closure | string $callback) : void

Inherited from Validation

Create a new native event for handling afterValidate().

Parameters
Property Description
$callback
Closure | string
Returns
void

inherited public static validating (Closure | string $callback) : void

Inherited from Validation

Create a new native event for handling beforeValidate().

Parameters
Property Description
$callback
Closure | string
Returns
void

inherited protected getRelationValidationValue ($relationName)

Inherited from Validation

Attachments validate differently to their simple values.

Parameters
Property Description
$relationName
mixed
Returns
mixed

inherited protected getValidationAttributes () : array

Inherited from Validation

Returns the model data used for validation.

Returns
array

inherited protected static makeValidator ($data, $rules, $customMessages, $attributeNames, $connection = null) : Illuminate\Contracts\Validation\Validator

Inherited from Validation

Instantiates the validator used by the validation process, depending if the class is being used inside or outside of Laravel. Optional connection string to make the validator use a different database connection than the default connection.

Parameters
Property Description
$data
mixed
$rules
mixed
$customMessages
mixed
$attributeNames
mixed
$connection
mixed
Returns
Illuminate\Contracts\Validation\Validator

inherited protected processRuleFieldNames (array $rules) : array

Inherited from Validation

Processes field names in a rule array.

Converts any field names using array notation (ie. field[child]) into dot notation (ie. field.child)

Parameters
Property Description
$rules
array

Rules array

Returns
array

inherited protected processValidationRules ($rules)

Inherited from Validation

Process rules

Parameters
Property Description
$rules
mixed
Returns
mixed

inherited protected processValidationUniqueRule (string $definition, string $fieldName) : string

Inherited from Validation

Rebuilds the unique validation rule to force for the existing ID

Parameters
Property Description
$definition
string
$fieldName
string
Returns
string
Copyright © 2025 Winter CMS