- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我拥有一个 DDD/CQRS 应用程序。
我的问题涉及通过 POST(Rest)处理项目创建。
CQRS(基于CQS原则)提倡命令不应该返回值。
那里有查询。
所以我想知道如何处理项目创建的用例。
这是我当前的命令处理程序模式(示例的灯(无接口(interface)等)):
@Service
@Transactional
public CreateItem {
public void handle(CreateItemCommand command) {
Customer customer = customerRepository.findById(command.customerId);
ItemId generatedItemId = itemRepository.nextIdentity(); //generating the GUID
customer.createItem(generatedItemId, .....);
}
}
通过阅读this文章中,一个简单的方法是在命令中声明一个输出属性,填充在 handle
方法的末尾,如下所示:
public void handle(CreateItemCommand command) {
Customer customer = customerRepository.findById(command.customerId);
ItemId generatedItemId = itemRepository.nextIdentity(); //generating the GUID
customer.createItem(generatedItemId, .....);
command.itemId = generatedItemId; //populating the output property
}
但是,我发现这种方法有一个缺点: - 从理论上讲,命令应该是不可变的。
由于调用 controller (webapp),此 itemId
将通过 Location Header 发送,状态为 201 或 202(取决于我是否期望异步)。
另一种解决方案是让 Controller 通过访问存储库本身来初始化 GUID,从而使命令不可变:
//in my controller:
ItemId generatedItemId = itemRepository.nextIdentity(); //controller generating the GUID
createItem.handle(command);
// setting here the location header (201-202) containing the URL to the newly created item with the using the previous itemId.
缺点: Controller (适配器层)直接访问存储库...,IMO 级别太低。
我的极端客户端是一个 Javascript 应用程序,我可能有另一种解决方案让 Javascript 本身生成一个 GUID,并在将整个命令发送到服务器之前将其提供给 CreateItemCommand
。
优点:不再有可能违反 CQ(R)S 准则的问题。
缺点:应该在服务器端检查传递的 id 的有效性。尽管在这上面会有一个唯一的索引,以防止在数据库中意外插入。
处理此问题的最佳(或良好)策略是什么?
最佳答案
我是基于 CQRS 模式的 CRM 应用程序的开发人员。我倾向于将命令视为不可变的。该团队很早就决定,所有 ID 都在客户端生成,以具有不可变的命令。这完全没问题,因为我们使用的是 UUID。所以我们非常有信心,ID 是有效的并且没有 ID 冲突。到目前为止,我们采用这种方法进展顺利——我绝对可以推荐这种方法。在这种情况下,客户端只知道 ID。
虽然有时会发生这种情况 - 特别是在手动测试中 - 使用相同的 ID 分派(dispatch)创建命令两次。在那种情况下,在事件存储中添加事件失败(我们使用事件源)并出现重复键异常。异常被传递给 Controller 。事实上,我们确实会通过回调返回命令执行的结果,即使大多数时候它只是“一切正常”——所以不会抛出异常。命令验证也是通过这种方式完成的。我们使用命令总线概念来做到这一点。
我建议您看一下 Axon 框架。我们使用它,它提供了通用的构建 block ,而且它可以正常工作。也许你可以从中得到一些启发!
关于java - 通知客户新创建的 itemId 的最佳实践,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24434672/
我有一个应用程序应该在应用程序处于前台和后台(不在历史记录中)时显示提醒通知。 在前景情况下,我通过以下方法实现了这一点。 PendingIntent pendingIntent = PendingI
如何为我的 WPF 应用程序创建通知,例如浏览器上的通知,它们通过浏览器顶部的“工具栏”显示消息或通过在右下角向上/向下滑动的弹出窗口显示“MSN”样式通知屏幕。也许在应用程序中心淡入/淡出的面板可以
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 9 年前。 Improve
我正在使用 Redis 作为分布式缓存。我有不同的应用程序,它们只听特定的键。例如:App1 听 App1.*App2 监听 App2.* 等等。 我的应用程序使用以下模式接收通知:App1:“ ke
我正在尝试构建一个基于官方节点 docker 镜像的 docker 镜像,我想知道是否有某种方法可以在推送新版本的官方节点镜像时自动重建镜像。这样我的图像就不会基于过时的基础图像。 也许有类似 rss
我在一个项目中工作,我需要在添加或修改文件时在数据库中记录文件信息,以便它们保持同步。这些文件应该存储在 Nextcloud 服务器中,那么 Nextcloud 是否有办法通知这些更改(例如 webh
通知类中的方法via 如何根据用户的偏好动态变化,一个用户可能想通过电子邮件接收,而另一个用户则不想 public function via($notifiable) { return ['d
我有一个应用程序,我正在发送推送通知,如果用户登录到应用程序,这很好 - 但是,如果他们没有/如果他们没有在 X 分钟内阅读通知,我想给他们发送一封电子邮件. 我要解决的方法是使用 Laravel N
我正在使用 Django 的 contrib.comments 并想了解以下内容。 是否有任何实用程序或应用程序可以插入到某个应用程序中,当对某个项目发表评论时向您发送通知? 我并没有真正使用过那么多
我希望用户在启动应用程序之前接受协议(protocol)。所以在 appDelegate.m 中我有以下内容: - (BOOL)application:(UIApplication *)applica
我正在创建一个新指令,我想知道如何在 angular 从 DOM 中删除元素时收到通知。 我的目标是在删除元素时添加 jquery 动画。 最佳答案 如果您尝试对元素的移除进行动画处理,则需要在移除元
我正在编写一个应用程序,其工作方式与Apple的Weather.app非常相似:底部有一个UIPageControl,屏幕中间有一个UIScrollView。在我的代码中,我实现了 - (void)s
如何查明 iPhone 注册了哪些通知? 例如: notify_post("com.apple.springboard/Prefs"); 最佳答案 虽然这个问题的答案已经得到确认,但由于 @Nate
我的 Cocoa 应用程序中有一个 TextField。该文本字段有时会被填充,有时会为空。 我希望当字段为空时按钮被禁用。现在,每当我对 Core Data 执行某些操作时,我都会检查该字段,Tex
我的应用程序在其数据库中包含文档。用户可以打开文档,在这种情况下,文档将保存到临时文件夹并在用户计算机上打开。 我希望在这些临时文件之一发生更改时收到通知,并让用户将更改后的文档保存回数据库。 在 D
我目前正在开发一个网络应用程序,它不断对 php 进行 ajax 调用(轮询),以从数据库中提取新的“任务”,有点像 gmail/facebook 检查新电子邮件和消息的方式。当前的 JavaScri
我正在尝试让通知适用于我使用 Angular 5 和 Electron 制作的 Electron 应用程序。到目前为止,我的 index.html 文件中有以下代码: function doNo
我有一个录音/播放应用程序。它在后台运行。当它进入后台时,如果任何其他音频应用程序打开或开始使用音频资源,我想适本地处理我的应用程序。 iOS 提供了一种发送此类通知的方法,如在 ipod 播放器中看
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 4 年前。 Improve this ques
是否有 Subversion 的工具可以在对某些文件提交更改时自动通知我? 最佳答案 您可以创建一个 post-commit hook script “ Hook ”提交。 在钩子(Hook)脚本中,
我是一名优秀的程序员,十分优秀!