signer-test-sdk-core 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +81 -0
- package/dist/src/components/OnboardingUI/auth.d.ts +158 -0
- package/dist/src/components/OnboardingUI/auth.js +230 -0
- package/dist/src/components/OnboardingUI/auth.js.map +1 -0
- package/dist/src/components/OnboardingUI/index.d.ts +9 -0
- package/dist/src/components/OnboardingUI/index.js +9 -0
- package/dist/src/components/OnboardingUI/index.js.map +1 -0
- package/dist/src/components/OnboardingUI/types.d.ts +159 -0
- package/dist/src/components/OnboardingUI/types.js +5 -0
- package/dist/src/components/OnboardingUI/types.js.map +1 -0
- package/dist/src/core/AbstraxnWallet.d.ts +162 -0
- package/dist/src/core/AbstraxnWallet.js +593 -0
- package/dist/src/core/AbstraxnWallet.js.map +1 -0
- package/dist/src/core/AuthManager.d.ts +112 -0
- package/dist/src/core/AuthManager.js +685 -0
- package/dist/src/core/AuthManager.js.map +1 -0
- package/dist/src/core/Signer.d.ts +35 -0
- package/dist/src/core/Signer.js +156 -0
- package/dist/src/core/Signer.js.map +1 -0
- package/dist/src/index.d.ts +17 -0
- package/dist/src/index.js +19 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/interfaces/IAuth.d.ts +26 -0
- package/dist/src/interfaces/IAuth.js +2 -0
- package/dist/src/interfaces/IAuth.js.map +1 -0
- package/dist/src/interfaces/ISigner.d.ts +14 -0
- package/dist/src/interfaces/ISigner.js +2 -0
- package/dist/src/interfaces/ISigner.js.map +1 -0
- package/dist/src/interfaces/IStorage.d.ts +15 -0
- package/dist/src/interfaces/IStorage.js +2 -0
- package/dist/src/interfaces/IStorage.js.map +1 -0
- package/dist/src/interfaces/IWallet.d.ts +45 -0
- package/dist/src/interfaces/IWallet.js +2 -0
- package/dist/src/interfaces/IWallet.js.map +1 -0
- package/dist/src/services/ApiService.d.ts +131 -0
- package/dist/src/services/ApiService.js +626 -0
- package/dist/src/services/ApiService.js.map +1 -0
- package/dist/src/services/TokenService.d.ts +29 -0
- package/dist/src/services/TokenService.js +40 -0
- package/dist/src/services/TokenService.js.map +1 -0
- package/dist/src/services/TurnkeyService.d.ts +54 -0
- package/dist/src/services/TurnkeyService.js +91 -0
- package/dist/src/services/TurnkeyService.js.map +1 -0
- package/dist/src/storage/IndexedDBStorage.d.ts +39 -0
- package/dist/src/storage/IndexedDBStorage.js +280 -0
- package/dist/src/storage/IndexedDBStorage.js.map +1 -0
- package/dist/src/utils/constants.d.ts +52 -0
- package/dist/src/utils/constants.js +78 -0
- package/dist/src/utils/constants.js.map +1 -0
- package/dist/src/utils/errors.d.ts +23 -0
- package/dist/src/utils/errors.js +48 -0
- package/dist/src/utils/errors.js.map +1 -0
- package/dist/src/utils/helpers.d.ts +12 -0
- package/dist/src/utils/helpers.js +30 -0
- package/dist/src/utils/helpers.js.map +1 -0
- package/dist/src/utils/passkey.d.ts +33 -0
- package/dist/src/utils/passkey.js +122 -0
- package/dist/src/utils/passkey.js.map +1 -0
- package/dist/src/utils/types.d.ts +182 -0
- package/dist/src/utils/types.js +5 -0
- package/dist/src/utils/types.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +49 -0
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Auth Manager - Handles authentication flows
|
|
3
|
+
* All infrastructure details are internal - users don't need to know about them
|
|
4
|
+
*/
|
|
5
|
+
import { IAuth } from '../interfaces/IAuth';
|
|
6
|
+
import { User, AuthTokens, VerifyOtpResponse, WhoamiResponse } from '../utils/types';
|
|
7
|
+
import { ApiService } from '../services/ApiService';
|
|
8
|
+
import { TurnkeyService } from '../services/TurnkeyService';
|
|
9
|
+
import { TokenService } from '../services/TokenService';
|
|
10
|
+
import { IndexedDBStorage } from '../storage/IndexedDBStorage';
|
|
11
|
+
export declare class AuthManager implements IAuth {
|
|
12
|
+
private apiService;
|
|
13
|
+
private turnkeyService;
|
|
14
|
+
private tokenService;
|
|
15
|
+
private storage;
|
|
16
|
+
private currentUser;
|
|
17
|
+
private whoamiPromise;
|
|
18
|
+
constructor(apiService: ApiService, turnkeyService: TurnkeyService, tokenService: TokenService, storage: IndexedDBStorage);
|
|
19
|
+
/**
|
|
20
|
+
* Initialize OTP authentication
|
|
21
|
+
*/
|
|
22
|
+
loginWithOTP(email: string): Promise<{
|
|
23
|
+
otpId: string;
|
|
24
|
+
}>;
|
|
25
|
+
/**
|
|
26
|
+
* Verify OTP and complete authentication
|
|
27
|
+
*/
|
|
28
|
+
verifyOTP(otpId: string, otpCode: string): Promise<User>;
|
|
29
|
+
/**
|
|
30
|
+
* Call PROXY endpoint after successful authentication
|
|
31
|
+
* This is called internally after user is authenticated
|
|
32
|
+
* Calls Turnkey create_policy endpoint via PROXY
|
|
33
|
+
* @param authMethod - 'otp' for OTP login, 'google' for Google OAuth login
|
|
34
|
+
*/
|
|
35
|
+
private callProxyAfterVerification;
|
|
36
|
+
/**
|
|
37
|
+
* Login with Google OAuth
|
|
38
|
+
*/
|
|
39
|
+
loginWithGoogle(): Promise<void>;
|
|
40
|
+
/**
|
|
41
|
+
* Login with Discord OAuth
|
|
42
|
+
*/
|
|
43
|
+
loginWithDiscord(): Promise<void>;
|
|
44
|
+
/**
|
|
45
|
+
* Login with X (Twitter) OAuth
|
|
46
|
+
*/
|
|
47
|
+
loginWithTwitter(): Promise<void>;
|
|
48
|
+
/**
|
|
49
|
+
* Handle Google OAuth callback
|
|
50
|
+
* This is called when user returns from Google OAuth
|
|
51
|
+
* Calls the backend API to get accessToken, refreshToken, and user data
|
|
52
|
+
*/
|
|
53
|
+
handleGoogleCallback(): Promise<User | null>;
|
|
54
|
+
/**
|
|
55
|
+
* Handle Discord OAuth callback
|
|
56
|
+
*/
|
|
57
|
+
handleDiscordCallback(): Promise<User | null>;
|
|
58
|
+
/**
|
|
59
|
+
* Handle X (Twitter) OAuth callback
|
|
60
|
+
*/
|
|
61
|
+
handleTwitterCallback(): Promise<User | null>;
|
|
62
|
+
/**
|
|
63
|
+
* Logout
|
|
64
|
+
*/
|
|
65
|
+
logout(): Promise<void>;
|
|
66
|
+
/**
|
|
67
|
+
* Refresh access token
|
|
68
|
+
*/
|
|
69
|
+
refreshToken(): Promise<AuthTokens>;
|
|
70
|
+
/**
|
|
71
|
+
* Get current user
|
|
72
|
+
*/
|
|
73
|
+
getCurrentUser(): User | null;
|
|
74
|
+
/**
|
|
75
|
+
* Check if authenticated
|
|
76
|
+
*/
|
|
77
|
+
isAuthenticated(): Promise<boolean>;
|
|
78
|
+
/**
|
|
79
|
+
* Load user from storage
|
|
80
|
+
*/
|
|
81
|
+
loadUserFromStorage(): Promise<void>;
|
|
82
|
+
/**
|
|
83
|
+
* Get stored verification response
|
|
84
|
+
* Returns the full OTP verification response that was saved
|
|
85
|
+
*/
|
|
86
|
+
getVerifyResponse(): Promise<VerifyOtpResponse | null>;
|
|
87
|
+
/**
|
|
88
|
+
* Call whoami API and store the response
|
|
89
|
+
* This is called after successful OTP verification
|
|
90
|
+
* Always calls backend endpoint with access token (backend handles Turnkey call)
|
|
91
|
+
*/
|
|
92
|
+
private callWhoami;
|
|
93
|
+
/**
|
|
94
|
+
* Get stored whoami response
|
|
95
|
+
*/
|
|
96
|
+
getWhoami(): Promise<WhoamiResponse | null>;
|
|
97
|
+
/**
|
|
98
|
+
* Refresh whoami by making a fresh API call
|
|
99
|
+
* This bypasses the cache and always calls the API
|
|
100
|
+
*/
|
|
101
|
+
refreshWhoami(): Promise<WhoamiResponse | null>;
|
|
102
|
+
/**
|
|
103
|
+
* Signup with passkey
|
|
104
|
+
* Creates a WebAuthn credential and registers the user
|
|
105
|
+
*/
|
|
106
|
+
signupWithPasskey(): Promise<User>;
|
|
107
|
+
/**
|
|
108
|
+
* Login with passkey
|
|
109
|
+
* Uses WebauthnStamper to authenticate with existing passkey
|
|
110
|
+
*/
|
|
111
|
+
loginWithPasskey(): Promise<User>;
|
|
112
|
+
}
|