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                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Jinget.AzureDevOps.Connector" Version="2.0.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Jinget.AzureDevOps.Connector --version 2.0.1                
#r "nuget: Jinget.AzureDevOps.Connector, 2.0.1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// 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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.0.1 622 7/1/2023
2.0.0 609 6/27/2023
1.0.0 608 6/24/2023