
Three Simple Methods to Invoke the Vidispine API From .NET Code by Vidispine June 15, 2016 Howto
Binagora is on fire and returns with another guest post. We know we have a bunch of developers on .NET, therefore we created a .NET SDK. This post shows how you can invoke the Vidispine API from .NET, using the SDK or using standard .NET classes. All with example code.
The following article describe three simple ways to invoke the Vidispine API from .NET code. Two of them use standard .NET classes, while the last one uses the Vidispine .NET SDK. Code snippets were written using C# but you can of course use another language, such as VB.NET, if you want to.
We'll use the simplest test case possible, and let us retrieve the id of the first available item in the Vidispine library.
First of all, let's see how it's done in Postman. As you may already know, it's just a simple http GET request to the Vidispine API to retrieve an item id.
Notice that we're using two Postman variables for a specific environment:
{{vs}}: this is the Vidispine base address (url + port)
{{credentials}}: this is the username and password in basic http format (:) encoded in base64.
Ok, that was the principle of how to query the Vidispine API for an item id. Now let's do the same thing from code.
Given the following constants:
C#
private const string address = http://xxx.xxx.xxx.xxx:8080/API; private const string userName = admin; private const string password = admin;
1
2
3
private const string address = http://xxx.xxx.xxx.xxx:8080/API;
private const string userName = admin;
private const string password = admin;
Option 1: Using WebRequest class
C#
private static string GetUsingWebRequest(string requestUri) { var request = (HttpWebRequest)WebRequest.Create(requestUri); request.Credentials = new NetworkCredential(userName, password); using(var response = (HttpWebResponse)request.GetResponse()) { var stream = response.GetResponseStream(); var reader = new StreamReader(stream); string result = reader.ReadToEnd(); return result; } }
1
2
3
4
5
6
7
8
9
10
11
12
13
14
private static string GetUsingWebRequest(string requestUri)
{
var request = (HttpWebRequest)WebRequest.Create(requestUri);
request.Credentials = new NetworkCredential(userName, password);
using(var response = (HttpWebResponse)request.GetResponse())
{
var stream = response.GetResponseStream();
var reader = new StreamReader(stream);
string result = reader.ReadToEnd();
return result;
}
}
Create a WebRequest, set the credentials and execute the request. Remember to release the request calling the Dispose() method or wrapping the instance into a using statement as we did in the sample.
Notice that in this case, we know the response contains a plain text with an item id. That's why we read the stream, and converts it into a string instead of a specific type.
Option 2: Using HttpClient class
C#
private static string GetUsingHttpClient(string requestUri) { var handler = new HttpClientHandler() { Credentials = new NetworkCredential(userName, password) }; var client = new HttpClient(handler); client.BaseAddress = new Uri(address); string message = client.GetStringAsync(requestUri).Result; return message; }
1
2
3
4
5
6
7
8
9
10
11
12
13
private static string GetUsingHttpClient(string requestUri)
{
var handler = new HttpClientHandler()
{
Credentials = new NetworkCredential(userName, password)
};
var client = new HttpClient(handler);
client.BaseAddress = new Uri(address);
string message = client.GetStringAsync(requestUri).Result;
return message;
}
Similar to previous option, it is just a matter of using another http client from the .NET framework.
In this case, credentials are specified on a client handler, then the http client is created using that handler.
The request is executed asynchronously, which is powerful and could be needed in a real situation.
In this case we're just reading the Result property immediately, but it's important to understand that the request is fired in an independent thread. Once thread is completed, you can execute your own callback.
Option 3: Using Vidispine .NET SDK
C#
private static string GetUsingVidispineSdk() { var rootResource = new VidispineResource(address).Authenticate(userName, password); var itemResource = rootResource.Item; string result = itemResource.SearchPlainGET.Number(1).CallText(); return result; }
1
2
3
4
5
6
7
8
private static string GetUsingVidispineSdk()
{
var rootResource = new VidispineResource(address).Authenticate(userName, password);
var itemResource = rootResource.Item;
string result = itemResource.SearchPlainGET.Number(1).CallText();
return result;
}
Finally the easiest way to do it, just call the SDK. Notice that in this case, the action to be executed is not part of the address. You specify the object and action based on the properties. We may say this is the strongly typed option to do it.
You can find more information about how to download and use the Vidispine .NET SDK in the post Getting Started With the Vidispine .NET SDK. If you want to try out the SDK, you can find the latest versions of the SDK here:
64-bit version of the Vidispine .NET SDK v4.5
32-bit version of the Vidispine .NET SDK v4.5
Running the app will show you the result 3 times, once for each option. In this case first item available is #525 but of course that will depend on your environment.
You can download the full console app code from the following GitHub Gist.
Hope you like it.
This blog post was written by our friends at Binagora. Check them out and see how they can help you with your next Media&Entertainment project.
Most recent headlines
05/01/2027
Worlds first 802.15.4ab-UWB chip verified by Calterah and Rohde & Schwarz to be ...
01/06/2026
January 6 2026, 05:30 (PST) Dolby Sets the New Standard for Premium Entertainment at CES 2026
Throughout the week, Dolby brings to life the latest innovatio...
02/05/2026
Dalet, a leading technology and service provider for media-rich organizations, t...
01/05/2026
January 5 2026, 18:30 (PST) NBCUniversal's Peacock to Be First Streamer to ...
01/04/2026
January 4 2026, 18:00 (PST) DOLBY AND DOUYIN EMPOWER THE NEXT GENERATON OF CREATORS WITH DOLBY VISION
Douyin Users Can Now Create And Share Videos With Stun...
05/03/2026
More than 250 sports-graphics professionals packed into The Cutting Room in New ...
05/03/2026
Cosm announces that it will open its third immersive entertainment venue at downtown Atlanta's Centennial Yards on June 10, 2026. Its first public event wil...
05/03/2026
Following last year's broadcast television debut, The CW Network is growing its partnership with the Savannah Bananas, announcing that it will be the exclus...
05/03/2026
TGL presented by SoFi, the primetime, men's team golf league, announces AT&T...
05/03/2026
Ateme, which specializes in video compression software, announces that it has entered into a multi-year agreement with Netflix for the deployment of its TITAN L...
05/03/2026
As part of its strategy to deliver flexible and scalable media solutions, NEP Europe, part of NEP Group, has redesigned an outside broadcast (OB) unit to help b...
05/03/2026
Net Insight's Nimbra Edge and the Nimbra 400 series are now included in YouTube's Live verified encoders list. This confirms that the solutions have bee...
05/03/2026
Audinate, the creator of the Dante audio networking platform, announces the laun...
05/03/2026
LiveU announces the first large-scale deployment of its AI-driven LiveU IQ (LIQ) technology at a global, multi-venue sporting event, setting a new benchmark for...
05/03/2026
SportsEngine Play, a first-of-its-kind subscription streaming service for captur...
05/03/2026
The senior from small-town Pennsylvania has had a huge impact on the Spartans' B1G Student U program
In the live-sports-video industry, the future is brigh...
05/03/2026
Real-time animated presentation of Capitals-Rangers game blends tracking data, o...
05/03/2026
With Super Bowl LX taking place in Santa Clara, all eyes were not only on the field - but on the future of fandom itself. New technologies are being introduced ...
05/03/2026
The network aims for a uniform production while accommodating tech differences i...
05/03/2026
MLB Network produces the host broadcast, and FOX layers in cameras, studio prese...
05/03/2026
Barbara Hammer appears in Barbara Forever by Brydie O'Connor, an official se...
05/03/2026
A little over a year ago, Spotify introduced the quarterly Creator Milestone Awa...
05/03/2026
SBS and Mint Pictures to chronicle the Bondi terror attack in major feature docu...
05/03/2026
Winter Olympic stars return to the ice for ISU World Figure Skating Championship...
05/03/2026
Rohde & Schwarz enables rapid validation of next-gen Wi-Fi 8 networking platform...
05/03/2026
Rohde & Schwarz acquires Software Radio Systems (SRS), specialists in software d...
05/03/2026
Quality control (QC) has long been a gatekeeper of technical fidelity. Editors and technicians have adhered to a simple, disciplined checklist: bitrate, resolut...
05/03/2026
Leading video software provider Synamedia today announced it has partnered with Swiss sports technology specialist, Asport to deliver global live streaming for ...
05/03/2026
Advanced Systems Group, LLC (ASG), a technology and services provider for media creatives and content owners, announced the promotion of Gretchen Taipale to Vic...
05/03/2026
Clear-Com has provided Gen-IC virtual intercom, its cloud-based voice communications system for SaxaVord Spaceport, the first fully licensed vertical launch s...
05/03/2026
The Hollywood Professional Association (HPA) concluded the 2026 HPA Tech Retreat, convening more than 800 industry leaders, technologists, creatives and executi...
05/03/2026
LynTec, a leading manufacturer of electrical power control solutions for professional audio, video, and lighting systems, today announced that its new Dual DMX ...
05/03/2026
Snicket Labs is pleased to announce a new distribution partnership with ES Broadcast for its award winning solutions, Match and Enrich.
Under the agreement, ES...
05/03/2026
LiveU today announced the first large-scale deployment of its AI-driven LiveU IQ (LIQ ) technology at a global, multi-venue sporting event, setting a new benchm...
05/03/2026
Thursday 5 March 2026
Sky News secures ninth News Channel of the Year award as ...
05/03/2026
Thursday 5 March 2026
Sky Sports launches first ever nationwide creator competi...
05/03/2026
Back to All News
Innovation for Filmmaking, By Filmmakers: Why InterPositive Is Joining Netflix
Business
05 March 2026
Global
Link copied to clipboard
Dow...
05/03/2026
New LinkedIn Data Shows Women's Path to Senior Leadership Is Narrowing Published on Mar 5, 2026 Categories: Data and insights
LinkedIn Corporate Commun...
05/03/2026
SAN JOSE, Calif. - March 5, 2026 - At the 2026 NAB Show, Harmonic (NASDAQ: HLIT)...
05/03/2026
Comscore and Yahoo DSP Partner to Advance CTV Political Advertising with Proximi...
05/03/2026
March is in full bloom, and that means a fresh wave of games heading to the cloud. 15 new titles are joining the GeForce NOW library this month.
Leading the Ma...
04/03/2026
Lega Basket Serie A (LBA), the governing body for Italy's premier basketball...
04/03/2026
Wrexham AFC co-chairmen Rob Mac and Ryan Reynolds will host a first-of-its-kind ...
04/03/2026
The countdown is underway and with just 100 days to go until the world's greatest sporting event begins on Thurs., June 11, FOX Sports, America's Englis...
04/03/2026
No matter where they are in the world, service members and veterans can stream N...
04/03/2026
Telemundo officially releases Somos M s, the anthem for the network's cove...
04/03/2026
The Hollywood Professional Association (HPA) concluded the 2026 HPA Tech Retreat, convening more than 800 industry leaders, technologists, creatives, and execut...
04/03/2026
Smith Entertainment Group transformed how local sports are consumed by creating ...
04/03/2026
The production method, which spans a distance of 36.2 miles, was designed and im...
04/03/2026
Haivision, a global provider of mission-critical, real-time video networking and...