KS.Fiks.Maskinporten.Client
2.0.1
dotnet add package KS.Fiks.Maskinporten.Client --version 2.0.1
NuGet\Install-Package KS.Fiks.Maskinporten.Client -Version 2.0.1
<PackageReference Include="KS.Fiks.Maskinporten.Client" Version="2.0.1" />
paket add KS.Fiks.Maskinporten.Client --version 2.0.1
#r "nuget: KS.Fiks.Maskinporten.Client, 2.0.1"
// Install KS.Fiks.Maskinporten.Client as a Cake Addin #addin nuget:?package=KS.Fiks.Maskinporten.Client&version=2.0.1 // Install KS.Fiks.Maskinporten.Client as a Cake Tool #tool nuget:?package=KS.Fiks.Maskinporten.Client&version=2.0.1
fiks-maskinporten-dotnet
About this library
This is a .NET library for Maskinporten authentication and authorization. There is also a similar version available for Java here
Integrity
The NuGet package is signed with a KS certificate in our build process, stored securely in a safe build environment. The package assemblies are also strong-named.
Installation
Install KS.Fiks.Maskinporten.Client NuGet package in your .NET project.
Example
Setup configuration
Using factory for TEST and PROD environments
// For TEST
var maskinportenConfigTest = MaskinportenClientConfigurationFactory.CreateTestConfiguration("test_issuer", testCertificate);
// For PROD
var maskinportenConfigProd = MaskinportenClientConfigurationFactory.CreateProdConfiguration("prod_issuer", certificate);
// DEPRECATED - For TEST (ver2)
var maskinportenConfigVer2 = MaskinportenClientConfigurationFactory.CreateVer2Configuration("ver2_issuer", testCertificate);
Complete configuration
Test environment
var maskinportenConfig = new MaskinportenClientConfiguration(
audience: @"https://test.maskinporten.no/", // Maskinporten audience path
tokenEndpoint: @"https://test.maskinporten.no/token", // Maskinporten token path
issuer: @"issuer", // Issuer name, heter nå Integrasjonens identifikator i selvbetjeningsløsningen til DigDir
numberOfSecondsLeftBeforeExpire: 10, // The token will be refreshed 10 seconds before it expires
certificate: /* virksomhetssertifikat as a X509Certificate2 */,
privateKey: /* use together with public key if not using certificate parameter */,
publicKey: /* use together with private key if not using certificate parameter */,
keyIdentifier: /* optional value. Sets header kid */,
consumerOrg: /* optional value. Sets header consumer_org */);
Test environment - ver2 (deprecated)
var maskinportenConfig = new MaskinportenClientConfiguration(
audience: @"https://ver2.maskinporten.no/", // Maskinporten audience path
tokenEndpoint: @"https://ver2.maskinporten.no/token", // Maskinporten token path
issuer: @"issuer", // Issuer name, heter nå Integrasjonens identifikator i selvbetjeningsløsningen til DigDir
numberOfSecondsLeftBeforeExpire: 10, // The token will be refreshed 10 seconds before it expires
certificate: /* virksomhetssertifikat as a X509Certificate2 */,
privateKey: /* use together with public key if not using certificate parameter */,
publicKey: /* use together with private key if not using certificate parameter */,
keyIdentifier: /* optional value. Sets header kid */,
consumerOrg: /* optional value. Sets header consumer_org */);
DigDir maintains a list of well-know endpoints and configuration for the available environments
Create instance of MaskinportenClient
var maskinportenClient = new MaskinportenClient(maskinportenConfig);
Get access token
var scope = "ks:fiks"; // Scope for access token
var accessToken = await maskinportenClient.GetAccessToken(scope);
Get access token using TokenRequest builder
var tokenRequest = new TokenRequestBuilder()
.WithScopes("ks:fiks") // Scope for access token
.WithConsumerOrg("123456789") // Official 9 digit organization number for an organization that has delegated access to you in ALTINN
.WithOnBehalfOf("123456789") // Official 9 digit organization number for an organization that has delegated access to you in ALTINN
.WithAudience("https://some/api") // 'resource' claim in the JWT grant and 'aud' claim in the resulting access token
.WithPid("12345678901") // Personal indentification number of the intended subject of the subsequent API calls
.Build();
var accessToken = await maskinportenClient.GetAccessToken(tokenRequest);
Get delegated access token
var scope = "ks:fiks"; // Scope for access token
var consumerOrgNo = ...; // Official 9 digit organization number for an organization that has delegated access to you in ALTINN
var accessToken = await maskinportenClient.GetDelegatedAccessToken(consumerOrgNo, scope);
For more information on this feature, check the delegation documentation at DigDir
Get delegated access audience-restricted token
var audience = "https://some/api"; // Audience for access token
var scope = "ks:fiks"; // Scope for access token
var consumerOrgNo = ...; // Official 9 digit organization number for an organization that has delegated access to you in ALTINN
var accessToken = await maskinportenClient.GetDelegatedAccessTokenForAudience(consumerOrgNo, audience, scope);
For more information on this feature, check the delegation documentation audience-restricted tokens at DigDir
Get on behalf of access token
This is a feature with limited usecase
var scope = "ks:fiks"; // Scope for access token
var consumerOrgNo = ...; // Official 9 digit organization number for an organization that has delegated access to you in ALTINN
var accessToken = await maskinportenClient.GetOnBehalfOfAccessToken(consumerOrgNo, scope);
For more information on this feature, check the onbehalfof documentation at DigDir
Please note that as stated in the documentation at DigDir, "Det gir ingen mening å bruke onbehalfof for Maskinporten-integrasjoner", means that for most cases it is not usable and is planned for removal. When it is removed this feature will be removed from this client too.
Send request using access token
var httpClient = new HttpClient();
using (var requestMessage = new HttpRequestMessage(HttpMethod.Post, /* api uri */))
{
// Set authorization header with maskinporten access token
requestMessage.Headers.Authorization = new AuthenticationHeaderValue("Bearer", accessToken.Token);
/* Set other headers. Integration id and password etc.*/
// Send message
var response = await httpClient.SendAsync(requestMessage);
/* Handle response */
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. 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. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 is compatible. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- JWT (>= 11.0.0)
- Newtonsoft.Json (>= 13.0.3)
-
.NETStandard 2.1
- JWT (>= 11.0.0)
- Newtonsoft.Json (>= 13.0.3)
-
net8.0
- JWT (>= 11.0.0)
- Newtonsoft.Json (>= 13.0.3)
NuGet packages (2)
Showing the top 2 NuGet packages that depend on KS.Fiks.Maskinporten.Client:
Package | Downloads |
---|---|
KS.Fiks.IO.Send.Client
Package Description |
|
KS.Fiks.IO.Client
Package Description |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
2.0.1 | 1,346 | 1/2/2025 |
2.0.0 | 249 | 12/19/2024 |
1.2.0 | 430 | 12/13/2024 |
1.1.11 | 129 | 12/9/2024 |
1.1.10 | 63,296 | 1/15/2024 |
1.1.9 | 12,111 | 11/10/2023 |
1.1.8 | 495 | 11/7/2023 |
1.1.7 | 23,555 | 8/15/2023 |
1.1.6 | 591 | 5/31/2023 |
1.1.5 | 48,371 | 1/23/2023 |
1.1.4 | 557 | 1/23/2023 |
1.1.3 | 3,512 | 11/3/2022 |
1.1.2 | 13,841 | 7/1/2022 |
1.1.1 | 28,273 | 12/21/2021 |
1.1.0 | 313 | 12/21/2021 |
1.0.7 | 30,434 | 5/10/2021 |
1.0.6 | 1,699 | 11/13/2020 |
1.0.5 | 3,323 | 11/9/2020 |
1.0.4 | 468 | 11/9/2020 |
1.0.3 | 644 | 9/30/2020 |
1.0.2 | 582 | 8/20/2020 |
1.0.1 | 570 | 6/29/2020 |
1.0.0 | 7,144 | 5/6/2019 |
0.0.6 | 829 | 5/6/2019 |