1.1.3 • Published 1 year ago
@coffee-tree/sejong-auth-delegator v1.1.3
SejongAuthDelegator
목차
소개
SejongAuthDelegator는 세종대학교의 인증 시스템을 위해 개발된 라이브러리입니다. 사용자의 ID와 패스워드를 이용해 세종대학교 시스템에 로그인하고, 인증된 세션을 통해 사용자의 프로필 정보를 가져올 수 있습니다.
사용가능한 메서드
메서드
getUserProfile(loginRequestDto: LoginRequestDto): Promise<ProfileResponseDto> | null
설명
세종대학교 사용자 프로필 정보를 조회하여 반환합니다.
인자
loginRequestDto:LoginRequestDto객체
반환값
| 조건 | 반환 타입 | 설명 |
|---|---|---|
| 성공 | ProfileResponseDto | 사용자 프로필 정보 |
| 실패 | null | 사용자 인증 실패 시 null 반환 |
getAuthenticatedJsessionId(loginRequestDto: LoginRequestDto): Promise<string> | null
설명
사용자를 인증하고 세션 ID(jsessionId)를 반환합니다.
인자
loginRequestDto:LoginRequestDto객체
반환값
| 조건 | 반환 타입 | 설명 |
|---|---|---|
| 성공 | string | 인증된 사용자의 세션 ID (유효기간 존재) |
| 실패 | null | 사용자 인증 실패 시 null 반환 |
isAuthenticatedUser(loginRequestDto: LoginRequestDto): Promise<boolean>
설명
사용자의 인증 가능 여부를 판단합니다.
인자
loginRequestDto:LoginRequestDto객체
반환값
| 조건 | 반환 타입 | 설명 |
|---|---|---|
| 성공 | boolean | 사용자 인증 성공 시 true |
| 실패 | boolean | 사용자 인증 실패 시 false |
createLoginRequestDto(userId: string, password: string): LoginRequestDto
설명
userId와 password를 받아서 LoginRequestDto 객체를 생성합니다.
인자
userId: 사용자 IDpassword: 사용자 비밀번호
반환값
LoginRequestDto: 생성된LoginRequestDto객체
객체
LoginRequestDto
사용자 로그인 요청 정보를 담는 객체입니다.
| 필드명 | 타입 | 설명 |
|---|---|---|
| userId | string | sju 통합 로그인 ID |
| password | string | sju 통합 로그인 Password |
ProfileResponseDto
사용자 프로필 정보를 담는 객체입니다.
| 필드명 | 타입 | 설명 |
|---|---|---|
| major | string | 전공 |
| studentCode | string | 학번 |
| name | string | 이름 |
| gradeLevel | number | 학년 |
| userStatus | string | 사용자 상태 |
| completedSemesters | number | 이수한 학기 수 |
| verifiedSemesters | number | 인증받은 학기 수 |
설치방법
npm에 배포되어 있는 라이브러리를 install 하여 사용하는 것이 권장된다.
npm i @coffee-tree/sejong-auth-delegator사용예시
cjs(commonjs)와 esm(module) 방식 모두 지원된다.
CJS
Then 방식
const {
sejongAuthDelegator,
LoginRequestDto,
} = require("@coffee-tree/sejong-auth-delegator");
const login = (userId, password) => {
const delegator = sejongAuthDelegator();
const loginRequestDto = new LoginRequestDto(userId, password);
const profile = delegator
.getUserProfile(loginRequestDto)
.then((userProfile) => {
return userProfile;
})
.catch((error) => {
console.error("Error fetching user profile", error);
throw error;
});
return profile;
};Async/Await 방식
const {
sejongAuthDelegator,
LoginRequestDto,
} = require("@coffee-tree/sejong-auth-delegator");
const login = (userId, password) => {
const delegator = sejongAuthDelegator();
const loginRequestDto = new LoginRequestDto(userId, password);
try {
const userProfile = await delegator.getUserProfile(loginRequestDto);
return userProfile;
} catch (error) {
console.error("Error fetching user profile", error);
throw error;
}
};ESM
Promise 방식
import {
sejongAuthDelegator,
LoginRequestDto,
} from "@coffee-tree/sejong-auth-delegator";
const login = (userId, password) => {
const delegator = sejongAuthDelegator();
const loginRequestDto = new LoginRequestDto(userId, password);
const profile delegator
.getUserProfile(loginRequestDto)
.then((userProfile) => {
return userProfile;
})
.catch((error) => {
console.error("Error fetching user profile", error);
throw error;
});
return profile;
};Async/Await 방식
import {
sejongAuthDelegator,
LoginRequestDto,
} from "@coffee-tree/sejong-auth-delegator";
const login = (userId, password) => {
const delegator = sejongAuthDelegator();
const loginRequestDto = new LoginRequestDto(userId, password);
try {
const profile = await delegator.getUserProfile(loginRequestDto);
return profile;
} catch (error) {
console.error("Error fetching user profile", error);
throw error;
}
};이슈등록
코드에 오류 및 개선사항이 있을 경우 해당 저정소에 이슈를 남겨주시면 감사합니다sejong-auth-delegator-github
패치내역
2024-05-23
- 로그인 성공 판단 기준을 변경하였습니다
- TEST 검증 코드를 추가하였습니다.
LoginRequestDTO클래스를 직접 반환받아 사용할 수 있게 하였습니다.- README 예시 코드를 변경하였습니다.