EZRadiusClient 1.0.2

dotnet add package EZRadiusClient --version 1.0.2                
NuGet\Install-Package EZRadiusClient -Version 1.0.2                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="EZRadiusClient" Version="1.0.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add EZRadiusClient --version 1.0.2                
#r "nuget: EZRadiusClient, 1.0.2"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install EZRadiusClient as a Cake Addin
#addin nuget:?package=EZRadiusClient&version=1.0.2

// Install EZRadiusClient as a Cake Tool
#tool nuget:?package=EZRadiusClient&version=1.0.2                

EZRadius Client

This repository contains the Nuget Package for EZRadius. The EZRadiusClient contains several functions to get, create, edit, and delete EZRadius policies in addition to getting authorization logs. The SampleApp is a simple console application that shows how to use the EZRadiusClient. Shown below are example commands that demonstrate how to invoke the different EZRadiusClient methods.

To run the SampleApp, it requires a token scope ID, a url for EZRadius instance (defaults to usa.ezradius.io), and an Azure Active Directory instance (Entra ID). It also takes a connection string for logging to Azure Application Insights. These parameters can be passed as command line arguments based on the flags below.

Getting Started

  1. Add the Nuget Package to your project with dotnet add package EZRadiusClient
  2. Use the SampleApp to see how the client can be used and configured (must have EZRadius instance with a Radius policy)

Displaying Radius Policies

Starting with a basic feature, the show verb will display all the Radius policies. This command calls the GetRadiusPoliciesAsync() method and prints to the console the Radius policies and their attributes currently in the passed EZRadius instance.

    -s, --scope          The token scope for the EZRadius instance.
    
    -u, --url            The URL for the EZRadius instance. (Default: https://usa.ezradius.io)
    
    -a, --adUrl          The Azure Active Directory instance (Entra ID) url.
    
    -l, --log            The Azure Application Insights connection string. (Optional)

Sample Call: .\RADIUSConsole.exe show -s <scope_id> -u <instance_url> -a <ad_url> -l <insight_connection_string>

Downloading Allowed IP Addresses from Policy

Building off of the previous command, this command also calls the GetRadiusPoliciesAsync() method to get the policies, but it saves all the allowed IP addresses of a policy into a .csv file. The program asks the user which policy's IP addresses should be saved. To run this, use the download verb when running the SampleApp with the following flags. An example of the output .csv file is in the SampleApp directory and titled Sample.csv.

    -s, --scope          The token scope for the EZRadius instance.
    
    -u, --url            The URL for the EZRadius instance. (Default: https://usa.ezradius.io)
    
    -a, --adUrl          The Azure Active Directory instance (Entra ID) url.
    
    -l, --log            The Azure Application Insights connection string. (Optional)
    
    -o, --output         The output file path to save or read the IP addresses and their secrets from Radius policy. (Required)
    
    -n, --name           The name of the policy to download the IP addresses from. (Required)

Sample Call: .\RADIUSConsole.exe download -s <scope_id> -u <instance_url> -a <ad_url> -l <insight_connection_string> -o <path_to_output_file> -n <policy_name>

Updating Allowed IP Addresses for Policy

This command utilizes the CreateOrEditRadiusPolicyAsync() method to make changes to an existing Radius policy from the EZRadius instance. The method takes in the RadiusPolicyModel which is one of the fields returned by the GetRadiusPoliciesAsync(). It takes a .csv file containing IP addresses and their secrets; the format should match that of the sample .csv file in the SampleApp directory titled Sample.csv. The IP addresses will overwrite the current IP addresses for that policy, which is then saved in the EZRadius instance. This command is run using the upload verb.

    -s, --scope          The token scope for the EZRadius instance.
    
    -u, --url            The URL for the EZRadius instance. (Default: https://usa.ezradius.io)
    
    -a, --adUrl          The Azure Active Directory instance (Entra ID) url.
    
    -l, --log            The Azure Application Insights connection string. (Optional)
    
    -i, --input          The input file path containing IP addresses and their secrets for updating Radius policy. (Required)
    
    -n, --name           The name of the policy to update the IP addresses for. (Required)

Sample Call: .\RADIUSConsole.exe upload -s <scope_id> -u <instance_url> -a <ad_url> -l <insight_connection_string> -i <path_to_input_file> -n <policy_name>

Deleting Radius Policy

Deleting a Radius policy can be done using the delete verb. This command calls the DeleteRadiusPolicyAsync() which takes in a RadiusPolicyModel and deletes that Radius policy from the EZRadius instance. This command cannot be undone, so once the policy is removed, it will cannot be recovered.

    -s, --scope          The token scope for the EZRadius instance.
    
    -u, --url            The URL for the EZRadius instance. (Default: https://usa.ezradius.io)
    
    -a, --adUrl          The Azure Active Directory instance (Entra ID) url.
    
    -l, --log            The Azure Application Insights connection string. (Optional)   
    
    -n, --name           The name of the policy to delete. (Required)

Sample Call: .\RADIUSConsole.exe delete -s <scope_id> -u <instance_url> -a <ad_url> -l <insight_connection_string> -n <policy_name>

Displaying Authorization Logs

Similar to the displaying Radius policies, this command gets authentication logs and displays them to the console. It uses the GetAuthAuditLogsAsync() method to get the logs from the EZRadius instance, and prints information about each log to the terminal. To run this command, use the verb getlogs. The SampleApp is configured to return logs for the previous 2 days; to change this see TimeFrameModel in the EZRadiusClient directory.

    -s, --scope          The token scope for the EZRadius instance.
    
    -u, --url            The URL for the EZRadius instance. (Default: https://usa.ezradius.io)
    
    -a, --adUrl          The Azure Active Directory instance (Entra ID) url.
    
    -l, --log            The Azure Application Insights connection string. (Optional)
    
    -d, --days           The number of days to get logs from. (Required)

Sample Call: .\RADIUSConsole.exe getlogs -s <scope_id> -u <instance_url> -a <ad_url> -l <insight_connection_string> -d <number_of_days>

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.2 109 7/23/2024

First Release