我是CRM的新手。我已经为应用程序实现了OAuth。我正在使用Web API方法来访问特定的CRM用户数据。我已经成功地为“获取用户机会”,“更新用户机会”实现了Web api。但是我无法为“接近机会”或“获胜机会”做同样的事情。
注意:访问用户数据时,我没有使用OrganizationService代理。我正在使用OAuth令牌并调用特定的API请求网址。
请指导我实现相同目标。如果有人可以在代码上显示任何示例,或者如何在邮递员中进行测试,则非常感谢。
我的查询:
1)是否可以使用OAuth令牌,我们可以在不传递用户凭据的情况下连接到OrganizationServiceProxy吗?
例如:获得机会
请求网址:https://testdevcrm.crm8.dynamics.com/api/data/v9.1/opportunities
标题:
Authorization:Bearer(accessToken)
Accept:application / json
OData-MaxVersion:4.0
OData版本:4.0
方法类型:GET
代码
#region FectchUserOpportunities
public async Task<JToken> FectchUserOpportunities(string systemuserid,string bearerToken)
{
JToken jResu = null;
try
{
var httpClient = new HttpClient();
httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", bearerToken);
ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12;
string filter = "&$filter=_createdby_value eq '" + systemuserid + "' and opportunityid ne null and statuscode eq 1&$orderby=createdon asc&$top=5";
string opportunitiesURL = string.Concat(GenericMethods.GetAppSetting("FetchCRMOpportunitiesAPI"), filter);
var result = httpClient.GetAsync(opportunitiesURL).Result;
if (result != null)
{
var opporJSON = await result.Content.ReadAsStringAsync();
JToken jsonResult = JsonConvert.DeserializeObject<JObject>(opporJSON);
jResu = jsonResult["value"];
}
else
{
jResu = null;
}
}
catch (Exception ex)
{
}
return jResu;
}
#endregion
答案 0 :(得分:1)
好吧,可以通过WebAPI调用特定操作,以WIN或LOSS的形式关闭机会。叫做
WinOpportunity
失去机会
现在如何通过Webapi调用它。这是从前端方调用它的示例代码。您可以使用Postman轻松复制此代码,并查看它的帮助。
var parameters = {};
var opportunityclose = {};
opportunityclose.activityid = "00000000-0000-0000-0000-000000000000"; //Delete if creating new record
opportunityclose["@odata.type"] = "Microsoft.Dynamics.CRM.opportunityclose";
opportunityclose["opportunityid@odata.bind"] = "/opportunities(8CA20837-715F-E911-A83A-000D3A3852A3)";
parameters.OpportunityClose = opportunityclose;
parameters.Status = 0;
var req = new XMLHttpRequest();
req.open("POST", Xrm.Page.context.getClientUrl() + "/api/data/v9.1/WinOpportunity", false);
req.setRequestHeader("OData-MaxVersion", "4.0");
req.setRequestHeader("OData-Version", "4.0");
req.setRequestHeader("Accept", "application/json");
req.setRequestHeader("Content-Type", "application/json; charset=utf-8");
req.onreadystatechange = function() {
if (this.readyState === 4) {
req.onreadystatechange = null;
if (this.status === 204) {
//Success - No Return Data - Do Something
} else {
Xrm.Utility.alertDialog(this.statusText);
}
}
};
req.send(JSON.stringify(parameters));
var parameters = {};
var opportunityclose = {};
opportunityclose.activityid = "00000000-0000-0000-0000-000000000000"; //Delete if creating new record
opportunityclose["@odata.type"] = "Microsoft.Dynamics.CRM.opportunityclose";
opportunityclose["opportunityid@odata.bind"] = "/opportunities(8CA20837-715F-E911-A83A-000D3A3852A3)";
parameters.OpportunityClose = opportunityclose;
parameters.Status = 0;
var req = new XMLHttpRequest();
req.open("POST", Xrm.Page.context.getClientUrl() + "/api/data/v9.1/LoseOpportunity", false);
req.setRequestHeader("OData-MaxVersion", "4.0");
req.setRequestHeader("OData-Version", "4.0");
req.setRequestHeader("Accept", "application/json");
req.setRequestHeader("Content-Type", "application/json; charset=utf-8");
req.onreadystatechange = function() {
if (this.readyState === 4) {
req.onreadystatechange = null;
if (this.status === 204) {
//Success - No Return Data - Do Something
} else {
Xrm.Utility.alertDialog(this.statusText);
}
}
};
req.send(JSON.stringify(parameters));
答案 1 :(得分:0)
最后,我使用Web api实现了C#代码,以获得机会作为WON。
代码:
#region UpdateUserOpportunityWon
public async Task<string> UpdateUserOpportunityWon(string bearerToken, string opportunityid, string wonsubject, string actualend = "", int actualrevenue = 0, string wondesc = "")
{
string jResu = "";
try
{
string opportunitiesURL = string.Format(GenericMethods.GetAppSetting("UpdateCRMOpportunityAPI"), opportunityid);
var httpClient = new HttpClient();
httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", bearerToken);
httpClient.DefaultRequestHeaders.Add("OData-MaxVersion", "4.0");
httpClient.DefaultRequestHeaders.Add("OData-Version", "4.0");
httpClient.DefaultRequestHeaders.Add("Accept", "application/json");
//httpClient.DefaultRequestHeaders.Add("Content-Type", "application/json; charset=utf-8");
ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12;
string jsonBody = "";
if (String.IsNullOrEmpty(actualend))
{
jsonBody = "{'Status':3,'OpportunityClose':{'subject':'" + wonsubject + "','actualrevenue':" + actualrevenue + ",'description':'" + wondesc + "','opportunityid@odata.bind':'" + opportunitiesURL + "'}}";
}
else
{
jsonBody = "{'Status':3,'OpportunityClose':{'subject':'" + wonsubject + "','actualrevenue':" + actualrevenue + ",'actualend':'" + actualend + "','description':'" + wondesc + "','opportunityid@odata.bind':'" + opportunitiesURL + "'}}";
}
var content = new StringContent(jsonBody, Encoding.UTF8, "application/json");
string opportunitiesWonURL = string.Format(GenericMethods.GetAppSetting("UpdateOpportunityWon"), opportunityid);
var result = httpClient.PostAsync(opportunitiesWonURL, content).Result;
// TelemetryHelper.Trace("API res", result.ToString());
string statuscode = result.StatusCode.ToString();
if (result != null)
{
var opporJSON = await result.Content.ReadAsStringAsync();
if (statuscode.ToLower() == "nocontent")
{
jResu = statuscode; //success
}
else
{
JToken jsonResult = JsonConvert.DeserializeObject<JObject>(opporJSON);
if (jsonResult["error"] != null)
{
jResu = jsonResult["error"]["message"].ToString();
}
}
}
else
{
jResu = Resources.CommonAPIError + statuscode;
}
}
catch (Exception ex)
{
TelemetryHelper.Trace("API Ex", ex.Message.ToString());
}
return jResu;
}
#endregion