aimeos /
aimeos-core
| 1 | <?php |
||||
| 2 | |||||
| 3 | /** |
||||
| 4 | * @license LGPLv3, https://opensource.org/licenses/LGPL-3.0 |
||||
| 5 | * @copyright Aimeos (aimeos.org), 2021-2024 |
||||
| 6 | */ |
||||
| 7 | |||||
| 8 | |||||
| 9 | namespace Aimeos; |
||||
| 10 | |||||
| 11 | |||||
| 12 | /** |
||||
| 13 | * Setup Aimeos data structures and storeages |
||||
| 14 | */ |
||||
| 15 | class Setup |
||||
| 16 | { |
||||
| 17 | private $bootstrap; |
||||
| 18 | private $context; |
||||
| 19 | private $config; |
||||
| 20 | private $verbose; |
||||
| 21 | |||||
| 22 | |||||
| 23 | /** |
||||
| 24 | * Initializes the Aimeos setup object |
||||
| 25 | * |
||||
| 26 | * @param Bootstrap $bootstrap Aimeos bootstrap object |
||||
| 27 | * @param array $config Associative list of config keys and values |
||||
| 28 | */ |
||||
| 29 | public function __construct( Bootstrap $bootstrap, array $config = [] ) |
||||
| 30 | { |
||||
| 31 | $this->bootstrap = $bootstrap; |
||||
| 32 | $this->config = $config; |
||||
| 33 | |||||
| 34 | $this->macros(); |
||||
| 35 | } |
||||
| 36 | |||||
| 37 | |||||
| 38 | /** |
||||
| 39 | * Creates a new initialized setup object |
||||
| 40 | * |
||||
| 41 | * @param Bootstrap $bootstrap Aimeos bootstrap object |
||||
| 42 | * @param array $config Associative list of config keys and values |
||||
| 43 | * @return self Aimeos setup object |
||||
| 44 | */ |
||||
| 45 | public static function use( Bootstrap $bootstrap, array $config = [] ) : self |
||||
| 46 | { |
||||
| 47 | return new static( $bootstrap, $config ); |
||||
| 48 | } |
||||
| 49 | |||||
| 50 | |||||
| 51 | /** |
||||
| 52 | * Sets a custom context object |
||||
| 53 | * |
||||
| 54 | * @param \Aimeos\MShop\ContextIface $context Context object |
||||
| 55 | * @return self Same object for fluid method calls |
||||
| 56 | */ |
||||
| 57 | public function context( \Aimeos\MShop\ContextIface $context ) : self |
||||
| 58 | { |
||||
| 59 | $this->context = $context; |
||||
| 60 | return $this; |
||||
| 61 | } |
||||
| 62 | |||||
| 63 | |||||
| 64 | /** |
||||
| 65 | * Performs the migrations |
||||
| 66 | * |
||||
| 67 | * @param string $site Site code to execute the migrations for |
||||
| 68 | * @param string $template Name of the migration template |
||||
| 69 | */ |
||||
| 70 | public function up( string $site = 'default', string $template = 'default' ) |
||||
| 71 | { |
||||
| 72 | $ctx = ( $this->context ?? $this->createContext() )->setEditor( 'setup' ); |
||||
| 73 | |||||
| 74 | \Aimeos\Upscheme\Task\Base::macro( 'context', function() use ( $ctx ) { |
||||
| 75 | return $ctx; |
||||
| 76 | } ); |
||||
| 77 | |||||
| 78 | |||||
| 79 | $config = $ctx->config(); |
||||
| 80 | $config->set( 'setup/site', $site ); |
||||
| 81 | $dbconf = $this->getDBConfig( $config ); |
||||
| 82 | $taskPaths = $this->bootstrap->getSetupPaths( $template ); |
||||
| 83 | |||||
| 84 | \Aimeos\Upscheme\Up::use( $dbconf, $taskPaths )->verbose( $this->verbose )->up(); |
||||
| 85 | } |
||||
| 86 | |||||
| 87 | |||||
| 88 | /** |
||||
| 89 | * Sets the verbosity level |
||||
| 90 | * |
||||
| 91 | * @param mixed $level Verbosity level (empty: none, v: notice, vv: info, vvv: debug) |
||||
| 92 | * @return self Same object for fluid method calls |
||||
| 93 | */ |
||||
| 94 | public function verbose( $level = 'v' ) : self |
||||
| 95 | { |
||||
| 96 | $this->verbose = $level; |
||||
| 97 | return $this; |
||||
| 98 | } |
||||
| 99 | |||||
| 100 | |||||
| 101 | /** |
||||
| 102 | * Returns a new context object |
||||
| 103 | * |
||||
| 104 | * @return \Aimeos\MShop\ContextIface New context object |
||||
| 105 | */ |
||||
| 106 | protected function createContext() : \Aimeos\MShop\ContextIface |
||||
| 107 | { |
||||
| 108 | $ctx = new \Aimeos\MShop\Context(); |
||||
| 109 | |||||
| 110 | $conf = new \Aimeos\Base\Config\PHPArray( [], $this->bootstrap->getConfigPaths() ); |
||||
| 111 | |||||
| 112 | foreach( $this->config as $key => $value ) { |
||||
| 113 | $conf->set( $key, $value ); |
||||
| 114 | } |
||||
| 115 | |||||
| 116 | $conf = new \Aimeos\Base\Config\Decorator\Memory( $conf ); |
||||
| 117 | $ctx->setConfig( $conf ); |
||||
| 118 | |||||
| 119 | $dbm = new \Aimeos\Base\DB\Manager\Standard( $conf->get( 'resource', [] ), 'DBAL' ); |
||||
| 120 | $ctx->setDatabaseManager( $dbm ); |
||||
| 121 | |||||
| 122 | $fsm = new \Aimeos\Base\Filesystem\Manager\Standard( $conf->get( 'resource', [] ) ); |
||||
| 123 | $ctx->setFilesystemManager( $fsm ); |
||||
| 124 | |||||
| 125 | $logger = new \Aimeos\Base\Logger\Errorlog( \Aimeos\Base\Logger\Iface::INFO ); |
||||
| 126 | $ctx->setLogger( $logger ); |
||||
| 127 | |||||
| 128 | $password = new \Aimeos\Base\Password\Standard(); |
||||
| 129 | $ctx->setPassword( $password ); |
||||
| 130 | |||||
| 131 | $session = new \Aimeos\Base\Session\None(); |
||||
| 132 | $ctx->setSession( $session ); |
||||
| 133 | |||||
| 134 | $cache = new \Aimeos\Base\Cache\None(); |
||||
| 135 | $ctx->setCache( $cache ); |
||||
| 136 | |||||
| 137 | $process = new \Aimeos\Base\Process\Pcntl( $conf->get( 'pcntl_max', 4 ), $conf->get( 'pcntl_priority', 19 ) ); |
||||
| 138 | $process = new \Aimeos\Base\Process\Decorator\Check( $process ); |
||||
| 139 | $ctx->setProcess( $process ); |
||||
| 140 | |||||
| 141 | return $ctx; |
||||
| 142 | } |
||||
| 143 | |||||
| 144 | |||||
| 145 | /** |
||||
| 146 | * Returns the database configuration |
||||
| 147 | * |
||||
| 148 | * @param \Aimeos\Base\Config\Iface $conf Configuration object |
||||
| 149 | * @return array Database configuration |
||||
| 150 | */ |
||||
| 151 | protected function getDBConfig( \Aimeos\Base\Config\Iface $conf ) : array |
||||
| 152 | { |
||||
| 153 | $dbconfig = $conf->get( 'resource', [] ); |
||||
| 154 | |||||
| 155 | foreach( $dbconfig as $rname => $entry ) |
||||
| 156 | { |
||||
| 157 | if( strncmp( $rname, 'db', 2 ) !== 0 ) { |
||||
| 158 | unset( $dbconfig[$rname] ); |
||||
| 159 | } |
||||
| 160 | } |
||||
| 161 | |||||
| 162 | return $dbconfig; |
||||
| 163 | } |
||||
| 164 | |||||
| 165 | |||||
| 166 | /** |
||||
| 167 | * Adds the required marcos to the Upscheme objects |
||||
| 168 | */ |
||||
| 169 | protected function macros() |
||||
| 170 | { |
||||
| 171 | \Aimeos\Upscheme\Up::macro( 'connect', function( array $cfg ) { |
||||
| 172 | |||||
| 173 | switch( $cfg['adapter'] ) |
||||
| 174 | { |
||||
| 175 | case 'mysql': $cfg['driver'] = 'pdo_mysql'; break; |
||||
| 176 | case 'oracle': $cfg['driver'] = 'pdo_oci'; break; |
||||
| 177 | case 'pgsql': $cfg['driver'] = 'pdo_pgsql'; break; |
||||
| 178 | case 'sqlsrv': $cfg['driver'] = 'pdo_sqlsrv'; break; |
||||
| 179 | default: $cfg['driver'] = $cfg['adapter']; |
||||
| 180 | } |
||||
| 181 | |||||
| 182 | if( isset( $cfg['database'] ) ) { |
||||
| 183 | $cfg['dbname'] = $cfg['database']; |
||||
| 184 | } |
||||
| 185 | |||||
| 186 | if( isset( $cfg['username'] ) ) { |
||||
| 187 | $cfg['user'] = $cfg['username']; |
||||
| 188 | } |
||||
| 189 | |||||
| 190 | unset( $cfg['adapter'], $cfg['database'], $cfg['username'] ); |
||||
| 191 | |||||
| 192 | return \Doctrine\DBAL\DriverManager::getConnection( $cfg ); |
||||
| 193 | } ); |
||||
| 194 | |||||
| 195 | |||||
| 196 | $codelen = $this->config['codelength'] ?? 64; |
||||
| 197 | |||||
| 198 | \Aimeos\Upscheme\Schema\Table::macro( 'startend', function() { |
||||
| 199 | $this->datetime( 'start' )->null( true ); |
||||
|
0 ignored issues
–
show
|
|||||
| 200 | return $this->datetime( 'end' )->null( true ); |
||||
| 201 | } ); |
||||
| 202 | |||||
| 203 | \Aimeos\Upscheme\Schema\Table::macro( 'code', function( string $name = 'code' ) use ( $codelen ) { |
||||
| 204 | return $this->string( $name, $codelen ) |
||||
|
0 ignored issues
–
show
The method
string() does not exist on Aimeos\Setup.
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
This check looks for calls to methods that do not seem to exist on a given type. It looks for the method on the type itself as well as in inherited classes or implemented interfaces. This is most likely a typographical error or the method has been renamed. Loading history...
|
|||||
| 205 | ->opt( 'charset', 'utf8mb4', 'mysql' ) |
||||
| 206 | ->opt( 'collation', 'utf8mb4_bin', 'mysql' ) |
||||
| 207 | ->default( '' ); |
||||
| 208 | } ); |
||||
| 209 | |||||
| 210 | \Aimeos\Upscheme\Schema\Table::macro( 'config', function( string $name = 'config' ) { |
||||
| 211 | return $this->text( $name ) |
||||
|
0 ignored issues
–
show
The method
text() does not exist on Aimeos\Setup.
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
This check looks for calls to methods that do not seem to exist on a given type. It looks for the method on the type itself as well as in inherited classes or implemented interfaces. This is most likely a typographical error or the method has been renamed. Loading history...
|
|||||
| 212 | ->opt( 'charset', 'utf8mb4', 'mysql' ) |
||||
| 213 | ->opt( 'collation', 'utf8mb4_general_ci', 'mysql' ) |
||||
| 214 | ->null( true ); |
||||
| 215 | } ); |
||||
| 216 | |||||
| 217 | \Aimeos\Upscheme\Schema\Table::macro( 'type', function( string $name = 'type' ) use ( $codelen ) { |
||||
| 218 | return $this->string( $name, $codelen ) |
||||
| 219 | ->opt( 'charset', 'utf8mb4', 'mysql' ) |
||||
| 220 | ->opt( 'collation', 'utf8mb4_bin', 'mysql' ) |
||||
| 221 | ->default( '' ); |
||||
| 222 | } ); |
||||
| 223 | |||||
| 224 | \Aimeos\Upscheme\Schema\Table::macro( 'refid', function( string $name = 'refid' ) { |
||||
| 225 | return $this->string( $name, 36 ) |
||||
| 226 | ->opt( 'charset', 'utf8mb4', 'mysql' ) |
||||
| 227 | ->opt( 'collation', 'utf8mb4_bin', 'mysql' ) |
||||
| 228 | ->default( '' ); |
||||
| 229 | } ); |
||||
| 230 | |||||
| 231 | \Aimeos\Upscheme\Schema\Table::macro( 'i18n', function( string $name = 'i18n' ) { |
||||
| 232 | return $this->text( $name ) |
||||
| 233 | ->opt( 'charset', 'utf8mb4', 'mysql' ) |
||||
| 234 | ->opt( 'collation', 'utf8mb4_bin', 'mysql' ) |
||||
| 235 | ->null( true ); |
||||
| 236 | } ); |
||||
| 237 | |||||
| 238 | \Aimeos\Upscheme\Schema\Table::macro( 'meta', function() { |
||||
| 239 | $this->datetime( 'mtime' ); |
||||
| 240 | $this->datetime( 'ctime' ); |
||||
| 241 | return $this->string( 'editor' ); |
||||
| 242 | } ); |
||||
| 243 | } |
||||
| 244 | } |
||||
| 245 |
This check looks for calls to methods that do not seem to exist on a given type. It looks for the method on the type itself as well as in inherited classes or implemented interfaces.
This is most likely a typographical error or the method has been renamed.