From T3_KR_KNU
Revision as of 06:32, 22 June 2021 by Hanbi (Talk | contribs) (view_macaroon을 이용한 토큰 정보 확인)

Jump to: navigation, search

1 dCache에서 WebDav 프로토콜 및 마카롱 인증 사용하기

향후 GridFTP와 x507 그리드 인증을 대체하는 WebDav 프로토콜과 마카롱 인증에 대한 소개 문서입니다.

1.1 사전 작업

X509_USER_PROXY 변수가 있는지 확인하고 없다면 다음과 같이 만들어줍니다.

echo $X509_USER_PROXY
export X509_USER_PROXY=/tmp/x509up_u`id -u $USER`
echo $X509_USER_PROXY

프록시를 생성합니다. 마카롱 토큰을 발급받기 위해서는 여러기지 인증을 사용할 수 있지만 일단 지금은 X509_USER_PROXY로 부터 마카롱 토큰을 발급받겠습니다.

voms-proxy-init --voms cms  
or
voms-proxy-init --voms cms --valid 168:00 # 전송에 긴 시간이 소요될것으로 예상이 된다면 프록시를 생성할때 유효기간을 충분히 늘려줘야 합니다.

1.2 마카롱 인증

1.2.1 권한

LIST, DOWNLOAD, UPLOAD, DEL

1.2.2 토큰의 유효기간

발급하는 토큰은 유효기간을 정할 수 있습니다. 오용을 방지하기 위해서 반드시 적절한 유효기간을 설정하기를 권장합니다.

ex) PT1H : 1시간

1.2.3 curl을 이용한 토큰 발급

curl -L --capath /etc/grid-security/certificates --cacert $X509_USER_PROXY -E $X509_USER_PROXY \
            -X POST -d '{"caveats": ["activity:DOWNLOAD,LIST"], "validity": "PT1H"}' \
            -H 'Content-Type: application/macaroon-request' \
            https://cluster142.knu.ac.kr:2880/cms/store/user/{my_cern_id}/test/
{
   "macaroon": "MDA0NmxvY2F0aW9uIE9wdGlvbmFsWy9wbm..............................................................",
    "uri": {
       "targetWithMacaroon": "https://cluster142.knu.ac.kr:2880/cms/store/user/dhhan/test/?authz=MDA0NmxvY2F0aW9uIE9wdGlvbm.....................................................",
       "baseWithMacaroon": "https://cluster142.knu.ac.kr:2880/?authz=MDA0NmxvY2F0aW9uIE9wdGlvbmFsWy9wbm..............................................................",
       "target": "https://cluster142.knu.ac.kr:2880/cms/store/user/{my_cern_id}/test/",
       "base": "https://cluster142.knu.ac.kr:2880/"
    }
}

1.2.4 get_macaroon을 이용한 토큰 발급

1.2.5 view_macaroon을 이용한 토큰 정보 확인

1.3 WebDav 프로토콜

1.3.1 WebDav 프로토콜 클라이언트 프로그램

이름 지원 권한 비고
웹브라우저 list, download firefox, chrome, etc
curl list, download, upload, del
rclone list, download, upload, del

1.3.2 웹브라우저를 이용하여 SE에서 파일 다운로드하기

1.3.3 curl 사용법

1.3.4 rclone 사용법