Tuesday, October 31, 2023

Exploring NDepend v2023.2: Unraveling the Latest Features


For .NET developers and software quality enthusiasts, NDepend is an indispensable tool. NDepend v2023.2 introduces an array of new features that promise to streamline your development process and enhance the quality of your code. In this comprehensive article, we’ll delve into the latest updates and enhancements.

Full .NET 8.0 Support:

  • With .NET 8.0’s release, NDepend ensures seamless compatibility.
  • Analyze .NET 8 code quickly, covering project types like ASP.NET Core, Windows Desktop, Blazor, and Console applications.
  • Your .NET 8.0 projects are now within NDepend’s scope for analysis.

C# 12 Support and Parsing Improvements:

  • NDepend v2023.2 embraces the new features of C# 12, including primary constructors for classes and inline arrays.
  • Achieve 100% resolution of code element declarations in your source code, from fields and enumeration values to abstract methods and more.
  • Source declaration line enhancements clarify your code, making issue identification more straightforward.

Performance Enhancements:

  • Say hello to a faster analysis process. NDepend v2023.2 reduces report generation time by a staggering 40%.
  • Even for extensive code bases with thousands of source files and millions of lines of code, report generation is now a matter of seconds.
  • NDependReport.html file sizes are halved thanks to new optimizations, ranging from one to 5MB. Sharing and usability have never been more convenient.

UI Enhancements:

  • The user interface receives significant improvements.
  • Loading code base snapshots with the baseline snapshot is now parallelized, resulting in a 40% reduction in loading time.
  • Lazy initialization of panels makes the UI instantly responsive once snapshots are loaded.
  • In Project Properties, the “Code to Analyze” panel now resolves all assemblies 41% faster.

    NDepend Dashboard

    NDepend Report Dashboard
    NDepend Report Dashboard

    NDepend_2023_Report_Abstractness versus Instability Diagram
    NDepend Report - Abstractness versus Instability Diagram

Customizable Issue Explanations:

  • NDepend v2023.2 empowers users to define patterns for issue explanations.
  • This customization enables tailored issue explanations to meet specific project needs, enhancing insights into the codebase.
  • Issue explanations are integrated into the NDepend UI and source code views in reports, providing an in-depth understanding. NDepend_2023_Report_Issues Improvement

Fewer False Positives:

  • Reducing false positives remains a top priority for NDepend.
  • In this release, various rules have been refined to minimize false positive issues, allowing developers to focus on genuine code quality concerns.

Conclusion: NDepend v2023.2 emerges as a powerhouse tool for .NET developers. With complete .NET 8.0 support, compatibility with C# 12, and substantial performance enhancements, it becomes a valuable asset for your toolkit. The UI improvements and customizable issue explanations elevate the code analysis experience. Bid farewell to false positives and embrace an accurate analysis.

In a world where software quality is non-negotiable, NDepend v2023.2 is the tool you need to ensure your .NET projects shine.

Final Thoughts: NDepend v2023.2 continues its commitment to delivering an exceptional code analysis experience. Its ability to adapt to the latest .NET technologies and enhanced performance makes it a crucial tool for any .NET developer. Dive into NDepend v2023.2 and watch your codebase reach new heights of quality and maintainability.

Monday, October 2, 2023

Securing .NET Web Applications with Authentication: Harnessing the Power of Social Media Provider Authentication


In today's interconnected world, users expect a seamless and secure login experience on websites and applications. Social media provider authentication, such as Google Authentication, offers a convenient and trusted way for users to access your application using their existing social media accounts. In this tutorial, we'll explore how to integrate Google Authentication into your ASP.NET Core application step by step.


Before we dive into the implementation, make sure you have the following:

  1. Visual Studio or Visual Studio Code installed on your system.
  2. An ASP.NET Core web application project was created.

Step 1: Install the Required NuGet Package

The first step is to install the Microsoft.AspNetCore.Authentication.Google NuGet package into your ASP.NET Core project. This package provides the necessary tools for integrating Google Authentication.

Open the NuGet Package Manager in Visual Studio, search for Microsoft.AspNetCore.Authentication.Google, and install the latest stable version.

Install-Package Microsoft.AspNetCore.Authentication.Google

Step 2: Configure Google Authentication

To enable Google Authentication in your application, you need to set up the necessary credentials on the Google Developer Console. Follow these steps:

  1. Navigate to the Google Developer Console.

  2. Create a new project or select an existing one.

  3. Set up the consent screen by providing the required information, including the application name, support email, and domain.

  4. Add authorized JavaScript origins and redirect URIs for your application. Make sure to include both the development and production URLs.

  5. Under the "Scopes" section, add the necessary scopes, such as emailprofile, and openid.

  6. Save your changes and publish the app.

  7. Create OAuth 2.0 credentials by going to "Credentials" and selecting "Create credentials" > "OAuth client ID." Choose the application type as "Web application" and configure the redirect URIs.

  8. After creating the OAuth client ID, note down the "Client ID" and "Client Secret" values.

Step 3: Configure Your ASP.NET Core Application

Now, let's configure your ASP.NET Core application to use Google Authentication. Open your appsettings.json file and add the Google Authentication settings:

  "Authentication": {
    "Google": {
      "ClientId": "YOUR_CLIENT_ID",
      "ClientSecret": "YOUR_CLIENT_SECRET"
  // Other application settings...

Replace "YOUR_CLIENT_ID" and "YOUR_CLIENT_SECRET" with the values you obtained from the Google Developer Console.

Step 4: Enable Google Authentication in Your App

In your ASP.NET Core application, navigate to the Program.cs file. Inside the CreateHostBuilder method, add the following code to enable Google Authentication:

    .AddGoogle(options =>
        options.ClientId = Configuration["Authentication:Google:ClientId"];
        options.ClientSecret = Configuration["Authentication:Google:ClientSecret"];

This code configures the authentication services to use Google Authentication and sets the client ID and client secret from your appsettings.json file.

Step 5: Run Your Application

With Google Authentication configured, you can start your ASP.NET Core application. You should now see the "Use other services to log in" option on your login page, with Google as one of the available choices.

Click the "Google" button, and a popup will appear, prompting you to sign in with your Google account. After signing in, you'll be redirected back to your application, logged in, and authenticated via Google.


Integrating Google Authentication into your ASP.NET Core application provides users with a convenient and secure way to access your services without creating additional accounts. This enhances the user experience and can boost user engagement on your platform.