Agregar un bloque CMS a través del script de configuración

19

Estoy trabajando en un sitio que tiene, creo, 9 instancias separadas de Magento, mismo sitio.

Por lo tanto, existen procedimientos estrictos que rodean cualquier dato de fondo: configuración e incluso para bloques CMS.

Me gustaría saber cómo agregar un bloque CMS a través de un script de configuración.

Francis Kim
fuente

Respuestas:

36

Para esto, sugiero usar la datacarpeta de uno de sus módulos personalizados.
Digamos que el módulo está actualmente en versión 1.0.4.

Crea el archivo data/[module]_setup/data-upgrade-1.0.4-1.0.5.php con el siguiente contenido:

Editar: nombre de archivo modificado

$content = 'BLOCK CONTENT HERE';
//if you want one block for each store view, get the store collection
$stores = Mage::getModel('core/store')->getCollection()->addFieldToFilter('store_id', array('gt'=>0))->getAllIds();
//if you want one general block for all the store viwes, uncomment the line below
//$stores = array(0);
foreach ($stores as $store){
    $block = Mage::getModel('cms/block');
    $block->setTitle('Block title here');
    $block->setIdentifier('block_identifier_here');
    $block->setStores(array($store));
    $block->setIsActive(1);
    $block->setContent($content);
    $block->save();
}

Después de esto, simplemente cambie la versión config.xmlpara 1.0.5borrar el caché y actualizar cualquier página.

Marius
fuente
Agregar un CMS es bloquear no es una corrección de errores, por lo que se debe eliminar la versión de la función. 😜
user487772
Haría Mage::app()->getStores()lo mismo?
user487772
4

En lugar de usar la sqlcarpeta, debe colocar cualquier script de configuración que modifique los datos del CMS en la datacarpeta. Ver app/code/core/Mage/Cms/data/cms_setupalgunos buenos ejemplos. Estos scripts de instalación agregan bloques estáticos y páginas CMS.

Para cambiar los valores de configuración, use este código:

$installer->setConfigData(
    Mage_Page_Model_Config::XML_PATH_CMS_LAYOUTS,
    'your_value_here'
);

Además, aquí hay un artículo útil

jharrison.au
fuente
1

También puede usar el siguiente código en el script de actualización:

$installer = $this;
/* @var $installer Mage_Core_Model_Resource_Setup */
$connection = $installer->getConnection();
/* @var $connection Varien_Db_Adapter_Pdo_Mysql */

$installer->startSetup();
$connection->insert($installer->getTable('cms/block'), array(
    'title'             => 'Footer Links',  
    'identifier'        => 'footer-links',
    'content'           => '<ul>\r\n<li><a href=\"{{store direct_url=\"about-magento-demo-store\"}}\">About Us</a></li>\r\n<li class=\"last\"><a href=\"{{store direct_url=\"customer-service\"}}\">Customer Service</a></li>\r\n</ul>',
    'creation_time'     => now(),
    'update_time'       => now(),
));
$connection->insert($installer->getTable('cms/block_store'), array(
    'block_id'   => $connection->lastInsertId(),
    'store_id'  => 0
));
$installer->endSetup();
Bijal Bhavsar
fuente
No debe agregar contenido a la base de datos con SQL directo si se puede evitar (lo cual es casi siempre). En este caso, puede usar el modelo cms / block para agregar datos de manera segura.
Ian
0

El siguiente código crea y actualiza el bloque estático usando scripts magento

http://www.pearlbells.co.uk/how-to-create-and-update-the-static-blocks-using-magento-script/

function createBlock($blockData) {

$block = Mage::getModel('cms/block')->load($blockData['identifier']);
$block->setTitle($blockData['title']);
$block->setIdentifier($blockData['identifier']);
$block->setStores(array($blockData['storeId']));
$block->setIsActive($blockData['active']);
$block->setContent($blockData['content']);
$block->save();

}

Liz Eipe C
fuente