Skip to content

Latest commit

 

History

History
143 lines (104 loc) · 5.95 KB

README.md

File metadata and controls

143 lines (104 loc) · 5.95 KB

Kontomanager Client .NET

.NET Client library that wraps the functionalities provided by the kontomanager.at web management interface used by a number of mobile carriers in Austria (MVNOs in the A1 network). Starting with version 2.1.0, the library also supports A1 accounts, which do not have a Kontomanager interface, but use a different system.

UPDATE 02/2023

The Kontomanager Web interface has had a major design overhaul. Unfortunately, the WebSMS functionality was removed in the process. v1.x is no longer working for at least XOXO and YESSS as of 15.02.2023.

v2.0.0 provides basic account usage reading functionality comparable to what was present before. Reading of current monthly cost is not implemented yet.

Installation

Simply install the nuget package from https://www.nuget.org/packages/KontomanagerClient to your project.

Carrier Support

The library was testet for:

Other carriers that use Kontomanager but were not tested include:

And possibly more. Feel free to add carriers to that list.

Usage

Basic Example

var client = new XOXOClient("<login_username/number>", "<login_password>")
    .EnableDebugLogging(true) // Enables Console Log outputs
    .UseAutoReconnect(true); // Enables automatic re-login after a connection timeout
    
await client.CreateConnection();

var usage = await client.GetAccountUsage();
usage.PrintToConsole();

2.1.0 Additions

A1 Business

Some extra units, such as USA minutes, are included in the AdditionalQuotas dictionary of PackageUsage. The key is the string used in the MeinA1 interface to describe the unit.

var client = new A1BusinessClient("<login_username/email>", "<login_password>");
await client.CreateConnection();
var numbers = await client.GetSelectablePhoneNumbers();
var usage = await client.GetAccountUsage(numbers.First());
usage.PrintToConsole();

1.2.0 Additions

var client = new XOXOClient("<login_username/number>", "<login_password>")
    .EnableDebugLogging(true) // Enables Console Log outputs
    .UseAutoReconnect(true); // Enables automatic re-login after a connection timeout
    
await client.CreateConnection();

string firstNumber = await client.GetSelectedPhoneNumber(); // returns the currently selected phone number in format 43681...
var usage = await client.GetAccountUsage(); // Get Account usage for firstNumber
usage.PrintToConsole(); // Prints a summary to the console


var numbers = await client.GetSelectablePhoneNumbers(); // gets a list of PhoneNumber object for each number linked to the account (has string number and string subscriberId)
PhoneNumber otherNumber = numbers.First(n => !n.Selected); 
await client.SelectPhoneNumber(otherNumber); // select other phone number for the client
var otherNumberUsage = await client.GetAccountUsage(); // get account usage for otherNumber
otherNumberUsage.PrintToConsole();

Similar projects

The following projects seem to do the same thing as this client in other languages. However, I did not test any of them.

Changelog

04.04.2024 2.1.4

  • set culture for parsing numbers to de-DE. This fixes the problem where used data was read incorrectly if the system locale is not de-DE.

04.04.2024 2.1.3

  • add more information to A1BusinessClient, such as contract validity periods, loyalty points and customer number.
  • fix bugs found in versions 2.1.0 - 2.1.2

03.04.2024 2.1.0

  • add ICarrierAccount interface to introduce a common interface for all carriers
  • add support for non-kontomanager MeinA1 accounts via the A1BusinessClient

27.03.2023 2.0.6

  • fix bug that parsed the remaining EU data incorrectly

07.03.2023 2.0.5

  • fix bug that returned null instead of an empty list for selectable phone numbers

28.02.2023 2.0.4

  • fix bug that caused prepaid credit to be read incorrectly if system culture was not german

20.02.2023 2.0.3

  • includes fix intended for 2.0.2

20.02.2023 2.0.2

  • bug fixes

16.02.2023 2.0.1

  • bug fixes

15.02.2023 2.0.0

This is a breaking change. Some methods were removed and the constructor was refactored to only require one URL.

  • remove no longer supported WebSMS functionality
  • add support for new Kontomanager UI

07.06.2022 1.2.7

  • added a function to extract the selected phone number from the header

07.06.2022 1.2.6

  • fix issue that caused an exception when the settings.php page redirects to kundendaten.php for disabled phone numbers

03.06.2022 1.2.5

  • fix issue that caused an exception when trying to switch to a phone number that has been deactivated

20.05.2022 1.2.3

  • fix issue with package validity not being read for some packages
  • add .net6 as target framework

19.05.2022 1.2.2

  • fix wrong used data number for eu data

19.05.2022: 1.2.1

  • fix bad return value in CreateConnection

19.05.2022: 1.2.0

  • add support for multiple sims managed under one account
  • add support for reading basic information on the contract (available min/sms/mb, ...)