.NetCore package to make trades with Unofficial Robinhood API.
See @Sanko's Unofficial Documentation for more information.
- Install the package from GitHub packages or NuGet packages
dotnet add package robinhood-csharp
- Create Authentication section configuration in your project that call this package
In order to get device token, follow https://stackoverflow.com/a/64775021
"RobinhoodAuthentication": {
//UserName is email format
"UserName": "**********",
"Password": "**********",
"ExpirationTime": 734000,
"Timeout": 5,
"ChallengeType": "sms",
"DeviceToken": "**********"
}
-
Add the configuration needed for the package in
Program.cs
- REST API
builder.Services.ConfigureRb(builder.Configuration.GetSection("RobinhoodAuthentication"))
- Console APP
private static IConfiguration _configuration; private static IServiceProvider _serviceProvider; private static IHostBuilder CreateHostBuilder(string[] args) { return Host.CreateDefaultBuilder(args) .ConfigureHostConfiguration(AddConfiguration) .ConfigureServices(services => { services.ConfigureRb(_configuration.GetSection("RobinhoodAuthentication")); _serviceProvider = services.BuildServiceProvider(); }); } private static void AddConfiguration(IConfigurationBuilder builder) { IConfigurationBuilder configurationBuilder = builder .SetBasePath(Directory.GetCurrentDirectory()) .AddJsonFile("appsettings.json", false, true); _configuration = configurationBuilder.Build(); }
- REST API
-
Inject
IRobinhood
Interface -
Call login method
AuthenticationResponse authResponse = await _robinhood.LoginAsync();
- Manage challenge case
if (authResponse.IsChallenge)
{
do
{
Challenge challenge = authResponse.Challenge;
Console.WriteLine($"Input challenge code from {challenge.Type} ({challenge.RemainingAttempts}/{challenge.RemainingRetries}):");
string code = Console.ReadLine();
authResponse = await _robinhood.ChallengeOauth2Async(challenge.Id, code);
} while (authResponse.IsChallenge && authResponse.Challenge.CanRetry);
}
- Manage Mfa case
if (authResponse.MfaRequired)
{
int attempts = 3;
(HttpStatusCode statusCode, AuthenticationResponse mfaAuth) mfaResponse;
do
{
Console.WriteLine($"Input the MFA code:");
string code = Console.ReadLine();
mfaResponse = await _robinhood.MfaOath2Async(code);
attempts--;
} while (attempts > 0 && mfaResponse.statusCode != HttpStatusCode.OK);
authResponse = mfaResponse.mfaAuth;
}
- Configure the token expiration date, refresh token and Authorization header by calling ConfigureManager method
_robinhood.ConfigureManager(authResponse);
- Check user information example :
User user = await _robinhood.GetUserAsync();
- Find tests examples for all routes under samples/RbConsoleApp project.
- Find one test example for REST API under samples/RbWebApi project.