| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175 | <?php namespace Laravel\CLI\Tasks\Migrate;use Laravel\Bundle;class Resolver {	/**	 * The migration database instance.	 *	 * @var Database	 */	protected $database;	/**	 * Create a new instance of the migration resolver.	 *	 * @param  Database  $database	 * @return void	 */	public function __construct(Database $database)	{		$this->database = $database;	}	/**	 * Resolve all of the outstanding migrations for a bundle.	 *	 * @param  string  $bundle	 * @return array	 */	public function outstanding($bundle = null)	{		$migrations = array();		// If no bundle was given to the command, we'll grab every bundle for		// the application, including the "application" bundle, which is not		// returned by "all" method on the Bundle class.		if (is_null($bundle))		{			$bundles = array_merge(Bundle::names(), array('application'));		}		else		{			$bundles = array($bundle);		}		foreach ($bundles as $bundle)		{			// First we need to grab all of the migrations that have already			// run for this bundle, as well as all of the migration files			// for the bundle. Once we have these, we can determine which			// migrations are still outstanding.			$ran = $this->database->ran($bundle);			$files = $this->migrations($bundle);			// To find outstanding migrations, we will simply iterate over			// the migration files and add the files that do not exist in			// the array of ran migrations to the outstanding array.			foreach ($files as $key => $name)			{				if ( ! in_array($name, $ran))				{					$migrations[] = compact('bundle', 'name');				}			}		}		return $this->resolve($migrations);	}	/**	 * Resolve an array of the last batch of migrations.	 *	 * @return array	 */	public function last()	{		return $this->resolve($this->database->last());	}	/**	 * Resolve an array of migration instances.	 *	 * @param  array  $migrations	 * @return array	 */	protected function resolve($migrations)	{		$instances = array();		foreach ($migrations as $migration)		{			$migration = (array) $migration;			// The migration array contains the bundle name, so we will get the			// path to the bundle's migrations and resolve an instance of the			// migration using the name.			$bundle = $migration['bundle'];			$path = Bundle::path($bundle).'migrations/';			// Migrations are not resolved through the auto-loader, so we will			// manually instantiate the migration class instances for each of			// the migration names we're given.			$name = $migration['name'];			require_once $path.$name.EXT;			// Since the migration name will begin with the numeric ID, we'll			// slice off the ID so we are left with the migration class name.			// The IDs are for sorting when resolving outstanding migrations.			//			// Migrations that exist within bundles other than the default			// will be prefixed with the bundle name to avoid any possible			// naming collisions with other bundle's migrations.			$prefix = Bundle::class_prefix($bundle);			$class = $prefix.\Laravel\Str::classify(substr($name, 18));			$migration = new $class;			// When adding to the array of instances, we will actually			// add the migration instance, the bundle, and the name.			// This allows the migrator to log the bundle and name			// when the migration is executed.			$instances[] = compact('bundle', 'name', 'migration');		}		// At this point the migrations are only sorted within their		// bundles so we need to resort them by name to ensure they		// are in a consistent order.		usort($instances, function($a, $b)		{			return strcmp($a['name'], $b['name']);		});		return $instances;	}	/**	 * Grab all of the migration filenames for a bundle.	 *	 * @param  string  $bundle	 * @return array	 */	protected function migrations($bundle)	{		$files = glob(Bundle::path($bundle).'migrations/*_*'.EXT);		// When open_basedir is enabled, glob will return false on an		// empty directory, so we will return an empty array in this		// case so the application doesn't bomb out.		if ($files === false)		{			return array();		}		// Once we have the array of files in the migration directory,		// we'll take the basename of the file and remove the PHP file		// extension, which isn't needed.		foreach ($files as &$file)		{			$file = str_replace(EXT, '', basename($file));		}		// We'll also sort the files so that the earlier migrations		// will be at the front of the array and will be resolved		// first by this class' resolve method.		sort($files);		return $files;	}}
 |