createLocationIfNotExists($row); } /** * Create a location if a duplicate does not exist. * @todo Investigate how this should interact with Importer::createLocationIfNotExists * * @author A. Gianotto * @since 6.1.0 * @param array $row */ public function createLocationIfNotExists(array $row) { $editingLocation = false; $location = Location::where('name', '=', $this->findCsvMatch($row, 'name'))->first(); if ($location) { if (! $this->updating) { $this->log('A matching Location '.$this->item['name'].' already exists'); return; } $this->log('Updating Location'); $editingLocation = true; } else { $this->log('No Matching Location, Create a new one'); $location = new Location; } // Pull the records from the CSV to determine their values $this->item['name'] = trim($this->findCsvMatch($row, 'name')); $this->item['address'] = trim($this->findCsvMatch($row, 'address')); $this->item['address2'] = trim($this->findCsvMatch($row, 'address2')); $this->item['city'] = trim($this->findCsvMatch($row, 'city')); $this->item['state'] = trim($this->findCsvMatch($row, 'state')); $this->item['country'] = trim($this->findCsvMatch($row, 'country')); $this->item['zip'] = trim($this->findCsvMatch($row, 'zip')); $this->item['currency'] = trim($this->findCsvMatch($row, 'currency')); $this->item['ldap_ou'] = trim($this->findCsvMatch($row, 'ldap_ou')); $this->item['manager'] = trim($this->findCsvMatch($row, 'manager')); $this->item['manager_username'] = trim($this->findCsvMatch($row, 'manager_username')); $this->item['user_id'] = auth()->id(); if ($this->findCsvMatch($row, 'parent_location')) { $this->item['parent_id'] = $this->createOrFetchLocation(trim($this->findCsvMatch($row, 'parent_location'))); } if (!empty($this->item['manager'])) { if ($manager = $this->createOrFetchUser($row, 'manager')) { $this->item['manager_id'] = $manager->id; } } Log::debug('Item array is: '); Log::debug(print_r($this->item, true)); if ($editingLocation) { Log::debug('Updating existing location'); $location->update($this->sanitizeItemForUpdating($location)); } else { Log::debug('Creating location'); $location->fill($this->sanitizeItemForStoring($location)); } if ($location->save()) { $this->log('Location '.$location->name.' created or updated from CSV import'); return $location; } else { Log::debug($location->getErrors()); return $location->errors; } } }