背景:不了解我的人如果只看过我的博客,会以为我是一个发亮稀少,或者表情严肃的程序狗。但是其实和我做过项目的基本都知道,我是一个年纪轻轻骚话不断的小逗比。以此为背景,前几天同事问我说岳奇,我有一段代码是公用的逻辑,但是想在trigger和batch都共用到,两个逻辑差不多,区别就是那么一小点点。怎样才能判断当前这个方法运行的上下文是在trigger里面还是batch里面啊。此时的我就和他说:哦我的上帝,先必应,在谷歌,找不到解决方案再找我,我就可以和你很自信的说这个实现不了了,搞定~~~当然,玩笑归玩笑,本着朋友的信任,基本上朋友问的问题我都知无不言,所以我说,以我干salesforce 开发5年的经验来看,这个确实好像实现不了,只能告诉你如果想知道是否batch运行可以System.isBatchable()。我对apex的概念还是有点落后的,之前apex develop guide没事确实也扫过一遍,当时扫的时候还是V36.0,现在都已经看不到了。
这几天对象出差,在家呆着刷剧也无聊,寻思好久没有看最新release的开发文档了,扫一扫哪些好用的新功能,混个脸熟。结果我发现前几天的回复是多么的无知,特此写下此篇,告诫自己不要太自负,温故而知新,说以前先多查查,多确定。
一. Quiddity
Quiddity是salesforce winter21新加的枚举类,apex如果使用,api version需要50及以上。我们通过上面的连接可以看到这个枚举类中包含的枚举元素。元素很多,找几个单独说一下:
还有很多其他的枚举元素用于不同的场景,感兴趣的自行查看,那么如何在apex中获取当前的枚举呢,更简单了。只需要通过 Request获取当前的请求,然后调getQuiddity即可。具体如下:
//Get info about the current request
Request reqInfo = Request.getCurrent();
//Get the identifier for this request, which is universally unique
//Same as requestId in splunk or REQUEST_ID in event monitoring
String currentRequestId = reqInfo.getRequestId();
//Enum representing how Apex is running. e.g. BULK_API vs LIGHTNING
Quiddity currentType = reqInfo.getQuiddity();
//Use this with a switch statement,
//instead of checking System.isFuture() || System.isQueueable() || ...
通过上面的博客链接,我们可以对这个功能做更好的拓展,做一个功能阀,保证我们的代码只在部分场景运行。可扩展性很多,大家可以基于自身的业务去进行使用。下面截图是上述相似代码trigger上下文的apex class的执行结果。
总结:本篇本来还想介绍一下Security的stripInaccessible方法实现sf针对数据访问权限的安全化策略,后来过了一遍新的文档,发现还是有好多更新的内容没有查看,作罢了越更越多的特性点,还是推荐个人可以自己养成自我学习的习惯。篇中有错误欢迎指出,有不懂欢迎留言。自信是好东西,前提是有支撑着你自信的能力,我这次很惭愧。技术不断的更新变化,拥抱变化,不断努力。共勉。