Jinget.AzureDevOps.Connector
2.0.1
Prefix Reserved
dotnet add package Jinget.AzureDevOps.Connector --version 2.0.1
NuGet\Install-Package Jinget.AzureDevOps.Connector -Version 2.0.1
<PackageReference Include="Jinget.AzureDevOps.Connector" Version="2.0.1" />
paket add Jinget.AzureDevOps.Connector --version 2.0.1
#r "nuget: Jinget.AzureDevOps.Connector, 2.0.1"
// Install Jinget.AzureDevOps.Connector as a Cake Addin #addin nuget:?package=Jinget.AzureDevOps.Connector&version=2.0.1 // Install Jinget.AzureDevOps.Connector as a Cake Tool #tool nuget:?package=Jinget.AzureDevOps.Connector&version=2.0.1
Jinget Azure DevOps Connector
By using Jinget Azure DevOps Connector, the communication between your software application and Azure DevOps is facilitated and you can easily connect to Azure DevOps through this package.
How to Use:
Download the package from NuGet using Package Manager:
Install-Package Jinget.AzureDevOps.Connector
You can also use other methods supported by NuGet. Check Here for more information.
Consuming Process APIs
Create an object from ProcessConnector
class:
Note that if url
is not specified then https://dev.azure.com
will be used by default.
var connector = new ProcessConnector(pat, organization, apiVersion: "7.0");
Where pat
is your Personal Access Token. organization
is the name of your organization/collection. 7.0
is the Azure DevOps api version.
Get list of processes:
var result = await connector.ListAsync();
Get specific process details:
varr result = await connector.GetAsync(Guid.Parse("<process id>"));
Consuming Project APIs
Create object from ProjectConnector
class:
Note that if url
is not specified then https://dev.azure.com
will be used by default.
connector = new ProjectConnector(pat, organization, apiVersion: "7.0");
Create new project:
To create new project, create an object of type NewProjectModel
and pass it to the CreateAsync
method:
NewProjectModel newProject = new()
{
name = "<project name>",
capabilities = new NewProjectModel.Capabilities
{
versioncontrol = new NewProjectModel.Versioncontrol
{
sourceControlType = "Git"
},
processTemplate = new NewProjectModel.Processtemplate
{
templateTypeId = "b8a3a935-7e91-48b8-a94c-606d37c3e9f2"
}
},
description = "<description>"
};
await connector.CreateAsync(newProject);
Get List of projects:
await connector.ListAsync();
Get first n
projects:
Dictionary<string, string> urlParameters = new()
{
{ "$top","n"}
};
ProjectsListViewModel result = await connector.ListAsync(urlParameters);
Get specific project details:
await connector.GetAsync("<project name>")
Get specific projects properties:
Note that to use this api, you need to pass 7.0-preview.1
as api version
await projectConnector.GetPropertiesAsync(Guid.Parse(<project id>))
Delete Specific project:
await connector.DeleteAsync(Guid.Parse(<project id>))
Consuming Team APIs
Create object from TeamConnector
class:
Note that if apiVersion
is not specified while creating the connector, by default version 7.0-preview.3
will be selected. If url
is not specified then https://dev.azure.com
will be used by default.
connector = new TeamConnector(pat, organization);
Get list of all teams:
await connector.GetAllTeamsAsync();
Get list of all teams in specific project:
await connector.GetTeamsAsync(Guid.Parse("<project id>"));
Get specific team details inside a specific project:
await connector.GetAsync(Guid.Parse("<project id>"), "<team name>");
Consuming WorkItem APIs
Create object from WorkItemConnector
class:
Note that if apiVersion
is not specified while creating the connector, by default version 7.0
will be selected. If url
is not specified then https://dev.azure.com
will be used by default.
connector = new WorkItemConnector(pat, organization, "<project name>");
Get list of work items:
GetWorkItemBatchModel request = new GetWorkItemBatchModel
{
fields = new string[]
{
"System.Id",
"System.Title",
"System.WorkItemType",
"Microsoft.VSTS.Scheduling.RemainingWork"
},
ids = new string[] { "96", "97", "98" }
};
var result = await connector.ListBatchAsync<WorkItemBatchViewModel>(request);
In the above code we are going to select only System.Id
, System.Title
, System.WorkItemType
and Microsoft.VSTS.Scheduling.RemainingWork
fields.
Get list of work items using Work Item Query Language(WIQL):
string query = "SELECT System.Id, System.Title, System.WorkItemType, Microsoft.VSTS.Scheduling.RemainingWork FROM WorkItems";
await connector.ListWIQLAsync<WorkItemBatchViewModel>(query);
Create new work item:
List<NewWorkItemModel> properties = new List<NewWorkItemModel>()
{
new NewWorkItemModel()
{
path="/fields/System.Title",
value="<work item title>"
},
new NewWorkItemModel()
{
path="/fields/System.Description",
value="<work item description>"
},
new NewWorkItemModel()
{
path="/fields/System.History",
value="<work item comment>"
},
new NewWorkItemModel()
{
path="/fields/System.AssignedTo",
value="<assign the task to specified user>"
},
new NewWorkItemModel()
{
path="/fields/System.AreaPath",
value="<put the work item in given area>"
}
};
var result = await connector.CreateAsync("$<work item type>", properties);
Working with OData
Create object from ODataConnector
class:
new ODataConnector(pat, "https://analytics.dev.azure.com", organization, project: "<project name>")
You can pass any url which is suitable for you instead of https://analytics.dev.azure.com
.
Get work items from one project:
var queries = new Dictionary<string, string>()
{
{"$filter","WorkItemType eq 'Task' and State eq 'To Do'"},
{"$select","WorkItemId,Title,AssignedTo,State" }
};
ODataResultViewModel result = await connector.QueryAsync("WorkItems", queries);
In the above code we are going to select work items which are Task
and also are in To Do
state. Also we are going to select only WorkItemId
, Title
, AssignedTo
and State
fields.
Get work items from one project and deserial it to custom type:
var queries = new Dictionary<string, string>()
{
{"$filter","WorkItemType eq 'Task' and State eq 'To Do'"},
{"$select","WorkItemId,Title,AssignedTo,State" }
};
MyCustomType result = await connector.QueryAsync<MyCustomType>("WorkItems", queries);
Get work items from multiple projects:
var otherConnector = new ODataConnector(pat, "https://analytics.dev.azure.com", organization);
var queries = new Dictionary<string, string>()
{
{"$filter","(Project/ProjectName eq '<project one>' or Project/ProjectName eq '<project two>') and WorkItemType eq 'Task' and State eq 'To Do'"},
{"$select","WorkItemId,Title,AssignedTo,State" }
};
var result = await otherConnector.QueryAsync("WorkItems", queries);
For cross-project queries, In line 1, while creating an object of ODataConnector
type project name should not specified. Also in line number 4, in $filter
the desired projects are specified.
How to install
In order to install Jinget Azure DevOps Connector please refer to nuget.org
Further Information
Sample codes are available via Unit Test projects which are provided beside the main source codes.
Contact Me
👨💻 Twitter: https://twitter.com/_jinget
📧 Email: farahmandian2011@gmail.com
📣 Instagram: https://www.instagram.com/vahidfarahmandian
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.1 is compatible. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.1
- Jinget.Handlers.ExternalServiceHandlers (>= 2.0.3)
- System.Text.Json (>= 7.0.2)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.