idcon 16ã¬ãã¼ã
5æ24æ¥ã«è¡ããã #idcon #16ã«è¡ã£ã¦ãã¾ããããã«ãªã¨21Fã®:DeNAã»ããã¼ã«ã¼ã ã§ãã
ä»åã¯consumer secretã®ç§å¿ãIIWå ±åãªã©ãã£ã¼ããªè©±ãèãããã§ãã
(19:10)
OIDFJããããããã¤
- ã¤ã³ãããããã¬ã¤ã«ããå±±ä¸ããããåç»ãå±ãã¦ãã¾ã
- æ±å·ããããã¤ãã³ãåç¥
- Enterprise Identity Working Group 7/4 14:00ã
- éæç·åç 究æ 丸ãå ç·åã»ã³ã¿ã¼
ãå ¬å¼Twitterã¢ããªã«æã¾ããèªè¨¼éµã®é£èªåã¨ãªãã¼ã¹ã¨ã³ã¸ãã¢ãªã³ã°å¯¾ç(ä»®)ã
- @BlackWingCat (é»ç¿¼ç«)
- スライド
- [è£å©è³æ] 超軽量Twitterクライアント「もふったー」コンシューマシークレットキー難読化最後の挑戦 - GIGAZINE
- ããªã¼ã½ããä½å®¶: ãã¯ã¿ã¼ãªã©ã§å
Ž
- Application Blocker
- User32.dllããã¼ãããã¨ãã«ãããªã·ã¼ãåç §ãã¦ãç¹å®ããã°ã©ã ããããã¯
- Windows 2000æ¡å¼µã«ã¼ãã«
- ã¬ã¬ã·ã¼ã«ã¼ãã«ã使ãããã.Netã¢ããªãææ°ãã©ã¦ã¶ãã¡ãã£ã¢ãã¬ã¤ã¤ã¼ãªã©ãåä½å¯è½
- Application Blocker
- ããµã£ãã¼
- Win95ã§åãuser stream対å¿ã®twitter client
- MS Unicode, OpenSSL, GDIPLUSã使ããæ¥æ¬èªã«ã対å¿ãã¢ãã¡ã¢ã¤ã³ã³ã対å¿
- Win95ãã¶ã¤ã³ã®ã¬ã¬ã·ã¼ãªè¦ãç®ãã¯ã¼ã«
- æ¬é¡: GIGAZINEè¨äºã®ãã¿: consumer secret keyã®é£èªåã«ã¤ãã¦
- twitterã¯ã©ã¤ã¢ã³ãã®Consumer key, Consumer secret key
- Q: consumer secret keyã¯é£èªåããªãã¨ãããªãã®ã
- A: å ¬å¼ã®éçºãã¼ã¸ã«ãnever be human-readableãã¨ãã
- ã¨ãããtwitterå ¬å¼ã¢ããªã§ã¯çã§èªããç¶æ ã ã£ã(ã¡ã¢å¸³ã§éãã ãã§è¦ãã)
- ããµã£ãã¼ã®é£èªå1
- ããã·ã¥åãã¦ããããå®è¡æã«ã¡ã¢ãªãã³ãããã¨è¦ãã¦ãã¾ã
- ããµã£ãã¼ã®é£èªå2
- å¿ è¦ãªã¨ãã«secretãé¨åãã¨ã«åãåºããããã«ãã¦ã¿ã
- HMACè¨ç®ã®éä¸ã§è¦ãã¦ãã¾ããã¡ãã»ã¼ã¸ã空ç½ãªã®ã§padã¨xorããã ãã®ãã®ãè¦ãã¦ãã¾ã
- 対ç
- ã¡ãã»ã¼ã¸ã空ç½ã¨ãããã¨ã¯å®æ°ãªã®ã§ãããã·ã¥æ¸ã®ãã®ãæã£ã¦ãã
- padã®xorãè¡ãé¢æ°ãã²ã¨ã¤ã«ãã(ãã¬ã¼ã¯ãã¤ã³ããç½®ããªãããã«)
- ããµã£ãã¼ã®é£èªå3
- ã¡ãã»ã¼ã¸ãé·ãå ´åã®SHA-1è¨ç®2åç®ãé£ãã
- ããã°ã©ã ä¸ã®ä»ã®é¨åã¨xorãã©ãã ãã¯ããããªã
- ãã¾ã: ãªãã¼ã¹ã¨ã³ã¸ãã¢ãªã³ã°å¯¾ç
- IsDebuggerPresent()ãå®æçã«ãã§ã㯠â ãããã¬ãã¢ã¿ãããããã®ãæ¤åº (iTunesãªã©)
- ããã°ã©ã å ã§ç¹å®ç¯å²ã®ãã§ãã¯ãµã ãç£è¦ â ãã¬ã¼ã¯ãã¤ã³ããç½®ããããã®ãæ¤åº (MS Skypeãªã©)
- Q&A
- nov: Windowsã®å ´åã®è©±ã ã£ãããiPhoneã¨ãã ã¨ã©ããããããããã®ã
- BlackWingCat: éçºç°å¢ã§ãªãã¨ããããè¦ãããªããå°ãé£èªåããæ¹ãããã ãããJavaã ã¨éã³ã³ãã¤ã«ã§è¦ãã¦ãã¾ãå ´åããããå ¬å¼ã¢ããªã¯ç¹æ¨©ãæã£ã¦ããã®ã§ãæ¼ãã¦ãã¾ãã¨å°ã
- nov: å ¬å¼ã¢ããªã ããã£ã¦ç¹æ¨©(rate limitãä¸ãããªã©)ãä¸ããªããã°ããã®ã«
- lef: ãããã©ãã¾ã§ãã£ããç´å¾ããã®ããæå¾ã®æå¾ã¯èªã¾ãã¦ãã¾ãã®ã¯é¿ããããªããã¿ããªããã¾ã§ããããã§ããã¨ãããã©ã³ã¹ã®åé¡ãå®éã©ãã ã£ããããããã ã£ãã®ã
- BlackWingCat: ãã¡ã®ã¯å ¬å¼ã¢ããªã§ã¯ãªããæåã§ããªãã£ãã®ã§ãããã¾ã§ããå¿ è¦ã¯ãªãã£ãã ããããããkeyãæããã¦æªæããã¢ããªã«çµã¿è¾¼ã¾ããã¨ä¿¡ç¨ã失ã£ã¦ãã¾ããæä½éã®é£èªåã¯å¿ è¦ã ãã
- ?: secretããµã¼ãã¼ã«ç½®ãã¦ããã¼ã¯ã³ã ããã¯ã©ã¤ã¢ã³ãã«ããã£ã¦ããããã«ãããã©ãã ãã
- â nov: OAuth1.0aã ã¨ãªã¯ã¨ã¹ããã¨ã«ç½²åãå¿ è¦ãªãããã¯ã©ã¤ã¢ã³ããsecretãç¥ã£ã¦ããªãã¨
- â BlackWingCat: ãµã¼ãã¼ã§proxyãã¦ããã°OK â ãããªããã©ã¦ã¶ã¢ããªã§ããããã
- â nov: OAuth2.0ãªãã°ããã¼ã¯ã³ã ã渡ãã¦ããã°ãã
- nat: dynamic client registrationã§ã¤ã³ã¹ã¿ã³ã¹ãã¨ã«secretä½ããããªãããã以ä¸ã¯OSã®æ¯æ´ã§ã¯ã©ã¤ã¢ã³ãã®ããã·ã¥ãå¾ããªã©ãå¿ è¦
- mad_p: æããã¦å°ãã®ã¯ãèªåã®ã¯ã©ã¤ã¢ã³ãã®åãããã£ã¦æªæã®ããã¯ã©ã¤ã¢ã³ããä½ããããªã¹ã¯ã ãã? ã¨ã³ãã¦ã¼ã¶ã¼ããµã¼ãã¼ãå°ããªããã¢ããªä½è
ã ããå°ã
- nov: å ¬å¼ã¢ããªã®secretã使ã£ã¦twitterã®phishingãµã¤ããä½ããã¨ãã§ãããå¤ãã®äººã使ã£ã¦ããå ¬å¼ã¢ããªãbanãã«ããã ãã
- nov: nativeã¢ããªã®credentialãæãã¦nativeã¢ããªã§ä½¿ãããåã«ã¯App Storeã®ãããªä»çµã¿ã§ãªãã¨ããªããiframeã§ãããããããã¨å°ã
- lef: twitterã«OAuth2対å¿ãã¦ãããã§FAãéçºè ã¨ãã¦ã¯ã¤ãã
- ?: API1.1ãããããã¤ãã®APIã§ã¯OAuth2.0ãã¼ã¹ã§å®è£
ããã¦ããé¨åãããããã
- nov: twitter anywareã¯è£ã§OAuth2ã®ãããªä½ãã使ã£ã¦ããããã ãå®è£ ã¯æã£ã¦ããã®ã«å ¬éãã¦ããªãå°è±¡
- ææ³: æ親ä¼ãªã©ã§ããçµè«ã¯ OAuth2.0ã«ãã¦dynamic registrationã使ããã¨ãããã¨ã®ããã§ããrefresh_tokenãæ°¸ç¶åããã®ã§ããããdynamic registrationã¯é£ãããªãã¨ã®ãã¨
(20:00)
ä¼æ©
(20:10)
ãIIWã§ã»ãã·ã§ã³ç«ã¦ãã(æè¡è ãããªããã©) -- IIW#15å ±åã
- @IdentityPenguin
- æ¬è·ã¯ç¤¾ä¼ç§å¦ã¨æè¡ã®é¢ããã«ã¤ãã¦ãç 究ãã¦ãã
- IIW#15 (2012/10/23-25)ã®ã¬ãã¼ã
- ä¼å ´ã¯ããªãã¿: Computer History Museum
- IIW: worshopã®é²ãæ¹â¦ã¢ã³ã«ã³ãã¡ã¬ã³ã¹
- é¡ãåãããåæ¥ã«ã¹ã±ã¸ã¥ã¼ã«ã決ãã
- ãã®åéã®å¤åãé常ã«æ©ã â ãã¼ãºã¯ãããããããããªã
- å¦ã¶ãã¨ãcontributeããæ ç±ãæã¤åå è ã主ä½ã¨ããã
- æ¯æã»ãã·ã§ã³åº§é·ãç«åè£ã§æ±ºãã
- é¡ãåãããåæ¥ã«ã¹ã±ã¸ã¥ã¼ã«ã決ãã
- 軽ãæé£ãã¨ã¹ãã¬ãã½ãæä¾ããã¦ãã â é£ã¹ç©ãããã¨äººãéã¾ã
- ã¾ãã¯ãã¼ãã«ã«åããã¦åº§ã
- å¿ ãæ°äººãä¸äººã¯å ¥ãããã¨! by IdentityWoman
- ãã¼ãã«ãã¨ã«ãé¡ãé ããã¦ãè¨èã®å®ç¾©ãåãã¼ãã«ã§è©±ãåããä¾:ãframeworkã
- åå è
å
¨å¡ã輪ã«ãªã£ã¦åº§ã
- ãã¼ãã«ãã¨ã®ãé¡ã®ç´¹ä» â ã»ãã·ã§ã³ãç«ã¦ã
- ã»ãã·ã§ã³ãAnonymousã
- ã»ãã·ã§ã³ãReputation Consulting .05Centsã
- 1vs1ã®ã»ãã·ã§ã³ã«ãªã£ã¦ãã¾ã£ã
- å人ãä¼æ¥ã«ã¤ãã¦ã®reputation controlã®å¿ è¦æ§
- ãã¹ã¦å®åã§ãªã¼ãã³ã¯å±éºããã
- ã·ãªã³ã³ãã¬ã¼ã¯ã¿ããªå®åã§ãã â ãããªãã¨ã¯ãªããã·ãªã³ã³ãã¬ã¼ã¯ä¸çããã¾ãã®ã§ãããããªã¼ãã³ã«ã§ããªã
- ä¾: Facebookã¯å®¶æã»è¦ªåã®ã¿ãLinkedInã¯ãªã¼ãã³ãç§çãªãã¨ã¯ååãå¤ãã¦blogã«æ¸ããããidentity controlãå¿ è¦ãåå¯ãããããå°ã
- Dinnerã§
- ãAnonymousã®éã£ã¦ä½ã ã¨æã?ã â è°è«ãããä¸ãããã»ãã·ã§ã³ãããããª
- ã»ãã·ã§ã³ãããã â ãã£ã¦ã¿ãã
- ã»ãã·ã§ã³ã®ç«ã¦æ¹
- 誰ã§ãOK!
- 1ã»ãã·ã§ã³50å
- èªåã§ãã¼ãã決ããè²ç´ã«æ¸ããæ©ãè åã¡ã§ã»ãã·ã§ã³ãã¼ãã«è²¼ã£ã¦ãã
- 大ããç´ã«ãããã¯ãæ¸ãããµãããé¨å±ã«ãªã£ã¦ãã
- æ¬å½ã«æ©ãè é
- ä¼å ´ã«ã¦ãã°ä¿(note taker)ãæå®ãã
- ã»ãã·ã§ã³ãWhat is Real Nameã
- 17å
- note takeræåããªãã£ãã誰ãåã£ã¦ããªãã£ã
- å£ç«ãåã£ã人ã¯ãä½åº¦ãå®åãå¤ãã£ã¦ãã人ã ã£ã
- ããããå®åã£ã¦å¤ãããã®ãããªãã®? å®åã¯å¤æ´ã§ããã®?
- æ³å¾ã®åé¡
- Williamã®æ称ã¯Billãåä¸äººç©ã®æ ä¿ãå¿ è¦ãªå ´åã
- å人ã®èå¥ã¨ç¹å®ã«å¿
è¦ãªæ
å ±ã¯ä½ã?
- åå§ååã®äººãããã°å¥ã®å±æ§ãå¿ è¦ãå± ä½å°ã髪ã®è²ãªã©
- åå空éã®å¤§ããã«ããããå½å®¶ã»ã³ãã¥ããã£ã¼ã«ãã£ã¦éã â ãµã¤ãºã«ããã®ã§ã¯?
- å®åã¯ãªãå¿
è¦ã?
- Reputationã«çµã³ã¤ã
- ä¿¡é ¼ãæ ä¿ããã社ä¼ã®ããã¿ã¨ãã¦å¿ è¦
- ãããªããå½ã«ç»é²ãã¦ããååã§ãªãã¦ãããã®ã§ã¯?
- ãã£ã¦ã¿ã¦
- unconferenceå½¢å¼ â æãæãã¦ãã£ã¦ã¿ãã¨å¾ããã®ã¯å¤ã
- è°è«ã¯ã§ãã
- ãã°ã¯æ®ãã¦ãããã¨!
- ãã¬ãã·ã¥ãªãã®ãè°è«ãã â ãã¬ãã·ã¥ãªãã®ã»ã©æ®ãã¦ããã¹ã
- ãæå¾ã«åå¯ããã¦ããã¾ããã¨ãããã¨ã§@IdentityPenguin ã®ä¸ã®äººã¯@oritakoããã§ãããå±±ä¸ããã®ãããªã§è¨ããã¦ãã¾ããããããã¯ãã©ã¤ãã·ã¼ä¾µå®³ã§ãããã¼ãèªåã®æã¾ãªãåå¯ãã¯å°ãããã¼ãã¨ã®ææ
- nat: ãã®1v1ã ã£ãreputationã®æ¬æ¸ãã人ã£ã¦Randy Farmer?
- IdentityPenguin: ããããªããååºãããã£ããã ãã©â¦
- nat: real nameã®è©±ã§ãç¯å²ãå°ããã¨å±æ§ãå°ãªãã¦ããã大ãããªãã¨å±æ§ãããããå¿
è¦ã¨ããã®ããã£ãâããã£ã¦ISOã®å®ç¾©ãã®ãã®ãããç¯å²ã§ç¹å®ããã«è¶³ãååãªå±æ§ã®éåãæ¥æ¬äººã¯identityã¨è¨ãã¨1åã®identifierã ã¨æã£ã¦ãã¾ãããå±æ§ã®éåã¨ãã¦ã¨ãããã¹ã
- IdentityPenguin: ãªãã»ã©! å®çæ´»ã§ã®å®åã®èãæ¹ã¨ISOã®å®ç¾©ãã¤ãªãã£ã¦ãã£ãããã
(20:38)
ãIIW #16ã«åå ãã¦ãããSponsored by GREEã
- @nov
- IIWåå ã¯2åç®ãGWããç´å¾
- ååã¯æ給åã£ã¦èªè²»ã§è¡ã£ããä»åã¯ä¼ç¤¾ãåºå¼µæ±ãã«ãã¦ããã
- ä¼å ´ã¯ãã¤ãåã: Computer History Museum
- session creation
- personal cloudãããºã£ã¦ã
- 大ããªé¨å±ã¯30人ããããå°ããªé¨å±ã¯8人ä¼è°å®¤ã«15人ã¨ããå»ä¸ããã
- NotesãWebã§å
¬éããã
- http://iiw.idcommons.net/IIW_16_Notes
- 赤ããªã³ã¯ã¯ãã¼ãããªãã
- ã»ãã·ã§ã³ãMobile SSOã
- Sascha Preibisch, Layer7
- ã¨ã³ã¿ã¼ãã©ã¤ãºåéã®iPhoneã«ç¹åããSSO
- Connectãã®ã¾ã¾ã¯ãªãããOAuthããã¨ãã«id_tokenãçºè¡ â åããã³ãã¼ã§ã ãshareã§ããkey chainã«å
¥ãã
- ã¢ããªA1ãèªå¯ããå¾ãåãä¼ç¤¾ã®A2ãå ¥ããã¨ãèªå¯ã®å¿ è¦ããªã
- mssoã¨ããã¹ã³ã¼ããã¤ãã
- generate RSA key pair on client side (OPTIONAL)
- è¤æ°ã®ã¢ããªãããããIdPã«ãªã
- nat: OpenID Foundationã§ãããããã®æã®ãã¨ã®working groupãã§ãã
- ã»ãã·ã§ã³ãMobile SSOã
- George Fletcher, AOL
- ã¢ãã¤ã«ã®ãã¤ãã£ãã¢ããªã¨åãããã¤ã¹ä¸ã®webãã©ã¦ã¶
- webssoã¨ããã¹ã³ã¼ãã§access_tokenãåã
- webssoã«down scopeããtokenãrefreshã§åã£ã¦æ¸¡ã
- ID tokenãweb appã«æ¸¡ããããªæã
- ãAuth@Google - Next 5 Yearsã
- Eric Sachs, Google
- Google docsã«è³æãã
- éå»5å¹´ä½ããã£ãã: ãªã¹ã¯ãã¼ã¹ã2è¦ç´ ãOpenId, OAuth
- good news: ã¢ã«ã¦ã³ãhijackããã¦ã¹ãã é ä¿¡ãããã¢ã«ã¦ã³ãæ°ããªã¹ã¯ãã¼ã¹ã§ããªãæ¸ã£ã
- bad news:
- OpenIDã¸ã®migrationã¯é£ããã£ããusabilityã«é£ãã â account chooserã¸ã®æµããaccount linking: åãã¡ã¢ãã®ã¨ãã«åãã¢ã«ã¦ã³ãã«ãããåãã¦ããã¹ãã â RPã®äººéãèãè¾¼ãã§ãã¾ã
- Account recoveryãã¢ãã¬ã¹è ±
- ä»å¾5å¹´é
- 5å¹´åã«ãããã¨ãã¦ãããã¨ã¨5å¹´éã§ãã£ããã¨ã¨ã¯çµæ§éã£ã¦ãããã¹ãããæµè¡ã£ãã¨ã
- Setup, not sign-in
- ãã¤ãã£ãã¢ããªã¯ã¤ã³ã¹ãã¼ã«æã«ãã°ã¤ã³ãããããã£ãããã¯ã©ã¦ãã®webãµã¤ãã¯ãã¤ããã°ã¤ã³ãç´ã
- webã§ãsetupããã°ããããããªãããOSã¬ãã«ã®account managerãå¿ è¦
- account switchã®æ©è½ãOSã¬ãã«ã§æä¾
- Reduce Bearer Tokens
- OAuth 2.0ã®access tokenã¯bearer
- JWT bearer tokens
- ã»ãã·ã§ã³ã¯ããã¼ãbearer
- â ããã¤ãããã£ã¨secureã«ããã
- self-signed cookie: ãã©ã¦ã¶å ã«ãã¼ãã¢ãçæããµã¤ãã«public keyãç»é²
- chrome://settings/cookies ã«è¡ãã¨ããã£ã³ãã«IDãã¨åºãã®ããã
- Smarter Hardware
- Chromeã§ãµã¤ãã«ã¢ã¯ã»ã¹ããã¨ãªã¹ã¯ãã¼ã¹ã®ç¢ºèªãAndroidå´ã«åºã
- ããã¤ã¹ã®unlock/activationããã§ã«æã£ã¦ããdeviceã使ã£ã¦è¡ããgoogle deviceå士ã ã¨ã§ãããã ãã© â æ¨æºåããã (FIDO ãã¡ã¤ã Alliance)
- nat: PayPalãä¸å¿ã«ãªã£ã¦ããããããæ¨æºåããã
- universal second factor
- yubikey: USB keyboardã¨ãã¦ã¯ã³ã¿ã¤ã ãã¹ã¯ã¼ããå ¥åãã¦ããããå®ãããã¤ã¹
- ãOAuth & JOSE @ BlueButton+ã
- Justin Richer, MITRE
- OAuth, OpenID Connectã®MLã«ãããã
- OAuth2ã®dynamic client registrationã®author
- use caseã¨ãã¦BlueButton+ã¨ããã®ãä½ã£ã¦ãã
- ãtrusted registrationã
- BlueButtonã¨ã¯: ãã«ã¹ã±ã¢æ å ±ãæ£è ãèªåã§ã¢ã¯ã»ã¹å¯è½ã«ãã
- nat: éå½¹è»äººããéãèªåã®å¥åº·æ å ±ãåã£ã¦ãå»è ããã«æã£ã¦ãã
- class: ã¯ã©ã¤ã¢ã³ãã®ãã³ãã¬ã¼ã
- registration_jwtãçºè¡ â nativeã¢ããªã«ããè¾¼ã
- instantiation: Dynamic client registration
- registration_jwtã使ã£ã¦trusted registrationã§ãã
- discovery: OAuth2ã«ã¯ã¾ã ãªãã
- registry discovery: ã¨ã³ããã¤ã³ããè¦ã¤ãã
- providers authãµã¼ãã¼ã®ãªã¹ã
- provider ã²ã¨ã¤ã®ãããã¤ãã®ã¨ã³ããã¤ã³ããªã¹ã
- apps discovery AuthZãã¯ã©ã¤ã¢ã³ãã®ãªã¹ãã確èª
- push authorization
- ããã¦ã¼ã¶ã¼ã«å®æçã«éå»3ãæéã®éé¢è¨é²ãéãããã®èªå¯
- authorizationã ããã¦ãaccess tokenã¯çºè¡ããªã
- Justin Richer, MITRE
- Personal Cloudãããããããªãã£ã
- nat: lifelog managementã«è¿ãæ¦å¿µãã
- nov: ãã¼ããå ¨é¨ã¯ã©ã¦ãã«ãã£ã¦ãã©ã®ãã¼ãã«ã©ã®ãã³ã¿ã¼ã使ãããèªåã§é¸ã¹ã
- nov: deviceä¸ã«key-pairãä½ã£ã¦seld-issuedã¿ãããªã®ãé¢ç½ãã£ã
(21:20)
æ親ä¼
- :DeNAæ§ãæä¾ã®ãã¼ãã¨ãã¼ã«ãããã ãã¾ããããã¡ãããã¾ã§ãã
- @flano_yuki ãããããOAuthãããã¹ããã«ã¼ãé
å¸ããã¾ãã!
- ç§å¯ã®è³ªåã¨çã®æµåºäºä»¶ããã¤ãã³ãã¼æ³æ¡ãOAuth2 dynamic client registrationãªã©ã話é¡ã«ãªã£ã¦ãã¾ãã
- å人çã«ã¯natããããOpenID Connectã®Request File Methodãèããèå³ãæã¡ã¾ãããOpen ID Artifact Bindingã¨å¼ã°ãã¦ãããã®ã§ããããã®ã¡ã½ããã§ã¯ãªã¯ã¨ã¹ããæ¥åã«å¿ è¦ãªæ å ±ããåå¾ããªããã¨ã第ä¸è æ©é¢ã«ãã£ã¦æ¤è¨¼ã§ããããã§ããæ³å¾ã®è¦ä»¶ã«åè´ãããã¨ãèªããããã°ãã¦ã¼ã¶ã¼ã®åæç»é¢ãã¹ãããå¯è½ã¨ã®ãã¨ã§ããã¡ãã£ã¨è©³ããåå¼·ãã¦ã¿ããã¨æãã¾ã
以ä¸ã§ãã誤ããçºè¨æå³ã¨éããªã©ããã°ãææãã ããã