BankSystem7 0.4.2

There is a newer version of this package available.
See the version list below for details.
dotnet add package BankSystem7 --version 0.4.2                
NuGet\Install-Package BankSystem7 -Version 0.4.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="BankSystem7" Version="0.4.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add BankSystem7 --version 0.4.2                
#r "nuget: BankSystem7, 0.4.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 BankSystem7 as a Cake Addin
#addin nuget:?package=BankSystem7&version=0.4.2

// Install BankSystem7 as a Cake Tool
#tool nuget:?package=BankSystem7&version=0.4.2                

Bank system 7

This library provides opportunities for using likeness of bank system. You can handle not only users but also other models like banks, cards and etc.

Updates in version 0.4.2

  • Added implementation of interface IReaderServiceWithTracking to CardRepository, CreditRepository and UserRepository.
  • Added possibility that lies in neednessless to explicity disable logger.
  • Added new method overload for IServiceCollection extension.
  • Added overriding base methods for all models.

Documentation

Structure of project

  1. Folder AppContext is folder where contains context classes for interaction with database without business logic.
  2. Folder Middleware is folder where contains middleware.
  3. Folder Services contains 2 sub folders: Interfaces and Repositories.
  4. Folder Interfaces contains interfaces which describes structure of inherited classes.
  5. Folder Repositories is folder with all business logic of project. Only there simple developer has access.

How to interact with library?

The library provides ways to pass and use own models. For example, You can inherit Your class from base class User and pass it as type to initialized instance of ServiceConfiguration or ServiceConfigurationMiddleware and use own model. Developer can interact with library by following next steps:

  1. create instance of class ServiceConfiguration and pass as parameters class ConfigurationOptions with own settings.
  2. interact with repositories throughout public properties of instanced class ServiceConfiguration

New feature for library is adding services to internal DI in ASP.Net application. For that You have to write something like this:

  1. in Program.cs

      builder.Services.AddNationBankSystem<User, Card, BankAccount, Bank, Credit>(o =>
      {
            o.EnsureCreated = false;
            o.EnsureDeleted = false;
            o.DatabaseName = "Test";
            o.OperationOptions = new OperationServiceOptions()
            {
               DatabaseName = "Test",
            };
            o.LoggerOptions = new LoggerOptions()
            {
               // In the example we aren't using logger
               IsEnabled = false,
            };
      });
      //or
      builder.Services.AddNationBankSystem<User, Card, BankAccount, Bank, Credit>(new ConfigurationOptions()
      {
         EnsureCreated = false,
         EnsureDeleted = false,
         DatabaseName = "Test",
         OperationOptions = new OperationServiceOptions()
         {
            DatabaseName = "Test",
         },
         LoggerOptions = new LoggerOptions()
         {
            IsEnabled = false,
         },
      });
    

But use only one of the above approaches to use service.

  1. in Your controller

     private readonly IServiceConfiguration<User, Card, BankAccount, Bank, Credit> _service;
    
     public UsersController(IServiceConfiguration<User, Card, BankAccount, Bank, Credit> service)
     {
         _service = service;
     }
    

And all will work fine.

Remember!

If you'll not pass options to ServiceConfiguration method CreateInstance You can get different kind of exceptions.

API documentation

AppContext

There are 2 classes context:

  1. ApplicationContext - is responsible for all operations in the database.
  2. BankContext - is responsible for handling operations when use ApplicationContext is impossible.
API ApplicationContext

Methods:

  1. internal ExceptionModel AvoidDuplication(Bank item) - implements function for avoiding duplication in table Banks in the database.
  2. private void DatabaseHandle() - implements handling creating and deleting database.

Properties:

  1. public static bool EnsureCreated { get; set; } - property for handling create database operation
  2. public static bool EnsureDeleted { get; set; } - property for handling delete database operation
  3. protected internal DbSet<User> Users { get; set; } - an instance of the table Users in database.
  4. protected internal DbSet<Bank> Banks { get; set; } -an instance of the table Banks in database.
  5. protected internal DbSet<BankAccount> BankAccounts { get; set; } - an instance of the table BankAccounts in database.
  6. protected internal DbSet<Credit> Credits { get; set; } - an instance of the table Credits in database.
