ページ ツリー

比較バージョン

キー

  • この行は追加されました。
  • この行は削除されました。
  • 書式設定が変更されました。

目次


IdP管理者に必要な情報

学認参加IdPがGakuNin mAPを利用するために必要な情報をまとめます。学認参加IdPが学認クラウドゲートウェイサービスを利用するためには以下の手順に従って設定を行ってください。

まず、GakuNin mAP 学認クラウドゲートウェイサービス (entityID:  https://mapcg.gakunin.nii.ac.jp/shibboleth-sp ) に対して以下の属性を送信するようにしてください。

属性名必須 / 任意備考

ePPN (eduPersonPrincipalName)

必須


eduPersonTargetedID

任意


jao

任意

アカウント登録時のユーザ情報「所属(日)」の初期値として使われます。

o

任意

jaou
アカウント登録時のユーザ情報「所属(英)」の初期値として使われます。

任意

ou

jaDisplayName

任意

jaDisplayName

任意
アカウント登録時のユーザ情報「氏名(日)」の初期値として使われます。

displayName

任意

アカウント登録時のユーザ情報「氏名(英)」の初期値として使われます。

mail

任意

アカウント登録時のユーザ情報「メールアドレス」の初期値として使われます。
eduPersonAffiliation任意

ou/jaou/eduPersonTargetedIDを除いた任意の各属性は、GakuNin mAP上でのアカウント登録時にユーザ情報を初期入力するために使用されます。ユーザ情報の「所属」は日本語および英語がそれぞれjaoおよびoに対応します。ユーザ情報の「氏名」は日本語および英語がjaDisplayNameおよびdisplayNameに対応します。

また、o/jaoおよびou/jaouについては、機関グループもしくは部局グループを作成するのに利用可能です。詳しくは左記お問い合わせ先までお問い合わせください。

eduPersonAffiliationはmAP次期バージョンで利用予定です。

そして、GakuNin mAPと連携しているサービス(SP)に対しても、必要な属性を送信していないとIdPの利用者は当該サービスが利用できません。

SP管理者に必要な情報


eduPersonAffiliationは、faculty/staffであれば当該利用者が管理者となっているグループのメンバーに対する招待なし入会・属性送信同意のオプションが加わります。詳しくはお問い合わせください。

学認クラウドゲートウェイサービスへの属性送信の設定例は以下を参照してください。設定例となっていますので、所属機関IdPで送信可能な属性へ変更してご利用ください。

コード ブロック
<!-- Policy for GakuNin Cloud Gateway Service -->
<AttributeFilterPolicy id="PolicyforGakuNinCloudGatewayService">
 
    <PolicyRequirementRule xsi:type="Requester" value="https://cg.gakunin.jp/shibboleth-sp" />
 
    <AttributeRule attributeID="eduPersonPrincipalName">
        <PermitValueRule xsi:type="ANY" />
    </AttributeRule>

    <AttributeRule attributeID="jao">
        <PermitValueRule xsi:type="ANY" />
    </AttributeRule>
 
    <AttributeRule attributeID="jaOrganizationName">
        <PermitValueRule xsi:type="ANY" />
    </AttributeRule>
 
    <AttributeRule attributeID="o">
        <PermitValueRule xsi:type="ANY" />
    </AttributeRule>

    <AttributeRule attributeID="organizationName">
        <PermitValueRule xsi:type="ANY" />
    </AttributeRule>

    <AttributeRule attributeID="jaDisplayName">
        <PermitValueRule xsi:type="ANY" />
    </AttributeRule>
 
    <AttributeRule attributeID="displayName">
        <PermitValueRule xsi:type="ANY" />
    </AttributeRule>
 
    <AttributeRule attributeID="mail">
        <PermitValueRule xsi:type="ANY" />
    </AttributeRule>
 
</AttributeFilterPolicy>
ヒント

本設定例は学認テンプレートv4およびv3両対応です。
お使いのattribute-resolver.xmlでの定義に応じて attributeID="jao" もしくは attributeID="jaOrganizationName" 、attributeID="o" もしくは attributeID="organizationName" の必要なほうを残してください。

そして、学認クラウドゲートウェイサービスと連携しているサービス(SP)に対しても、必要な属性を送信していないとIdPの利用者は当該サービスが利用できませんのでご注意ください。


API

連携するIdPが利用できる、ゲートウェイトップ画面で表示される利用可能サービスの情報を取得するためのAPIを以下に示します。
API(IdP)

SP管理者に必要な情報

SP管理者が提供しているサービスを学認クラウドゲートウェイサービスと連携させるためには以下の手順に従って設定を行ってください。SP管理者が提供しているサービスをGakuNin mAPと連携させるためには以下の手順に従って設定を行ってください。

注意

以下の手順でisMemberOf属性を取得するためにはあらかじめIdPからeduPersonPrincipalName(ePPN)を取得していなければなりません。
この制限はmAPの次期バージョンで緩和される予定です。


  1. グループメンバー情報を取得できるようにする
    以下のようにShibboleth SPの設定ファイルを変更してください。動作確認は Shibboleth SP 2.

...

  1. 6 で行っています。

      ...

        1. 学認クラウドゲートウェイサービス (IdP)のメタデータを次のリンクから取得して /etc/shibboleth/metadata/ に保存してください。

      ...

        1. cgidp-metadata.xml

          警告

          2017年2月22日以前に設定されたかたは、アクセス先が変わっておりますので、最新のメタデータを用いてください。

          パネル

              <ProtocolProvider type="XML" validate="true" reloadChanges="false" path="protocols.xml"/>

              <TransportOption provider="CURL" option="81">0</TransportOption>
          </SPConfig>

          なお、メタデータ取得時のサーバ証明書検証(初期値ではいずれにしろ不完全です)については以下でご案内しておりますので、もし設定がまだのようであれば別途ご検討いただければと思います。
          shibboleth2.xml ファイル の<TransportOption>の3行

        2. shibboleth2.xmlの編集
          /etc/shibboleth/shibboleth2.xml を編集します。

        ...

            • 学認クラウドゲートウェイサービス (IdP)メタデータの読み込み
              a.でダウンロードしたメタデータを読み込むように設定します。他の<MetadataProvider>の後に下記を追加してください。

              コード ブロック
              xml
              xml
              <MetadataProvider type="XML" 

        ...

            • path="/etc/shibboleth/metadata/

        ...

            • cgidp-metadata.xml"/>

        ...

            • SimpleAggregationの追加

        ...

            • 通常の認証フローの後にeppnを手がかりとして学認クラウドゲートウェイサービス (IdP)からisMemberOf属性を取得するよう、SimpleAggregation設定を行います。
              既存の<AttributeResolver>の後に以下の記述を追加します。

              コード ブロック
              xml
              xml
              <AttributeResolver type="SimpleAggregation" attributeId="eppn" format="urn:oid:1.3.6.1.4.1.5923.1.1.1.6">
                  

        ...

            • <Entity>https://

        ...

            • cg.gakunin

        ...

            • .jp/idp/

        ...

            • shibboleth</Entity>
                  

        ...

            • <saml2:Attribute xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" Name="urn:oid:1.3.6.1.4.1.5923.1.5.1.1" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri"

        ...

            •  FriendlyName="isMemberOf"/>
              </AttributeResolver>
              
          1. attribute-map.xmlの編集
            /etc/shibboleth/attribute-map.

        ...

          1. xmlにてisMemberOf属性の設定を確認します。

        ...

          1. 以下の記述がない場合、最終行の</

        ...

          1. Attributes>の直前に追加してください。

            コード ブロック
            xml
            xml
            <Attribute name="urn:oid:1.3.6.1.4.1.5923.1.5.1.1

        ...

        以前の版では以下の行も含めるように書いておりましたが、標準に準拠しておりませんのでこの記述は削除してください。

        ...

          1. " id="isMemberOf"/>
            
          2. attribute-policy.xmlの編集

        ...

          1. 他のIdPからのisMemberOf属性を拒否し、学認クラウドゲートウェイサービスからのisMemberOfのみを利用する設定を行ないます。

            <!-- Catch-all that pases everything else through unmolested. -->

            の直前に以下の記述を追加してください。

            コード ブロック
            xml
            xml

        ...

          1. <AttributeRule attributeID="isMemberOf" xmlns="urn:mace:shibboleth:2.0:afp">
                

        ...

          1. <PermitValueRule xsi:type="

        ...

          1. Issuer"
                    value="https://

        ...

          1. cg.gakunin

        ...

          1. .jp/idp/shibboleth"/>
            </

        ...

          1. AttributeRule>

        ...

          1. .

        1. 取得したisMemberOf属性を利用するようにサービスを変更する
          例えば、isMemberOf属性には下記のような値が入ります。全てURI形式です。

          https://

        ...

        1. cg.gakunin

        ...

        1. .jp/sp/SPCID ← SPコネクタ名
          https://

        ...

        1. cg.gakunin.

        ...

        1. jp/gr/GROUPID ← ユーザが参加しているグループ名
          https://cg.gakunin.jp/gr/GROUPID

        ...

        1. /admin ← ユーザが当該グループの管理者の場合

          後者2つは、SPコネクタの設定で「グループ情報も取得する」を選択した場合のみ取得できます。

          展開
          title旧形式への対応
          ヒント

          取得したisMemberOf属性のホスト部をチェックしているプラグインを使用している等で属性値が https://map.gakunin.nii.ac.jp/gr

        ...

        1. /... でないと支障がある場合は、shibboleth2.xmlに以下2箇所を追加してください。

          1. 既存の<ApplicationDefaults> より前に記述を追加。

            コード ブロック
                 <OutOfProcess>
                     <Extensions>
                         <Library path="plugins.so" fatal="true"/>
                     </Extensions>
                 </OutOfProcess>
            
          2. 既存の<AttributeResolver> の後に記述を追加。

            コード ブロック
                     <AttributeResolver type="Transform" source="isMemberOf">
                         <Regex match="^https://cg.gakunin.jp/gr/(.+)$">https://map.gakunin.nii.ac.jp/gr/$1</Regex>
                     </AttributeResolver>
        2. SPに対応するSPコネクタを作成する

          警告

          本項目の操作には適切に権限が付与されている必要があります。権限付与を希望する学認参加SPの運用担当者の方は学認クラウドゲートウェイサービスのページ下にある「問い合わせ先」(要ログイン)からサービスサポートまでご連絡ください。

          グループの接続先となるSPコネクタを作成します。グループが当該SPコネクタに接続した場合のみSPはそのグループに関する情報を取得できます。SPコネクタ作成の詳細は、mAP利用マニュアルの「SPコネクタを作成する」の章をご参照ください。
          .

        API

        連携するSPが利用できる、利用者のグループ情報等を取得するためのAPIを以下に示します。
        API

        ...

        SPに対応するSPコネクタを作成する

        注意

        以下の機能はまだ実装されておりませんので、権限が必要な方はお手数ですが下記メールアドレスまでご一報ください。

        ...

        SP連携のトラブルシューティング

        1. isMemberOf属性が取得できない

        以下2つの条件を満たす場合にはisMemberOf属性が取得できません。

        • SP側の設定ファイルshibboleth2.xmlのApplicationDefaultsに encryption="true" と指定されている
        • ダウンロードしたメタデータcgidp-metadata.xmlの KeyDescriptor use="signing" (2か所)が設定されている (以前配布していたメタデータには use="signing" を設定していました)

        上記でisMemberOf属性が取得できない原因はAttributeQueryのNameIDが暗号化されているためによるものですが、NameIDを暗号化したままisMemberOf属性を取得するためには、最新のメタデータcgidp-metadata.xmlをダウンロードし直すか(最新のメタデータでは use="signing" を削除済み)、以前ダウンロードしたメタデータの use="signing" (2か所)を削除してください。.xmlにて、ApplicationDefaultsに signing="true" encryption="true" と指定されている場合、isMemberOf属性が取得できないようです。詳細は調査中ですが、このような状況になった場合は上記指定を外して試してみてください。