{"id":434206,"date":"2024-10-02T15:01:30","date_gmt":"2024-10-02T15:01:30","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=434206"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=434206","title":{"rendered":"<span>\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 SSO \u0410\u0432\u0442\u043e\u0440\u0438\u0437\u0430\u0446\u0438\u0438 \u0414\u043b\u044f BookStack<\/span>"},"content":{"rendered":"<div><!--[--><!--]--><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u041e\u0434\u043d\u0438\u043c \u0438\u0437 \u043d\u0430\u0438\u0431\u043e\u043b\u0435\u0435 \u0443\u0434\u0430\u0447\u043d\u044b\u0445 \u0441\u0435\u0440\u0432\u0438\u0441\u043e\u0432 (\u0441\u0440\u0435\u0434\u0438 \u043c\u043d\u0435 \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0445 ) \u0434\u043b\u044f \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0435\u0439 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f  <a href=\"https:\/\/www.bookstackapp.com\/\" rel=\"noopener noreferrer nofollow\">BookStack<\/a>. \u041f\u043e \u0442\u043e\u043c\u0443 \u043a\u0430\u043a \u0435\u0433\u043e \u0440\u0430\u0437\u0432\u0435\u0440\u043d\u0443\u0442\u044c \u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u0411\u0430\u0437\u043e\u0432\u0443\u044e \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0443 \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0447\u0438\u0442\u0430\u0442\u044c \u043d\u0430 \u041e\u0424 \u0441\u0430\u0439\u0442\u0435, \u0442\u0430\u043c \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u0430\u044f \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044f. \u041d\u043e \u0432\u043e\u0442 \u0432\u043e\u043f\u0440\u043e\u0441 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 \u0430\u0432\u0442\u043e\u0440\u0438\u0437\u0430\u0446\u0438\u0438 SSO \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f ADFS \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044f \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u043d\u0430\u044f, \u0434\u0430 \u0438 \u0442\u043e \u0447\u0442\u043e \u0432 \u0438\u043d\u0435\u0442\u0435 \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0439\u0442\u0438 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0433\u043b\u0443\u0431\u043e\u043a\u0438\u0445  \u0437\u043d\u0430\u043d\u0438\u0439 \u0442\u0435\u043c\u044b. \u041f\u043e\u0441\u0435\u043c\u0443 \u0440\u0435\u0448\u0438\u043b \u043f\u043e\u0434\u0435\u043b\u0438\u0442\u044c\u0441\u044f \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0435\u0439 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438 \u043f\u043e \u0434\u0430\u043d\u043d\u043e\u043c\u0443 \u0432\u043e\u043f\u0440\u043e\u0441\u0443  <\/p>\n<h4>\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 BookStack<\/h4>\n<p>\u041d\u0435 \u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u043c\u043d\u043e\u0433\u043e \u043d\u0430\u0441\u0442\u0440\u043e\u0435\u043a, \u043f\u0440\u043e\u0441\u0442\u043e \u043e\u0442\u0440\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u0443\u0439\u0442\u0435\u00a0<code>.env<\/code>\u0444\u0430\u0439\u043b,\u00a0<\/p>\n<pre><code>\u00a0nano \/var\/www\/bookstack\/.env<\/code><\/pre>\n<p>\u0414\u043e\u0431\u0430\u0432\u0438\u0432 \u0432 \u043a\u043e\u043d\u0435\u0446 \u0444\u0430\u0439\u043b\u0430 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435:  <\/p>\n<pre><code>AUTH_METHOD=saml2 AUTH_AUTO_INITIATE=true SAML2_NAME=ADFS SAML2_EMAIL_ATTRIBUTE=mail SAML2_EXTERNAL_ID_ATTRIBUTE=http:\/\/schemas.xmlsoap.org\/ws\/2005\/05\/identity\/claims\/upn SAML2_DISPLAY_NAME_ATTRIBUTES=displayName SAML2_IDP_ENTITYID=https:\/\/adfs.*****.com\/FederationMetadata\/2007-06\/FederationMetadata.xml SAML2_AUTOLOAD_METADATA=true SAML2_IDP_SSO=https:\/\/adfs.******.com\/adfs\/ls SAML2_IDP_SLO=null SAML2_IDP_AUTHNCONTEXT=true SAML2_USER_TO_GROUPS=true SAML2_GROUP_ATTRIBUTE=groups SAML2_REMOVE_FROM_GROUPS=false    #APP_DEBUG=true #SAML2_DUMP_USER_DETAILS=true #SAML2_ONELOGIN_OVERRIDES=&lt;json_format_data&gt;<\/code><\/pre>\n<h4>\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 ADFS \u0421\u0435\u0440\u0432\u0435\u0440\u0430<\/h4>\n<h3>\u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c Relaying Party trusts<\/h3>\n<p>\u00a0\u041e\u0442\u043a\u0440\u043e\u0435\u043c \u043e\u0441\u043d\u0430\u0441\u0442\u043a\u0443 Relaying Party trusts \u043f\u043e\u0441\u043b\u0435 \u041d\u0430\u0436\u043c\u0435\u043c Add Relaying Party trusts<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/5f0\/cb4\/44b\/5f0cb444b80b77300cf603b8958566dc.png\" width=\"533\" height=\"286\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/5f0\/cb4\/44b\/5f0cb444b80b77300cf603b8958566dc.png\"\/><\/figure>\n<p>\u0414\u0430\u043b\u0435\u0435 \u0432\u044b\u0431\u0438\u0440\u0430\u0435\u043c Claims aware\u00a0 \u0436\u043c\u0435\u043c Start<\/p>\n<h3>\u0412\u044b\u0431\u0435\u0440\u0435\u043c \u0418\u0441\u0442\u043e\u0447\u043d\u0438\u043a \u0434\u0430\u043d\u043d\u044b\u0445<\/h3>\n<p>\u0412\u044b\u0431\u0438\u0440\u0430\u0435\u043c \u043f\u0443\u043d\u043a\u0442 Enter data about the relying parity manually  <\/p>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/0f3\/581\/7f1\/0f35817f19d5fb1a7a77e9b0eb5531fc.png\" width=\"510\" height=\"86\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/0f3\/581\/7f1\/0f35817f19d5fb1a7a77e9b0eb5531fc.png\"\/><\/figure>\n<h3>\u0417\u0430\u0434\u0430\u0434\u0438\u043c Display Name<\/h3>\n<p>\u0414\u0430\u0435\u043c \u041b\u044e\u0431\u043e\u0435 \u043f\u043e\u043d\u044f\u0442\u043d\u043e\u0435 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435 \u0432 \u043f\u043e\u043b\u0435 Display Name<\/p>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/e87\/960\/1ce\/e879601cefdc449d14b42dbbd72bb7e3.png\" width=\"491\" height=\"125\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e87\/960\/1ce\/e879601cefdc449d14b42dbbd72bb7e3.png\"\/><\/figure>\n<h4>\u041a\u043e\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044f \u0421\u0435\u0440\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0432<\/h4>\n<p>\u041f\u0440\u043e\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044e \u0441\u0435\u0440\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u0430\u00a0 \u043d\u0430\u0436\u0430\u0432 next<\/p>\n<h3>\u041a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044f URL<\/h3>\n<p>\u00a0\u0412\u044b\u0431\u0435\u0440\u0435\u043c \u043f\u0443\u043d\u043a\u0442 &#171;Enable support for the SAML2.0&#187; \u043f\u043e\u0441\u043b\u0435 \u0447\u0435\u0433\u043e \u0432 \u043f\u043e\u043b\u0435 \u0443\u043a\u0430\u0436\u0435\u043c\u00a0<\/p>\n<pre><code>https:\/\/book.***\u0412\u0430\u0448 \u0434\u043e\u043c\u0435\u043d***.com\/saml2\/acs<\/code><\/pre>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/833\/437\/748\/8334377484c416282048743c117f7e2b.png\" width=\"546\" height=\"174\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/833\/437\/748\/8334377484c416282048743c117f7e2b.png\"\/><\/figure>\n<h3>C\u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0438\u0440\u0443\u0435\u043c \u00a0\u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440\u044b<\/h3>\n<p>\u00a0\u0412 \u043f\u043e\u043b\u0435 Relying party trust identifilers \u0432\u0441\u0442\u0430\u0432\u0438\u043c\u00a0<\/p>\n<pre><code>https:\/\/book.*******.com\/saml2\/metadata<\/code><\/pre>\n<p>\u0438 \u043d\u0430\u0436\u043c\u0435\u043c ADD  <\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/11d\/7bb\/915\/11d7bb9154815f3e604c06fcb2c515dd.png\" width=\"714\" height=\"299\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/11d\/7bb\/915\/11d7bb9154815f3e604c06fcb2c515dd.png\"\/><\/figure>\n<h3>\u0412\u044b\u0431\u0435\u0440\u0435\u043c \u043f\u043e\u043b\u0438\u0442\u0438\u043a\u0443 \u0430\u0432\u0442\u043e\u0440\u0438\u0437\u0430\u0446\u0438\u0438<\/h3>\n<p>\u0432 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0430\u0432\u043b\u0435\u043d\u043d\u043e\u043c \u0441\u043f\u0438\u0441\u043a\u0435 \u0432\u044b\u0431\u0435\u0440\u0435\u043c Permit everyone\u00a0<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/2f2\/b9c\/976\/2f2b9c97642311eccca8904501d4d1ec.png\" width=\"727\" height=\"294\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/2f2\/b9c\/976\/2f2b9c97642311eccca8904501d4d1ec.png\"\/><\/figure>\n<p>\u041d\u0430 \u0432\u043a\u043b\u0430\u0434\u043a\u0435 finish \u0423\u0431\u0435\u0440\u0435\u043c \u0433\u0430\u043b\u043e\u0447\u043a\u0443 \u043d\u0430\u043f\u0440\u043e\u0442\u0438\u0432 Configure claims issuance policy for this application  <\/p>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/48a\/3e6\/2ad\/48a3e62ad5774f870cff461df395964d.png\" width=\"325\" height=\"90\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/48a\/3e6\/2ad\/48a3e62ad5774f870cff461df395964d.png\"\/><\/figure>\n<h3>\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u0422\u043e\u0447\u0435\u043a \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f<\/h3>\n<p>\u00a0\u041e\u0442\u043a\u0440\u043e\u0435\u043c \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430\u00a0 \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u043e\u0433\u043e Party trusts \u0438 \u043f\u0435\u0440\u0435\u0439\u0434\u0435\u043c \u0432\u043e \u0432\u043a\u043b\u0430\u043a\u0443 Endpoints<\/p>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/70d\/ebf\/9ac\/70debf9acb41597b7aa5a1081177df4b.png\" width=\"204\" height=\"87\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/70d\/ebf\/9ac\/70debf9acb41597b7aa5a1081177df4b.png\"\/><\/figure>\n<p>\u041f\u0440\u043e\u0432\u0435\u0440\u0438\u043c \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u0443\u044e\u00a0 \u00a0assertion consumer endpoint\u00a0  <\/p>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/6ad\/7eb\/468\/6ad7eb4687c710c9245b1fa2ecd0669e.png\" width=\"390\" height=\"403\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/6ad\/7eb\/468\/6ad7eb4687c710c9245b1fa2ecd0669e.png\"\/><\/figure>\n<p>\u041f\u043e\u0441\u043b\u0435 \u0447\u0435\u0433\u043e \u0441\u043e\u0437\u0434\u0430\u0434\u0438\u043c Logout Endpoints \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0430\u0436\u043c\u0435\u043c\u00a0  <\/p>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/091\/d83\/25d\/091d8325dc27e573b42d636dc30319c9.png\" width=\"100\" height=\"40\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/091\/d83\/25d\/091d8325dc27e573b42d636dc30319c9.png\"\/><\/figure>\n<p>\u0438 \u0437\u0430\u043f\u043e\u043b\u043d\u0438\u043c \u0432 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0438\u0438 \u0441 \u0441\u043a\u0440\u0438\u043d\u0448\u043e\u0442\u043e\u043c  <\/p>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/6cb\/c9d\/24e\/6cbc9d24e806697d834c87d2cfa8485f.png\" width=\"375\" height=\"394\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/6cb\/c9d\/24e\/6cbc9d24e806697d834c87d2cfa8485f.png\"\/><\/figure>\n<h3>\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u0432\u044b\u0434\u0430\u0447\u0438\u00a0 \u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043d\u0438\u0439\u00a0\u00a0<\/h3>\n<h3>\u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u043f\u0440\u0430\u0432\u0438\u043b\u043e \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0438\u044f \u043f\u043e\u043b\u0435\u0439 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439<\/h3>\n<p>\u0432 \u043f\u043e\u044f\u0432\u0438\u0432\u0448\u0435\u043c\u0441\u044f \u043e\u043a\u043d\u0435 \u043d\u0430\u0436\u043c\u0438\u0442\u0435 Add Rule\u00a0<\/p>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/260\/0e5\/c98\/2600e5c98005f072853f5bb3165ec7ef.png\" width=\"240\" height=\"129\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/260\/0e5\/c98\/2600e5c98005f072853f5bb3165ec7ef.png\"\/><\/figure>\n<p>\u0417\u0430\u043f\u043e\u043b\u043d\u044f\u0435\u043c \u043f\u043e\u043b\u0435 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c\u00a0  <\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/720\/6d5\/0cf\/7206d50cfa851002e2be32bdb4729e0a.png\" width=\"715\" height=\"343\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/720\/6d5\/0cf\/7206d50cfa851002e2be32bdb4729e0a.png\"\/><\/figure>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/f09\/516\/f7a\/f09516f7a0acf9483c2db498987925fd.png\" width=\"550\" height=\"589\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/f09\/516\/f7a\/f09516f7a0acf9483c2db498987925fd.png\"\/><\/figure>\n<pre><code>c:[Type == \"http:\/\/schemas.microsoft.com\/ws\/2008\/06\/identity\/claims\/windowsaccountname\", Issuer == \"AD AUTHORITY\"]  =&gt; issue(store = \"Active Directory\", types = (\"http:\/\/schemas.xmlsoap.org\/ws\/2005\/05\/identity\/claims\/upn\", \"mail\", \"groups\", \"displayName\"), query = \";userPrincipalName,otherMailbox,tokenGroups,displayName;{0}\", param = c.Value);<\/code><\/pre>\n<h3>\u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u043f\u0440\u0430\u0432\u0438\u043b\u043e \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f<\/h3>\n<p>\u043d\u0430\u0436\u043c\u0438\u0442\u0435 Add Rule\u00a0<\/p>\n<p>\u0417\u0430\u043f\u043e\u043b\u043d\u044f\u0435\u043c \u043f\u043e\u043b\u0435 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c\u00a0<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/750\/0c3\/2df\/7500c32df42a0ecebce8493fc6ca6d60.png\" width=\"718\" height=\"585\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/750\/0c3\/2df\/7500c32df42a0ecebce8493fc6ca6d60.png\"\/><\/figure>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/d45\/04b\/6ae\/d4504b6ae8174428f9b8e1ec44e7ac41.png\" width=\"557\" height=\"591\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d45\/04b\/6ae\/d4504b6ae8174428f9b8e1ec44e7ac41.png\"\/><\/figure>\n<pre><code>c:[Type == \"http:\/\/schemas.xmlsoap.org\/ws\/2005\/05\/identity\/claims\/upn\"]  =&gt; issue(Type = \"http:\/\/schemas.xmlsoap.org\/ws\/2005\/05\/identity\/claims\/nameidentifier\", Issuer = c.Issuer, OriginalIssuer = c.OriginalIssuer, Value = c.Value, ValueType = c.ValueType, Properties[\"http:\/\/schemas.xmlsoap.org\/ws\/2005\/05\/identity\/claimproperties\/format\"] = \"urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress\");<\/code><\/pre>\n<p>\u0413\u043e\u0442\u043e\u0432\u043e, \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0442\u044c  <\/p>\n<h4>\u0422\u0440\u0430\u0431\u043b\u0448\u0443\u0442\u0442\u0438\u043d\u0433<\/h4>\n<p>\u00a0\u0434\u043b\u044f \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0440\u0430\u0431\u043e\u0442\u044b ADFS, \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0432 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0435 \u0432 \u0444\u043e\u0440\u043c\u0430\u0442\u0435 json \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044e \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 ADFS \u0421\u0435\u0440\u0432\u0435\u0440 \u043c\u043e\u0436\u043d\u043e\u00a0 \u0440\u0430\u0441\u043a\u043e\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0432 \u0444\u0430\u0439\u043b\u0435\u00a0<code>.env<\/code><\/p>\n<pre><code>APP_DEBUG=true SAML2_DUMP_USER_DETAILS=true SAML2_ONELOGIN_OVERRIDES=&lt;json_format_data&gt;<\/code><\/pre>\n<p><strong>\u0412 \u044d\u0442\u043e\u043c \u0440\u0435\u0436\u0438\u043c\u0435 \u0410\u0412\u0422\u041e\u0420\u0418\u0417\u0410\u0426\u0418\u042f \u0411\u0423\u0414\u0415\u0422 \u041e\u0422\u041a\u041b\u042e\u0427\u0415\u041d\u0410<\/strong>  <\/p>\n<\/div>\n<\/div>\n<\/div>\n<p><!----><!----><\/div>\n<p><!----><!----><br \/> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/articles\/847644\/\"> https:\/\/habr.com\/ru\/articles\/847644\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div><!--[--><!--]--><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u041e\u0434\u043d\u0438\u043c \u0438\u0437 \u043d\u0430\u0438\u0431\u043e\u043b\u0435\u0435 \u0443\u0434\u0430\u0447\u043d\u044b\u0445 \u0441\u0435\u0440\u0432\u0438\u0441\u043e\u0432 (\u0441\u0440\u0435\u0434\u0438 \u043c\u043d\u0435 \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0445 ) \u0434\u043b\u044f \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0435\u0439 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f  <a href=\"https:\/\/www.bookstackapp.com\/\" rel=\"noopener noreferrer nofollow\">BookStack<\/a>. \u041f\u043e \u0442\u043e\u043c\u0443 \u043a\u0430\u043a \u0435\u0433\u043e \u0440\u0430\u0437\u0432\u0435\u0440\u043d\u0443\u0442\u044c \u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u0411\u0430\u0437\u043e\u0432\u0443\u044e \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0443 \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0447\u0438\u0442\u0430\u0442\u044c \u043d\u0430 \u041e\u0424 \u0441\u0430\u0439\u0442\u0435, \u0442\u0430\u043c \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u0430\u044f \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044f. \u041d\u043e \u0432\u043e\u0442 \u0432\u043e\u043f\u0440\u043e\u0441 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 \u0430\u0432\u0442\u043e\u0440\u0438\u0437\u0430\u0446\u0438\u0438 SSO \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f ADFS \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044f \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u043d\u0430\u044f, \u0434\u0430 \u0438 \u0442\u043e \u0447\u0442\u043e \u0432 \u0438\u043d\u0435\u0442\u0435 \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0439\u0442\u0438 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0433\u043b\u0443\u0431\u043e\u043a\u0438\u0445  \u0437\u043d\u0430\u043d\u0438\u0439 \u0442\u0435\u043c\u044b. \u041f\u043e\u0441\u0435\u043c\u0443 \u0440\u0435\u0448\u0438\u043b \u043f\u043e\u0434\u0435\u043b\u0438\u0442\u044c\u0441\u044f \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0435\u0439 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438 \u043f\u043e \u0434\u0430\u043d\u043d\u043e\u043c\u0443 \u0432\u043e\u043f\u0440\u043e\u0441\u0443  <\/p>\n<h4>\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 BookStack<\/h4>\n<p>\u041d\u0435 \u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u043c\u043d\u043e\u0433\u043e \u043d\u0430\u0441\u0442\u0440\u043e\u0435\u043a, \u043f\u0440\u043e\u0441\u0442\u043e \u043e\u0442\u0440\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u0443\u0439\u0442\u0435\u00a0<code>.env<\/code>\u0444\u0430\u0439\u043b,\u00a0<\/p>\n<pre><code>\u00a0nano \/var\/www\/bookstack\/.env<\/code><\/pre>\n<p>\u0414\u043e\u0431\u0430\u0432\u0438\u0432 \u0432 \u043a\u043e\u043d\u0435\u0446 \u0444\u0430\u0439\u043b\u0430 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435:  <\/p>\n<pre><code>AUTH_METHOD=saml2 AUTH_AUTO_INITIATE=true SAML2_NAME=ADFS SAML2_EMAIL_ATTRIBUTE=mail SAML2_EXTERNAL_ID_ATTRIBUTE=http:\/\/schemas.xmlsoap.org\/ws\/2005\/05\/identity\/claims\/upn SAML2_DISPLAY_NAME_ATTRIBUTES=displayName SAML2_IDP_ENTITYID=https:\/\/adfs.*****.com\/FederationMetadata\/2007-06\/FederationMetadata.xml SAML2_AUTOLOAD_METADATA=true SAML2_IDP_SSO=https:\/\/adfs.******.com\/adfs\/ls SAML2_IDP_SLO=null SAML2_IDP_AUTHNCONTEXT=true SAML2_USER_TO_GROUPS=true SAML2_GROUP_ATTRIBUTE=groups SAML2_REMOVE_FROM_GROUPS=false    #APP_DEBUG=true #SAML2_DUMP_USER_DETAILS=true #SAML2_ONELOGIN_OVERRIDES=&lt;json_format_data&gt;<\/code><\/pre>\n<h4>\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 ADFS \u0421\u0435\u0440\u0432\u0435\u0440\u0430<\/h4>\n<h3>\u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c Relaying Party trusts<\/h3>\n<p>\u00a0\u041e\u0442\u043a\u0440\u043e\u0435\u043c \u043e\u0441\u043d\u0430\u0441\u0442\u043a\u0443 Relaying Party trusts \u043f\u043e\u0441\u043b\u0435 \u041d\u0430\u0436\u043c\u0435\u043c Add Relaying Party trusts<\/p>\n<figure class=\"full-width\"><\/figure>\n<p>\u0414\u0430\u043b\u0435\u0435 \u0432\u044b\u0431\u0438\u0440\u0430\u0435\u043c Claims aware\u00a0 \u0436\u043c\u0435\u043c Start<\/p>\n<h3>\u0412\u044b\u0431\u0435\u0440\u0435\u043c \u0418\u0441\u0442\u043e\u0447\u043d\u0438\u043a \u0434\u0430\u043d\u043d\u044b\u0445<\/h3>\n<p>\u0412\u044b\u0431\u0438\u0440\u0430\u0435\u043c \u043f\u0443\u043d\u043a\u0442 Enter data about the relying parity manually  <\/p>\n<figure class=\"\"><\/figure>\n<h3>\u0417\u0430\u0434\u0430\u0434\u0438\u043c Display Name<\/h3>\n<p>\u0414\u0430\u0435\u043c \u041b\u044e\u0431\u043e\u0435 \u043f\u043e\u043d\u044f\u0442\u043d\u043e\u0435 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435 \u0432 \u043f\u043e\u043b\u0435 Display Name<\/p>\n<figure class=\"\"><\/figure>\n<h4>\u041a\u043e\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044f \u0421\u0435\u0440\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0432<\/h4>\n<p>\u041f\u0440\u043e\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044e \u0441\u0435\u0440\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u0430\u00a0 \u043d\u0430\u0436\u0430\u0432 next<\/p>\n<h3>\u041a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044f URL<\/h3>\n<p>\u00a0\u0412\u044b\u0431\u0435\u0440\u0435\u043c \u043f\u0443\u043d\u043a\u0442 &#171;Enable support for the SAML2.0&#187; \u043f\u043e\u0441\u043b\u0435 \u0447\u0435\u0433\u043e \u0432 \u043f\u043e\u043b\u0435 \u0443\u043a\u0430\u0436\u0435\u043c\u00a0<\/p>\n<pre><code>https:\/\/book.***\u0412\u0430\u0448 \u0434\u043e\u043c\u0435\u043d***.com\/saml2\/acs<\/code><\/pre>\n<figure class=\"full-width\"><\/figure>\n<h3>C\u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0438\u0440\u0443\u0435\u043c \u00a0\u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440\u044b<\/h3>\n<p>\u00a0\u0412 \u043f\u043e\u043b\u0435 Relying party trust identifilers \u0432\u0441\u0442\u0430\u0432\u0438\u043c\u00a0<\/p>\n<pre><code>https:\/\/book.*******.com\/saml2\/metadata<\/code><\/pre>\n<p>\u0438 \u043d\u0430\u0436\u043c\u0435\u043c ADD  <\/p>\n<figure class=\"full-width\"><\/figure>\n<h3>\u0412\u044b\u0431\u0435\u0440\u0435\u043c \u043f\u043e\u043b\u0438\u0442\u0438\u043a\u0443 \u0430\u0432\u0442\u043e\u0440\u0438\u0437\u0430\u0446\u0438\u0438<\/h3>\n<p>\u0432 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0430\u0432\u043b\u0435\u043d\u043d\u043e\u043c \u0441\u043f\u0438\u0441\u043a\u0435 \u0432\u044b\u0431\u0435\u0440\u0435\u043c Permit everyone\u00a0<\/p>\n<figure class=\"full-width\"><\/figure>\n<p>\u041d\u0430 \u0432\u043a\u043b\u0430\u0434\u043a\u0435 finish \u0423\u0431\u0435\u0440\u0435\u043c \u0433\u0430\u043b\u043e\u0447\u043a\u0443 \u043d\u0430\u043f\u0440\u043e\u0442\u0438\u0432 Configure claims issuance policy for this application  <\/p>\n<figure class=\"\"><\/figure>\n<h3>\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u0422\u043e\u0447\u0435\u043a \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f<\/h3>\n<p>\u00a0\u041e\u0442\u043a\u0440\u043e\u0435\u043c \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430\u00a0 \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u043e\u0433\u043e Party trusts \u0438 \u043f\u0435\u0440\u0435\u0439\u0434\u0435\u043c \u0432\u043e \u0432\u043a\u043b\u0430\u043a\u0443 Endpoints<\/p>\n<figure class=\"\"><\/figure>\n<p>\u041f\u0440\u043e\u0432\u0435\u0440\u0438\u043c \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u0443\u044e\u00a0 \u00a0assertion consumer endpoint\u00a0  <\/p>\n<figure class=\"\"><\/figure>\n<p>\u041f\u043e\u0441\u043b\u0435 \u0447\u0435\u0433\u043e \u0441\u043e\u0437\u0434\u0430\u0434\u0438\u043c Logout Endpoints \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0430\u0436\u043c\u0435\u043c\u00a0  <\/p>\n<figure class=\"\"><\/figure>\n<p>\u0438 \u0437\u0430\u043f\u043e\u043b\u043d\u0438\u043c \u0432 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0438\u0438 \u0441 \u0441\u043a\u0440\u0438\u043d\u0448\u043e\u0442\u043e\u043c  <\/p>\n<figure class=\"\"><\/figure>\n<h3>\u041d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u0432\u044b\u0434\u0430\u0447\u0438\u00a0 \u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043d\u0438\u0439\u00a0\u00a0<\/h3>\n<h3>\u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u043f\u0440\u0430\u0432\u0438\u043b\u043e \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0438\u044f \u043f\u043e\u043b\u0435\u0439 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439<\/h3>\n<p>\u0432 \u043f\u043e\u044f\u0432\u0438\u0432\u0448\u0435\u043c\u0441\u044f \u043e\u043a\u043d\u0435 \u043d\u0430\u0436\u043c\u0438\u0442\u0435 Add Rule\u00a0<\/p>\n<figure class=\"\"><\/figure>\n<p>\u0417\u0430\u043f\u043e\u043b\u043d\u044f\u0435\u043c \u043f\u043e\u043b\u0435 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c\u00a0  <\/p>\n<figure class=\"full-width\"><\/figure>\n<figure class=\"full-width\"><\/figure>\n<pre><code>c:[Type == \"http:\/\/schemas.microsoft.com\/ws\/2008\/06\/identity\/claims\/windowsaccountname\", Issuer == \"AD AUTHORITY\"]  =&gt; issue(store = \"Active Directory\", types = (\"http:\/\/schemas.xmlsoap.org\/ws\/2005\/05\/identity\/claims\/upn\", \"mail\", \"groups\", \"displayName\"), query = \";userPrincipalName,otherMailbox,tokenGroups,displayName;{0}\", param = c.Value);<\/code><\/pre>\n<h3>\u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u043f\u0440\u0430\u0432\u0438\u043b\u043e \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f<\/h3>\n<p>\u043d\u0430\u0436\u043c\u0438\u0442\u0435 Add Rule\u00a0<\/p>\n<p>\u0417\u0430\u043f\u043e\u043b\u043d\u044f\u0435\u043c \u043f\u043e\u043b\u0435 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c\u00a0<\/p>\n<figure class=\"full-width\"><\/figure>\n<figure class=\"full-width\"><\/figure>\n<pre><code>c:[Type == \"http:\/\/schemas.xmlsoap.org\/ws\/2005\/05\/identity\/claims\/upn\"]  =&gt; issue(Type = \"http:\/\/schemas.xmlsoap.org\/ws\/2005\/05\/identity\/claims\/nameidentifier\", Issuer = c.Issuer, OriginalIssuer = c.OriginalIssuer, Value = c.Value, ValueType = c.ValueType, Properties[\"http:\/\/schemas.xmlsoap.org\/ws\/2005\/05\/identity\/claimproperties\/format\"] = \"urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress\");<\/code><\/pre>\n<p>\u0413\u043e\u0442\u043e\u0432\u043e, \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0442\u044c  <\/p>\n<h4>\u0422\u0440\u0430\u0431\u043b\u0448\u0443\u0442\u0442\u0438\u043d\u0433<\/h4>\n<p>\u00a0\u0434\u043b\u044f \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0440\u0430\u0431\u043e\u0442\u044b ADFS, \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0432 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0435 \u0432 \u0444\u043e\u0440\u043c\u0430\u0442\u0435 json \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044e \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 ADFS \u0421\u0435\u0440\u0432\u0435\u0440 \u043c\u043e\u0436\u043d\u043e\u00a0 \u0440\u0430\u0441\u043a\u043e\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0432 \u0444\u0430\u0439\u043b\u0435\u00a0<code>.env<\/code><\/p>\n<pre><code>APP_DEBUG=true SAML2_DUMP_USER_DETAILS=true SAML2_ONELOGIN_OVERRIDES=&lt;json_format_data&gt;<\/code><\/pre>\n<p><strong>\u0412 \u044d\u0442\u043e\u043c \u0440\u0435\u0436\u0438\u043c\u0435 \u0410\u0412\u0422\u041e\u0420\u0418\u0417\u0410\u0426\u0418\u042f \u0411\u0423\u0414\u0415\u0422 \u041e\u0422\u041a\u041b\u042e\u0427\u0415\u041d\u0410<\/strong>  <\/p>\n<\/div>\n<\/div>\n<\/div>\n<p><!----><!----><\/div>\n<p><!----><!----><br \/> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/articles\/847644\/\"> https:\/\/habr.com\/ru\/articles\/847644\/<\/a><br \/><\/br><\/br><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-434206","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/434206","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=434206"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/434206\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=434206"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=434206"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=434206"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}