Skip to content

Commit

Permalink
Update ios to GoogleSignIn 6.0.1 Pod (#136)
Browse files Browse the repository at this point in the history
* allow clientId to be set from capacitor config rather than google services plist

* accept different android/ios client ids

* update to google auth 6.0.1

* update podfile lock

* need to update the podspec

* update ios plugin/bridge for v6

* some versions of xcode don't like this guard

* silence some swift compiler warnings

* docs: add information about `Client ID`

* Update Plugin.swift

Co-authored-by: reslear <reslear@gmail.com>
  • Loading branch information
joeflateau and reslear authored Aug 27, 2021
1 parent 44d766b commit 4859f9c
Show file tree
Hide file tree
Showing 7 changed files with 112 additions and 123 deletions.
2 changes: 1 addition & 1 deletion CodetrixStudioCapacitorGoogleAuth.podspec
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,6 @@
s.source_files = 'ios/Plugin/**/*.{swift,h,m,c,cc,mm,cpp}'
s.ios.deployment_target = '12.0'
s.dependency 'Capacitor'
s.dependency 'GoogleSignIn', '~> 5.0.2'
s.dependency 'GoogleSignIn', '~> 6.0.1'
s.static_framework = true
end
20 changes: 17 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -115,14 +115,28 @@ or see more [CapacitorGoogleAuth-Vue3-example](https://github.com/reslear/Capaci

### iOS

Make sure you have `GoogleService-Info.plist` with `CLIENT_ID`
1. Create in Google cloud console credential **Client ID for iOS** and get **Client ID** and **iOS URL scheme**

2. Add **identifier** `REVERSED_CLIENT_ID` as **URL schemes** to `Info.plist` from **iOS URL scheme**<br>
(Xcode: App - Targets/App - Info - URL Types, click plus icon)

3. Set **Client ID** one of the ways:
1. Set in `capacitor.config.json`
- `iosClientId` - specific key for iOS
- `clientId` - or common key for Android and iOS
3. Download `GoogleService-Info.plist` file with `CLIENT_ID` and copy to **ios/App/App** necessarily through Xcode for indexing.


Add `REVERSED_CLIENT_ID` as url scheme to `Info.plist`

### Android

Inside your `strings.xml`
Set **Client ID** :

1. In `capacitor.config.json`
- `androidClientId` - specific key for Android
- `clientId` - or common key for Android and iOS

2. or set inside your `strings.xml`
```xml
<resources>
<string name="server_client_id">Your Web Client Key</string>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,13 +27,11 @@ public class GoogleAuth extends Plugin {

@Override
public void load() {
String clientId = this.getContext().getString(R.string.server_client_id);
boolean forceCodeForRefreshToken = false;
String clientId = getConfig().getString("androidClientId",
getConfig().getString("clientId",
this.getContext().getString(R.string.server_client_id)));

Boolean forceRefreshToken = (Boolean) getConfigValue("forceCodeForRefreshToken");
if (forceRefreshToken != null) {
forceCodeForRefreshToken = forceRefreshToken;
}
boolean forceCodeForRefreshToken = getConfig().getBoolean("forceCodeForRefreshToken", false);

GoogleSignInOptions.Builder googleSignInBuilder = new GoogleSignInOptions.Builder(GoogleSignInOptions.DEFAULT_SIGN_IN)
.requestIdToken(clientId)
Expand All @@ -43,17 +41,13 @@ public void load() {
googleSignInBuilder.requestServerAuthCode(clientId, true);
}

try {
JSONArray scopeArray = (JSONArray) getConfigValue("scopes");
Scope[] scopes = new Scope[scopeArray.length() - 1];
Scope firstScope = new Scope(scopeArray.getString(0));
for (int i = 1; i < scopeArray.length(); i++) {
scopes[i - 1] = new Scope(scopeArray.getString(i));
}
googleSignInBuilder.requestScopes(firstScope, scopes);
} catch (JSONException e) {
e.printStackTrace();
String[] scopeArray = getConfig().getArray("scopes", new String[] {});
Scope[] scopes = new Scope[scopeArray.length - 1];
Scope firstScope = new Scope(scopeArray[0]);
for (int i = 1; i < scopeArray.length; i++) {
scopes[i - 1] = new Scope(scopeArray[i]);
}
googleSignInBuilder.requestScopes(firstScope, scopes);

GoogleSignInOptions googleSignInOptions = googleSignInBuilder.build();
googleSignInClient = GoogleSignIn.getClient(this.getContext(), googleSignInOptions);
Expand Down
40 changes: 2 additions & 38 deletions ios/Plugin.xcodeproj/project.pbxproj
Original file line number Diff line number Diff line change
Expand Up @@ -151,7 +151,6 @@
50ADFF84201F53D600D50D53 /* Frameworks */,
50ADFF85201F53D600D50D53 /* Headers */,
50ADFF86201F53D600D50D53 /* Resources */,
D5C0AD06C6436A87FC8525B9 /* [CP] Copy Pods Resources */,
);
buildRules = (
);
Expand All @@ -171,7 +170,6 @@
50ADFF8E201F53D600D50D53 /* Frameworks */,
50ADFF8F201F53D600D50D53 /* Resources */,
CDBD6291F99392856E80ED8A /* [CP] Embed Pods Frameworks */,
954E831AAF3D05995C5AB46F /* [CP] Copy Pods Resources */,
);
buildRules = (
);
Expand Down Expand Up @@ -262,24 +260,6 @@
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
showEnvVarsInLog = 0;
};
954E831AAF3D05995C5AB46F /* [CP] Copy Pods Resources */ = {
isa = PBXShellScriptBuildPhase;
buildActionMask = 2147483647;
files = (
);
inputPaths = (
"${PODS_ROOT}/Target Support Files/Pods-PluginTests/Pods-PluginTests-resources.sh",
"${PODS_ROOT}/GoogleSignIn/Resources/GoogleSignIn.bundle",
);
name = "[CP] Copy Pods Resources";
outputPaths = (
"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/GoogleSignIn.bundle",
);
runOnlyForDeploymentPostprocessing = 0;
shellPath = /bin/sh;
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-PluginTests/Pods-PluginTests-resources.sh\"\n";
showEnvVarsInLog = 0;
};
AB5B3E54B4E897F32C2279DA /* [CP] Check Pods Manifest.lock */ = {
isa = PBXShellScriptBuildPhase;
buildActionMask = 2147483647;
Expand Down Expand Up @@ -310,6 +290,7 @@
"${BUILT_PRODUCTS_DIR}/AppAuth/AppAuth.framework",
"${BUILT_PRODUCTS_DIR}/GTMAppAuth/GTMAppAuth.framework",
"${BUILT_PRODUCTS_DIR}/GTMSessionFetcher/GTMSessionFetcher.framework",
"${BUILT_PRODUCTS_DIR}/GoogleSignIn/GoogleSignIn.framework",
);
name = "[CP] Embed Pods Frameworks";
outputPaths = (
Expand All @@ -318,30 +299,13 @@
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/AppAuth.framework",
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/GTMAppAuth.framework",
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/GTMSessionFetcher.framework",
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/GoogleSignIn.framework",
);
runOnlyForDeploymentPostprocessing = 0;
shellPath = /bin/sh;
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-PluginTests/Pods-PluginTests-frameworks.sh\"\n";
showEnvVarsInLog = 0;
};
D5C0AD06C6436A87FC8525B9 /* [CP] Copy Pods Resources */ = {
isa = PBXShellScriptBuildPhase;
buildActionMask = 2147483647;
files = (
);
inputPaths = (
"${PODS_ROOT}/Target Support Files/Pods-Plugin/Pods-Plugin-resources.sh",
"${PODS_ROOT}/GoogleSignIn/Resources/GoogleSignIn.bundle",
);
name = "[CP] Copy Pods Resources";
outputPaths = (
"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/GoogleSignIn.bundle",
);
runOnlyForDeploymentPostprocessing = 0;
shellPath = /bin/sh;
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-Plugin/Pods-Plugin-resources.sh\"\n";
showEnvVarsInLog = 0;
};
/* End PBXShellScriptBuildPhase section */

/* Begin PBXSourcesBuildPhase section */
Expand Down
95 changes: 58 additions & 37 deletions ios/Plugin/Plugin.swift
Original file line number Diff line number Diff line change
Expand Up @@ -8,34 +8,36 @@ import GoogleSignIn
*/
@objc(GoogleAuth)
public class GoogleAuth: CAPPlugin {
var signInCall: CAPPluginCall?
let googleSignIn: GIDSignIn = GIDSignIn.sharedInstance();
var signInCall: CAPPluginCall!
var googleSignIn: GIDSignIn!;
var googleSignInConfiguration: GIDConfiguration!;
var forceAuthCode: Bool = false;
var scopes: [String]?;


public override func load() {
guard let path = Bundle.main.path(forResource: "GoogleService-Info", ofType: "plist") else {
print("GoogleService-Info.plist not found");
googleSignIn = GIDSignIn.sharedInstance;

let serverClientId = getServerClientIdValue();

guard let clientId = getClientIdValue() else {
NSLog("no client id found in config")
return;
}
guard let dict = NSDictionary(contentsOfFile: path) as? [String: AnyObject] else {return}
guard let clientId = dict["CLIENT_ID"] as? String else {return}
googleSignIn.clientID = clientId;
googleSignIn.delegate = self;
googleSignIn.presentingViewController = bridge?.viewController;
if let serverClientId = getConfigValue("serverClientId") as? String {
googleSignIn.serverClientID = serverClientId;
}
if let scopes = getConfigValue("scopes") as? [String] {
googleSignIn.scopes = scopes;
}

googleSignInConfiguration = GIDConfiguration.init(clientID: clientId, serverClientID: serverClientId)

scopes = getConfigValue("scopes") as? [String];

if let forceAuthCodeConfig = getConfigValue("forceCodeForRefreshToken") as? Bool {
forceAuthCode = forceAuthCodeConfig;
}
NotificationCenter.default.addObserver(self, selector: #selector(handleOpenUrl(_ :)), name: Notification.Name(CAPNotifications.URLOpen.name()), object: nil);

NotificationCenter.default.addObserver(self, selector: #selector(handleOpenUrl(_ :)), name: Notification.Name(Notification.Name.capacitorOpenURL.rawValue), object: nil);
}

@objc
func init(_ call: CAPPluginCall) {
func `init`(_ call: CAPPluginCall) {
call.unimplemented("Not available on iOS")
}

Expand All @@ -46,7 +48,13 @@ public class GoogleAuth: CAPPlugin {
if self.googleSignIn.hasPreviousSignIn() && !self.forceAuthCode {
self.googleSignIn.restorePreviousSignIn();
} else {
self.googleSignIn.signIn();
self.googleSignIn.signIn(with: self.googleSignInConfiguration, presenting: self.bridge!.viewController!) { user, error in
if let error = error {
self.signInCall?.reject(error.localizedDescription);
return;
}
self.processCallback(user: user!);
};
}
}
}
Expand All @@ -58,14 +66,14 @@ public class GoogleAuth: CAPPlugin {
call.reject("User not logged in.");
return
}
self.googleSignIn.currentUser.authentication.getTokensWithHandler { (authentication, error) in
self.googleSignIn.currentUser!.authentication.do { (authentication, error) in
guard let authentication = authentication else {
call.reject(error?.localizedDescription ?? "Something went wrong.");
return;
}
let authenticationData: [String: Any] = [
"accessToken": authentication.accessToken,
"idToken": authentication.idToken,
"idToken": authentication.idToken ?? NSNull(),
"refreshToken": authentication.refreshToken
]
call.resolve(authenticationData);
Expand Down Expand Up @@ -93,6 +101,29 @@ public class GoogleAuth: CAPPlugin {
}
googleSignIn.handle(url);
}


func getClientIdValue() -> String? {
if let clientId = getConfigValue("iosClientId") as? String {
return clientId;
}
else if let clientId = getConfigValue("clientId") as? String {
return clientId;
}
else if let path = Bundle.main.path(forResource: "GoogleService-Info", ofType: "plist"),
let dict = NSDictionary(contentsOfFile: path) as? [String: AnyObject],
let clientId = dict["CLIENT_ID"] as? String {
return clientId;
}
return nil;
}

func getServerClientIdValue() -> String? {
if let serverClientId = getConfigValue("serverClientId") as? String {
return serverClientId;
}
return nil;
}

func processCallback(user: GIDGoogleUser) {
var userData: [String: Any] = [
Expand All @@ -101,26 +132,16 @@ public class GoogleAuth: CAPPlugin {
"idToken": user.authentication.idToken,
"refreshToken": user.authentication.refreshToken
],
"serverAuthCode": user.serverAuthCode,
"email": user.profile.email,
"familyName": user.profile.familyName,
"givenName": user.profile.givenName,
"id": user.userID,
"name": user.profile.name
"serverAuthCode": user.serverAuthCode ?? NSNull(),
"email": user.profile?.email ?? NSNull(),
"familyName": user.profile?.familyName ?? NSNull(),
"givenName": user.profile?.givenName ?? NSNull(),
"id": user.userID ?? NSNull(),
"name": user.profile?.name ?? NSNull()
];
if let imageUrl = user.profile.imageURL(withDimension: 100)?.absoluteString {
if let imageUrl = user.profile?.imageURL(withDimension: 100)?.absoluteString {
userData["imageUrl"] = imageUrl;
}
signInCall?.resolve(userData);
}
}

extension GoogleAuth: GIDSignInDelegate {
public func sign(_ signIn: GIDSignIn!, didSignInFor user: GIDGoogleUser!, withError error: Error!) {
if let error = error {
signInCall?.reject(error.localizedDescription);
return;
}
processCallback(user: user);
}
}
2 changes: 1 addition & 1 deletion ios/Podfile
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ target 'Plugin' do
pod 'Capacitor', :path => '../node_modules/@capacitor/ios'
pod 'CapacitorCordova', :path => '../node_modules/@capacitor/ios'

pod 'GoogleSignIn', '~> 5.0.2'
pod 'GoogleSignIn', '~> 6.0.1'

end

Expand Down
50 changes: 23 additions & 27 deletions ios/Podfile.lock
Original file line number Diff line number Diff line change
@@ -1,29 +1,25 @@
PODS:
- AppAuth (1.3.0):
- AppAuth/Core (= 1.3.0)
- AppAuth/ExternalUserAgent (= 1.3.0)
- AppAuth/Core (1.3.0)
- AppAuth/ExternalUserAgent (1.3.0)
- Capacitor (1.5.1):
- CapacitorCordova (= 1.5.1)
- CapacitorCordova (1.5.1)
- GoogleSignIn (5.0.2):
- AppAuth (~> 1.2)
- AppAuth (1.4.0):
- AppAuth/Core (= 1.4.0)
- AppAuth/ExternalUserAgent (= 1.4.0)
- AppAuth/Core (1.4.0)
- AppAuth/ExternalUserAgent (1.4.0)
- Capacitor (3.0.1):
- CapacitorCordova
- CapacitorCordova (3.0.1)
- GoogleSignIn (6.0.1):
- AppAuth (~> 1.4)
- GTMAppAuth (~> 1.0)
- GTMSessionFetcher/Core (~> 1.1)
- GTMAppAuth (1.0.0):
- AppAuth/Core (~> 1.0)
- GTMSessionFetcher (~> 1.1)
- GTMSessionFetcher (1.3.1):
- GTMSessionFetcher/Full (= 1.3.1)
- GTMSessionFetcher/Core (1.3.1)
- GTMSessionFetcher/Full (1.3.1):
- GTMSessionFetcher/Core (= 1.3.1)
- GTMAppAuth (1.2.2):
- AppAuth/Core (~> 1.4)
- GTMSessionFetcher/Core (~> 1.5)
- GTMSessionFetcher/Core (1.6.1)

DEPENDENCIES:
- "Capacitor (from `../node_modules/@capacitor/ios`)"
- "CapacitorCordova (from `../node_modules/@capacitor/ios`)"
- GoogleSignIn (~> 5.0.2)
- GoogleSignIn (~> 6.0.1)

SPEC REPOS:
trunk:
Expand All @@ -39,13 +35,13 @@ EXTERNAL SOURCES:
:path: "../node_modules/@capacitor/ios"

SPEC CHECKSUMS:
AppAuth: 73574f3013a1e65b9601a3ddc8b3158cce68c09d
Capacitor: 373adb05f4591a70c22adfe979b5a443ac1e9b0a
CapacitorCordova: 169792fba40cc325d70b3cbca49d0563acdf5924
GoogleSignIn: 7137d297ddc022a7e0aa4619c86d72c909fa7213
GTMAppAuth: 4deac854479704f348309e7b66189e604cf5e01e
GTMSessionFetcher: cea130bbfe5a7edc8d06d3f0d17288c32ffe9925
AppAuth: 31bcec809a638d7bd2f86ea8a52bd45f6e81e7c7
Capacitor: 92088387144015b95e369bd7840e8ef28b8fe9f3
CapacitorCordova: 624ae0d33d61b554eda6823da8ea6c3e5170f646
GoogleSignIn: 1b0c4ec33a6fe282f4fa35d8ac64263230ddaf36
GTMAppAuth: ad5c2b70b9a8689e1a04033c9369c4915bfcbe89
GTMSessionFetcher: 36689134877faeb055b27dfa4ccc9ceaa42e029e

PODFILE CHECKSUM: 26646079fafcf11562258f66ca17008384d1890a
PODFILE CHECKSUM: 0f3f70de2469d6ef87a4f55c3a96868777b79b2e

COCOAPODS: 1.8.4
COCOAPODS: 1.10.1

0 comments on commit 4859f9c

Please sign in to comment.