Skip to content

Azure demo app, features a URL shortener, using Azure storage blob and queues, SAS tokens, AAD/B2C auth, Web Apps with Webjobs, Redis Cache, and Azure SQL DB.

License

rcyrus/Wutnu

 
 

Repository files navigation

WutNu - Mother of All Azure Demos (MOAAD)

Based on the initial "Unofficial Work Account & B2C Combined Sample App" by Danny Strockis at https://github.com/dstrockis/AAD-B2C-Hybrid.

This app is designed as a multi-purpose Azure demo, utilizing:

  • Web Apps
  • Web Jobs
  • Azure Storage (blobs and queues)
  • Storage SAS tokens
  • Azure SQL DB
  • Azure Redis Cache
  • Azure Active Directory/B2C

The app presents as a general purpose URL shortener. Logging in enables shortened links to require a login from AAD before they are lengthened. Social accounts are enabled via AAD B2C, and work accounts are enabled via AAD user accounts and optionally, accounts linked via AAD B2B.

Files are uploadable via the web portal - each authenticated user gets a blob storage container in the designated storage account, linked to their login. These uploaded files can then be shortened, and the shortened URLs can be protected behind a login so they can't be lengthened until the person authenticates. Finally, queues are used to audit the URL lengthening, and a rudimentary report is available.

User accounts have a rudimentary "API Key" generated that is associated with their blob container. The "BlobCopy" project is a simple console app that allows list/put/get operations against the container associated with the api key (kept in the settings file). The utility makes an API call and, for put and get operations, gets a SAS token to upload and download directly to blob storage.

ISSUES:

  • The report engine "works on my box" but rendering is having an issue in Azure - the report renders and the database is called; it may be font-related.
  • This is sample code - it's strictly a proof of concept.

INSTALLATION:

$webappname="wuttest"
$webappRG="wuttest"

Add-AzureRmAccount
#Set-AzureRmContext -SubscriptionName "yourSubscriptionName"

$settings=@{
    "DomainName" = "localhost:44316";
    "RedisConnection" = "[parameters('RedisConnectionString')]";
    "RedisUrlDBNum" = "[parameters('RedisUrlDBNum')]";
    "RedisUserDBNum" = "[parameters('RedisUserDBNum')]";
    "StorageConnectionString" = "[parameters('StorageConnectionString')]";
    "B2BGraphKey" = "[parameters('B2BGraphKey')]";
    "B2CGraphKey" = "[parameters('B2CGraphKey')]";
    "ActivateWebApiTracing" = "false";
    "ida:AadInstance" = "https://login.microsoftonline.com/{0}";
    "ida:RedirectUri" = "https://localhost:44316";
    "ida:TenantB2B" = "[parameters('TenantB2B')]";
    "ida:ClientIdB2B" = "[parameters('ClientIdB2B')]";
    "ida:TenantB2C" = "[parameters('TenantB2C')]";
    "ida:ClientIdB2C" = "[parameters('ClientIdB2C')]";
    "ida:SignUpPolicyId" = "B2C_1_DefaultSignup";
    "ida:SignInPolicyId" = "B2C_1_DefaultSignin";
    "ida:UserProfilePolicyId" = "B2C_1_DefaultProfileEditPolicy";
    "ida:ResetPolicyId" = "B2C_1_DefaultReset";
    "ConfigStorageCors" = "true";
    "Environment" = "[parameters('DeploymentEnvironment')]";
    "LocalReports" = "false";
    "EnableDashboardLogging" = "true"
}

Set-AzureRmWebApp -AppSettings $settings -Name $webappname -ResourceGroupName $webappRG

For each of those settings, either in the Azure web application settings, or in your web.config, you'll need to populate the values from the services you just spun up.

For the Azure Active Directory settings, please see the following articles for details:

For your primary AAD, create a group named "WutNuAdmins" and add any users that need access to the error logs.

About

Azure demo app, features a URL shortener, using Azure storage blob and queues, SAS tokens, AAD/B2C auth, Web Apps with Webjobs, Redis Cache, and Azure SQL DB.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 77.6%
  • C# 16.8%
  • CSS 4.5%
  • Other 1.1%