카우치베이스 모바일

동기화 게이트웨이에서 문서 유형을 확인하는 방법

동기화 게이트웨이 시리즈의 이전 블로그에서는 다음과 같은 내용을 살펴보았습니다. 사용자 인증 및 권한 부여 방법 를 동기화 게이트웨이의 일부 기능을 통해 애플리케이션에 추가할 수 있습니다. 이 시리즈를 바탕으로 이제 문서 유형의 유효성을 검사하는 방법을 살펴보겠습니다. 동기화 게이트웨이 를 사용하여 모바일 클라이언트 측에서 특정 사용자에 대한 접근성을 결정할 수 있습니다. 이는 다음 블로그에서 Couchbase Mobile이 읽기 측 보안을 수행하는 방법에 대한 채널 토론으로 이어질 것입니다. 쓰기 측 보안의 경우, 알려진 사용자로부터 들어오는 특정 문서를 백엔드 데이터베이스에 기록할 수 있도록 하는 동기화 기능의 주요 방법을 살펴보겠습니다.

동기화 기능

예를 들어 데이터베이스에 유효성 검사 코드에서 참조할 유형 키가 있는 문서가 하나 또는 여러 개 있다고 가정해 보겠습니다. 동기화 게이트웨이의 핵심은 동기화 함수의 구현 로직이며, 아래에서는 애플리케이션에서 사용자의 접근성 제어를 위해 문서 유형을 확인하는 방법을 살펴봅니다.  

문서의 '유형' 필드를 사용하면 문서가 나타내는 특정 값으로 구분할 수 있습니다. 문서 유형이 '학교', '차량' 또는 '친구'를 나타내는 경우 동기화 함수 내에서 스위치 문을 추가하여 동기화 함수 내에서 다른 문서 유형을 다른 방식으로 처리할 수 있는 방법을 캡처할 수 있습니다. 먼저 문서 유형을 확인하여 '친구' 유형인지 확인한 다음 문서 소유자 속성이 현재 인증된 사용자 ID와 일치하는지 '요구 사용자()' 메서드를 호출합니다. 소유자 속성이 현재 인증된 사용자와 일치하면 'items-doc.owner' 채널을 통해 모든 친구에게 문서에 대한 액세스 권한을 부여합니다. 이는 기본적으로 사용자가 초대한 친구 목록은 사용자 본인에게만 비공개이므로 다른 사람이 볼 수 없음을 의미합니다.

'기타' 조항은 친구 또는 차량의 문서가 아닌 경우입니다, 를 입력하면 학교의 항목 문서가 되고 소유자 속성이 현재 인증된 사용자 ID와 일치하는지 다시 한 번 확인합니다. 이전과 동일합니다, 항목 소유자 속성의 'items-' 채널에 항목을 추가하고 해당 사용자에게 해당 채널에 대한 액세스 권한을 부여합니다.

위의 스위치 로직으로 동기화 기능을 업데이트했지만, 실제로 알 수 없는 문서 유형을 거부하는 테스트를 추가하여 '친구', '차량' 또는 '학교 문서' 유형이 아닌 경우 'throw()' 메서드를 사용합니다.

'requireUser()' 메서드 대신, 이를 이제 기본적으로 목록에 새 항목을 작성하려면 항목을 추가하려는 특정 사용자의 항목 채널에 대한 액세스 권한이 있어야 하는 'requireAccess("items-"+doc.owner)' 메서드가 추가되었습니다.

이 문서 공유하기
받은 편지함에서 카우치베이스 블로그 업데이트 받기
이 필드는 필수 입력 사항입니다.

작성자

게시자 윌리엄 호앙, 모바일 개발자 옹호자, Couchbase

윌리엄은 카우치베이스의 모바일 엔지니어링/개발자 경험 팀의 개발자 옹호자였습니다. 커피와 코드에 대한 그의 사랑은 오프라인 대면 경험을 즐기면서 모바일의 세계로 넘어왔습니다. 그 전에는 Twitter, BlackBerry, Microsoft에서 개발자 관계 팀에서 일했으며, Research In Motion에서 소프트웨어 임베디드 GPS 엔지니어로 근무하기도 했습니다. 윌리엄은 맥길 대학교에서 전기 소프트웨어 공학을 전공했습니다.

댓글 남기기

카우치베이스 카펠라를 시작할 준비가 되셨나요?

구축 시작

개발자 포털에서 NoSQL을 살펴보고, 리소스를 찾아보고, 튜토리얼을 시작하세요.

카펠라 무료 사용

클릭 몇 번으로 Couchbase를 직접 체험해 보세요. Capella DBaaS는 가장 쉽고 빠르게 시작할 수 있는 방법입니다.

연락하기

카우치베이스 제품에 대해 자세히 알고 싶으신가요? 저희가 도와드리겠습니다.