zoukankan      html  css  js  c++  java
  • 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即可。具体如下:

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

    作者:zero

    博客地址:http://www.cnblogs.com/zero-zyq/

    本文欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接

    个人下载了一些相关学习的PDF文件,如果需要下载请访问百度云 点击此处访问 密码:jhuy

    如果文章的内容对你有帮助,欢迎点赞~

    为方便手机端查看博客,现正在将博客迁移至微信公众号:Salesforce零基础学习,欢迎各位关注。

  • 相关阅读:
    监控Redis集群
    host主机监控规则
    Prometheus自身的监控告警规则
    Prometheus alerts 各种告警规则
    Elasticsearch官方文档离线访问实操指南
    Ceph 存储集群
    采用阿里云 yum的方式安装ceph
    设置HTTP请求自动跳转HTTPS
    jumpserver 2222端口的使用
    安装jumpserver 2.1.2版本遇到的坑
  • 原文地址:https://www.cnblogs.com/zero-zyq/p/14487301.html
Copyright © 2011-2022 走看看