Sample code for 30+ languages & platforms
C#

Trello OAuth1 Authorization

See more OAuth1 Examples

Demonstrates OAuth1 authentication for Trello.

Chilkat C# Downloads

C#
bool success = false;

// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

string consumerKey = "TRELLO_CONSUMER_KEY";
string consumerSecret = "TRELLO_CONSUMER_SECRET";

string requestTokenUrl = "https://trello.com/1/OAuthGetRequestToken";
string authorizeUrl = "https://trello.com/1/OAuthAuthorizeToken";
string accessTokenUrl = "https://trello.com/1/OAuthGetAccessToken";

// The port number is picked at random. It's some unused port that won't likely conflict with anything else..
string callbackUrl = "http://localhost:3017/";
int callbackLocalPort = 3017;

// The 1st step in 3-legged OAuth1.0a is to send a POST to the request token URL to obtain an OAuth Request Token
Chilkat.Http http = new Chilkat.Http();

http.OAuth1 = true;
http.OAuthConsumerKey = consumerKey;
http.OAuthConsumerSecret = consumerSecret;
http.OAuthCallback = callbackUrl;

Chilkat.HttpRequest req = new Chilkat.HttpRequest();
req.HttpVerb = "POST";
req.ContentType = "application/x-www-form-urlencoded";

Chilkat.HttpResponse resp = new Chilkat.HttpResponse();
success = http.HttpReq(requestTokenUrl,req,resp);
if (success == false) {
    Debug.WriteLine(http.LastErrorText);
    return;
}

// If successful, the resp.BodyStr contains something like this:  
// oauth_token=c173ff088a09a67389a42b1ee22366a4&oauth_token_secret=717e6015c6749fe050a923516e739dbb&oauth_callback_confirmed=true
Debug.WriteLine(resp.BodyStr);

Chilkat.Hashtable hashTab = new Chilkat.Hashtable();
hashTab.AddQueryParams(resp.BodyStr);

string requestToken = hashTab.LookupStr("oauth_token");
string requestTokenSecret = hashTab.LookupStr("oauth_token_secret");
http.OAuthTokenSecret = requestTokenSecret;

Debug.WriteLine("oauth_token = " + requestToken);
Debug.WriteLine("oauth_token_secret = " + requestTokenSecret);

// ---------------------------------------------------------------------------
// The next step is to form a URL to send to the authorizeUrl
// This is an HTTP GET that we load into a popup browser.
Chilkat.StringBuilder sbUrlForBrowser = new Chilkat.StringBuilder();
sbUrlForBrowser.Append(authorizeUrl);
sbUrlForBrowser.Append("?oauth_token=");
sbUrlForBrowser.Append(requestToken);
sbUrlForBrowser.Append("&scope=read,write,account");

string url = sbUrlForBrowser.GetAsString();

Debug.WriteLine("url = " + url);

// When the urlForBrowser is loaded into a browser, the response from Trello will redirect back to localhost:3017
// We'll need to start a socket that is listening on port 3017 for the callback from the browser.
Chilkat.Socket listenSock = new Chilkat.Socket();

int backLog = 5;
success = listenSock.BindAndListen(callbackLocalPort,backLog);
if (success == false) {
    Debug.WriteLine(listenSock.LastErrorText);
    return;
}

// Wait for the browser's connection in a background thread.
// (We'll send load the URL into the browser following this..)
// Wait a max of 60 seconds before giving up.
Chilkat.Socket sock = new Chilkat.Socket();
int maxWaitMs = 60000;
Chilkat.Task task = listenSock.AcceptNextAsync(maxWaitMs,sock);
task.Run();

// Launch the system's default browser navigated to the URL.
Chilkat.OAuth2 oauth2 = new Chilkat.OAuth2();
success = oauth2.LaunchBrowser(url);
if (success == false) {
    Debug.WriteLine(oauth2.LastErrorText);
    return;
}

// Wait for the listenSock's task to complete.
success = task.Wait(maxWaitMs);
if (!success || (task.StatusInt != 7) || (task.TaskSuccess != true)) {
    if (!success) {
        // The task.LastErrorText applies to the Wait method call.
        Debug.WriteLine(task.LastErrorText);
    }
    else {
        // The ResultErrorText applies to the underlying task method call (i.e. the AcceptNextConnection)
        Debug.WriteLine(task.Status);
        Debug.WriteLine(task.ResultErrorText);
    }

    return;
}

