persistence/DD.Persistence.Client
Roman Efremov 45fbfaf657
All checks were successful
Unit tests / test (push) Successful in 1m40s
Merge branch 'master' into Partitioning
2024-12-25 13:49:41 +05:00
..
Clients 1. Исправлены namespaces. 2024-12-16 15:38:46 +05:00
CustomExceptions 1. Исправлены namespaces. 2024-12-16 15:38:46 +05:00
Helpers 1. Исправлены namespaces. 2024-12-16 15:38:46 +05:00
DD.Persistence.Client.csproj Миграция с .net 8 на .net 9. 2024-12-24 11:45:42 +05:00
PersistenceClientFactory.cs Добавить Timeout клиента 2024-12-17 13:40:17 +05:00
Readme.md 1. Исправлены namespaces. 2024-12-16 15:38:46 +05:00

Persistence Client Nuget Readme

Краткое описание Persistence сервиса

Persistence сервис отвечает за работу с хранимыми данными в рамках совокупности различных систем.

Описание пакета

Данный пакет предоставляет возможность взаимодействия с Persistence сервисом посредством обращения к конкретному клиенту, ответственному за работу с одной из областей сервиса.

Список предоставляемых клиентов

  • ISetpointClient - Клиент для работы с уставками
  • ITechMessagesClient - Клиент для работы с технологическими сообщениями
  • ITimeSeriesClient - Клиент для работы с временными данными
  • ITimestampedSetClient - Клиент для работы с данными с отметкой времени
  • IChangeLogClient - Клиент для работы с записями ChangeLog
  • IWitsDataClient - Клиент для работы с параметрами Wits
  • IDataSourceSystemClient - Клиент для работы с системами

Использование

Для получения того или иного Persistence - клиента нужно обращаться к фабрике Persistence клиентов - PersistenceClientFactory. Для этого требуется:

  1. Добавить в проект фабрику HTTP - клиентов IHttpClientFactory.
    Она должна предоставлять HTTP - клиента через метод GetClient().

В том случае, если фабрика клиентов предоставляет не авторизованного клиента - необходимо добавить в проект фабрику токенов аутентификации IAuthTokenFactory с методом GetToken(), возвращающем токен в виде строки (без префикса Bearer).

  1. Добавить логирование ILoger
  2. Внедрить зависимость в проект services.AddSingleton<PersistenceClientFactory>(); - пример.
  3. Обратиться к фабрике Persistence - клиентов и получить требуемого клиента.

xunit тестирование

При написании интеграционных тестов с использованием Persistence - клиентов Http - клиент не обязан быть авторизован через передачу токена в PersistenceClientFactory. Для осуществления тестовой авторизации достаточно добавить в appsettings.Tests.json :

"NeedUseKeyCloak": false,
  "AuthUser": {
    "username": "myuser",
    "password": 12345,
    "clientId": "webapi",
    "grantType": "password"
  },
  "KeycloakGetTokenUrl": "http://192.168.0.10:8321/realms/Persistence/protocol/openid-connect/token"

При этом возможна авторизация через KeyCloak.