Portál AbcLinuxu, 8. května 2025 06:30
$role = RoleManager::getRoleById(x); // kde x je ID role $user->addRole($role);nebo
$user->addRole(x); // kde x je ID rolea jaké z toho plynou budoucí výhody/nevýhody?
Není problém, aby tam byly obě metody, ovšem asi by se tím zkomplikovaly závislosti, protože by vás to asi svádělo k tomu, že budete ve třídě User používat RoleManager (a to si pak rovnou rozmyslete, jestli jedete podle ActiveRecord vzoru nebo jinak).Prošel jsem si PropelORM a tohle ale přesně dělá. Respektive dělá to oklikou. Tj. něco jako bych měl objekt RoleCollection a ten by se sám plnil, tj. v něm by se používalo RoleManager.
Prošel jsem si PropelORM a tohle ale přesně dělá.Ano, však PropelORM je taky podle ActiveRecord vzoru - záznamy ukládají samy sebe. Ve Vašem návrhu máte ale na ukládání Manager. Rozhodněte se pro jeden přístup a ten dodržujte. To jsem měl na mysli. Je spousta nuancí, jak komponenty skládat - pamatujte na to, že budete potřebovat nejen základní CRUD operace, ale i uživatelsky definované dotazy, stránkování a podmínky. Pak už je docela těžké, aby byly závislosti přehledné a jednotlivé komponenty třeba i nahraditelné. Dobrá otázka dále například je, zde mají být záznamy snadno automaticky serializovatelné třeba do XML nebo do JSON - a do jaké hloubky má serializace probíhat. A odlišujte, jak vypadá váš systém uvnitř a jak vypadá pro použití programátorem. Interně mohou záznamy používat nějaký Manager, ale zvenčí se třeba používají jako ActiveRecord.
... $user = new User( $userData ); $user->addresses = new ModelRelation( $this->_addressesMapper, 'getAddressesByUserId', array( $id ) ); ...V čem je horší přístup, kdyby místo výše uvedeného bylo použito toto?
... $user = new User( $userData ); $user->addresses = new UserAddressList(); ...Samozřejmě ta instance UserAddressList by se dělala přímo v User automaticky při prvním dotazu typu getAddresses(). UserAddressList by byla speciálně třída pro tuto funkci a ta by si sama získávala instanci Managera.
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.