react-native-nitro-auth 0.1.0

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.
Files changed (110) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +254 -0
  3. package/android/CMakeLists.txt +37 -0
  4. package/android/build.gradle +99 -0
  5. package/android/gradle.properties +4 -0
  6. package/android/src/main/AndroidManifest.xml +12 -0
  7. package/android/src/main/cpp/JniOnLoad.cpp +7 -0
  8. package/android/src/main/cpp/PlatformAuth+Android.cpp +293 -0
  9. package/android/src/main/java/com/auth/AuthAdapter.kt +286 -0
  10. package/android/src/main/java/com/auth/GoogleSignInActivity.kt +73 -0
  11. package/android/src/main/java/com/auth/NitroAuthModule.kt +19 -0
  12. package/android/src/main/java/com/auth/NitroAuthPackage.kt +16 -0
  13. package/app.plugin.js +64 -0
  14. package/cpp/AuthCache.cpp +105 -0
  15. package/cpp/AuthCache.hpp +20 -0
  16. package/cpp/HybridAuth.cpp +213 -0
  17. package/cpp/HybridAuth.hpp +47 -0
  18. package/cpp/JSONSerializer.hpp +57 -0
  19. package/cpp/PlatformAuth.hpp +25 -0
  20. package/ios/AuthAdapter.swift +200 -0
  21. package/ios/PlatformAuth+iOS.mm +119 -0
  22. package/lib/commonjs/Auth.nitro.js +6 -0
  23. package/lib/commonjs/Auth.nitro.js.map +1 -0
  24. package/lib/commonjs/Auth.web.js +256 -0
  25. package/lib/commonjs/Auth.web.js.map +1 -0
  26. package/lib/commonjs/global.d.js +6 -0
  27. package/lib/commonjs/global.d.js.map +1 -0
  28. package/lib/commonjs/index.js +52 -0
  29. package/lib/commonjs/index.js.map +1 -0
  30. package/lib/commonjs/index.web.js +52 -0
  31. package/lib/commonjs/index.web.js.map +1 -0
  32. package/lib/commonjs/service.js +9 -0
  33. package/lib/commonjs/service.js.map +1 -0
  34. package/lib/commonjs/service.web.js +13 -0
  35. package/lib/commonjs/service.web.js.map +1 -0
  36. package/lib/commonjs/ui/social-button.js +103 -0
  37. package/lib/commonjs/ui/social-button.js.map +1 -0
  38. package/lib/commonjs/ui/social-button.web.js +102 -0
  39. package/lib/commonjs/ui/social-button.web.js.map +1 -0
  40. package/lib/commonjs/use-auth.js +144 -0
  41. package/lib/commonjs/use-auth.js.map +1 -0
  42. package/lib/module/Auth.nitro.js +4 -0
  43. package/lib/module/Auth.nitro.js.map +1 -0
  44. package/lib/module/Auth.web.js +252 -0
  45. package/lib/module/Auth.web.js.map +1 -0
  46. package/lib/module/global.d.js +4 -0
  47. package/lib/module/global.d.js.map +1 -0
  48. package/lib/module/index.js +7 -0
  49. package/lib/module/index.js.map +1 -0
  50. package/lib/module/index.web.js +7 -0
  51. package/lib/module/index.web.js.map +1 -0
  52. package/lib/module/service.js +5 -0
  53. package/lib/module/service.js.map +1 -0
  54. package/lib/module/service.web.js +4 -0
  55. package/lib/module/service.web.js.map +1 -0
  56. package/lib/module/ui/social-button.js +97 -0
  57. package/lib/module/ui/social-button.js.map +1 -0
  58. package/lib/module/ui/social-button.web.js +96 -0
  59. package/lib/module/ui/social-button.web.js.map +1 -0
  60. package/lib/module/use-auth.js +140 -0
  61. package/lib/module/use-auth.js.map +1 -0
  62. package/lib/typescript/Auth.nitro.d.ts +38 -0
  63. package/lib/typescript/Auth.nitro.d.ts.map +1 -0
  64. package/lib/typescript/Auth.web.d.ts +32 -0
  65. package/lib/typescript/Auth.web.d.ts.map +1 -0
  66. package/lib/typescript/index.d.ts +5 -0
  67. package/lib/typescript/index.d.ts.map +1 -0
  68. package/lib/typescript/index.web.d.ts +5 -0
  69. package/lib/typescript/index.web.d.ts.map +1 -0
  70. package/lib/typescript/service.d.ts +3 -0
  71. package/lib/typescript/service.d.ts.map +1 -0
  72. package/lib/typescript/service.web.d.ts +2 -0
  73. package/lib/typescript/service.web.d.ts.map +1 -0
  74. package/lib/typescript/ui/social-button.d.ts +17 -0
  75. package/lib/typescript/ui/social-button.d.ts.map +1 -0
  76. package/lib/typescript/ui/social-button.web.d.ts +17 -0
  77. package/lib/typescript/ui/social-button.web.d.ts.map +1 -0
  78. package/lib/typescript/use-auth.d.ts +15 -0
  79. package/lib/typescript/use-auth.d.ts.map +1 -0
  80. package/nitro.json +15 -0
  81. package/nitrogen/generated/.gitattributes +1 -0
  82. package/nitrogen/generated/android/NitroAuth+autolinking.cmake +81 -0
  83. package/nitrogen/generated/android/NitroAuth+autolinking.gradle +27 -0
  84. package/nitrogen/generated/android/NitroAuthOnLoad.cpp +44 -0
  85. package/nitrogen/generated/android/NitroAuthOnLoad.hpp +25 -0
  86. package/nitrogen/generated/android/kotlin/com/margelo/nitro/com/auth/NitroAuthOnLoad.kt +35 -0
  87. package/nitrogen/generated/ios/NitroAuth+autolinking.rb +60 -0
  88. package/nitrogen/generated/ios/NitroAuth-Swift-Cxx-Bridge.cpp +17 -0
  89. package/nitrogen/generated/ios/NitroAuth-Swift-Cxx-Bridge.hpp +27 -0
  90. package/nitrogen/generated/ios/NitroAuth-Swift-Cxx-Umbrella.hpp +38 -0
  91. package/nitrogen/generated/ios/NitroAuthAutolinking.mm +35 -0
  92. package/nitrogen/generated/ios/NitroAuthAutolinking.swift +12 -0
  93. package/nitrogen/generated/shared/c++/AuthProvider.hpp +76 -0
  94. package/nitrogen/generated/shared/c++/AuthTokens.hpp +84 -0
  95. package/nitrogen/generated/shared/c++/AuthUser.hpp +107 -0
  96. package/nitrogen/generated/shared/c++/HybridAuthSpec.cpp +30 -0
  97. package/nitrogen/generated/shared/c++/HybridAuthSpec.hpp +85 -0
  98. package/nitrogen/generated/shared/c++/LoginOptions.hpp +81 -0
  99. package/package.json +113 -0
  100. package/react-native-nitro-auth.podspec +40 -0
  101. package/src/Auth.nitro.ts +50 -0
  102. package/src/Auth.web.ts +310 -0
  103. package/src/global.d.ts +38 -0
  104. package/src/index.ts +4 -0
  105. package/src/index.web.ts +4 -0
  106. package/src/service.ts +4 -0
  107. package/src/service.web.ts +1 -0
  108. package/src/ui/social-button.tsx +129 -0
  109. package/src/ui/social-button.web.tsx +128 -0
  110. package/src/use-auth.ts +157 -0
