आपको Apigee Edge दस्तावेज़ दिख रहा है.
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
इस पेज पर जाएं
Apigee X दस्तावेज़. जानकारी
क्या
ऐक्सेस टोकन, रीफ़्रेश टोकन, ऑथराइज़ेशन कोड, और क्लाइंट ऐप्लिकेशन के एट्रिब्यूट मिलते हैं एट्रिब्यूट इस्तेमाल करता है और वैरिएबल को उन एट्रिब्यूट की वैल्यू से पॉप्युलेट करता है.
यह नीति तब काम आती है, जब आपको वैल्यू के आधार पर डाइनैमिक और कंडिशनल व्यवहार को कॉन्फ़िगर करने की ज़रूरत हो उसे किसी टोकन या ऑथराइज़ेशन कोड में डालें. जब भी टोकन की पुष्टि की जाती है, वैरिएबल अपने-आप पॉप्युलेट हो जाते हैं . हालांकि, टोकन की पुष्टि नहीं होने के मामलों में, आपको इस सुविधा का इस्तेमाल करके, किसी टोकन की एट्रिब्यूट वैल्यू के साथ वैरिएबल को साफ़ तौर पर भरा जा सकता है. इन्हें भी देखें टोकन को कस्टमाइज़ करना और ऑथराइज़ेशन कोड.
इस नीति को पास किया जाने वाला ऐक्सेस टोकन मान्य होना चाहिए. ऐसा न करने पर, नीति
invalid_access_token
गड़बड़ी.
सैंपल
नीचे दिए गए सैंपल, OAuth V2 की जानकारी पाने की नीति का इस्तेमाल करते हैं. इससे, को अपडेट और फिर कोड में उस जानकारी को ऐक्सेस करता है.
ऐक्सेस टोकन
ऐक्सेस टोकन का रेफ़रंस पाने के लिए, इसमें <AccessToken>
एलिमेंट का इस्तेमाल करें
आपकी नीति.
इस उदाहरण में, ऐक्सेस टोकन नाम के क्वेरी पैरामीटर में खोजा जा सकता है "access_token" (लागू करने से जुड़ी जानकारी आपको खुद तय करनी होती है):
<GetOAuthV2Info name="MyTokenAttrsPolicy"> <AccessToken ref="request.queryparam.access_token"></AccessToken> </GetOAuthV2Info>
ऐक्सेस टोकन दिए जाने पर, यह नीति टोकन की प्रोफ़ाइल को खोजती है और प्रोफ़ाइल डेटा के साथ वैरिएबल बनाएं.
इसके बाद, JavaScript या किसी दूसरे तरीके का इस्तेमाल करके, वैरिएबल को ऐक्सेस किया जा सकता है. यह उदाहरण JavaScript का इस्तेमाल करके, ऐक्सेस टोकन से जुड़े दायरे को हासिल करता है:
var scope = context.getVariable('oauthv2accesstoken.MyTokenAttrsPolicy.scope');
ध्यान दें कि कोड में उन वैरिएबल को ऐक्सेस करने के लिए, आपको उनके प्रीफ़िक्स की शुरुआत "oauthv2accesstoken". ऐक्सेस टोकन के ज़रिए उपलब्ध वैरिएबल की पूरी सूची देखने के लिए, देखें टोकन वैरिएबल को ऐक्सेस करना.
ऑथराइज़ेशन कोड
ऑथराइज़ेशन कोड के एट्रिब्यूट पाने के लिए, <AuthorizationCode>
का इस्तेमाल करें
शामिल किया जा सकता है.
यहां दिए गए उदाहरण में, ऐक्सेस टोकन को किसी फ़ॉर्म में ढूंढा जा सकता है "कोड" नाम वाला पैरामीटर (लागू करने से जुड़ी जानकारी आपको खुद तय करनी होती है):
<GetOAuthV2Info name="MyAuthCodeAttrsPolicy"> <AuthorizationCode ref="request.formparam.code"></AuthorizationCode> </GetOAuthV2Info>
ऑथराइज़ेशन कोड दिए जाने पर, यह नीति कोड की जानकारी को ढूंढती है और के साथ वैरिएबल की जांच कर सकते हैं.
इसके बाद, JavaScript या किसी दूसरे तरीके का इस्तेमाल करके, वैरिएबल को ऐक्सेस किया जा सकता है. यह उदाहरण JavaScript का इस्तेमाल करके, ऑथराइज़ेशन कोड से जुड़ा कस्टम एट्रिब्यूट हासिल करता है:
var attr = context.getVariable(‘oauthv2authcode.MyAuthCodeAttrsPolicy.custom_attribute_name’);
ध्यान दें कि कोड में उन वैरिएबल को ऐक्सेस करने के लिए, उनसे पहले "oauthv2authcode" लगा दें. ऑथराइज़ेशन कोड के ज़रिए उपलब्ध वैरिएबल की पूरी सूची देखने के लिए, देखें ऑथराइज़ेशन कोड वैरिएबल.
टोकन रीफ़्रेश करें
रीफ़्रेश टोकन एट्रिब्यूट पाने के लिए, अपने<RefreshToken>
की नीति देखें.
इस उदाहरण में, ऐक्सेस टोकन नाम के क्वेरी पैरामीटर में खोजा जा सकता है "refresh_token" (लागू करने से जुड़ी जानकारी आपको खुद तय करनी होती है):
<GetOAuthV2Info name="MyRefreshTokenAttrsPolicy"> <RefreshToken ref="request.queryparam.refresh_token"/> </GetOAuthV2Info>
रीफ़्रेश टोकन दिए जाने पर, नीति रीफ़्रेश टोकन की जानकारी को देखती है और उसे अपने-आप भर देती है रीफ़्रेश टोकन डेटा वाले वैरिएबल का एक सेट.
इसके बाद, JavaScript या किसी दूसरे तरीके से उन वैरिएबल को ऐक्सेस किया जा सकता है. नीचे दिए गए उदाहरण: JavaScript का इस्तेमाल करके रीफ़्रेश टोकन से जुड़ा कस्टम एट्रिब्यूट हासिल किया जाता है:
var attr = context.getVariable(‘oauthv2refreshtoken.MyRefreshTokenAttrsPolicy.accesstoken.custom_attribute_name’);
ध्यान दें कि कोड में वैरिएबल को ऐक्सेस करने के लिए, आपको उनकी शुरुआत में "oauthv2refreshtoken". रीफ़्रेश टोकन के ज़रिए उपलब्ध वैरिएबल की पूरी सूची देखने के लिए, देखें टोकन वैरिएबल रीफ़्रेश करें.
स्थिर
कुछ मामलों में, आपको स्टैटिक तरीके से कॉन्फ़िगर किए गए टोकन की प्रोफ़ाइल की ज़रूरत पड़ सकती है ( जिसे किसी वैरिएबल के ज़रिए ऐक्सेस नहीं किया जा सकता). ऐसा करने के लिए आपको ऐक्सेस टोकन का इस्तेमाल एलिमेंट के तौर पर करें.
<GetOAuthV2Info name="GetTokenAttributes"> <AccessToken>shTUmeI1geSKin0TODcGLXBNe9vp</AccessToken> </GetOAuthV2Info>
अन्य सभी टाइप के टोकन (क्लाइंट आईडी, ऑथराइज़ेशन कोड, और रीफ़्रेश करें) के साथ ऐसा किया जा सकता है टोकन) भी शामिल है.
Client ID
इस उदाहरण में, क्लाइंट आईडी का इस्तेमाल करके क्लाइंट ऐप्लिकेशन के बारे में जानकारी पाने का तरीका बताया गया है.
लागू होने के बाद, यह नीति वैरिएबल के एक सेट को क्लाइंट की जानकारी से भर देती है. इसमें
केस, नीति के अनुसार क्लाइंट आईडी को क्वेरी पैरामीटर में खोजा जा सकता है
client_id
कॉल किया गया. क्लाइंट आईडी को देखते हुए, नीति क्लाइंट के
प्रोफ़ाइल डेटा के साथ वैरिएबल के एक सेट को पॉप्युलेट करता है. वैरिएबल
oauthv2client.
से पहले जोड़ा गया
<GetOAuthV2Info name="GetClientAttributes"> <ClientId ref="request.queryparam.client_id"></ClientId> </GetOAuthV2Info>
इसके बाद, JavaScript या किसी दूसरे तरीके का इस्तेमाल करके, वैरिएबल को ऐक्सेस किया जा सकता है. उदाहरण के लिए, इसका इस्तेमाल करके, क्लाइंट ऐप्लिकेशन से जुड़े डेवलपर ऐप्लिकेशन का नाम और डेवलपर का ईमेल पता डालें JavaScript:
context.getVariable("oauthv2client.GetClientAttributes.developer.email"); context.getVariable("oauthv2client.GetClientAttributes.developer.app.name");
एलिमेंट का रेफ़रंस
एलिमेंट के रेफ़रंस में, GetOAuthV2Info नीति के एलिमेंट और एट्रिब्यूट के बारे में पता चलता है.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <GetOAuthV2Info async="false" continueOnError="false" enabled="true" name="GetOAuthV2Info-1" <DisplayName>Get OAuth v2.0 Info 1</DisplayName> <AccessToken ref="variable"></AccessToken> <AuthorizationCode ref="variable"></AuthorizationCode> <ClientId ref="variable"></ClientId> <RefreshToken ref="variable"></RefreshToken> </GetOAuthV2Info>
<GetOAuthV2Info> एट्रिब्यूट
<GetOAuthV2Info async="false" continueOnError="false" enabled="true" name="Get-OAuth-v20-Info-1">
यहां दी गई टेबल में, ऐसे एट्रिब्यूट के बारे में बताया गया है जो नीति के सभी पैरंट एलिमेंट में एक जैसे होते हैं:
एट्रिब्यूट | ब्यौरा | डिफ़ॉल्ट | मौजूदगी |
---|---|---|---|
name |
नीति का अंदरूनी नाम. इसके अलावा, नीति को लेबल करने के लिए, |
लागू नहीं | ज़रूरी है |
continueOnError |
किसी नीति के काम न करने पर, गड़बड़ी दिखाने के लिए नीति के लागू होने के बाद भी फ़्लो को एक्ज़ीक्यूट करने के लिए, इसे |
गलत | वैकल्पिक |
enabled |
नीति को लागू करने के लिए, नीति को बंद करने के लिए, |
सही | वैकल्पिक |
async |
यह एट्रिब्यूट अब काम नहीं करता. |
गलत | बहिष्कृत |
<DisplayName> एलिमेंट
इस कॉलम में नीति को लेबल करने के लिए, name
एट्रिब्यूट के साथ-साथ इस्तेमाल करें
मैनेजमेंट यूज़र इंटरफ़ेस (यूआई) प्रॉक्सी एडिटर, जिसका नाम अलग और सामान्य भाषा में है.
<DisplayName>Policy Display Name</DisplayName>
डिफ़ॉल्ट |
लागू नहीं अगर आप इस एलिमेंट को छोड़ देते हैं, तो नीति की |
---|---|
मौजूदगी | वैकल्पिक |
टाइप | स्ट्रिंग |
<AccessToken> एलिमेंट
ऐक्सेस टोकन के लिए प्रोफ़ाइल को वापस लाता है. आप कोई ऐसा वैरिएबल पास करते हैं जिसमें ऐक्सेस टोकन स्ट्रिंग या लिटरल टोकन स्ट्रिंग (बहुत कम इस्तेमाल होने वाला केस). इस उदाहरण में, ऐक्सेस टोकन यह किसी अनुरोध में पास किए गए क्वेरी पैरामीटर से मिलता है. <ignoreAccessTokenStatus> का इस्तेमाल करें एलिमेंट शामिल करें.
<AccessToken ref="request.queryparam.access_token"></AccessToken>
डिफ़ॉल्ट: |
request.formparam.access_token (एक x-www-form-urlencoded और अनुरोध में बताया गया हो शरीर) |
मौजूदगी: |
वैकल्पिक |
टाइप: | स्ट्रिंग |
मान्य वैल्यू: |
ऐक्सेस टोकन स्ट्रिंग वाला कोई फ़्लो वैरिएबल या लिटरल स्ट्रिंग. |
<AuthorizationCode> एलिमेंट
ऑथराइज़ेशन कोड के लिए प्रोफ़ाइल को वापस लाता है. आप कोई ऐसा वैरिएबल पास करते हैं जिसमें यह शामिल है ऑथराइज़ेशन कोड स्ट्रिंग या लिटरल टोकन स्ट्रिंग (बहुत कम इस्तेमाल होने वाला केस). इस उदाहरण में, ऑथराइज़ेशन कोड यह किसी अनुरोध में पास किए गए क्वेरी पैरामीटर से मिलता है. इससे भरी गई वैरिएबल की सूची के लिए "फ़्लो वैरिएबल" देखें.
<AuthorizationCode ref="request.queryparam.authorization_code"></AuthorizationCode>
डिफ़ॉल्ट: |
request.formparam.access_token (एक x-www-form-urlencoded और अनुरोध में बताया गया हो शरीर) |
मौजूदगी: |
वैकल्पिक |
टाइप: | स्ट्रिंग |
मान्य वैल्यू: |
ऐसा फ़्लो वैरिएबल जिसमें ऑथराइज़ेशन कोड स्ट्रिंग हो या कोई लिटरल स्ट्रिंग हो. |
<ClientId> एलिमेंट
क्लाइंट आईडी से जुड़ी जानकारी हासिल करता है. इस उदाहरण में, Client-ID को वापस लाया गया है अनुरोध में पास किए गए क्वेरी पैरामीटर से मिलती है. इस कार्रवाई से भरे गए वैरिएबल की सूची के लिए, "फ़्लो वैरिएबल" देखें.
<ClientId ref="request.queryparam.client_id"></ClientId>
डिफ़ॉल्ट: |
request.formparam.access_token (एक x-www-form-urlencoded और अनुरोध में बताया गया हो शरीर) |
मौजूदगी: |
वैकल्पिक |
टाइप: | स्ट्रिंग |
मान्य वैल्यू: | ऐसा फ़्लो वैरिएबल जिसमें ऑथराइज़ेशन कोड स्ट्रिंग हो या कोई लिटरल स्ट्रिंग हो. |
<IgnoreAccessTokenStatus> एलिमेंट
टोकन की समयसीमा खत्म होने या उसे रद्द कर दिए जाने पर भी टोकन की जानकारी दिखाता है. यह एलिमेंट सिर्फ़ इसे ऐक्सेस टोकन के साथ इस्तेमाल किया जा सकता है. रीफ़्रेश टोकन और अनुमति देने जैसी अन्य इकाइयों की जानकारी कोड डिफ़ॉल्ट रूप से, उनकी स्थिति पर ध्यान दिए बिना वापस दिखाए जाते हैं.
<IgnoreAccessTokenStatus>true</IgnoreAccessTokenStatus>
डिफ़ॉल्ट: |
गलत |
मौजूदगी: |
वैकल्पिक |
टाइप: | बूलियन |
मान्य वैल्यू: | सही या गलत |
<RefreshToken> एलिमेंट
रीफ़्रेश टोकन के लिए प्रोफ़ाइल को वापस लाता है. आप कोई ऐसा वैरिएबल पास करते हैं जिसमें रीफ़्रेश टोकन स्ट्रिंग या लिटरल टोकन स्ट्रिंग (बहुत कम इस्तेमाल होने वाला केस). इस उदाहरण में, रीफ़्रेश टोकन यह किसी अनुरोध में पास किए गए क्वेरी पैरामीटर से मिलता है. इससे भरी गई वैरिएबल की सूची के लिए "फ़्लो वैरिएबल" देखें.
<RefreshToken ref="request.queryparam.refresh_token"></RefreshToken>
डिफ़ॉल्ट: |
request.formparam.access_token (एक x-www-form-urlencoded और अनुरोध में बताया गया हो शरीर) |
मौजूदगी: |
वैकल्पिक |
टाइप: | स्ट्रिंग |
मान्य वैल्यू: |
रीफ़्रेश टोकन स्ट्रिंग वाला फ़्लो वैरिएबल या लिटरल स्ट्रिंग. |
फ़्लो वैरिएबल
GetOAuthV2Info नीति इन वैरिएबल को पॉप्युलेट करती है और आम तौर पर इसका इस्तेमाल उन मामलों में किया जाता है, जहां आप को प्रोफ़ाइल डेटा की ज़रूरत है, लेकिन अभी तक अनुमति या पुष्टि नहीं हुई है. .
Client-ID वैरिएबल
ClientId एलिमेंट सेट होने पर, इन वैरिएबल में जानकारी अपने-आप भर जाती है:
oauthv2client.{policy_name}.client_id oauthv2client.{policy_name}.client_secret oauthv2client.{policy_name}.redirection_uris // Note the spelling -- 'redirection_uris' oauthv2client.{policy_name}.developer.email oauthv2client.{policy_name}.developer.app.name oauthv2client.{policy_name}.developer.id oauthv2client.{policy_name}.{developer_app_custom_attribute_name}
टोकन वैरिएबल ऐक्सेस करें
AccessToken एलिमेंट सेट होने पर, इन वैरिएबल में जानकारी अपने-आप भर जाती है:
oauthv2accesstoken.{policy_name}.developer.id oauthv2accesstoken.{policy_name}.developer.app.name oauthv2accesstoken.{policy_name}.developer.app.id oauthv2accesstoken.{policy_name}.developer.email oauthv2accesstoken.{policy_name}.organization_name oauthv2accesstoken.{policy_name}.api_product_list oauthv2accesstoken.{policy_name}.access_token oauthv2accesstoken.{policy_name}.scope oauthv2accesstoken.{policy_name}.expires_in //in seconds oauthv2accesstoken.{policy_name}.status oauthv2accesstoken.{policy_name}.client_id oauthv2accesstoken.{policy_name}.accesstoken.{custom_attribute_name} oauthv2accesstoken.{policy_name}.refresh_token oauthv2accesstoken.{policy_name}.refresh_token_status oauthv2accesstoken.{policy_name}.refresh_token_expires_in //in seconds oauthv2accesstoken.{policy_name}.refresh_count oauthv2accesstoken.{policy_name}.refresh_token_issued_at oauthv2accesstoken.{policy_name}.revoke_reason //Apigee hybrid only with value of REVOKED_BY_APP, REVOKED_BY_ENDUSER, REVOKED_BY_APP_ENDUSER, or TOKEN_REVOKED
ऑथराइज़ेशन कोड वैरिएबल
AuthorizationCode एलिमेंट के सेट होने पर इन वैरिएबल का डेटा जनरेट होता है:
oauthv2authcode.{policy_name}.code oauthv2authcode.{policy_name}.scope oauthv2authcode.{policy_name}.redirect_uri oauthv2authcode.{policy_name}.client_id oauthv2authcode.{policy_name}.{auth_code_custom_attribute_name}
टोकन वैरिएबल रीफ़्रेश करें
RefreshToken एलिमेंट के सेट होने पर, इन वैरिएबल में जानकारी अपने-आप भर जाती है:
oauthv2refreshtoken.{policy_name}.developer.id oauthv2refreshtoken.{policy_name}.developer.app.name oauthv2refreshtoken.{policy_name}.developer.app.id oauthv2refreshtoken.{policy_name}.developer.email oauthv2refreshtoken.{policy_name}.organization_name oauthv2refreshtoken.{policy_name}.api_product_list oauthv2refreshtoken.{policy_name}.access_token oauthv2refreshtoken.{policy_name}.scope oauthv2refreshtoken.{policy_name}.expires_in //in seconds oauthv2refreshtoken.{policy_name}.status oauthv2refreshtoken.{policy_name}.client_id oauthv2refreshtoken.{policy_name}.accesstoken.{custom_attribute_name} oauthv2refreshtoken.{policy_name}.refresh_token oauthv2refreshtoken.{policy_name}.refresh_token_status oauthv2refreshtoken.{policy_name}.refresh_token_expires_in //in seconds oauthv2refreshtoken.{policy_name}.refresh_count oauthv2refreshtoken.{policy_name}.refresh_token_issued_at oauthv2refreshtoken.{policy_name}.revoke_reason //Apigee hybrid only with value of REVOKED_BY_APP, REVOKED_BY_ENDUSER, REVOKED_BY_APP_ENDUSER, or TOKEN_REVOKED
स्कीमा
हर तरह की नीति को एक्सएमएल स्कीमा (.xsd
) से तय किया जाता है. रेफ़रंस के लिए, नीति के स्कीमा
GitHub पर उपलब्ध हैं.
गड़बड़ी का रेफ़रंस
इस सेक्शन में, गड़बड़ी के कोड और गड़बड़ी के मैसेज के बारे में बताया गया है. साथ ही, इन गड़बड़ियों के वैरिएबल के बारे में भी बताया गया है, जो Edge की मदद से सेट किए जाते हैं. यह जानकारी जानना ज़रूरी है कि क्या आप गड़बड़ियों को ठीक करता है. ज़्यादा जानने के लिए, आपके लिए ज़रूरी जानकारी देखें नीति से जुड़ी गड़बड़ियों और हैंडलिंग के बारे में जानकारी गलतियां.
रनटाइम की गड़बड़ियां
नीति के लागू होने पर ये गड़बड़ियां हो सकती हैं. नीचे दिखाए गए गड़बड़ी के नाम स्ट्रिंग हैं
जिन्हें कोई गड़बड़ी होने पर fault.name
वैरिएबल को असाइन किया जाता है. गलती देखें
'वैरिएबल' सेक्शन में जाएं.
गड़बड़ी कोड | एचटीटीपी कोड स्थिति | वजह |
---|---|---|
steps.oauth.v2.access_token_expired |
500 | नीति को भेजे गए ऐक्सेस टोकन की समयसीमा खत्म हो गई है. |
steps.oauth.v2.authorization_code_expired |
500 | नीति को भेजे गए ऑथराइज़ेशन कोड की समयसीमा खत्म हो गई है. |
steps.oauth.v2.invalid_access_token |
500 | नीति को भेजा गया ऐक्सेस टोकन अमान्य है. |
steps.oauth.v2.invalid_client-invalid_client_id |
500 | नीति को भेजा गया क्लाइंट आईडी अमान्य है. |
steps.oauth.v2.invalid_refresh_token |
500 | नीति को भेजा गया रीफ़्रेश टोकन अमान्य है. |
steps.oauth.v2.invalid_request-authorization_code_invalid |
500 | नीति को भेजा गया ऑथराइज़ेशन कोड अमान्य है. |
steps.oauth.v2.InvalidAPICallAsNoApiProductMatchFound |
401 | कृपया देखें यह Apigee कम्यूनिटी पोस्ट पढ़ें. |
steps.oauth.v2.refresh_token_expired |
500 | नीति को भेजे गए रीफ़्रेश टोकन की समयसीमा खत्म हो गई है. |
डिप्लॉयमेंट से जुड़ी गड़बड़ियां
डिप्लॉयमेंट की गड़बड़ियों के बारे में जानकारी के लिए, यूज़र इंटरफ़ेस (यूआई) में रिपोर्ट किया गया मैसेज देखें.
गड़बड़ी के वैरिएबल
ये वैरिएबल तब सेट किए जाते हैं, जब यह नीति रनटाइम के दौरान कोई गड़बड़ी ट्रिगर करती है.
वैरिएबल | कहां | उदाहरण |
---|---|---|
fault.name="fault_name" |
fault_name गड़बड़ी का नाम है, जैसा कि ऊपर रनटाइम में गड़बड़ियां टेबल में बताया गया है. गड़बड़ी का नाम, गड़बड़ी के कोड का आखिरी हिस्सा होता है. | fault.name Matches "IPDeniedAccess" |
oauthV2.policy_name.failed |
policy_name, उपयोगकर्ता की ओर से बताया गया उस नीति का नाम है जिसमें गड़बड़ी हुई है. | oauthV2.GetTokenInfo.failed = true |
oauthV2.policy_name.fault.name |
policy_name, उपयोगकर्ता की ओर से बताया गया उस नीति का नाम है जिसमें गड़बड़ी हुई है. | oauthV2.GetToKenInfo.fault.name = invalid_client-invalid_client_id |
oauthV2.policy_name.fault.cause |
policy_name, उपयोगकर्ता की ओर से बताया गया उस नीति का नाम है जिसमें गड़बड़ी हुई है. | oauthV2.GetTokenInfo.cause = ClientID is Invalid |
गड़बड़ी के रिस्पॉन्स का उदाहरण
{ "fault":{ "faultstring":"ClientId is Invalid", "detail":{ "errorcode":"keymanagement.service.invalid_client-invalid_client_id" } } }
गड़बड़ी के नियम का उदाहरण
<FaultRule name="OAuthV2 Faults"> <Step> <Name>AM-InvalidClientIdResponse</Name> </Step> <Condition>(fault.name = "invalid_client-invalid_client_id")</Condition> </FaultRule>