Slides from my talk at the International PHP Conference (Spring Edition) 2010 in Berlin.
OOP helps us creating a clearly laid out and intuitive model of the reality by means of objects. However, concerns like security, logging or transactions need to be implemented virtually anywhere, resulting in scattered error-prone code. Aspect-oriented Programming separates these cross-cutting concerns from the rest of the code and lets you handle them in a well-known, central location.
1. Robert Lemke
Create Clean Code with Aspect-Oriented Programming
International PHP Conference, Spring Edition 2010
Photo: Wolfgang Staudt
2. Robert Lemke
chief architect of TYPO3 Phoenix and FLOW3
co-founder of the TYPO3 Association
34 years old
lives in Lübeck, Germany
1 wife, 1 daughter, 1 espresso machine
likes drumming
4. DI Dependency Injection DRY
LLATIP
OOP Object-Oriented Programming
YAGNI
AOP Aspect-Oriented Programming
CoC
MVC Model View Controller
POPO Plain Old PHP Object TDD
5. /**
* Creates a new post
*
* @param F3BlogDomainModelPost $newPost A fresh Post object which has not yet been
* added to the repository
* @return void
*/
public function createAction(F3BlogDomainModelPost $newPost) {
if ($this->policyService->isGranted($this->currentUser, __CLASS__, __METHOD__) {
$this->blog->addPost($newPost);
$this->flashMessageContainer->add('Your new post was created.');
$this->systemLogger->log('A new post was created.', LOG_INFO);
$this->notificationService->notify('A new post was created.', 'robert@typo3.org');
} else {
$this->systemLogger->log('Someone tried to create a post.', LOG_WARNING);
throw new F3FLOW3SecurityExceptionAccessDeniedException('Tried to create.');
}
$this->redirect('index');
}
Create Clean Code with AOP IPC SE 2010, Berlin
6. /**
* Creates a new post
*
* @param F3BlogDomainModelPost $newPost A fresh Post object which has not yet been
* added to the repository
* @return void
*/
public function createAction(F3BlogDomainModelPost $newPost) {
if ($this->authorizationService->isGranted($this->currentUser, __CLASS__, __METHOD__) {
$this->blog->addPost($newPost);
$this->flashMessageContainer->add('Your new post was created.');
$this->systemLogger->log('A new post was created.', LOG_INFO);
$this->notificationService->notify('A new post was created.', 'robert@typo3.org');
} else {
$this->systemLogger->log('Someone tried to create a post.', LOG_WARNING);
$this->flashMessageContainer->add('Access denied.');
}
$this->redirect('index');
}
Create Clean Code with AOP IPC SE 2010, Berlin
8. Aspect-Oriented Programming
programming paradigm
separates concerns to improve modularization
OOP modularizes concerns into objects
AOP modularizes cross-cutting concerns into aspects
Create Clean Code with AOP IPC SE 2010, Berlin
9. /**
* Creates a new post
*
* @param F3BlogDomainModelPost $newPost A fresh Post object which has not yet been
* added to the repository
* @return void
*/
public function createAction(F3BlogDomainModelPost $newPost) {
$this->blog->addPost($newPost);
$this->flashMessageContainer->add('Your new post was created.');
$this->redirect('index');
}
Create Clean Code with AOP IPC SE 2010, Berlin
11. Concerns
Separation of Concerns
group features and behavior into manageable parts
have a specific purpose and business to take care of
Cross-Cutting Concerns
are the party poopers who want to have a say in everything
Create Clean Code with AOP IPC SE 2010, Berlin
12. Cross-Cutting Concerns
Logging
Security
Persistence
Global Business Logic
Dirty Hacks
Create Clean Code with AOP IPC SE 2010, Berlin
13. We don't want infrastructure code
in our models.
Create Clean Code with AOP IPC SE 2010, Berlin
14. We want to unit-test even
cross-cutting concerns
Create Clean Code with AOP IPC SE 2010, Berlin
15. We want to centralize
security-related code
Create Clean Code with AOP IPC SE 2010, Berlin
17. Aspect
Part of the application where cross-cutting concerns are implemented
In FLOW3 aspects are classes annotated with @aspect
Create Clean Code with AOP IPC SE 2010, Berlin
18. Join Point
Is a single point in the call graph
Method Execution
Exception
Represents an event, not a location
Create Clean Code with AOP IPC SE 2010, Berlin
19. Pointcut
A set of join points where advices could be executed
can be composed
can be named
Create Clean Code with AOP IPC SE 2010, Berlin
20. Advice
Action to take at a join points defined by the point cut
Create Clean Code with AOP IPC SE 2010, Berlin
21. DEMO
Inspiring people to
Hitchhiker's Guide to FLOW3 share
22. Kinds of Advice
Advice types supported by FLOW3:
@before
@afterreturning
@afterthrowing
@after
@around
Inspiring people to
Hitchhiker's Guide to FLOW3 share
25. Compound Pointcuts
! /**
! * @around method(.*Controller->(new|create|edit|update|delete)Action()) &&
!methodTaggedWith(anybodyMayAccessThis)
! */
! public function interceptMethodCalls($joinPoint) {
...
}
Inspiring people to
Hitchhiker's Guide to FLOW3 share
26. DEMO
Inspiring people to
Hitchhiker's Guide to FLOW3 share
27. FLOW3's AOP implementation
based on proxy classes
unlike with most pre-processors line numbers stay the same
no scaffolding
0 Lines of generated code which need to be maintained by you
fast (on the second hit)
Inspiring people to
Hitchhiker's Guide to FLOW3 share
29. Progress
FLOW3 1.0.0
Create Clean Code with AOP IPC SE 2010, Berlin
30. Further Reading
FLOW3 Website
http://flow3.typo3.org
TYPO3 Forge
http://forge.typo3.org
Further Reading
http://flow3.typo3.org/about/principles/further-reading
http://bit.ly/GoodAOPArticle
Create Clean Code with AOP IPC SE 2010, Berlin
31. Questions
Email: robert@typo3.org
Blog: http://robertlemke.de/blog
Twitter: @t3rob
Feedback: http://joind.in/1743
Create Clean Code with AOP IPC SE 2010, Berlin