API BankContext

Methods:

  1. public ExceptionModel CreateOperation(Operation operation, OperationKind operationKind) - creates transaction operation.
  2. public ExceptionModel DeleteOperation(Operation operation) - deletes transaction operation
  3. public ExceptionModel BankAccountWithdraw(User user, Bank bank, Operation operation) - withdraws money from user bank account and accrual to bank's account.
  4. private ExceptionModel BankAccountAccrual(User user, Bank bank, Operation operation) - accruals money to user bank account from bank's account.
  5. private StatusOperationCode StatusOperation(Operation operation, OperationKind operationKind) - returns status of operation for next handling of operation.
  6. private void DatabaseHandle() - implements handling creating and deleting database.

Properties:

  1. public DbSet<User> Users { get; set; } - an instance of the table Users in database.
  2. public DbSet<Bank> Banks { get; set; } -an instance of the table Banks in database.
  3. public DbSet<Cards> Cards { get; set; } - an instance of the table Cards in database.
  4. public DbSet<BankAccount> BankAccounts { get; set; } - an instance of the table BankAccounts in database.

Services

Services are dividing on 3 sub-folders:

  1. Configuration
  2. Interfaces
  3. Repositories

And some classes that don't belong to any of folders:

  1. BankServiceOptions - defines options that used by internal services.
  2. Logger - service for logging some info about repositories operations.
  3. OperationService - provides connection to mongodb services.

Configuration

Here located services for configuring library.

  1. ConfigurationOptions - service provides options for the most full configuring of library.
  2. ModelConfiguration - service ensures correct relationships between models.
  3. ServiceConifiguration - service that handles all services that there are in the library.

Interfaces (and abstract classes)

Here located interfaces which describes behavior of inherited repo-classes.

  1. Interface IRepository<T> : IReaderService<T>, IWriterService<T>, IDisposable where T : class - interface for implement standard library logic.

    • bool FitsConditions(T? item); - implements logic for checking on conditions true of passed entity.
  2. Interface IReaderService<T> where T : class - interface for implement reading data from database.

    Methods

    • T Get(Expression<Func<T, bool>> predicate); - implements getting an object from database with predicate.
    • bool Exist(Expression<Func<T, bool>> predicate); - implements checking exist object with in database predicate.

    Properties

    • IQueryable<T> All { get; } - implements getting a sequence of the objects from database.
  3. Interface IReaderServiceWithTracking<T> where T : class - interface for implement reading data from database with another type of parameters.

    Methods

    • T GetWithTracking(Expression<Expression<Func<T, bool>>> predicate); - implements getting an object from database with predicate.
    • bool ExistWithTracking(Expression<Expression<Func<T, bool>>> predicate); - implements checking exist object with in database predicate. Properties
    • IQueryable<T> AllWithTracking { get; } - implements getting a sequence of the objects from database.
  4. Interface IWriterService<in T> where T : class - interface for implement writing, updating and deleting data in database

    Methods

    • ExceptionModel Create(T item); - implements adding item in database.
    • ExceptionModel Update(T item); - implements updating item in database.
    • ExceptionModel Delete(T item); - implements deleting item from database.
  5. Interface ILogger - interface that provides standard set for logging

    Methods

    • ExceptionModel Log(Report report); - implements logging report in database.
    • ExceptionModel Log(IEnumerable<Report> reports); - implements logging collection of reports in database.

    Properties

    • public bool IsReused { get; set; } - defines possibility use already initialized logger.
    • public LoggerOptions LoggerOptions { get; set; } - defines options for logger configuration.
  6. Abstract class LoggerExecutor<TOperationType> where TOperationType : Enum - simple implementation of service for added reports to logger queue

    Methods

    • virtual void Log(ExceptionModel exceptionModel, string methodName, string className, TOperationType operationType, ICollection<GeneralReport<TOperationType>> reports) - implements standard logic of inserting log data to logger queue. Can be overrided.

