-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
4 changed files
with
116 additions
and
4 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
27 changes: 27 additions & 0 deletions
27
src/main/java/com/backend/allreva/auth/util/JwtTestTokenInitializer.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 |
---|---|---|
@@ -0,0 +1,27 @@ | ||
package com.backend.allreva.auth.util; | ||
|
||
|
||
import java.util.HashMap; | ||
import java.util.Map; | ||
import org.springframework.stereotype.Component; | ||
|
||
@Component | ||
public class JwtTestTokenInitializer { | ||
|
||
private final Map<String, String> jwtTokens; | ||
|
||
public JwtTestTokenInitializer(JwtProvider jwtProvider) { | ||
this.jwtTokens = new HashMap<>(); | ||
|
||
jwtTokens.put("ADMIN", jwtProvider.generateRefreshToken(String.valueOf(1L))); | ||
jwtTokens.put("USER", jwtProvider.generateRefreshToken(String.valueOf(2L))); | ||
jwtTokens.put("GUEST", jwtProvider.generateRefreshToken(String.valueOf(3L))); | ||
|
||
jwtTokens.forEach((role, token) -> | ||
System.out.println(role + " Token: " + token)); | ||
} | ||
|
||
public String getToken(String role) { | ||
return jwtTokens.get(role); | ||
} | ||
} |
37 changes: 35 additions & 2 deletions
37
src/main/java/com/backend/allreva/common/config/SwaggerConfig.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,16 +1,49 @@ | ||
package com.backend.allreva.common.config; | ||
|
||
import com.backend.allreva.auth.util.JwtTestTokenInitializer; | ||
import io.swagger.v3.oas.models.Components; | ||
import io.swagger.v3.oas.models.OpenAPI; | ||
import io.swagger.v3.oas.models.info.Info; | ||
import io.swagger.v3.oas.models.security.SecurityRequirement; | ||
import io.swagger.v3.oas.models.security.SecurityScheme; | ||
import lombok.RequiredArgsConstructor; | ||
import org.springframework.context.annotation.Bean; | ||
import org.springframework.context.annotation.Configuration; | ||
|
||
@Configuration | ||
@RequiredArgsConstructor | ||
public class SwaggerConfig { | ||
|
||
private final JwtTestTokenInitializer jwtTestTokenInitializer; | ||
|
||
@Bean | ||
public OpenAPI openAPI() { | ||
public OpenAPI customOpenAPI() { | ||
SecurityScheme userScheme = createSecurityScheme("USER", jwtTestTokenInitializer.getToken("USER")); | ||
SecurityScheme adminScheme = createSecurityScheme("ADMIN", jwtTestTokenInitializer.getToken("ADMIN")); | ||
SecurityScheme guestScheme = createSecurityScheme("GUEST", jwtTestTokenInitializer.getToken("GUEST")); | ||
|
||
SecurityRequirement userRequirement = new SecurityRequirement().addList("USER"); | ||
SecurityRequirement adminRequirement = new SecurityRequirement().addList("ADMIN"); | ||
SecurityRequirement guestRequirement = new SecurityRequirement().addList("GUEST"); | ||
|
||
return new OpenAPI() | ||
.info(new Info().title("AllReva")); | ||
.info(new Info().title("AllReva")) | ||
.components(new Components() | ||
.addSecuritySchemes("USER", userScheme) | ||
.addSecuritySchemes("ADMIN", adminScheme) | ||
.addSecuritySchemes("GUEST", guestScheme)) | ||
.addSecurityItem(userRequirement) | ||
.addSecurityItem(adminRequirement) | ||
.addSecurityItem(guestRequirement); | ||
} | ||
|
||
private SecurityScheme createSecurityScheme(String role, String token) { | ||
return new SecurityScheme() | ||
.type(SecurityScheme.Type.HTTP) | ||
.scheme("bearer") | ||
.bearerFormat("JWT") | ||
.name("Authorization") | ||
.description(String.format("%s Token: %s", role, token)) | ||
.in(SecurityScheme.In.HEADER); | ||
} | ||
} |
47 changes: 47 additions & 0 deletions
47
src/main/java/com/backend/allreva/common/runner/MemberDummyDataInitializer.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 |
---|---|---|
@@ -0,0 +1,47 @@ | ||
package com.backend.allreva.common.runner; | ||
|
||
import com.backend.allreva.common.model.Email; | ||
import com.backend.allreva.member.command.application.MemberRepository; | ||
import com.backend.allreva.member.command.domain.Member; | ||
import com.backend.allreva.member.command.domain.value.LoginProvider; | ||
import com.backend.allreva.member.command.domain.value.MemberRole; | ||
import lombok.RequiredArgsConstructor; | ||
import org.springframework.boot.CommandLineRunner; | ||
import org.springframework.stereotype.Component; | ||
|
||
@Component | ||
@RequiredArgsConstructor | ||
public class MemberDummyDataInitializer implements CommandLineRunner { | ||
|
||
private final MemberRepository memberRepository; | ||
|
||
@Override | ||
public void run(String... args) throws Exception { | ||
Member admin = Member.builder() | ||
.email(Email.builder().email("[email protected]").build()) | ||
.nickname("admin") | ||
.loginProvider(LoginProvider.GOOGLE) | ||
.memberRole(MemberRole.ADMIN) | ||
.introduce("test") | ||
.profileImageUrl("https://my_picture") | ||
.build(); | ||
memberRepository.save(admin); | ||
|
||
Member user = Member.builder() | ||
.email(Email.builder().email("[email protected]").build()) | ||
.nickname("user") | ||
.loginProvider(LoginProvider.GOOGLE) | ||
.memberRole(MemberRole.USER) | ||
.introduce("test") | ||
.profileImageUrl("https://my_picture") | ||
.build(); | ||
memberRepository.save(user); | ||
|
||
Member guest = Member.createTemporary( | ||
"[email protected]", | ||
"guest", | ||
LoginProvider.GOOGLE, | ||
"https://my_picture"); | ||
memberRepository.save(guest); | ||
} | ||
} |