Deployment를 생성합니다. 생성한 API Gateway를 선택한 후 좌측 Deployments 메뉴 선택, Create deployment 버튼을 클릭합니다.
- Basic Information
- Name: hello
- Path prefix: /
- Compartment: Deployment를 생성할 구획 선택
Authentication은 뒷 부분에서 설정할 것이므로 여기서는 일단 No Authentication을 선택하고 Next를 클릭합니다. data:image/s3,"s3://crabby-images/3fab8/3fab8e51091840cdb54a87c8ba65bf541e4b477b" alt=""
Routes에서 다음과 같이 Route를 등록합니다.
- Route 1
- Path: /hello
- Methods: GET
- Add a single backend: 체크
- Backend Type: Stock response
- Status Code: 201
- Body: {“message”: “Hello”}
- Header name: Content-type, Header value: application/json
data:image/s3,"s3://crabby-images/517cb/517cb88479c419a1437fdf7c2857b45cde7fc3ff" alt=""
Next를 클릭한 후 Create를 클릭하여 생성합니다.
다음과 같이 API Gateway의 Endpoint와 Route Path를 통해 호출해보면 정상적으로 호출이 되는 것을 확인할 수 있습니다. data:image/s3,"s3://crabby-images/389c4/389c41ba2eb7ec84e25c1badff1208b2ac094cf8" alt=""
OCI API Gateway에서 OAuth2을 구성하는 방법
이제 생성한 API에 OAuth2 보안을 적용해 보도록 하겠습니다.
Access signing certificate 사용 설정
클라이언트가 OCI Identity Domain에 로그인하지 않고도 Tenancy 서명 인증서에 액세스할 수 있도록 설정합니다. data:image/s3,"s3://crabby-images/66401/66401a77f278238fefb9bf59bdf56ad0d70b6ba0" alt=""
OCI Identity Domain의 Resource Server Application 구성
다음과 같이 OCI Console 메뉴 > Identity & Security > Domains 클릭 후 적용 할 도메인을 선택(여기서는 Default)합니다. data:image/s3,"s3://crabby-images/acb4d/acb4da10eaa7e463ed6d69ad207f35d0c119e882" alt=""
Integrated Applications > Add application 클릭 후 Dialog 창에서 Credential Application을 선택합니다. data:image/s3,"s3://crabby-images/0cc96/0cc960c493b6e5083386db5aef2715ff635a17b8" alt=""
다음과 같이 Name을 입력합니다.
- Name: Hello APIGW Application
Configure OAuth에서 다음과 같이 Resource Server 구성을 합니다.
- Configure this application as a resource server now: 선택
- Primary audience: hello
- Add scopes: 선택
- Scope: :read
- Add 버튼 클릭 후 Scope 이름으로 :read 입력
data:image/s3,"s3://crabby-images/0beb0/0beb002f4750a19d31e479cacc68dc9faeaddc58" alt=""
OCI Identity Domain의 Client 구성
Resource Server 구성에 이어서 Client Configuration 구성을 합니다.
- Configure this application as a client now: 선택
- Allowed grant types: Client credentials
- Client type: Confidential
- Allowed operations: Introspect
- Bypass consent: On
- Client IP address: Anywhere
- Authorized resources: Specific
- Add resources: 선택
- Resources
- Add scope 버튼 클릭 후 Hello APIGW Application 선택
data:image/s3,"s3://crabby-images/ba94f/ba94f692c458ac05cfdcaddfce67cebb584f2e7a" alt=""
Web tier policy는 Skip and do later를 선택하고 Finish를 클릭합니다.
생성된 애플리케이션을 선택하면 다음과 같이 Client ID와 Client secret을 확인할 수 있습니다. 이 정보는 Access Token을 발급받기 위해 사용되므로 메모합니다. data:image/s3,"s3://crabby-images/23657/2365751ff749611baf0ad40e44899a5c140c44ba" alt=""
API Deployment Route Path에 OAuth2 인증 설정
이제 앞서 생성한 Deployment Route Path에 OAuth2 인증 설정을 진행합니다. 먼저 생성한 Deployment를 선택 후 Edit을 클릭합니다. data:image/s3,"s3://crabby-images/790a8/790a8890dab0445fd98f3b04133650f36d402941" alt=""
Authentication 단계에서 Single Authentication을 선택한 후 다음과 같이 설정합니다.
- Authentication type: OAuth 2.0 / OpenID Connect
- Token location: Header
- JWT token header name: Authorization
- Authentication scheme: Bearer
- Validation type: OAuth 2.0 introspection endpoint
- Identity Provider가 Introspection Endpoint API를 제공해야 합니다. OCI Identity Provider의 Introspection Endpoint로 JWT혹은 non-JWT토큰의 유효성을 검사합니다. 여기서 Introspection Endpoint를 얻을 때는 ID Provider의 Discovery URL이 필요한데, 기본적으로
https://my-idp/.well-known/openid-configuration
형태의 주소를 가집니다. my-idp 주소는 Identity Domain을 클릭하면 Domain URL로 확인이 가능합니다. data:image/s3,"s3://crabby-images/bf51f/bf51f023e0ea3c3c5242cbf5def35788b1153e6d" alt=""
- Client ID: Identity Domain에서 생성한 Credential Application의 Client ID
- Client Secret: Identity Domain에서 생성한 Credential Application의 Secret 값으로 OCI Vault에 저장한 후 사용 가능합니다. Vault 생성은 TheKoguryo’s 기술 블로그: Secret Store로 OCI Vault 사용하기를 참고합니다.
- Discovery URL: https://my-idp/.well-known/openid-configuration
- my-idp는 Identity Domain의 Domain URL입니다.
- Additional JWT validations
- Allowed issuers: https://identity.oraclecloud.com/
- Allowed Audiences: hello
- Validation failure policy: Default (HTTP 401 Unauthorized)
data:image/s3,"s3://crabby-images/51eb7/51eb773c333748761613d454168ed70ad2076441" alt=""
Next를 두 번 클릭한 후 Review에서 Save changes를 클릭하여 저정합니다.
이제 다시 API를 호출해보면 다음과 같이 401 Unauthorized 오류가 발생하는 것을 볼 수 있습니다. data:image/s3,"s3://crabby-images/8fdd7/8fdd71f6f96f06acfe5912e7c4b2de8571211aec" alt=""
OAuth2 적용 테스트
Postman으로 테스트를 진행합니다.
Get New Access Token 클릭한 후 Authentication complete이 되면 Proceed를 클릭합니다. data:image/s3,"s3://crabby-images/8683b/8683b3e66cb42d84723c0bc1856d3d777a78a2e4" alt=""
Use Token을 클릭합니다. data:image/s3,"s3://crabby-images/1f875/1f875178f37c8122f7631a3d75ea4d009c2e1d1f" alt=""
적용된 Access Token으로 API를 호출합니다. data:image/s3,"s3://crabby-images/9617a/9617a8826d3ff87f2b94b278ccab9671ecfd8c5c" alt=""
참고 웹사이트
- https://docs.oracle.com/en-us/iaas/Content/APIGateway/Tasks/apigatewayaddingauthzauthn.htm
- https://hudi.blog/open-id/
- https://juniortech.tistory.com/15
이 글은 개인적으로 얻은 지식과 경험을 작성한 글로 내용에 오류가 있을 수 있습니다. 또한 글 속의 의견은 개인적인 의견으로 특정 회사를 대변하지 않습니다.
Donghu Kim CLOUDNATIVE
api gateway oauth2