Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

FR-18338.3 #86

Open
wants to merge 5 commits into
base: master
Choose a base branch
from
Open

FR-18338.3 #86

wants to merge 5 commits into from

Conversation

alex-minaiev-frontegg
Copy link
Collaborator

This PR was founded on https://frontegg.atlassian.net/browse/FR-18338 point 3

Created FronteggApp and FronteggAuth interfaces for separation interface and realization and provided to customers only necessary methods and properties to avoid accessing the inner implementation of methods and properties.

New Component:

  1. FronteggAppService - implementation of FronteggApp interface.
  2. FronteggInnerStorage - store all necessary information about SDK running (baseUrl, clientId, applicationId, etc.). Created to avoid using FronteggApp and FronteggAppService by SDK components.
  3. FronteggAuthService - implementation of FronteggAuth interface.
  4. FronteggAppLifecycle - separate object for listening to application Lifecycle Events. Created to encapsulate all data and methods responsible for AppLifecycle (encapsulation Principle of OOP).
  5. FronteggRefreshTokenTimer - separate object for managing RefreshTokenTimer. Created to encapsulate all data and methods responsible for RefreshTokenTimer (encapsulation Principle of OOP).
  6. Renamed RefreshTokenService with RefreshTokenJobService - to avoid confusion with SDK Services.
  7. ReadOnlyObservableValue - using ObservableValue customer could change the value of ObservableValue. ReadOnlyObservableValue lock set ability of value.

@alex-minaiev-frontegg
Copy link
Collaborator Author

@frontegg-david I've added comments to main classes please check.

@dianaKhortiuk-frontegg
Copy link
Collaborator

@alex-minaiev-frontegg could you please fix conflicts first?

“oleksii-minaiev” added 2 commits November 13, 2024 10:14
# Conflicts:
#	android/src/main/java/com/frontegg/android/AuthenticationActivity.kt
#	android/src/main/java/com/frontegg/android/FronteggAuth.kt
#	android/src/main/java/com/frontegg/android/embedded/FronteggWebClient.kt
#	android/src/main/java/com/frontegg/android/embedded/FronteggWebView.kt
#	android/src/main/java/com/frontegg/android/services/RefreshTokenJobService.kt
* @property observable is the Subject of NullableObject;
* @property value is the read only value of [ReadOnlyObservableValue];
*/
abstract class ReadOnlyObservableValue<T>(value: T) {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

abstraction layer introduces additional complexity without providing clear advantages for most use cases

}
}

fun scheduleTimer(offset: Long) {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

add check if the token is already expired before scheduling

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants