EZRadiusClient 1.0.2
dotnet add package EZRadiusClient --version 1.0.2
NuGet\Install-Package EZRadiusClient -Version 1.0.2
<PackageReference Include="EZRadiusClient" Version="1.0.2" />
paket add EZRadiusClient --version 1.0.2
#r "nuget: EZRadiusClient, 1.0.2"
// 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
- Add the Nuget Package to your project with
dotnet add package EZRadiusClient
- 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 | Versions 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. |
-
net8.0
- Azure.Identity (>= 1.12.0)
- CommandLineParser (>= 2.9.1)
- CsvHelper (>= 33.0.1)
- Microsoft.Extensions.Logging (>= 8.0.0)
- Polly (>= 8.4.1)
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 | 94 | 7/23/2024 |
First Release