anroots/minion-importer

This package is abandoned and no longer maintained. No replacement package was suggested.

CLI data import module for Kohana

1.0.1 2013-02-26 09:35 UTC

This package is not auto-updated.

Last update: 2022-02-01 12:23:48 UTC


README

Extends the Minion module to provide a framework for importing/populating data.

Example terminal session

Two main use cases:

  • Importing legacy data from external databases
  • Generating dummy sample data

Real world use case

You are tasked with creating a new version of your in-house issue tracker, from scratch. You design your new database model and now you need to import existing data from the old system. The schema has changed so the columns do not match one-to-one and maybe you want to filter out deleted issues and what-knot.

Use this module to help you do that. Simply define a Minion_Import_* model for your entity to do data fetching, mapping and filtering. See example implementation for companies.

Usage

  • Create class: Minion_Import_Company
  • Implement Minion_Import_Importable
  • Modify APPPATH.'config/minion/import.php' (copy sample from the module dir), add your new model to the truncate_order and models arrays
  • Run ./minion import from the CLI

Faker

Use fzaninotto/Faker to generate dummy sample/test data with minion-importer.

Requires

  • Kohana Framework 3.3
  • PHP 5.4
  • Minion, Database, ORM modules

Installation

Place the files in your modules directory

As a Git submodule:

git clone git://github.com/anroots/kohana-minion-importer.git modules/minion-importer

As a Composer dependency

{
	"require": {
		"anroots/minion-importer":"1.*"
	}
}

Activate the module in bootstrap.php.

<?php
Kohana::modules(array(
	...
	'minion-importer' => MODPATH.'minion-importer',
));

Licence

MIT, do whatever. Pull requests and feedback appreciated.