¶ Angular Login Component
The Authing login component (Guard) is an embeddable login form that can be configured according to your needs and is recommended for single-page applications. It allows you to easily add various social login methods so that your users can log in seamlessly and have a consistent login experience on different platforms. Guard shields many implementation details of low-level authentication for developers, as well as cumbersome UI development.
Guard can be integrated into your Angular projects. You can use this component to quickly implement the login authentication process.
¶ Quick start
¶ Installation
$ yarn add @authing/ng-ui-components
# OR
$ npm install @authing/ng-ui-components --save
¶ Initialization
Initialize in the Angular project:
app.module.ts
import { BrowserModule } from "@angular/platform-browser";
import { NgModule } from "@angular/core";
import { authingGuardModule } from "@authing/ng-ui-components";
import { AppComponent } from "./app.component";
@NgModule({
declarations: [AppComponent],
imports: [BrowserModule, authingGuardModule],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule {}
app.component.ts
//
import { Component } from "@angular/core";
import { CommonMessage, AuthenticationClient } from "ng-ui-components";
@Component({
selector: "app-root",
templateUrl: "./app.component.html",
styleUrls: ["./app.component.scss"]
})
export class AppComponent {
appId = "AUTHING_APP_ID";
onLoad([e]: [AuthenticationClient]) {
console.log("ffffff", e);
}
}
app.component.html
<authing-guard [appId]="appId" (onLoad)="onLoad($event)"></authing-guard>
How to initialize in an HTML file?
¶ Import by CDN
<script src="https://cdn.jsdelivr.net/npm/@authing/ng-ui-components"></script>
¶ Initialize in Script code block
<div ng-app="">
<authing-guard [appId]="AUTHING_APP_ID"></authing-guard>
</div>
¶ Monitor login events
authing-guard
Component Callback function for onLogin
event,which is called when the user successfully logs in, and you can get the user information of the current user here.View the complete list of events.
<authing-guard [appId]="appId" (onLogin)="onLoad($event)"></authing-guard>
export class AppComponent {
appId = "AUTHING_APP_ID";
onLogin([user]) {
console.log("userInfo: ", user);
}
}
What should we do after understanding user information?
After obtaining the user information, you can get the user's identity credential (the token
field ), which you can carry in subsequent requests sent by the client to the backend server token
, for axios
example :
const axios = require("axios");
axios
.get({
url: "https://yourdomain.com/api/v1/your/resources",
headers: {
Authorization: "Bearer ID_TOKEN"
}
})
.then(res => {
// custom codes
});
The legitimacy of this needs to be checked in the back-end interface to verify the user's identity. For details of the verification method, see Verifying User Identity Credentials (token) . After identifying the user's identity, you may also need to perform permission management on the user to determine whether the user has permission to operate this API.
¶ Add social login
Pass in the socialConnections
list in the initialization parameter config
to specify the social logins that need to be displayed(all social logins configured by the applicationare displayed by default).
<authing-guard [appId]="appId" [config]="config"></authing-guard>
export class AppComponent {
appId = "AUTHING_APP_ID";
config = {
socialConnections: ["github"]
};
}
View the list of supported social logins and access procedures
Authing currently supports 4 social logins around the world, such as GitHub, Apple, etc. The following is a complete list:
Social Identity Provider | Scenes | Docs |
---|---|---|
WeChat QR Code on PC | Web | Documentation |
WeChat Mobile | Mobile App | Documentation |
WeChat Web Page | Wechat Browser | Documentation |
Wechat Official Accounts QR Code | Web | Documentation |
Mini Program | Mini Program | Documentation |
Mini Program QR Code on PC | Web | Documentation |
Pull-up Mini Program on App | Mobile App | Documentation |
Web | Documentation | |
Web | Documentation | |
GitHub | Web | Documentation |
Web | Documentation | |
Web | Documentation | |
Web | Documentation | |
Apple (Web) | Web | Documentation |
Apple (Mobile) | Mobile App | Documentation |
Alipay | Mobile App | Documentation |
Slack | Web | Documentation |
Gitee | Web | Documentation |
GitLab | Web | Documentation |
Baidu | Web | Documentation |
Web | Documentation | |
NetEase YIDUN | Mobile App | Documentation |
QingCloud | Web | Documentation |
Web | Documentation |
¶ Log out
- Initialize the [AuthenticationClient](/reference/sdk-for-node/#Use 认证模块)in the project entry file.
import { initAuthClient } from "@authing/ng-ui-components";
initAuthClient({
appId: "AUTHING_APP_ID"
});
- Add a
button
to log out and bind the click event togetAuthClient().logout()
.
<button (click)="logout()">Log out</button>
import { initAuthClient } from "@authing/react-ui-components";
export class AppComponent {
logout() {
getAuthClient().logout();
}
}
¶ Implement single sign-on
To use Guard for single sign-on, you need to set isSSO
to true
during initialization.
<authing-guard [appId]="appId" [config]="config"></authing-guard>
export class AppComponent {
appId = "AUTHING_APP_ID";
config = {
isSSO: true
};
}
¶ Export authing-js-sdk
The Guard component itself is packaged based on the authing JavaScript SDK. When you need to perform some more advanced operations (such as managing user-defined data, modifying user information, logging out):
- Call
initAuthClient
to initialize AuthenticationClient. Calling this function multiple times will only initialize it once.
import { initAuthClient } from "@authing/ng-ui-components";
initAuthClient({
appId: "AUTHING_APP_ID"
});
- Then use
getAuthClient
to getAuthenticationClient
instance.
import { getAuthClient } from "@authing/ng-ui-components";
const authClient = getAuthClient();
- Call the method of
AuthenticationClient
instance. For a complete list of methods, please see the AuthenticationClient method list.
authClient.getCurrentUser().then(user => console.log(user));
¶ Complete parameter
The Authing login component (Guard) provides many advanced configurations, such as customizing the UI and using specific login methods. See the complete parameter list.
¶ Event list
Event name | Event Introduction | Event parameter | Event parameter introduction |
---|---|---|---|
load | Authing appId authenticate success,loading complete | authClient | AuthenticationClient object,can directly operate login, register,details in authing-js-sdk |
load-error | Authing appId authenticate failed,loading failed | error | Error information |
login | User login success | user, authClient | user: user information authClient same as before |
login-error | User login failed | error | Error information,including information such as missing/illegal fields or server errors |
register | User login success | user, authClient | user: user information authClient same as before |
register-error | User login failed | error | Error information,including information such as missing/illegal fields or server errors |
pwd-email-send | Forgot password email sending success | - | - |
pwd-email-send-error | Forgot password email sending failed | error | Error information |
pwd-phone-send | Forgot password mobile verification code sending success | - | - |
pwd-phone-send-error | Forgot password mobile verification code sending failed | error | Error information |
pwd-reset | Reset password success | - | - |
pwd-reset-error | Reset password failed | error | Error information |
close | guard close event in modal mode | - | - |
login-tab-change | Login tab switching event | activeTab | Tab after switching |
register-tab-change | Register tab switching event | activeTab | Tab after switching |
register-tab-change | Register tab switching event | activeTab | Tab after switching |
register-info-completed | Register Supplemental Success Event | user, udfs, authClient | user: user information udfs: Supplementary custom field information authClient same as before |
register-info-completed-error | Register Supplemental Failure Event | error, udfs, authClient | error: error information udfs: Supplementary custom field information authClient same as before |
¶ Privatization deployment
The privatization deploymentscenario needs to specify the GraphQL endpoint of your privatized Authing service(without protocol header and Path).If you are not sure, you can contact the Authing IDaaS service administrator.
<authing-guard [appId]="appId" [config]="config"></authing-guard>
export class AppComponent {
appId = "AUTHING_APP_ID";
config = {
apiHost: "https://core.you-authing-service.com"
};
}
¶ Online experience
¶ Get help
Join us on forum: #authing-chat (opens new window)