-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* REFACTOR: 모바일 토큰 발급 API에 refresh 추가 * FEAT: 모바일 토큰 재발급 API
- Loading branch information
Showing
4 changed files
with
229 additions
and
154 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
74 changes: 41 additions & 33 deletions
74
src/main/java/com/soongsil/CoffeeChat/controller/RefreshTokenController.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,55 +1,63 @@ | ||
package com.soongsil.CoffeeChat.controller; | ||
|
||
import org.springframework.http.ResponseEntity; | ||
import org.springframework.web.bind.annotation.PostMapping; | ||
import org.springframework.web.bind.annotation.RequestMapping; | ||
import org.springframework.web.bind.annotation.RequestParam; | ||
import org.springframework.web.bind.annotation.RestController; | ||
|
||
import com.soongsil.CoffeeChat.config.jwt.JWTUtil; | ||
import com.soongsil.CoffeeChat.controller.handler.ApiResponseGenerator; | ||
import com.soongsil.CoffeeChat.service.CustomOAuth2UserService; | ||
import com.soongsil.CoffeeChat.service.RefreshTokenService; | ||
|
||
import io.swagger.v3.oas.annotations.Operation; | ||
import io.swagger.v3.oas.annotations.responses.ApiResponse; | ||
import io.swagger.v3.oas.annotations.tags.Tag; | ||
import jakarta.servlet.http.HttpServletRequest; | ||
import jakarta.servlet.http.HttpServletResponse; | ||
import lombok.RequiredArgsConstructor; | ||
import org.springframework.http.ResponseEntity; | ||
import org.springframework.web.bind.annotation.*; | ||
|
||
import java.util.Map; | ||
|
||
@RestController //RestController=Controller+ResponseBody | ||
@RequestMapping("/auth") | ||
@Tag(name = "REFRESHTOKEN", description = "리프레쉬 토큰 관련 api") | ||
@RequiredArgsConstructor | ||
public class RefreshTokenController { //Refresh토큰으로 Access토큰 발급 및 2차회원가입 컨트롤러 | ||
private final JWTUtil jwtUtil; | ||
private final RefreshTokenService refreshTokenService; | ||
private final JWTUtil jwtUtil; | ||
private final RefreshTokenService refreshTokenService; | ||
|
||
private final CustomOAuth2UserService oAuth2UserService; | ||
|
||
private final CustomOAuth2UserService oAuth2UserService; | ||
@PostMapping("/reissue") | ||
@Operation(summary = "리프레쉬 토큰으로 액세스 토큰 reissue") | ||
@ApiResponse(responseCode = "200", description = "헤더 : access, refresh, loginStatus") | ||
public ResponseEntity<ApiResponseGenerator<String>> reissue(HttpServletRequest request, | ||
HttpServletResponse response) { | ||
//System.out.println("ㅇㅇ"); | ||
return ResponseEntity.ok().body( | ||
ApiResponseGenerator.onSuccessOK( | ||
refreshTokenService.reissueByRefreshToken(request, response) | ||
) | ||
); | ||
} | ||
|
||
@PostMapping("/reissue") | ||
@Operation(summary = "리프레쉬 토큰으로 액세스 토큰 reissue") | ||
@ApiResponse(responseCode = "200", description = "헤더 : access, refresh, loginStatus") | ||
public ResponseEntity<ApiResponseGenerator<String>> reissue(HttpServletRequest request, | ||
HttpServletResponse response) { | ||
//System.out.println("ㅇㅇ"); | ||
return ResponseEntity.ok().body( | ||
ApiResponseGenerator.onSuccessOK( | ||
refreshTokenService.reissueByRefreshToken(request, response) | ||
) | ||
); | ||
} | ||
@PostMapping("/issue/mobile") | ||
@Operation(summary = "[MOBILE] google 서버에서 받은 accessToken으로 서비스 accessToken 발급") | ||
@ApiResponse(responseCode = "200", description = "유효한 google accessToken으로 요청시 body로 ROLE_USER 토큰 반환") | ||
public ResponseEntity<ApiResponseGenerator<Map<String, String>>> issueAccessToken(@RequestParam String accessToken, | ||
@RequestParam String name) { | ||
return ResponseEntity.ok().body( | ||
ApiResponseGenerator.onSuccessOK( | ||
oAuth2UserService.verifyGoogleToken(accessToken, name) | ||
) | ||
); | ||
} | ||
|
||
@PostMapping("/reissue/mobile") | ||
@Operation(summary = "리소스 서버에서 받은 accessToken으로 서비스 accessToken 발급") | ||
@ApiResponse(responseCode = "200", description = "유효한 google accessToken으로 요청시 body로 ROLE_USER 토큰 반환") | ||
public ResponseEntity<ApiResponseGenerator<String>> issueAccessToken(@RequestParam String accessToken, | ||
@RequestParam String name) { | ||
return ResponseEntity.ok().body( | ||
ApiResponseGenerator.onSuccessOK( | ||
oAuth2UserService.verifyGoogleToken(accessToken, name) | ||
) | ||
); | ||
} | ||
@PostMapping("/reissue/mobile") | ||
@Operation(summary = "[MOBILE] refreshToken으로 서비스 accessToken, refreshToken 재발급") | ||
@ApiResponse(responseCode = "200", description = "유효한 refreshToken 요청시 body로 accessToken, refreshToken 반환") | ||
public ResponseEntity<ApiResponseGenerator<Map<String, String>>> reissueAccessTokenWithRefreshToken( | ||
@RequestHeader String refreshToken) { | ||
return ResponseEntity.ok().body( | ||
ApiResponseGenerator.onSuccessOK( | ||
refreshTokenService.reissueByRefreshTokenWithResponseBody(refreshToken) | ||
)); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.