
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 ...
04/08/2026
Dalet, a leading technology and service provider for media-rich organizations, t...
04/07/2026
April 7 2026, 19:00 (PDT) Detective Conan: Fallen Angel of the Highway Opens in...
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 ...
19/04/2026
Share
Copy link
Facebook
X
Linkedin
Bluesky
Email...
19/04/2026
Share
Copy link
Facebook
X
Linkedin
Bluesky
Email...
19/04/2026
Share
Copy link
Facebook
X
Linkedin
Bluesky
Email...
19/04/2026
Share
Copy link
Facebook
X
Linkedin
Bluesky
Email...
18/04/2026
MultiDyne Video & Fiber Optic Systems has begun shipping the C16-AM-12G audio mo...
18/04/2026
FOR-A America is set to detail AI functionality for its software-defined IMPULSE...
18/04/2026
Cobalt Digital and SineSix Media have announced a partnership to integrate the v...
18/04/2026
The ATSC, the broadcast standards association, is highlighting the status of the ATSC 3.0 internet protocol-based broadcast standard at the 2026 NAB Show. The e...
18/04/2026
Bolin Technology has introduced a new range of hardware for live production envi...
18/04/2026
KMH Integration is participating in the 2026 NAB Show, focusing on its AV Casti...
18/04/2026
Appear has appointed Mike Burk as vice president of business development for North America. Burk brings over two decades of experience in the broadcast and live...
18/04/2026
Skyline Communications is showcasing its DataMiner platform and the new DataMine...
18/04/2026
Telos Alliance is exhibiting its portfolio of broadcast audio products at the 20...
18/04/2026
TAG Video Systems has announced an integration with the AWS Elemental MediaConne...
18/04/2026
Blackmagic Design has announced DaVinci Resolve 21, with a public beta available now for download. The update will be demonstrated at NAB Show 2026 (Booth N2502...
18/04/2026
Calrec (Booth C6907) and Grass Valley (Booth C2408) have announced a long-term broadcast audio technology partnership at NAB Show 2026, integrating Calrec's...
18/04/2026
Free software mixer now in public beta
Blackmagic Design are best known for their high-end video hardware and DaVinci Resolve editing software, but the latt...
18/04/2026
The first signs of spring in March led to Poles spending significantly less time in front of their screens, leading to a sharp 22-minute drop in average viewing...
18/04/2026
Share
Copy link
Facebook
X
Linkedin
Bluesky
Email...
18/04/2026
Clear-Com announced FreeSpeak Cell , a cellular-based wireless intercom system that uses LTE and 5G infrastructure to support large-scale production communicat...
18/04/2026
Share
Copy link
Facebook
X
Linkedin
Bluesky
Email...
18/04/2026
Share
Copy link
Facebook
X
Linkedin
Bluesky
Email...
18/04/2026
Share
Copy link
Facebook
X
Linkedin
Bluesky
Email...
18/04/2026
Share
Copy link
Facebook
X
Linkedin
Bluesky
Email...
18/04/2026
New York, NY, April 17, 2026 -- TAG Video Systems has announced an integration with Amazon Web Services (AWS) Elemental MediaConnect Router. The integration bri...
18/04/2026
Pro Sound Effects (PSE), the leading provider of professionally recorded sound effects for film, television, advertising, and technology today announced the lau...
18/04/2026
Fincons Group, a multinational IT business consulting and system integrator firm, announced today that it has achieved Amazon Web Services (AWS) Media & Enterta...
18/04/2026
Adobe extends leadership in video: unleashing new AI-powered creation in Firefly...
17/04/2026
The World Fencing League (WFL) has announced DAZN as its primary global streamin...
17/04/2026
ARRI Releases ALEXA 35 SUP 6.0 and LPS-1 SUP 1.3 Software Updates
ARRI has announced software updates for its ALEXA 35 Live camera and Live Production System L...
17/04/2026
Sennheiser has announced Spectera Studio, an offline system planner for its Spec...
17/04/2026
Deltatre and the German Football Association (DFB) have announced DFB.TV+, a DFB-owned direct-to-consumer streaming service developed and operated by Deltatre. ...
17/04/2026
Global sports marketing agency IMG has announced new senior leadership roles, designed to strengthen how it supports rightsholders and partners in the midst of ...
17/04/2026
NAGRAVISION and Harmonic have announced a watermarking-as-a-service solution for...
17/04/2026
NETGEAR and EVS Broadcast Equipment have announced a global technology partnersh...
17/04/2026
America's broadcasters are launching the NEXTGEN TV Converter Box Program, a new initiative designed to provide millions of American viewers with a low-cost...
17/04/2026
Quantum Corp. will exhibit at NAB Show 2026 (Booth N1726), presenting what it ca...
17/04/2026
Leadership and Staff Announce '20/20 Vision' Playbook...
17/04/2026
TNT Sports has announced a multi-year agreement for U.S. media rights to the FIA World Endurance Championship (WEC). Three events will air on truTV - the 24 Hou...
17/04/2026
Scripps Sports has announced a multi-year broadcast partnership with PBR (Profes...
17/04/2026
Adder Technology, a specialist in connectivity solutions and high performance IP KVM, today announced the latest release of AIM, its IP KVM matrix management so...
17/04/2026
Victory , a free sports streaming platform from A Parent Media Co. Inc. (APMC), has announced a multi-year content distribution partnership with the Dallas Cowb...
17/04/2026
In-venue and creative video staffers at the professional and collegiate level have one major thing in common: the intensity and attention to detail ramps up dur...
17/04/2026
Quickplay has announced the full-scale deployment of Gray Media's streaming ...