// If we get to this point, the connection from the browser arrived and was accepted.

// We no longer need the listen socket...
// Stop listening on port 3017.
listenSock.Close(10);

// Read the start line of the request..
string startLine = sock.ReceiveUntilMatch("\r\n");
if (sock.LastMethodSuccess == false) {
    Debug.WriteLine(sock.LastErrorText);
    return;
}

// Read the request header.
string requestHeader = sock.ReceiveUntilMatch("\r\n\r\n");
if (sock.LastMethodSuccess == false) {
    Debug.WriteLine(sock.LastErrorText);
    return;
}

// The browser SHOULD be sending us a GET request, and therefore there is no body to the request.
// Once the request header is received, we have all of it.
// We can now send our HTTP response.
Chilkat.StringBuilder sbResponseHtml = new Chilkat.StringBuilder();
sbResponseHtml.Append("<html><body><p>Chilkat thanks you!</b></body</html>");

Chilkat.StringBuilder sbResponse = new Chilkat.StringBuilder();
sbResponse.Append("HTTP/1.1 200 OK\r\n");
sbResponse.Append("Content-Length: ");
sbResponse.AppendInt(sbResponseHtml.Length);
sbResponse.Append("\r\n");
sbResponse.Append("Content-Type: text/html\r\n");
sbResponse.Append("\r\n");
sbResponse.AppendSb(sbResponseHtml);

sock.SendString(sbResponse.GetAsString());
sock.Close(50);

// The information we need is in the startLine.
// For example, the startLine will look something like this:
//  GET /?oauth_token=c173ff088a09a67389b42b1ee32366a4&oauth_verifier=c65bc8eed882e04bb94023bb12c0dbef HTTP/1.1
Chilkat.StringBuilder sbStartLine = new Chilkat.StringBuilder();
sbStartLine.Append(startLine);
int numReplacements = sbStartLine.Replace("GET /?","");
numReplacements = sbStartLine.Replace(" HTTP/1.1","");
sbStartLine.Trim();

// oauth_token=c173ff088a09a67389b42b1ee32366a4&oauth_verifier=c65bc8eed882e04bb94023bb12c0dbef
Debug.WriteLine("startline: " + sbStartLine.GetAsString());

hashTab.Clear();
hashTab.AddQueryParams(sbStartLine.GetAsString());

requestToken = hashTab.LookupStr("oauth_token");
string authVerifier = hashTab.LookupStr("oauth_verifier");

// ------------------------------------------------------------------------------
// Finally , we must exchange the OAuth Request Token for an OAuth Access Token.

http.OAuthToken = requestToken;
http.OAuthVerifier = authVerifier;req.HttpVerb = "POST";

req.HttpVerb = "POST";
req.ContentType = "application/x-www-form-urlencoded";

success = http.HttpReq(accessTokenUrl,req,resp);
if (success == false) {
    Debug.WriteLine(http.LastErrorText);
    return;
}

// Make sure a successful response was received.
if (resp.StatusCode != 200) {
    Debug.WriteLine(resp.StatusLine);
    Debug.WriteLine(resp.Header);
    Debug.WriteLine(resp.BodyStr);
    return;
}

// If successful, the resp.BodyStr contains something like this:
// oauth_token=4618e19f5101b7199f75aA9e678d1585576ad84fb89fa40c85c4da13589010d5&oauth_token_secret=64a997b26ea1f47105eca36ce1a5d22e
Debug.WriteLine("response BodyStr = " + resp.BodyStr);

hashTab.Clear();
hashTab.AddQueryParams(resp.BodyStr);

string accessToken = hashTab.LookupStr("oauth_token");
string accessTokenSecret = hashTab.LookupStr("oauth_token_secret");

// The access token + secret is what should be saved and used for
// subsequent REST API calls.
Debug.WriteLine("Access Token = " + accessToken);
Debug.WriteLine("Access Token Secret = " + accessTokenSecret);

// Save the access token for subsequent REST API calls.
Chilkat.JsonObject json = new Chilkat.JsonObject();
json.AppendString("oauth_token",accessToken);
json.AppendString("oauth_token_secret",accessTokenSecret);

Chilkat.FileAccess fac = new Chilkat.FileAccess();
fac.WriteEntireTextFile("qa_data/tokens/trello.json",json.Emit(),"utf-8",false);

Debug.WriteLine("Success.");