私の知る限りでは、ユーザーの姓に基づいてAPIへのアクセスを制限したい場合は、私が行う可能性のあるサンプルシナリオを設定します。
例えば、私は/api/family?lastname=doe
のようなエンドポイントを持つAPIを持っています。このAPIの目的は、この場合「doe」と同じ姓の人のリストを返すことです。 APIは、パラメータに指定された姓が現在の許可ユーザーの姓と等しい場合にのみ結果を返します。
ので、多分、私は次のように設定API必要があるだろう:
@RequestMapping(value="/api/family", method = RequestMethod.GET)
@ResponseBody
public List<Member> findFamilyMembersByLastName(@RequestParam(value="lastname", required=true) String lastName){
User authorizedUser = getCurrentUser(); // Set up a method that is able to get the current logged in user
if(!authorizedUser.getLastName().equals(lastName){
// Throw some kind of exception here
}
// otherwise perform a query to find a list of Members with last name and return them
}
だけ明確にするには、Googleのユーザーを除くすべての人へのアクセスを制限したいですか? – Dayna
本当にありません。今私はすべてのGoogleユーザーがAPIにアクセス/使用できるようになりました。私が欲しいのは、プロフィールからの何かに基づいて特定のGoogleユーザーへのアクセスを制限することです(たとえば、姓の例を挙げましょう) – salviialex