Table of contents
- How to enable Apple login in WordPress
- Apple Human Interface Guidelines compatibility
- Common error messages returned by Apple
- Registration limitations
How to enable Apple login in WordPress
Apple provider requires active subscription for the Apple Developer Program which costs 99 USD per year.
1.) Create the Apple App
- Navigate to https://developer.apple.com/account/resources/identifiers/list
- Click the blue + icon next to Identifiers, then select the App IDs option and click the “Continue” button.
- Enter a “Description“
- At the “Bundle ID” field select the “Explicit” option and enter your domain name in reverse-domain name style, with the name of the app at its end. E.g.: com.mydomain.nslapp
- Under the “Capabilities” section, tick the “Sign In with Apple” option.
- Scroll up and press the “Continue” button and then the “Register” button.
2.) Create the Apple Key:
- On the left hand side, click on the “Keys” tab.
- Click the blue + icon next to Keys heading.
- Enter a name in the Key Name field.
- Tick the “Sign In with Apple” option, then click on “Configure“.
- If you have multiple Apps, then at the “Choose a Primary App ID” field select the App what you just created, then click “Save“.
- Finally press the “Continue” button and then the “Register” button.
- Don’t download the key yet!
3.) Create the Apple Service:
- Go to the “Services IDs” section, what you will find within the “Identifiers” tab.
- Click the blue + icon next to Identifiers, then select the “Services IDs” option and click the “Continue” button.
- Enter a “Description“.
- At the “Identifier” field enter your domain name in reverse-domain name style, with the name of the client at its end. E.g.: com.mydomain.nslclient
- Note: This will also be used as “Service Identifier” later!
- Press the “Continue” button and then the “Register” button.
- In the “Services IDs” section, click the service you just created.
- Tick the “Sign In with Apple” option and click the “Configure” button next to it.
- If you have multiple Apps, then at the “Primary App ID” field select the App what you just created.
- Fill the “Domains and Subdomains” field with the domain that Nextend Social Login suggests
- Add the URL to the “Return URLs” field that Nextend Social Login suggests
- Save the configuration by clicking on the “Save” button and pressing “Done“.
- Finally press the “Continue” button and then the “Save” button.
4.) Configure Nextend Social Login with your credentials
Once everything is done above you’ll need to copy and paste the Private Key ID, Private Key, Team Identifier and Service Identifier to the Apple provider’s Settings tab and Generate a token.
Private Key ID:
Navigate to: https://developer.apple.com/account/resources/authkeys/list
Click on the name of your Key.
You will find your “Private Key ID” under “Key ID”.
Click the “Download” button to download the key file. Once this file is downloaded, it will no longer be available, so make sure you keep this file safe!
Open the downloaded file with a text editor like Notepad, copy all of its contents and paste it into Nextend Social Login’s Private Key field.
A 10 character long identifier, what you can find on the top-right corner, just under your name.
Navigate to: https://developer.apple.com/account/resources/identifiers/list/serviceId
You will find it under the IDENTIFIER column. If you configured the service according to the suggestions, it will probably end to .nslclient e.g.: com.mydomain.nslclient
When you need to change your credentials for some reason, then you must delete the token, copy the new credentials and generate a new token!
5.) Verifying the settings
After you successfully generated a token, the Client ID and the Client Secret will be filled up automatically. You will need these to verify the setup first. This verification helps you identify possible problems with the app.
The Client ID of your Apple app. The value is defined by the Service Identifier you entered earlier.
The JWT token that was generated from your Private Key ID, Private Key, Team Identifier and Service Identifier. Can not be edited directly! To generate a new token, you need to delete the currently stored JWT token.
Username prefix on register
Whenever a new user registers with their Apple account they can get a custom prefix so you can easily identify them.
Fallback username prefix on register
Whenever a new user registers with their Apple account and we can not generate a valid username from the first name or last name, a random username will be generated. With this option they can get a custom prefix so you can easily identify them.
Terms and conditions
This option can only be seen, if Terms and conditions is set to Show in Global Settings → Privacy tab. Here you can set custom Terms and Conditions for users who register with Apple. For more information please read our GDPR documentation.
Apple Human Interface Guidelines compatibility
According to the Apple Human Interface Guidelines, the button need to comply with some requirements. At the buttons tab of the Apple provider, there are predefined skins, which comply with those requirements.
Common error messages returned by Apple
Private key format is not valid!
Token generation failed: Private key format is not valid!
The problem is that the entered Private Key is not valid. Make sure you copied everything from the key file you downloaded, including the following parts:
- —–BEGIN PRIVATE KEY—–
- —–END PRIVATE KEY—–
Private Key ID, Team Identifier or Service Identifier is not valid. Delete your current token, insert the proper credentials and generate a new token!
invalid_request – Invalid redirect_uri.
The problem is that the entered Return URLs field is not correct for your app. You need to add the “Return URL” what you find at the “Create the Service” section.
Many web hosts have brute force protection enabled on the wp-login.php which prevent POST requests to wp-login.php for all domains except the originating domain. To fix the problem you need to use our OAuth redirect uri proxy page, as it will make the OAuth flow being handled on the selected page instead of the /wp-login.php.
Apple returns the first name and last name only the very first time a user authorizes your app! This means that, if the registration was not completed after the App authorization, then Nextend Social Login won’t be able to retrieve and store the name of the user the next time! In such cases the name will be empty and a random username will be generated!