@@ -0,0 +1,128 @@
1
+ import React, { useState } from "react";
2
+ import {
3
+ Pressable,
4
+ Text,
5
+ StyleSheet,
6
+ View,
7
+ ViewStyle,
8
+ TextStyle,
9
+ ActivityIndicator,
10
+ } from "react-native";
11
+ import type { AuthProvider, AuthUser } from "../Auth.nitro";
12
+ import { AuthModule } from "../Auth.web";
13
+
14
+ interface SocialButtonProps {
15
+ provider: AuthProvider;
16
+ variant?: "primary" | "outline" | "white" | "black";
17
+ borderRadius?: number;
18
+ style?: ViewStyle;
19
+ textStyle?: TextStyle;
20
+ disabled?: boolean;
21
+ onSuccess?: (user: AuthUser) => void;
22
+ onError?: (error: unknown) => void;
23
+ onPress?: () => void;
24
+ }
25
+
26
+ async function performLogin(provider: AuthProvider): Promise<AuthUser | null> {
27
+ await AuthModule.login(provider);
28
+ return AuthModule.currentUser ?? null;
29
+ }
30
+
31
+ export const SocialButton: React.FC<SocialButtonProps> = ({
32
+ provider,
33
+ variant = "primary",
34
+ borderRadius = 8,
35
+ style,
36
+ textStyle,
37
+ disabled,
38
+ onSuccess,
39
+ onError,
40
+ onPress,
41
+ }) => {
42
+ const [loading, setLoading] = useState(false);
43
+
44
+ const handleLogin = () => {
45
+ if (loading || disabled) return;
46
+ if (onPress) {
47
+ onPress();
48
+ return;
49
+ }
50
+ setLoading(true);
51
+ performLogin(provider)
52
+ .then((user) => {
53
+ setLoading(false);
54
+ if (user) onSuccess?.(user);
55
+ })
56
+ .catch((e) => {
57
+ setLoading(false);
58
+ onError?.(e);
59
+ });
60
+ };
61
+
62
+ const isGoogle = provider === "google";
63
+ const isDisabled = loading || disabled;
64
+
65
+ const getBackgroundColor = () => {
66
+ if (isDisabled) return "#CCCCCC";
67
+ if (variant === "black") return "#000000";
68
+ if (variant === "white") return "#FFFFFF";
69
+ if (variant === "outline") return "transparent";
70
+ return isGoogle ? "#4285F4" : "#000000";
71
+ };
72
+
73
+ const getTextColor = () => {
74
+ if (variant === "white" || variant === "outline") return "#000000";
75
+ return "#FFFFFF";
76
+ };
77
+
78
+ const getBorderColor = () => {
79
+ if (variant === "outline") return "#DDDDDD";
80
+ return "transparent";
81
+ };
82
+
83
+ return (
84
+ <Pressable
85
+ style={[
86
+ styles.button,
87
+ {
88
+ backgroundColor: getBackgroundColor(),
89
+ borderRadius,
90
+ borderColor: getBorderColor(),
91
+ borderWidth: variant === "outline" ? 1 : 0,
92
+ },
93
+ style,
94
+ ]}
95
+ onPress={handleLogin}
96
+ disabled={isDisabled}
97
+ >
98
+ <View style={styles.content}>
99
+ {loading ? (
100
+ <ActivityIndicator size="small" color={getTextColor()} />
101
+ ) : (
102
+ <Text style={[styles.text, { color: getTextColor() }, textStyle]}>
103
+ Sign in with {provider.charAt(0).toUpperCase() + provider.slice(1)}
104
+ </Text>
105
+ )}
106
+ </View>
107
+ </Pressable>
108
+ );
109
+ };
110
+
111
+ const styles = StyleSheet.create({
112
+ button: {
113
+ paddingVertical: 12,
114
+ paddingHorizontal: 16,
115
+ minHeight: 48,
116
+ justifyContent: "center",
117
+ alignItems: "center",
118
+ width: "100%",
119
+ },
120
+ content: {
121
+ flexDirection: "row",
122
+ alignItems: "center",
123
+ },
124
+ text: {
125
+ fontSize: 16,
126
+ fontWeight: "600",
127
+ },
128
+ });
@@ -0,0 +1,157 @@
1
+ import { useState, useEffect, useCallback, useMemo } from "react";
2
+ import { AuthService } from "./service";
3
+ import type {
4
+ AuthUser,
5
+ AuthProvider,
6
+ LoginOptions,
7
+ AuthTokens,
8
+ } from "./Auth.nitro";
9
+
10
+ interface AuthState {
11
+ user: AuthUser | undefined;
12
+ scopes: string[];
13
+ loading: boolean;
14
+ error: Error | undefined;
15
+ }
16
+
17
+ export function useAuth() {
18
+ const [state, setState] = useState<AuthState>({
19
+ user: AuthService.currentUser,
20
+ scopes: AuthService.grantedScopes,
21
+ loading: false,
22
+ error: undefined,
23
+ });
24
+
25
+ const login = useCallback(
26
+ async (provider: AuthProvider, options?: LoginOptions) => {
27
+ setState((prev) => ({ ...prev, loading: true, error: undefined }));
28
+ try {
29
+ await AuthService.login(provider, options);
30
+ setState({
31
+ user: AuthService.currentUser,
32
+ scopes: AuthService.grantedScopes,
33
+ loading: false,
34
+ error: undefined,
35
+ });
36
+ } catch (e) {
37
+ const error = e instanceof Error ? e : new Error(String(e));
38
+ setState((prev) => ({
39
+ ...prev,
40
+ loading: false,
41
+ error,
42
+ }));
43
+ throw error;
44
+ }
45
+ },
46
+ []
47
+ );
48
+
49
+ const logout = useCallback(() => {
50
+ AuthService.logout();
51
+ setState({
52
+ user: undefined,
53
+ scopes: [],
54
+ loading: false,
55
+ error: undefined,
56
+ });
57
+ }, []);
58
+
59
+ const requestScopes = useCallback(async (newScopes: string[]) => {
60
+ setState((prev) => ({ ...prev, loading: true, error: undefined }));
61
+ try {
62
+ await AuthService.requestScopes(newScopes);
63
+ setState({
64
+ user: AuthService.currentUser,
65
+ scopes: AuthService.grantedScopes,
66
+ loading: false,
67
+ error: undefined,
68
+ });
69
+ } catch (e) {
70
+ const error = e instanceof Error ? e : new Error(String(e));
71
+ setState((prev) => ({
72
+ ...prev,
73
+ loading: false,
74
+ error,
75
+ }));
76
+ throw error;
77
+ }
78
+ }, []);
79
+
80
+ const revokeScopes = useCallback(async (scopesToRevoke: string[]) => {
81
+ setState((prev) => ({ ...prev, loading: true, error: undefined }));
82
+ try {
83
+ await AuthService.revokeScopes(scopesToRevoke);
84
+ setState({
85
+ user: AuthService.currentUser,
86
+ scopes: AuthService.grantedScopes,
87
+ loading: false,
88
+ error: undefined,
89
+ });
90
+ } catch (e) {
91
+ const error = e instanceof Error ? e : new Error(String(e));
92
+ setState((prev) => ({
93
+ ...prev,
94
+ loading: false,
95
+ error,
96
+ }));
97
+ throw error;
98
+ }
99
+ }, []);
100
+
101
+ const getAccessToken = useCallback(() => AuthService.getAccessToken(), []);
102
+
103
+ const refreshToken = useCallback(async () => {
104
+ setState((prev) => ({ ...prev, loading: true, error: undefined }));
105
+ try {
106
+ const tokens = await AuthService.refreshToken();
107
+ setState({
108
+ user: AuthService.currentUser,
109
+ scopes: AuthService.grantedScopes,
110
+ loading: false,
111
+ error: undefined,
112
+ });
113
+ return tokens;
114
+ } catch (e) {
115
+ const error = e instanceof Error ? e : new Error(String(e));
116
+ setState((prev) => ({
117
+ ...prev,
118
+ loading: false,
119
+ error,
120
+ }));
121
+ throw error;
122
+ }
123
+ }, []);
124
+
125
+ useEffect(() => {
126
+ const unsubscribe = AuthService.onAuthStateChanged((currentUser) => {
127
+ setState((prev) => ({
128
+ ...prev,
129
+ user: currentUser,
130
+ scopes: AuthService.grantedScopes,
131
+ }));
132
+ });
133
+ return unsubscribe;
134
+ }, []);
135
+
136
+ return useMemo(
137
+ () => ({
138
+ ...state,
139
+ hasPlayServices: AuthService.hasPlayServices,
140
+ login,
141
+ logout,
142
+ requestScopes,
143
+ revokeScopes,
144
+ getAccessToken,
145
+ refreshToken,
146
+ }),
147
+ [
148
+ state,
149
+ login,
150
+ logout,
151
+ requestScopes,
152
+ revokeScopes,
153
+ getAccessToken,
154
+ refreshToken,
155
+ ]
156
+ );
157
+ }