ã¯ããã«
ãæ¨æ¥ã¯ã渋谷:VOYAGE GROUPãã§éå¬ãããDevLOVEåå¼·ä¼ãユーザーとシステムを繋ぐ「認証」を知ろう! 〜OpenID Connect〜ãã«åå ãã¾ããã
ãç¾å¨å¾äºãã¦ããä»äºãææã®æºå¸¯ã³ã³ãã³ãã®éçºã»éç¨ã¨ãããã¨ããã£ã¦ããã£ãªã¢ã¨ã®èªè¨¼å¦çã¯å¿
ãé¢ããã®ã§ãããã©ããé£ãéãã¦åãããªããã¨ãå¤ãâ¦ãã¡ãã£ã¨ã§ãåã£ã¤ãæãããããç解ãæ·±ãããã¨æããåå ããã®ãåæ©ã§ããèªåã§ãµã¼ãã¹ãä½ãã«ãã¦ã絶対ã«å¿
è¦ã«ãªãç¥èã§ãããã
ãå½æ¥ã®ãã¤ã¼ãã¯ãã¡ãã
ãªãOpenID Connectãå¿ è¦ã¨ãªã£ãã®ãããã®æ´å²çèæ¯
ãæåã¯å·¥è¤ééãããããèªè¨¼å¦çã®èæ¯ã¨æ´å²ã解説ãã¦é ãã¾ããã以ä¸ãè´è¬æã®ã¡ã¢ã§ãã
- SSO
- ã¦ã¼ã¶æ å ±ãè¤æ°ãããã©ãã²ã¨ã¤ã«ãã°ã¤ã³ãããè¤æ°ã§ããã°ã¤ã³ããç¶æ³ã«ãã
- ä¼æ¥ãã¾ãããåä¼æ¥ã§ãã¦ã¼ã¶æ å ±ãã²ã¨ã¤ã«ã¾ã¨ããããªã
- âã¡ã³ãã¯ãµã¤ç¶æ³ã«
- æ¹æ³ï¼ï¼ã¯ã©ã¤ã¢ã³ãå´ãé å¼µããOSãªããã©ã¦ã¶ãªã
- âã¦ã¼ã¶ã¼ç°å¢ã«æãå ¥ãããã¨ã¯ãã¼ãã«ãé«ããå ¨ã¦ã®ã±ã¼ã¹ã§åºæ¥ã訳ãããªã
- æ¹æ³ï¼ï¼ã¯ã¬ãã³ã·ã£ã«ã横åã
- âä»ã®ãã¡ã¤ã³ã®ã¢ããªãæ å ±ã横åãããã®ã¯ããããªãã®ã
- æ¹æ³ï¼ï¼ã¢ã¤ãã³ãã£ãã£é£æº
- SAML(Security Assertion Markup Language)(2002å¹´ v1.0, 2003å¹´ v1.1)
- XMLãã¼ã¹
- 誰ããã©ããªå±æ§ãæã¤ããã©ããããã¨ãåºæ¥ãã
- âãã©ã¦ã¶ã使ã£ã¦SSOãè¡ã
- SAMLã®ã³ã¢ã¯ãã¢ãµã¼ã·ã§ã³ã
- ããã¡ãã£ã¨åºããã¨ãããã
- Liberty Alliance
- ã°ã«ã¼ãå ã§ããã°IDã§ã©ãã§ããã°ã¤ã³ã§ãã
- SSOã ãã§ãªãã¦ã·ã³ã°ã«ãã°ã¢ã¦ãããµãã¼ã
- âã¦ã¼ã¶ã¼æ å ±ãã©ããã£ã¦å ±éã§ä½¿ãã(åã渡ãã)
- åãªãèªè¨¼ãããªã
- SAML2.0 (2005)
- å±æ§æ å ±ã¨ãèªè¨¼ã¨ããåºæ¥ãããã«ããã
- ID-WSFãç®æãããã®
- ã¨ãããµã¼ãã¹ãããä»ã®ãµã¼ãã¹ã®æã¤ã¦ã¼ã¶ã¼ã®æ å ±ãå©ç¨ã§ãã
- âçµå±ID-WSFã¯æ®åããªãã£ã
- ããéã
- ãµã¼ãã¹ä½¿ç¨ã¾ã§å®ç¾©ãããã¨ãã
- æ®åããªãã£ã(ä¹ã£ãã£ã¦ããæ¥è ãããªãã£ã)
- â2008-2009ã«ã³ã³ã»ããèªä½ã¯çµäº
- SAMLã¯ãäºåã®ä¿¡é ¼é¢ä¿ã«åºã¥ãé£æºã
- IDé£æºã¯ä¿¡é ¼é¢ä¿(ææº)ãç¡ãã¨ç¸äºå©ç¨ã§ããªã
- âãããä¸ä¾¿ã ã¨æã£ã
- Identity 2.0
- èªåã®æã£ã¦ããé転å 許証ããªã³ã©ã¤ã³ã§é å±ã§ä½¿ã£ã¦èªè¨¼ã§ããªãã®ã¯ããããï¼
- The Laws of Identity
- ã¦ã¼ã¶ã¼ã®åæ
- åºãæ å ±ã¯ã¦ã¼ã¶ã¼ã«æ±ºãããã
- 表æã¯é½åº¦ã¦ã¼ã¶ã¼ã«æ±ºãããã
- 人éã¯ä»å¨ãã¹ã
- ä¸è²«ãã使ãåæ
ãã¦ã¼ã¶ã¼ã»ã³ããªãã¯ã»ã¢ã¤ãã³ãã£ãã£ã
ã»ã©ã®æ å ±ã使ãããèªåã§æ±ºãã
- OpenID(2005å¹´)
- FlickerAuth
- GoogleAuth
- âãã¾ãã¾ãªèªè¨¼å½¢å¼
- âæ¨æºåï¼OAuth
- IDã¢ã¯ã»ã¹èªå¯
- ãããããã§OAuthã使ãããããã«ãªã£ãã
- 2010å¹´ãããï¼OpenIDï¼OAuth
- OpenID Connect
- æè¿ã¯OpenID Connectã«åæãã¤ã¤ãã
- ã¨ã³ã¿ã¼ãã©ã¤ãºã¯SAML
- ã¾ã¨ã
- ãµã¼ãã¹ã®ä¸ã¤ã¨ãã¦ã®ãã¢ã¤ãã³ãã£ãã£APIã
- ã¢ã¤ãã³ãã£ãã£ãä¸å¿ã«ãã£ã¦ããã®ãµã¼ãã¹
ãå·¥è¤ããã®ã¹ã©ã¤ãã¯ãã¡ãã
ãããé ãã¦ä¼å ´å ¥ãããçºãæåã®æ°åéãèããªãã£ãã®ã§ãã©ããã主æ¨ã§çºè¡¨ããã¦ããã®ãèããã³ãããã¨ããããå ¨ä½ã¨ãã¦ãåããã«ããããé£ãããã¨ããå°è±¡ã§ããããµã¼ãã¹ãä¸å¿ã¨ãã¦èªè¨¼æ©è½ãå®è£ ããã®ããèªè¨¼æ©è½ããµã¼ãã¹ã®ã²ã¨ã¤ã¨ãã¦ç¨æãããµã¼ãã¹ããããåãå·»ãå½¢ã§èªè¨¼æ©è½ãå©ç¨ããã®ããã¨ãã話ãèããæã«ã¯ããããããããªèãæ¹èªä½ããã£ããã¨ã«é©ãã¾ãããèªè¨¼æ©è½ã£ã¦ããµã¼ãã¹ã®å ¥å£ã ãã©ãµã¼ãã¹å ¨ä½ã¨ãã¦ã¯æ©è½ã®ä¸é¨ãã¨ããèªèã§ããã®ã§ãèªè¨¼ãä¸å¿ã«èãããã¨ããçºæ³èªä½ããªã¬ã«ããã¾ã§ç¡ãã£ããã§ãããã
ãOAuthãOpenIDãåèªèªä½ã¯è³æ
£ããè¨èãªãã§ãããå®æ
ã¯å
¨ç¶ç解ã§ãã¦ããããå·¥è¤ããã®èª¬æãèãã¦ãã¾ã è³å³åã«æµ¸éãã¦ããªããã§ãããã¨ããããããããã¡ããã¨ã¡ã¤ã³ãã¼ã¯ã¼ãã§ãããã¨ã確èªã§ãããã¨ãé¢é£ãããã¼ã¯ã¼ããããã¤ãè¦ãããããã¨ã¯åç©«ã§ãããããããåå¼·ããéã®åã£æããã«ãããã§ãã
ä¼æ©
ã10åç¨åº¦ã®ä¼æ©ããããã¨ããæ¯ãèããããã§ãããDevLOVEã«ã¯çããéããª(ã¨ããããæ²é»ã®)ä¼æ©æéã§ãããæ¡ã®å®ãDevLOVEåå çµé¨è
ã«ææãåã£ãã¨ãããååãæãä¸ãããªãã£ãã®ã§ãããªããã¤ãã¨åå è
層ãéããã¨ãããããã¾ããã
OAuthèªè¨¼åèããã®ãOpenID Connect
ãç¶ãã¦@novããããOpenID Connectã®èªè¨¼ã®ä¸èº«ã¨ããããå¦çæ¦è¦ã説æé ãã¾ããã以ä¸ãè´è¬æã®ã¡ã¢ã
- @nov
- ãââIDã§ãã°ã¤ã³ãã¨ããã話
- ã¦ã¼ã¶ã¼ç»é²ããã©ããã
- âãããªãID/PWã§ãã°ã¤ã³åºæ¥ããã³ã³ãã¼ã¸ã§ã³ä¸ãããã
- è¤æ°ãµã¤ãã§å ±éã®ãã¹ã¯ã¼ã
- Password List Attack
- âECãããGREEãetc
- âæ¯é±ã®ããã«ã©ããã®ãµã¤ããã¢ã¿ãã¯ãåãã¦ãã
- ãã¹ã¯ã¼ããæ¸ãããªãã¦ã¯ãããªã
- ã¡ããã¨ç®¡çã§ããæ¹æ³ã§
- Facebookãä¿¡ç¨ã§ãããï¼ãâæªãã
- Googleãâã»ãã¥ãªãã£å°ä»»ã®äººã1000人åãã¦ãã
- æ¥æ¬ã«1000人ãã»ãã¥ãªãã£å°ä»»ãåãã¦ããä¼ç¤¾ã¯æ¥æ¬ã«ã¯ãªã(Yahooï¼)
- OpenID / OAuth
- ã©ããªãµã¼ãã¹ãå©ç¨ãã¦ããããâã ãããåãããã
- OAuth2.0ã®è©±
- OAuthèªè¨¼â¦ã£ã¦è¨ããªãèªè¨¼ã®çºãããªã
- å®ç¾©:OAuthèªè¨¼
- å¤é¨ãµã¼ãã¹ãæä¾ããOAuth1.0/2.0ãã¼ã¹ã®Proprietaryãªãããã£ã¼ã«APIã使ã£ã¦ã¦ã¼ã¶ã¼èªè¨¼ãè¡ããã¨
- OAuthèªè¨¼ã®è½ã¨ãç©´
- ï¼è ç®(ã¦ã¼ã¶ã¼ãã¢ããªãèªè¨¼æ å ±å (ex:Facebook)ãã«ç¶ãä½ããã¢ããªã®ãµã¼ããµã¤ãã¨ã)ãããæã«ã¯è¦æ³¨æ
- è¦ãç¥ããã®ä»ã¢ããªã®Tokenãç°¡åã«åãå ¥ãã¦ã¯ãããªã
- ãªãã§ãããªç©´ã®ããã¢ããªãã§ãã¦ãã¾ãã®ãï¼
- Facebookã®ããã¥ã¡ã³ãã«ãããªãã¨æ¸ãã¦ãªãã£ã
- OpenID Connect
- OAuth2.0 + æ¨æºã¢ã¤ãã³ãã£ãã£å±¤
- èªè¨¼ã¤ãã³ãã®ã¢ãµã¼ã·ã§ã³
- iss-issuerã誰ã
- sub-Subject, End-user Identifierã誰ã
- aud Audience,Client IDã誰ã®çºã«ãèªè¨¼ããã®ã
- iat -issued at
- exp -expiry
- IDãã¼ã¯ã³Verification
- å ¬ééµã®ã¿ã§è¨¼æã§ããæ¹å¼
- IDãã¼ã¯ã³ããããã°èªè¨¼å¯è½
- UserInfo API
- OAuth2.0
- 対å¿ã®APIã¨ã³ããã¤ã³ã
- ã¬ã¹ãã³ã¹ãã©ã¼ãããæ¨æºå
- IDé£æºã«å¿ è¦ãªãããã£ã¼ã«ãã¼ã¿ã¯å²ã¨ä¼¼ã¦ã
- ç»é²æã ãå©ç¨ï¼
- OpenIDã®ä»æ§ã¯ããã¤ãã«åããã¦ãã
- Minimal
- Basic Client Profile
- Implicit Client Profile
- Dynamic
- Discoverry
- Dynamic Client Registration
- Complete
- Core
- Session Management
- â»ã·ã³ã°ã«ãµã¤ã³ã¢ã¦ããããã人åã
- Discovery & Dynamic Client Registration
- developers.facebook.comã§ã¢ããªã«ãããããç»é²
- client_id & client_secretãã¢ããªã«åãè¾¼ã
- å¿ è¦ãªAPIã¨ã³ããã¤ã³ãã¨ã¬ã¹ãã³ã¹ãã©ã¼ããããAPI Docmentèªãã§ææ¡
- âã¦ã¼ã¶ã¼ãèªç±ã«é¸ã¹ãããã«ããã«ã¯å ¨é¨èªååãå¿ è¦
- Discovery
- OP Config
- ã¨ã³ããã¤ã³ããåå¾ãã
- Dynamic Registration
- client_name application_type, regdirect_urlsã渡ãã¦èªè¨¼
- OpenID Connectã®ã³ã³ã»ãã
- ç°¡åãªãã¨ã¯ç°¡åã«ãã¾ããã
- é£ãããã¨ãå¯è½ã«ãã¾ããã
- å¿ è¦ãªãã®ã ãå®è£ ããã°ããããã«ããã(ä»æ§ãã¢ã¸ã¥ã¼ã«ã¨ãã¦ãã¶ã¤ã³)
- æ å ±ã¯æ¸¡ããããªããã©èªè¨¼ã¯ããã
- ãµã¼ãã¹ä¿¡é ¼æ§ï¼4段éã§è©ä¾¡
ããã£ã±ãé£ãããªããã¨ããå°è±¡ãã§ããããå®è£ å¯ãã®è©±ã ã£ãã®ã§ãããã°ã©ãã®ä¸å°ããã人ãªãæ¯è¼çåããæã話ã ã£ãããããªããã¨æãã¾ãã
ã@novããã®çºè¡¨è³æã¯ä»¥ä¸ã
ãã¤ã¢ãã°
ãDevLOVEæä¾ã®ãã¤ã¢ãã°ãä»åã¯ãã¯ã¼ã«ãã«ãã§ãã¨ãããæéãåºåã£ã¦è¤æ°ã®ã°ã«ã¼ããè¡ãæ¥ããã£ã¹ã«ãã·ã§ã³ããã¨ããæ¹å¼ã§ãããã¯ã¼ã«ãã«ãã§ã¨ããè¨èèªä½ã¯ç¥ã£ã¦ãã¾ããããä½é¨ããã®ã¯ä»åãå®ã¯åãã¦ã
ãå人çã«ã¯ãä»ã¾ã§ä½åãä½é¨ãã¦ãããã¤ã¢ãã°ã®ä¸ã§ãä»åãæãå¹æã大ããã£ãæ°ããã¾ãã
ããäºäººã®è©±ãèãã段éã§ã¯ããªã¬èªèº«ãããããèªåããåãããªããã¨ãåãããªããç¶æ
ã ã£ãããã§ããããã«ãæ°ä»ãã¦ããªãç¶æ
ã§ãã¤ã¢ãã°ã«è¨ãã ããã§ãããèªåã§æããªãããè¨èã«ãã¦ããã¨ããããåãããªãããããåãããªããã¨ããã®ãè¦ãã¦ãããä»ã®äººã®è©±ãèãã¦ãããããããåãããã¼ããã¨ç¢ºèªã§ãããèªåã®ä¸ã§ãã¤ã¢ãã°ãéãã¦ãåãããªããã¨ãªã¹ããããªãã¨ãªãæ§ç¯åºæ¥ããããªæ°ããã¾ã
ãæã
ã®ã°ã«ã¼ãã«ã¯ãå¾åã§çºè¡¨ããã@novãããããã£ããã£ãã®ã§ããã®åãããªããã¨ããã質åã§ããã®ãã©ããã¼ã§ããã
ã¯ãã¼ã¸ã³ã°
ãæå¾ã«æ¥å¹´2/14,15ã«éå¬ãããJapan Identity & Cloud Summit(学認シンポジウム, OpenID Summit)ã®å®£ä¼ãããã¾ãããä¸æ¥ç®æåã®ã»ãã·ã§ã³ã¯ããã®Rubyã¢ã¤ãã«ã®æ± 澤ããããããç»å£ããããããªã®ã§ãå¹³æ¥ã§ããèå³ã®ãã人ã¯ãã²åå ãæ¤è¨ãã¦ã¿ã¦ä¸ããã
ç·æ¬
ãä¼å ´çä»ããçµãã£ãå¾ã§è£æ¹é£ä¸ã¨é£¯ãé£ãã«(飲ã¿ã«ï¼)è¡ã£ãéã«è©±ããå
容ãè¾¼ã¿ã§ãããä»åã®åå¼·ä¼ã®ç·æ¬ãã°ã
ãåå åããããç¨åº¦ã¯è¦æãã¦ããã§ããããã£ã±ãé£ããã£ãã§ãããããããèªåããèªè¨¼ã¨ãããã®ã¨ã©ããã風ã«åãåããããã確ç«ããã«åå ãã¦ãã¾ã£ãã®ã§ã話ãèããªãããèªåã«ã¨ã£ã¦ä½ã大äºãªã®ãï¼ããããããæ¢ããªãã£ããã¨ããæºåä¸è¶³ã®é¢ãããã¾ãããããã¯ãªã¬ä»¥å¤ã®åå è ãããã ã£ãããã§ããªãã¨ãªããèªè¨¼ãã¨ããOpenIDããOAuthãã¨ãããã¼ã¯ã¼ãã«é£ããã¦ãã¦åå ãã人ãå¤ãã£ãããã«è¦åãããã¾ããåå è ã®è·æ¥ããITã®éçºå¨ãã«é¢ãã£ã¦ãããã¨ã¯å ±éã ã¨ãã¦ãã管çè ãä¼ç»ãPGãã¤ã³ãã©ãã¢ããªãæ§ã ã ã£ãããã§ããããããã¨ãã¦å ¨å¡ã«åºãã話ãããã®ã¯ã»ã¼ä¸å¯è½ãªç¶æ ã ã£ãã¨æããã¾ãã
ãä¸æ¹ã§ãã¹ã¿ããã®äººã®è©±ãèãã¦ããéãã ã¨ã話ãæã§ããå·¥è¤ããã¨@novããã®æ¹ã§ããã©ããªäººãæ¥ãã®ããã©ããªè©±ãèãããã®ããããã¾ãã¡ã¤ã¡ã¼ã¸ããããã«ç»å£ããã¦ãã®ããªãã¨ããå°è±¡ãåãã¾ãããã¢ã¤ãã³ãã£ãã£ã»èªè¨¼ã¾ããã®ã³ãã¥ããã£ã¯ãåå ãããæ¹ããããã°ããåºå®åããã¦ãã¦ãã³ãã¥ããã£ã¨ãã¦ã®ããã¥ã¾ãã»éå¡æã®ãããªãã®ãæãã¦ããã£ããã£ããããªãã§ããããããæç ´ãããã¨ããæãããã£ã¦ä»åã®ã³ã©ããå®ç¾ããããã§ãã帰ãéã«ææ³ã伺ã£ãéãåããã¥ããã»é£ããã¨è¨ãããã®ã¯ã·ã§ãã¯ã ã£ããã¨ãããããªãã¨ãä»°ã£ã¦ããã£ãããã¾ããããä»ã¾ã§ã¯ã³ãã¥ããã£ã®ä¸ã§ããã¼ã¹ãåºæ¥ã¦ãããããç¨åº¦ç¥èãããã人ã°ãããåå è ã ã£ãã®ããããã¾ãããããããçªç¶ãä½ã«ãç¥ããªããã³ã³ããã¹ãããã©ãã©ã®äººãã¡ãè´è¬è ã«ãªã£ãæã«ãã¬ãã«æãæ´ããªãã£ãããããªãããªãã¨æãã¾ãã
ããã ãã¾ãéã«è¨ãã°ãããã§äºãã®ç¥èã¬ãã«ã®ç¸äºèªèãåºæ¥ããã£ããã®ã¤ãã³ãã«ãªã£ããã¨ãããã¾ãããäºäººã®è©±ãèãã¦ããã®ã¯1æéåç¨åº¦ã§ãããããæ¬æ¥ãã®å 容ã¯ããã£ã¨æéããã¦ã3ã4åã®ã¤ãã³ãã«åããããå 容ã ã£ããªããã¨æãã¾ãããã ãããä½åãã«åãã¦ããã®é½åº¦ç義ã®ãã¼ããå®ãã¦ãããã«è¦åã£ãã³ã³ããã¹ãã®è´è¬è ãéããä¸ã§ãåå¼·ä¼ãéãã°ããã£ã¨å¹æçã«èªè¨¼å¨ãã«ã¤ãã¦å¦ã¹ãããããªããã¨æãã¾ããããã«ã¤ãã¦ã¯ã¹ã¿ããã®äººãåãææ³ãæ±ããããã§ããä»åä¸åããã§çµããã«ããã¤ããã¯ãªãããã§ããã°ç¶ç¶ãã¦éå¬ãã¦ãããããã¨ä»°ã£ã¦ãã¾ããã
ããã¨ããªã¬ã®éçºè ã¨ãã¦ã®ç«å ´ã ã¨ãçµå±ã®ã¨ãããã©ããããç°¡åã«å®è£ ã§ãããããä¸çªå¤§äºãªãã ãªãã¨ããã®ãæ¬é³ãªãã ã¨æ°ä»ãã¾ãããã©ããã£ããèªè¨¼ã§ãããããã°ã¤ã³ã«å¤±æããªãããã¡ããã¨èª²éã§ãããã極端ãªäºãããã°ãèªåãã¡ã®è²¬ä»»ãããªããªãã»ãã¥ãªãã£ã§ããã©ãã§ãããããã§ãã¦ã
ãã ããããã®ã¤ãã³ãã§ã話é ããèªè¨¼ã»ã¢ã¤ãã³ãã£ãã£å¨ãã®è©±ã¯ããããã£ããªã¬ã®ç«å ´ã§ãé常ã«ä¹±æ´ãªè¡¨ç¾ã§è¨ãã°ãã¶ã£ã¡ããã©ãã§ãããã話ã«ãªã£ã¡ãããã§ããããã©ã¤ãã©ãªãç¨æããã¦ãã¦ããããå¼ã³åºãã¦å¿ è¦ãªãã©ã¡ã¿æ¸¡ãã ãã§å®ç¾ã§ããããªãããã§åé¡ç¡ãã
ãåé¡ããã¨ããã°ããã©ãã«ããã£ãæã¨ãå°å ¥æã«ä¸å¸ã»ã¯ã©ã¤ã¢ã³ãã«èª¬æããæã«ç¥èãç¡ãã¨èª¬å¾åãæãããããªããã¨ãããã¨ãªãã ã¨æãã¾ãããã¨ã¯ãæ®æ®µããèªè¨¼å¨ãã®ã·ã¹ãã ãæ±ã人éã¨ãã¦ãèªä¿¡ãæã£ã¦æ¥åã«è¨ãããå¦ããã¨ãããã¨ããããã¯éçºã»éç¨ã«å¾äºããä¸ã§ã決ãã¦å°ãããªãæ¯éãæã¡ã¾ãã®ã§ãåãã»åããªããã¨ãã£ãä½æ¬¡å ã§ããããããªãã®ã§ããã°ããã£ã±ãè¦ãã¦ãããæ¹ããããè¦ããªãã¦ãã¨ããããåãããé£ããããè¦ããªãã¦ããããã¨ãããã¨ã«ã¯ãªããªãã¨æãã¾ãã
ãéçºè ã§ããã°ãä¸åãã³ãºãªã³ã§ããªãã§ãèªåã§çµãã§ã¿ãã°ãããããæ¬è³ªã«è¿«ã£ã¦ããããªãç解ãæ·±ã¾ãããããããã¨ããæè¦ãããã¾ãããä»ããèªè¨¼ã®è¦æ ¼ãå ¨ã¦è©¦ããã¨ã¯é£ããã§ãããã¾ãã¯æãåããã¨ããããå ¥ãã®ã¯ãã¢ãªãªããããªããã¨æãã¾ãã