mirror of
https://github.com/logto-io/logto.git
synced 2025-01-20 21:32:31 -05:00
docs: integrate iOS SDK (#748)
* docs: integrate iOS SDK * fix: change title * docs: remove unused import
This commit is contained in:
parent
631a8f0f49
commit
c535d90ff1
3 changed files with 93 additions and 8 deletions
|
@ -12,5 +12,5 @@ If the list doesn't cover your desired platform/framework, please file a feature
|
||||||
|
|
||||||
## Native
|
## Native
|
||||||
|
|
||||||
- iOS
|
- [iOS](./ios)
|
||||||
- [Android](./android)
|
- [Android](./android)
|
||||||
|
|
86
packages/docs/docs/tutorial/integrate-sdk/ios.mdx
Normal file
86
packages/docs/docs/tutorial/integrate-sdk/ios.mdx
Normal file
|
@ -0,0 +1,86 @@
|
||||||
|
---
|
||||||
|
sidebar_label: iOS
|
||||||
|
---
|
||||||
|
|
||||||
|
import Tabs from '@theme/Tabs';
|
||||||
|
import TabItem from '@theme/TabItem';
|
||||||
|
|
||||||
|
# Integrate Logto Swift SDK for iOS
|
||||||
|
|
||||||
|
:::note
|
||||||
|
This tutorial assumes you have created a Native App in Admin Console. If you are not ready, read this one before continuing.
|
||||||
|
:::
|
||||||
|
|
||||||
|
## Add Logto SDK as a Dependency
|
||||||
|
|
||||||
|
Use the following URL to add Logto SDK as a dependency in Swift Package Manager.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
https://github.com/logto-io/swift.git
|
||||||
|
```
|
||||||
|
|
||||||
|
Since Xcode 11, you can [directly import a swift package](https://developer.apple.com/documentation/swift_packages/adding_package_dependencies_to_your_app) w/o any additional tool.
|
||||||
|
|
||||||
|
We do not support **Carthage** and **CocoaPods** at the time due to some technical issues.
|
||||||
|
|
||||||
|
<details>
|
||||||
|
<summary>Carthage</summary>
|
||||||
|
Carthage <a href="https://github.com/Carthage/Carthage/issues/1226#issuecomment-290931385">needs a `xcodeproj` file to build</a>, but `swift package generate-xcodeproj` will report a failure since we are using binary targets for native social plugins. We will try to find a workaround later.
|
||||||
|
</details>
|
||||||
|
|
||||||
|
<details>
|
||||||
|
<summary>CocoaPods</summary>
|
||||||
|
CocoaPods <a href="https://github.com/CocoaPods/CocoaPods/issues/3276">does not support local dependency</a> and monorepo, thus it's hard to create a `.podspec` for this repo.
|
||||||
|
</details>
|
||||||
|
|
||||||
|
## Init `LogtoClient`
|
||||||
|
|
||||||
|
```swift
|
||||||
|
import Logto
|
||||||
|
|
||||||
|
let config = try? LogtoConfig(
|
||||||
|
endpoint: "<your-logto-endpoint>",
|
||||||
|
appId: "<your-application-id>"
|
||||||
|
)
|
||||||
|
let logtoClient = LogtoClient(useConfig: config)
|
||||||
|
```
|
||||||
|
|
||||||
|
By default, we store credentials like ID Token and Refresh Token in Keychain. Thus the user doesn't need to sign in again when he returns.
|
||||||
|
|
||||||
|
To turn off this behavior, set `usingPersistStorage` to `false`:
|
||||||
|
|
||||||
|
```swift
|
||||||
|
let config = try? LogtoConfig(
|
||||||
|
// ...
|
||||||
|
usingPersistStorage: false
|
||||||
|
)
|
||||||
|
```
|
||||||
|
|
||||||
|
## Sign In
|
||||||
|
|
||||||
|
:::note
|
||||||
|
Before calling `.signInWithBrowser(redirectUri:)`, make sure you have correctly [configured Redirect URI](https://logto.io) in Admin Console.
|
||||||
|
:::
|
||||||
|
|
||||||
|
```swift
|
||||||
|
do {
|
||||||
|
try await client.signInWithBrowser(redirectUri: "<your-redirect-uri>")
|
||||||
|
print(client.isAuthenticated) // true
|
||||||
|
} catch let error as LogtoClientErrors.SignIn {
|
||||||
|
// error occured during sign in
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Sign Out
|
||||||
|
|
||||||
|
```swift
|
||||||
|
await client.signOut()
|
||||||
|
```
|
||||||
|
|
||||||
|
This will clean all the Logto data in Keychain, if it has.
|
||||||
|
|
||||||
|
## Further Readings
|
||||||
|
|
||||||
|
- [SDK Documentation](https://link-url-here.org)
|
||||||
|
- [OIDC Documentation](https://link-url-here.org)
|
||||||
|
- [Calling API to fetch accessToken](https://link-url-here.org)
|
|
@ -2,8 +2,7 @@
|
||||||
sidebar_label: React
|
sidebar_label: React
|
||||||
---
|
---
|
||||||
|
|
||||||
// Wait for AC update
|
import Step from '@components/Step';
|
||||||
// import Step from '@components/Step';
|
|
||||||
import Tabs from '@theme/Tabs';
|
import Tabs from '@theme/Tabs';
|
||||||
import TabItem from '@theme/TabItem';
|
import TabItem from '@theme/TabItem';
|
||||||
|
|
||||||
|
@ -67,14 +66,14 @@ pnpm build
|
||||||
|
|
||||||
Add the following code to your main html file. You may need client ID and authorization domain.
|
Add the following code to your main html file. You may need client ID and authorization domain.
|
||||||
|
|
||||||
```typescript
|
```tsx
|
||||||
import { LogtoProvider, LogtoConfig } from '@logto/react';
|
import { LogtoProvider, LogtoConfig } from '@logto/react';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
|
||||||
//...
|
//...
|
||||||
|
|
||||||
const App = () => {
|
const App = () => {
|
||||||
const config: LogtoConfig = { clientId: 'foo', endpoint: 'https://your-endpoint-domain.com' };
|
const config: LogtoConfig = { appId: '<your-application-id>', endpoint: '<your-logto-endpoint>' };
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<BrowserRouter>
|
<BrowserRouter>
|
||||||
|
@ -115,7 +114,7 @@ The Logto React SDK provides you tools and hooks to quickly implement your own a
|
||||||
|
|
||||||
Add the following code to your web app
|
Add the following code to your web app
|
||||||
|
|
||||||
```typescript
|
```tsx
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { useLogto } from '@logto/react';
|
import { useLogto } from '@logto/react';
|
||||||
|
|
||||||
|
@ -131,7 +130,7 @@ export default SignInButton;
|
||||||
|
|
||||||
### Retrieve Auth Status
|
### Retrieve Auth Status
|
||||||
|
|
||||||
```typescript
|
```tsx
|
||||||
import React from "react";
|
import React from "react";
|
||||||
import { useLogto } from '@logto/react';
|
import { useLogto } from '@logto/react';
|
||||||
|
|
||||||
|
@ -165,7 +164,7 @@ Execute signOut() methods will redirect users to the Logto sign out page. After
|
||||||
|
|
||||||
Add the following code to your web app
|
Add the following code to your web app
|
||||||
|
|
||||||
```typescript
|
```tsx
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { useLogto } from '@logto/react';
|
import { useLogto } from '@logto/react';
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue