我正在构建一个从第三方检索并提交给第三方的服务.第三方提供了一个复杂的数据模型,其中包括三种不同的状态类型,所有这些类型的整数都有一个模糊的数字序列.下面提供了一个示例(键:值):
HandlerStatus CustomerStatus ArchiveStatus --- --- --- activeUnallocated:40 draftOpen:0 openOpen:0 activeAllocated:26 submitted:2 closed:1 activePromoted:102 approved:100 Declined:2 declined:1 ... ...
只有有限数量的组合,每个组合都有一个术语(提交,委托给另一个用户,等待确认等).例如:
Combination called "Submitted": HandlerStatus has to be "activeUnallocated" (40) CustomerStatus has to be "submitted" (2) ArchiveStatus has to be "openOpen" (0)
我们可以期待添加其他值,并且用户友好名称可能会随时间而变化.
此外,还有一些操作,例如提交和委托给不需要用户选择新值的其他用户,这意味着服务需要知道在这些操作发生时必须设置的一组组合.
我必须能够为每种状态类型中的每个状态值定义用户友好的显示名称
我必须能够从用户接收新的状态值并映射正确的状态类型
我必须能够查找定义组合的值
我必须能够根据一组状态值查找定义的组合
我想到了三种不同的解决方案,各有利弊.
优点:
强类型
维护仅限于一个文件
缺点:
枚举
UI表示的字符串格式
优点:
添加不需要更改代码
可以在运行时更新
缺点:
需要魔术字符串/数字用于具有相关组合的动作(没有用户输入的动作)
经常从文件系统中读取
优点:
强类型
灵活
缺点:
在第三方系统中发生更改时需要代码维护
我已经尝试研究最佳实践和模式,以确定哪种解决方案最适合,可维护性和良好的代码设计,但我没有得到任何地方(同时我在开发过程中严重依赖魔术字符串和数字) ).