Symfony event vs service











up vote
-1
down vote

favorite












Hi I have a question about symfony application architecture,
In my application I create different user, but when a user is created, updated, deleted, or his picture change, I need to do some action.



What is the best way to do this ? I excluded to do this on a controller action. There is 2 others solutions :




  • Create differents events like user.created, user.updated, ... And dispatch it on the controller action and make different listener to do the different action like MailListener (for user.created) TaskListener (for user.created) for add a task.


  • Use a service like UserManager and on this service have a method like userCreated() and on this method call differents actions like sendMailOnCreated, addTaskOnCreated for example.



For you what is the best method ?










share|improve this question






















  • As usual the answer is: it depends. An event based system is very flexible. If you need to do something else on user.create then you can just plugin another listener. On the other hand, a user manager lets you bring all the functionality together in one place and might be easier to maintain. My inclination is to use events but there is no "best" method.
    – Cerad
    Nov 20 at 13:14















up vote
-1
down vote

favorite












Hi I have a question about symfony application architecture,
In my application I create different user, but when a user is created, updated, deleted, or his picture change, I need to do some action.



What is the best way to do this ? I excluded to do this on a controller action. There is 2 others solutions :




  • Create differents events like user.created, user.updated, ... And dispatch it on the controller action and make different listener to do the different action like MailListener (for user.created) TaskListener (for user.created) for add a task.


  • Use a service like UserManager and on this service have a method like userCreated() and on this method call differents actions like sendMailOnCreated, addTaskOnCreated for example.



For you what is the best method ?










share|improve this question






















  • As usual the answer is: it depends. An event based system is very flexible. If you need to do something else on user.create then you can just plugin another listener. On the other hand, a user manager lets you bring all the functionality together in one place and might be easier to maintain. My inclination is to use events but there is no "best" method.
    – Cerad
    Nov 20 at 13:14













up vote
-1
down vote

favorite









up vote
-1
down vote

favorite











Hi I have a question about symfony application architecture,
In my application I create different user, but when a user is created, updated, deleted, or his picture change, I need to do some action.



What is the best way to do this ? I excluded to do this on a controller action. There is 2 others solutions :




  • Create differents events like user.created, user.updated, ... And dispatch it on the controller action and make different listener to do the different action like MailListener (for user.created) TaskListener (for user.created) for add a task.


  • Use a service like UserManager and on this service have a method like userCreated() and on this method call differents actions like sendMailOnCreated, addTaskOnCreated for example.



For you what is the best method ?










share|improve this question













Hi I have a question about symfony application architecture,
In my application I create different user, but when a user is created, updated, deleted, or his picture change, I need to do some action.



What is the best way to do this ? I excluded to do this on a controller action. There is 2 others solutions :




  • Create differents events like user.created, user.updated, ... And dispatch it on the controller action and make different listener to do the different action like MailListener (for user.created) TaskListener (for user.created) for add a task.


  • Use a service like UserManager and on this service have a method like userCreated() and on this method call differents actions like sendMailOnCreated, addTaskOnCreated for example.



For you what is the best method ?







symfony events service






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 20 at 11:36









eldiablo62

6310




6310












  • As usual the answer is: it depends. An event based system is very flexible. If you need to do something else on user.create then you can just plugin another listener. On the other hand, a user manager lets you bring all the functionality together in one place and might be easier to maintain. My inclination is to use events but there is no "best" method.
    – Cerad
    Nov 20 at 13:14


















  • As usual the answer is: it depends. An event based system is very flexible. If you need to do something else on user.create then you can just plugin another listener. On the other hand, a user manager lets you bring all the functionality together in one place and might be easier to maintain. My inclination is to use events but there is no "best" method.
    – Cerad
    Nov 20 at 13:14
















As usual the answer is: it depends. An event based system is very flexible. If you need to do something else on user.create then you can just plugin another listener. On the other hand, a user manager lets you bring all the functionality together in one place and might be easier to maintain. My inclination is to use events but there is no "best" method.
– Cerad
Nov 20 at 13:14




As usual the answer is: it depends. An event based system is very flexible. If you need to do something else on user.create then you can just plugin another listener. On the other hand, a user manager lets you bring all the functionality together in one place and might be easier to maintain. My inclination is to use events but there is no "best" method.
– Cerad
Nov 20 at 13:14