Repositories

Repositories are implementation of various interfaces and working with context classes for interact with database.

  1. BankRepository - implements interface IRepository<T> for handling bank model, contains methods for accrual or withdraw money from bank account and bank.
  2. BankAccountRepository - implements interface IRepository<T> for handling bank account model and Transfer money method.
  3. CardRepository - implements interface IRepository<T> for handling card model and Transfer money method.
  4. UserRepository - implements interface IRepository<T> for handling user model.
  5. CreditRepository - implements interface IRepository<T> for handling credit model and operations with credit(loan). For example: take, pay credit.
  6. LoggerRepository - implements interface IRepository<T> for handling reports.
  7. OperationRepository - implements interface IRepository<T> for handling operations.

When cause exception or error?

There are a lot of points when you can catch an exception or error while using api of project but we describe some of them:

  1. You use default connection string instead of Your. Can happen so that on Your machine won't database with name which was specified in default connection string.
  2. You change content of repositories or context class. If You change some of these You can get an error. Example:
   protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
   {
       optionsBuilder.EnableSensitiveDataLogging();
       optionsBuilder.UseSqlServer(queryConnection);
   }

You'll write something like this

   protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
   {
       optionsBuilder.EnableSensitiveDataLogging();
       optionsBuilder.UseSqlServer();
   }
  1. You use methods incorrectly. Example: You want to delete operation therefore You have to use method DeleteOperation(...) but You use method CreateOperation(...) and of course You'll get an exception because method CreateOperation(...)has return type ExceptionModel and it'll returns ExceptionModel.OperationFailed because same operation already exist in the database which You are using.
Remember!

Always change connection string either directly in context class, repository classes or use class BankServiceOptions for configuration. In any situations when Your program, OS or something else was broken, only You is responsible for it. Please, be more intelligent. :>

Conclusion

Downloading and next using this package is your responsible and only You decide use it or not. All exceptions and crashes of your projects is responsible on You. We was tested our product in many tests and have a conclusion in which says that all methods and logic of project are working correctly. So, we wish You luck.

Sincerely, hayako.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  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 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on BankSystem7:

Package Downloads
Standart7

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
0.5.8 158 9/13/2023
0.5.7 109 9/11/2023
0.5.6 148 7/22/2023
0.5.5 113 7/1/2023
0.5.4 104 6/19/2023
0.5.3 111 6/19/2023 0.5.3 is deprecated.
0.5.2 107 6/3/2023
0.5.1 99 5/22/2023
0.5.0 105 5/21/2023
0.4.9 101 5/14/2023
0.4.8 96 5/6/2023
0.4.7 92 5/6/2023
0.4.6 96 5/6/2023
0.4.5 105 5/6/2023
0.4.4 110 5/2/2023
0.4.2 106 4/29/2023
0.4.1 104 4/27/2023
0.4.0 110 4/27/2023
0.3.9 111 4/25/2023
0.3.8 110 4/19/2023
0.3.7 104 4/19/2023
0.3.6-beta 100 4/13/2023
0.3.5-beta 94 4/12/2023
0.3.4-beta 93 4/10/2023
0.3.3-beta 92 4/3/2023
0.3.2-beta 99 4/3/2023 0.3.2-beta is deprecated.
0.3.1-beta 97 4/2/2023
0.3.0-beta 103 4/1/2023
0.2.9-beta 106 4/1/2023
0.2.7-beta 118 3/28/2023
0.2.6-beta 124 3/24/2023
0.2.5-beta 122 3/20/2023
0.2.4-beta 118 3/20/2023
0.2.3-beta 112 3/20/2023
0.2.2-beta 125 3/20/2023
0.2.1-beta 127 3/20/2023
0.1.3-beta 120 3/20/2023
0.1.2-beta 122 3/19/2023
0.1.0-beta 119 3/19/2023