I have an existing attribute for an embed code. I need to associate this attribute with 120+ existing attribute sets.
If I know the attribute set id, how can I go about adding the attribute to all attribute sets programmatically?
Attribute sets are a collection of event layer attributes you can use to create multiple events with a set of additional, organization-specific attributes in a single edit. Attribute sets are created using event features in an LRS-enabled feature service.
I have found it interesting to write code for this issue so here is the solution that works :)
Run this code in php script including mage.php and let me know if it works well.
replace ( firstname ) with the attribute code that you want to mass add to all attribute sets
$attSet = Mage::getModel('eav/entity_type')->getCollection()->addFieldToFilter('entity_type_code','catalog_product')->getFirstItem(); // This is because the you adding the attribute to catalog_products entity ( there is different entities in magento ex : catalog_category, order,invoice... etc )
$attSetCollection = Mage::getModel('eav/entity_type')->load($attSet->getId())->getAttributeSetCollection(); // this is the attribute sets associated with this entity
$attributeInfo = Mage::getResourceModel('eav/entity_attribute_collection')
->setCodeFilter('firstname')
->getFirstItem();
$attCode = $attributeInfo->getAttributeCode();
$attId = $attributeInfo->getId();
foreach ($attSetCollection as $a)
{
$set = Mage::getModel('eav/entity_attribute_set')->load($a->getId());
$setId = $set->getId();
$group = Mage::getModel('eav/entity_attribute_group')->getCollection()->addFieldToFilter('attribute_set_id',$setId)->setOrder('attribute_group_id',"ASC")->getFirstItem();
$groupId = $group->getId();
$newItem = Mage::getModel('eav/entity_attribute');
$newItem->setEntityTypeId($attSet->getId()) // catalog_product eav_entity_type id ( usually 10 )
->setAttributeSetId($setId) // Attribute Set ID
->setAttributeGroupId($groupId) // Attribute Group ID ( usually general or whatever based on the query i automate to get the first attribute group in each attribute set )
->setAttributeId($attId) // Attribute ID that need to be added manually
->setSortOrder(10) // Sort Order for the attribute in the tab form edit
->save()
;
echo "Attribute ".$attCode." Added to Attribute Set ".$set->getAttributeSetName()." in Attribute Group ".$group->getAttributeGroupName()."<br>\n";
}
for people having problems with the code above,
like: Call to a member function getModelInstance() on a non-object
you need to add the following to to top of your file:
include 'app/Mage.php';
Mage::app();
edit:
im using magento 1.8.1.0 and the code still didn't work
i had to add the following line to $newItem, this way the validation passes
->setAttributeCode($attCode)
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With