前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >salesforce零基础学习(一百零一)如何了解你的代码得运行上下文

salesforce零基础学习(一百零一)如何了解你的代码得运行上下文

作者头像
Zero-Zhang
发布2021-03-09 11:58:46
6640
发布2021-03-09 11:58:46
举报
文章被收录于专栏:salesforce零基础学习

本篇参考:https://developer.salesforce.com/docs/atlas.en-us.228.0.apexcode.meta/apexcode/apex_enum_System_Quiddity.htm

https://developer.salesforce.com/blogs/2021/01/you-shall-not-pass-quiddity-for-secure-salesforce-development.html

https://developer.salesforce.com/docs/atlas.en-us.apexcode.meta/apexcode/apex_classes_with_security_stripInaccessible.htm

背景:不了解我的人如果只看过我的博客,会以为我是一个发亮稀少,或者表情严肃的程序狗。但是其实和我做过项目的基本都知道,我是一个年纪轻轻骚话不断的小逗比。以此为背景,前几天同事问我说岳奇,我有一段代码是公用的逻辑,但是想在trigger和batch都共用到,两个逻辑差不多,区别就是那么一小点点。怎样才能判断当前这个方法运行的上下文是在trigger里面还是batch里面啊。此时的我就和他说:哦我的上帝,先必应,在谷歌,找不到解决方案再找我,我就可以和你很自信的说这个实现不了了,搞定~~~当然,玩笑归玩笑,本着朋友的信任,基本上朋友问的问题我都知无不言,所以我说,以我干salesforce 开发5年的经验来看,这个确实好像实现不了,只能告诉你如果想知道是否batch运行可以System.isBatchable()。我对apex的概念还是有点落后的,之前apex develop guide没事确实也扫过一遍,当时扫的时候还是V36.0,现在都已经看不到了。

这几天对象出差,在家呆着刷剧也无聊,寻思好久没有看最新release的开发文档了,扫一扫哪些好用的新功能,混个脸熟。结果我发现前几天的回复是多么的无知,特此写下此篇,告诫自己不要太自负,温故而知新,说以前先多查查,多确定。

一. Quiddity

Quiddity是salesforce winter21新加的枚举类,apex如果使用,api version需要50及以上。我们通过上面的连接可以看到这个枚举类中包含的枚举元素。元素很多,找几个单独说一下:

  • ANONYMOUS: 匿名块或者develop console执行的代码,运行时环境将会是 ANONYMOUS;
  • AURA: 通过aura或者lwc调用的代码,运行时环境将会是AURA,需要注意的是,目前至少在API 51的版本上,无法区分当前运行的是aura还是lwc,以后有可能会改善吧;
  • BATCH_APEX:当前运行代码环境是batch job场景;
  • FUTURE:当前运行代码环境是feature场景;
  • QUICK_ACTION:当前运行的代码环境是 quick action;
  • REMOTE_ACTION:通常用于classic场景的 remote action;
  • SYNCHRONOUS:通常用于trigger等代码同步运行的场景;
  • VF: 通过VF page去触发的场景。

还有很多其他的枚举元素用于不同的场景,感兴趣的自行查看,那么如何在apex中获取当前的枚举呢,更简单了。只需要通过 Request获取当前的请求,然后调getQuiddity即可。具体如下:

代码语言:javascript
复制
//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针对数据访问权限的安全化策略,后来过了一遍新的文档,发现还是有好多更新的内容没有查看,作罢了越更越多的特性点,还是推荐个人可以自己养成自我学习的习惯。篇中有错误欢迎指出,有不懂欢迎留言。自信是好东西,前提是有支撑着你自信的能力,我这次很惭愧。技术不断的更新变化,拥抱变化,不断努力。共勉。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-03-05 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
批量计算
批量计算(BatchCompute,Batch)是为有大数据计算业务的企业、科研单位等提供高性价比且易用的计算服务。批量计算 Batch 可以根据用户提供的批处理规模,智能地管理作业和调动其所需的最佳资源。有了 Batch 的帮助,您可以将精力集中在如何分析和处理数据结果上。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档