From 3316286c766d5245af825343e4473a404dc60222 Mon Sep 17 00:00:00 2001 From: Sitaram Kalluri Date: Tue, 16 Apr 2024 15:48:13 +0530 Subject: [PATCH] fix: Add SelfEncryptionKey to the AtChops instance --- packages/at_client_mobile/lib/at_client_mobile.dart | 7 ++++--- packages/at_client_mobile/lib/src/at_client_service.dart | 4 +++- .../lib/src/auth/at_auth_service_impl.dart | 6 ++++++ 3 files changed, 13 insertions(+), 4 deletions(-) diff --git a/packages/at_client_mobile/lib/at_client_mobile.dart b/packages/at_client_mobile/lib/at_client_mobile.dart index 241f29ea7..3ce1a9dea 100644 --- a/packages/at_client_mobile/lib/at_client_mobile.dart +++ b/packages/at_client_mobile/lib/at_client_mobile.dart @@ -4,14 +4,15 @@ export 'package:at_client/at_client.dart'; @Deprecated('Use AtClientMobile.authService') export 'src/at_client_auth.dart'; +export 'src/at_client_mobile_base.dart'; @Deprecated('Use AtClientMobile.authService') export 'src/at_client_service.dart'; - // Contains public methods to handle the onboarding, authentication, and enrollment submission for an atSign export 'src/auth/at_auth_service.dart'; - +@Deprecated('Use AtClientMobile.authService') +// TODO: Remove this is next major release +export 'src/auth/at_auth_service_impl.dart'; // Contains the enrollment details export 'src/enrollment/enrollment_info.dart'; export 'src/keychain_manager.dart'; export 'src/onboarding_status.dart'; -export 'src/at_client_mobile_base.dart'; diff --git a/packages/at_client_mobile/lib/src/at_client_service.dart b/packages/at_client_mobile/lib/src/at_client_service.dart index 396ffb7d1..c0e7c35ed 100644 --- a/packages/at_client_mobile/lib/src/at_client_service.dart +++ b/packages/at_client_mobile/lib/src/at_client_service.dart @@ -2,12 +2,12 @@ import 'dart:convert'; import 'dart:core'; +import 'package:at_chops/at_chops.dart'; import 'package:at_client_mobile/at_client_mobile.dart'; import 'package:at_client_mobile/src/atsign_key.dart'; import 'package:at_commons/at_builders.dart'; import 'package:at_lookup/at_lookup.dart'; import 'package:at_utils/at_logger.dart'; -import 'package:at_chops/at_chops.dart'; import 'package:flutter/cupertino.dart'; class AtClientService { @@ -454,6 +454,8 @@ class AtClientService { decryptedAtKeys[BackupKeyConstants.PKAM_PUBLIC_KEY_FROM_KEY_FILE]!, decryptedAtKeys[BackupKeyConstants.PKAM_PRIVATE_KEY_FROM_KEY_FILE]!); final atChopsKeys = AtChopsKeys.create(atEncryptionKeyPair, atPkamKeyPair); + atChopsKeys.selfEncryptionKey = AESKey( + decryptedAtKeys[BackupKeyConstants.SELF_ENCRYPTION_KEY_FROM_FILE]!); final atChops = AtChopsImpl(atChopsKeys); return atChops; } diff --git a/packages/at_client_mobile/lib/src/auth/at_auth_service_impl.dart b/packages/at_client_mobile/lib/src/auth/at_auth_service_impl.dart index 61ba39e88..35eadd78a 100644 --- a/packages/at_client_mobile/lib/src/auth/at_auth_service_impl.dart +++ b/packages/at_client_mobile/lib/src/auth/at_auth_service_impl.dart @@ -41,6 +41,12 @@ class AtAuthServiceImpl implements AtAuthService { final Map> _outcomes = {}; + /// Returns an instance of [AtAuthService] + /// + /// Usage: + /// ```dart + /// AtAuthService authService = AtClientMobile.authService(_atsign!, _atClientPreference); + /// ``` AtAuthServiceImpl(this._atSign, this._atClientPreference) { // If the '@' symbol is omitted, it leads to an incorrect format for the AtKey when retrieving the // encrypted defaultEncryptionPrivateKey and encrypted defaultSelfEncryptionKey.