VBA 实现outlook 当邮件设置category: red 即触发自动创建jira issue

embedded/2024/12/22 1:03:47/

1. 打开: Outlook VBA(Visual Basic for Applications)

方法一: 在邮件直接搜索:Visual Basic editor

方法二: File -> Options -> Customize Ribbon-> 打钩 如下图:

2.设置运行VBA 脚本:

File -> Options -> Trust center -> Trust center Settings->Macro Settings ->打钩Enable all macros  如下图:

3.在打开的VBA中ThisOutlookSession文件中添加如下代码:

Public WithEvents objExplorer As Outlook.Explorer
Public WithEvents objInspectors As Outlook.Inspectors
Public WithEvents objMail As Outlook.MailItemPrivate Sub Application_Startup()Set objExplorer = Outlook.Application.ActiveExplorerSet objInspectors = Outlook.Application.Inspectors
End SubPrivate Sub objExplorer_Activate()On Error Resume NextSet objMail = objExplorer.Selection.Item(1)
End SubPrivate Sub objInspectors_NewInspector(ByVal Inspector As Inspector)Set objMail = Inspector.CurrentItem
End SubPrivate Sub objMail_PropertyChange(ByVal Name As String)Dim url As StringDim jsonBody As StringDim userName As StringDim apiToken As StringDim responseText As StringDim authCode As StringDim statusCode As IntegerIf Name = "Categories" ThenIf objMail.Categories = "Red Category" ThenMsgBox "You set the category as red for '" & objMail.Subject & "'"Debug.Print "objMail.Body:" & objMail.Bodyurl = "https://{jiraurl}/rest/api/2/issue"'url = "https://{jiraurl}/rest/api/2/issue/issueNumber"userName = "userName@ehealth.com"apiToken = "yourToken"jsonBody = "{" & _"""fields"": {" & _"""project"": {""id"": ""10000""}," & _"""summary"": """ & objMail.Subject & """," & _"""description"": """ & objMail.Body & """," & _"""issuetype"": {""name"": ""Maintenance""}," & _"""customfield_10029"": {""value"": ""2 - High""}," & _"""customfield_10063"": {""value"": ""*All test*""}," & _"""customfield_10030"": {""value"": ""PROD""}," & _"""customfield_10187"": {""value"": ""test""}," & _"""assignee"": {""accountId"": ""testid""}" & _"}}"Debug.Print "jsonBody:" & jsonBody'authCode = "Basic " & Base64Encode(userName & ":" & apiToken)authCode = "Basic test" & "RC1JZDZPX1FoeHFwZ0V1akNMX2NqOF83d29BMVUxX2praUJURkxSMFA5R0NadlJzaGJpaE01" & "NHRNVFNyTlQxcFFEc1BScTdqdko1bVdEWHdkWS1EZnF4NnMzSFdLTGQzZVJiTThPaUdaU2Vf" & "OHNWWG5yNWdTa0dmWk1DUG43b2dqNXJheVRYazhraDRDbWRDSjFobkR5az1FQTA1Nzcx" & "OQ=="Debug.Print "authCode:" & authCodeDim objHTTP As ObjectSet objHTTP = CreateObject("MSXML2.ServerXMLHTTP")'objHTTP.Open "GET", url, False'objHTTP.setRequestHeader "Accept", "application/json"'objHTTP.setRequestHeader "Content-Type", "application/json"'objHTTP.setRequestHeader "Authorization", authCode'objHTTP.SendobjHTTP.Open "POST", url, FalseobjHTTP.setRequestHeader "Accept", "application/json"objHTTP.setRequestHeader "Content-Type", "application/json"objHTTP.setRequestHeader "Authorization", authCodeobjHTTP.Send jsonBodyresponseText = objHTTP.responseTextstatusCode = objHTTP.StatusDebug.Print "Response Status Code: " & statusCodeDebug.Print "Response Body : " & responseTextMsgBox "Response Status Code: " & statusCode & vbCrLf & "Response Body : " & responseTextEnd IfEnd If
End Sub
Function Base64Encode(ByVal sText As String) As StringDim arrData() As BytearrData = StrConv(sText, vbFromUnicode)Dim objXML As ObjectSet objXML = CreateObject("MSXML2.DOMDocument")Dim objNode As ObjectSet objNode = objXML.createElement("b64")objNode.DataType = "bin.base64"objNode.nodeTypedValue = arrDataBase64Encode = objNode.textSet objNode = NothingSet objXML = Nothing
End Function

如下图:

4.可以点击上图View->Immediate Windows 查看debug的控制台输出,方便调试代码


http://www.ppmy.cn/embedded/6465.html

相关文章

FineBI 6.0 Linux 部署、ClickHouse 源配置

文章目录 FineBI 概述FineBI 部署安装环境说明1.下载安装包2.安装3.初始化设置4.登录5.快速入门 启动与关闭启动关闭 ClickHouse 源配置开启驱动上传功能驱动上传数据库连接配置基础表属性设置数据导入 FineBI 概述 FineBI 是一款国产的商业智能(BI)软件…

gazebo中vins-fusion在仿真小车上的部署

软件要求:Ubuntu 20.04 ros的noetic版本,我是在虚拟机vitrualbox上运行的 这几天在学ROS,跟着赵虚左老师过了一遍之后,感觉还是有很多不懂的地方,xtdrone上仿真跟着文档走了一遍,好像没学到什么东西&#…

微服务架构中的数据一致性设计及技术实现

目录 1.概要设计 1.1数据一致性模型 1.1.1 强一致性 1.1.2 最终一致性 1.2 技术实现策略 1.2.1 使用分布式事务 1.2.2 基于事件的最终一致性(Event-Driven Architecture, EDA) 1.2.3 使用数据库的特性 1.2.4 业务层面的策略 1.2.5 分布式锁和版…

【Python】如何在Ubuntu上设置Python脚本开机自启

你不知道我为什么狠下心 盘旋在你看不见的高空里 多的是 你不知道的事 蝴蝶眨几次眼睛 才学会飞行 夜空洒满了星星 但几颗会落地 我飞行 但你坠落之际 很靠近 还听见呼吸 对不起 我却没捉紧你 🎵 王力宏《你不知道的事》 前置要求 确保你的Ub…

JVM概述

JVM概述 1、一些性能上的问题 我好好运行的线上系统突然间卡死了,系统无法访问,当然这个原因非常多;想解决线上的JVM GC问题却无从下手;新的项目上线了,对于各种JVM参数的设置一脸茫然,全部直接默认&…

JS继承与原型、原型链

在 JavaScript 中,继承是实现代码复用和构建对象关系的重要概念。本文将讨论原型链继承、构造函数继承以及组合继承等几种常见的继承方式,并提供相应的示例代码,并分析它们的特点、优缺点以及适用场景。 在开始讲解 JavaScript 的继承方式之…

什么是边缘计算?它为何如此重要?-天拓四方

随着信息技术的快速发展,数据处理和计算的需求日益增大,特别是在实时性要求极高的场景中,传统的云计算模式面临着巨大的挑战。在这样的背景下,边缘计算作为一种新兴的计算模式,正逐渐受到业界的广泛关注。那么&#xf…

单页面应用使用Nginx部署页面路由直接访问404问题

使用Nginx发布单页面应用时候,因为只有一个index.html页面可能导致直接访问具体页面路由报404错误,如: 直接访问http://www.test.com正常 访问http://www/test.com/system/list 则报404 需要修改nginx配置让其所有未找到资源都返回到index.h…