
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...
09/03/2026
Foos Gone Wild and Combate Global have teamed up to create a twist on combat sports competition, announcing the launch of a special amateur Mixed Martial Arts (...
09/03/2026
At the 2026 NAB Show, Harmonic will introduce significant enhancements to its video appliances and SaaS solutions, highlighted by a next-generation media server...
09/03/2026
ESPN's March 3 spring training matchup between Team USA and the San Francisc...
09/03/2026
Most Valuable Promotions (MVP) announces the launch of MVPW, a new global platfo...
09/03/2026
Behind The Mic provides a roundup of recent news regarding on-air talent, includ...
09/03/2026
From Super Bowl compounds to Final Four setups, the Hofstra graduate helps coord...
09/03/2026
Stamford plays a key role, but a small team in Cortina and Milan powers local presence and mixed-zone coverage...
09/03/2026
The event brings together SVG's previous Cloud Production and Content Management Forums into a single, comprehensive day of programming...
09/03/2026
Updated Mar 9, 2026
Live surround sound has been a part of the plan for Roman a...
09/03/2026
Contains all six dual-ensemble libraries
VSL's Duality Strings series offers an intriguing alternative to your average string library, capturing two str...
09/03/2026
Outstanding Contribution To UK Music
Photo: Samuel Bradley
Ahead of their upcoming MPG Awards, the Music Producers Guild (MPG) have revealed the latest win...
09/03/2026
Two new high-quality DI boxes announced
Boasting some impressive technical specifications and versatile routing options, Strymon's latest active DI boxe...
09/03/2026
Latest MPE-capable Soundbox library released
The follow-up release for Sonora Cinematic's Pure Nylon has arrived, and becomes the latest addition to the...
09/03/2026
Popular wireless mic head design revived
Sennheiser have revealed that the MD 9235, a cardioid mic head designed to pair up with their handheld wireless sys...
09/03/2026
Captures two sought-after Dumble combo amps
The latest TONEX release captures a pair of sought-after Dumble amplifiers from IK Multimedia's private amp ...
09/03/2026
Flexible all-analogue insert matrix joins line-up
HUM Audio Devices don't tend to do things by halves - even the quickest of glances at the likes of the...
09/03/2026
Captures three sought-after pianos
Rhodes latest software release brings together a collection of three virtual pianos: a concert grand, an acoustic upright...
09/03/2026
Flagship compressor gets an upgrade
Techivation's flagship compressor plug-in has just been treated to a ground-up rebuild that kits it out with some po...
09/03/2026
Profiler OS 14.0 enters open beta
Kemper's amp-modelling systems already have a great reputation, but the latest update to their systems' underlying...
09/03/2026
Procedural stems smasher & recomposition engine
Blinksonic have recently launched a new Reaktor-based tool which they say takes a radical departure from yo...
09/03/2026
13 - 15 March 2026 at University of Warwick Conference Centre
The Institute of Professional Sound (IPS) have announced that The IPS Training Weekend 2026 wi...
09/03/2026
Rohde & Schwarz and NETGEAR collaborate for next generation Wi-Fi 8 access point...
09/03/2026
Share
Copy link
Facebook
X
Linkedin
Bluesky
Email...
09/03/2026
Share
Copy link
Facebook
X
Linkedin
Bluesky
Email...
09/03/2026
Broadpeak, a leader in streaming and monetization at scale, will showcase its latest innovations for broadcasters and streaming platforms at NAB Show 2026 (boot...
09/03/2026
UKTV has agreed a new partnership deal with Samsung that makes UKTV's free linear channels available to internet-only Samsung TV viewers in the UK for the f...
09/03/2026
Monday 9 March 2026
Sky reveals first look trailer and sets premiere date for S...
09/03/2026
Monday 9 March 2026
Sky Appoints Damian Saunders as Managing Director of Sky Business
Sky has today announced the appointment of Damian Saunders as Managing D...
09/03/2026
Back to All News
The Predator of Seville premieres on Netflix on 27 March
Entertainment
09 March 2026
GlobalSpain
Link copied to clipboard
Download the im...
09/03/2026
Back to All News
Netflix Debuts the Trailer for Love is Blind: Sweden Season 3
Entertainment
09 March 2026
GlobalSweden
Link copied to clipboard
That wait...
09/03/2026
Bill O'Reilly Announces New Weekly Podcast We'll Do It LIVE! We'll Do It LIVE!' A Bold, Fresh Presentation from Bill O'Reilly
New York...
09/03/2026
MOSOLF SE & Co. KG Relies on green.screen from Arvato Systems for Strategic Ener...
09/03/2026
A powerful new national initiative supporting people living with dementia launch...
09/03/2026
AI is everywhere and accelerating everything - becoming essential infrastructure...
09/03/2026
ABB Robotics and NVIDIA today announced a breakthrough partnership that brings i...
07/03/2026
Share
Copy link
Facebook
X
Linkedin
Bluesky
Email...
06/03/2026
TNT Sports and the International Basketball Federation (FIBA) have reached a mul...
06/03/2026
OffBall and TOGETHXR, two influential young media companies in sports, announce a strategic and operational partnership in a shared push to scale and create inn...
06/03/2026
InfoComm 2026, a destination for AV, IT, broadcast, and AI-driven systems, annou...
06/03/2026
LTN and MediaKind announce a strategic partnership to integrate MediaKind's ...
06/03/2026
X Games and the Greater New Orleans Sports Foundation (GNOSF) announce that New Orleans, Louisiana, will host the first-ever X Games Championship event - the fi...
06/03/2026
As part of a busy start of the year at Chyron, the AXIS team developed a set of improvements for AXIS Maps. The features released empower users with more flexib...
06/03/2026
At the 2026 NAB Show, BeckTV, a premier systems integrator for the broadcast ind...
06/03/2026
At NAB Show 2026, Net Insight introduces Nimbra Live Intelligence, which definin...
06/03/2026
SES announces that it has added new Medium Earth Orbit (MEO) satellite capacity ...