我在使用 laravel 开发应用程序时使用存储库模式,我的问题是我必须在哪里为火灾事件编写代码、发送电子邮件或发送通知?为什么?
1 回答
这确实是一个广泛的问题,许多人会提出自己的意见。在我看来,在 的上下文中Laravel
,我会根据操作定义我的事件类型。
例如,正如您提到的电子邮件/通知事件,我想这样想(这是一个假设的例子):
class UserController
{
public function register(Request $request, UserRepository $user)
{
if ($user = $user->register($request->all())) {
Email::send(...);
}
}
}
在这种情况下,注册后应该向用户发送一封电子邮件,以便我可以使用事件在控制器中执行相同的操作,例如:
class UserController
{
public function register(Request $request, UserRepository $user)
{
try {
$user = $user->register($request->all());
Event::fire('user_registered', $user);
} catch(RegistrationException $e) {
// Handle the exception
}
}
}
在这种情况下,我认为,事件调度应该在控制器中,因为它是我的应用程序层的一部分来控制应用程序流,因此,应该从控制器调度电子邮件发送事件。UserRepository
不应该关心您的应用程序的流程,向用户发送电子邮件不是您的一部分,UserRepository
就是这样。
现在,想想另一个假设的例子,假设你有一个delete
方法,UserController
如下所示:
class UserController
{
public function delete(UserRepository $user, $id)
{
if($user->findOrFail($id)->delete()) {
Post::where('user_id', $id)->delete();
}
}
}
好吧,在这种情况下,删除用户涉及一些与域相关的操作,所以我将重写方法如下:
public function delete(UserRepository $user, $id)
{
try {
$user->delete($id);
return redirect('/users'); // show users index page
} catch (InvalidOperationException $e) {
// Handle the custom exception thrown from UserRepository
}
}
请注意,删除方法中没有发生相关操作,因为我可能会在其中触发一个事件,UserRepository
因为此删除操作涉及一些其他领域/业务相关的操作,应用层不应该关心它(在这种情况下),因为删除用户会影响其他一些域对象,因此我将以这种方式处理该事件。
无论如何,这只是我的思维方式,这只是一个意见。也许在现实世界的情况下,我可以想出一个不同的想法,所以这取决于你,这取决于你应该考虑的上下文,最后在 Laravel 中没有推荐的方式,你甚至可以Models
用来触发事件,所以保持很简单,根据适合您的上下文做出决定。