1 Answer
1






active

oldest

votes

















up vote
1
down vote



accepted










For me, your first solution is the best one. It's clearly a use case for the Event component. It will be easier to maintain and more readable.



Moreover, if you need to add more listener you just need to create another one and bind it to your event. You don't need to modify your controller anymore.






share|improve this answer





















  • I don't understand why this should be easier to maintain or more readable. In the end you would replace the event emit with a method call, nothing else. Therefore unit testing events is more difficult I think than just using a normal service. If the above application is not a bundle, which shouldn't be used from 3rd party, then I would stick with the service solution.
    – baris1892
    Nov 20 at 19:15











Your Answer






StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");

StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53392166%2fsymfony-event-vs-service%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes








up vote
1
down vote



accepted










For me, your first solution is the best one. It's clearly a use case for the Event component. It will be easier to maintain and more readable.



Moreover, if you need to add more listener you just need to create another one and bind it to your event. You don't need to modify your controller anymore.






share|improve this answer





















  • I don't understand why this should be easier to maintain or more readable. In the end you would replace the event emit with a method call, nothing else. Therefore unit testing events is more difficult I think than just using a normal service. If the above application is not a bundle, which shouldn't be used from 3rd party, then I would stick with the service solution.
    – baris1892
    Nov 20 at 19:15















up vote
1
down vote



accepted










For me, your first solution is the best one. It's clearly a use case for the Event component. It will be easier to maintain and more readable.



Moreover, if you need to add more listener you just need to create another one and bind it to your event. You don't need to modify your controller anymore.






share|improve this answer





















  • I don't understand why this should be easier to maintain or more readable. In the end you would replace the event emit with a method call, nothing else. Therefore unit testing events is more difficult I think than just using a normal service. If the above application is not a bundle, which shouldn't be used from 3rd party, then I would stick with the service solution.
    – baris1892
    Nov 20 at 19:15













up vote
1
down vote



accepted







up vote
1
down vote



accepted






For me, your first solution is the best one. It's clearly a use case for the Event component. It will be easier to maintain and more readable.



Moreover, if you need to add more listener you just need to create another one and bind it to your event. You don't need to modify your controller anymore.






share|improve this answer












For me, your first solution is the best one. It's clearly a use case for the Event component. It will be easier to maintain and more readable.



Moreover, if you need to add more listener you just need to create another one and bind it to your event. You don't need to modify your controller anymore.







share|improve this answer












share|improve this answer



share|improve this answer










answered Nov 20 at 13:18









JacobDelcroix

262




262












  • I don't understand why this should be easier to maintain or more readable. In the end you would replace the event emit with a method call, nothing else. Therefore unit testing events is more difficult I think than just using a normal service. If the above application is not a bundle, which shouldn't be used from 3rd party, then I would stick with the service solution.
    – baris1892
    Nov 20 at 19:15


















  • I don't understand why this should be easier to maintain or more readable. In the end you would replace the event emit with a method call, nothing else. Therefore unit testing events is more difficult I think than just using a normal service. If the above application is not a bundle, which shouldn't be used from 3rd party, then I would stick with the service solution.
    – baris1892
    Nov 20 at 19:15
















I don't understand why this should be easier to maintain or more readable. In the end you would replace the event emit with a method call, nothing else. Therefore unit testing events is more difficult I think than just using a normal service. If the above application is not a bundle, which shouldn't be used from 3rd party, then I would stick with the service solution.
– baris1892
Nov 20 at 19:15




I don't understand why this should be easier to maintain or more readable. In the end you would replace the event emit with a method call, nothing else. Therefore unit testing events is more difficult I think than just using a normal service. If the above application is not a bundle, which shouldn't be used from 3rd party, then I would stick with the service solution.
– baris1892
Nov 20 at 19:15


















draft saved

draft discarded




















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.





Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


Please pay close attention to the following guidance:


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53392166%2fsymfony-event-vs-service%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

404 Error Contact Form 7 ajax form submitting

How to know if a Active Directory user can login interactively

TypeError: fit_transform() missing 1 required positional argument: 'X'