> ## Documentation Index
> Fetch the complete documentation index at: https://developer.box.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Create a metadata cascade policy

export const MultiRelatedLinks = ({sections = []}) => {
  if (!sections || sections.length === 0) {
    return null;
  }
  return <div className="space-y-8">
      {sections.map((section, index) => <RelatedLinks key={index} title={section.title} items={section.items} />)}
    </div>;
};

export const RelatedLinks = ({title, items = []}) => {
  const getBadgeClass = badge => {
    if (!badge) return "badge-default";
    const badgeType = badge.toLowerCase().replace(/\s+/g, "-");
    return `badge-${badge === "ガイド" ? "guide" : badgeType}`;
  };
  if (!items || items.length === 0) {
    return null;
  }
  return <div className="my-8">
      {}
      <h3 className="text-sm font-bold uppercase tracking-wider mb-4">{title}</h3>

      {}
      <div className="flex flex-col gap-3">
        {items.map((item, index) => <a key={index} href={item.href} className="py-2 px-3 rounded related_link hover:bg-[#f2f2f2] dark:hover:bg-[#111827] flex items-center gap-3 group no-underline hover:no-underline border-b-0">
            {}
            <span className={`px-2 py-1 rounded-full text-xs font-semibold uppercase tracking-wide flex-shrink-0 ${getBadgeClass(item.badge)}`}>
              {item.badge}
            </span>

            {}
            <span className="text-base">{item.label}</span>
          </a>)}
      </div>
    </div>;
};

export const Link = ({href, children, className, ...props}) => {
  const localizedHref = href;
  return <a href={localizedHref} className={className} {...props}>
      {children}
    </a>;
};

When a metadata template has been applied to a folder, a metadata cascade policy
can be created by calling the  <Link href="/reference/post-metadata-cascade-policies">`POST /metadata_cascade_policies`</Link> API
endpoint with the `folder_id` of the folder to apply the policy to, and the
`scope` and `templateKey` of metadata template to.

<CodeGroup>
  ```sh cURL theme={null}
  curl -i -X POST "https://api.box.com/2.0/metadata_cascade_policies" \
       -H "authorization: Bearer <ACCESS_TOKEN>" \
       -H "content-type: application/json" \
       -d '{
         "folder_id": "12321",
         "scope": "enterprise_27335",
         "templateKey": "productInfo"
       }'
  ```

  ```typescript Node/TypeScript v10 theme={null}
  await client.metadataCascadePolicies.createMetadataCascadePolicy({
    folderId: folder.id,
    scope: 'enterprise' as CreateMetadataCascadePolicyRequestBodyScopeField,
    templateKey: templateKey,
  } satisfies CreateMetadataCascadePolicyRequestBody);
  ```

  ```python Python v10 theme={null}
  client.metadata_cascade_policies.create_metadata_cascade_policy(
      folder.id, CreateMetadataCascadePolicyScope.ENTERPRISE, template_key
  )
  ```

  ```csharp .NET v10 theme={null}
  await client.MetadataCascadePolicies.CreateMetadataCascadePolicyAsync(requestBody: new CreateMetadataCascadePolicyRequestBody(folderId: folder.Id, scope: CreateMetadataCascadePolicyRequestBodyScopeField.Enterprise, templateKey: templateKey));
  ```

  ```swift Swift v10 theme={null}
  try await client.metadataCascadePolicies.createMetadataCascadePolicy(requestBody: CreateMetadataCascadePolicyRequestBody(folderId: folder.id, scope: CreateMetadataCascadePolicyRequestBodyScopeField.enterprise, templateKey: templateKey))
  ```

  ```java Java v10 theme={null}
  client.getMetadataCascadePolicies().createMetadataCascadePolicy(new CreateMetadataCascadePolicyRequestBody(folder.getId(), CreateMetadataCascadePolicyRequestBodyScopeField.ENTERPRISE, templateKey))
  ```

  ```py Python v4 theme={null}
  folder = client.folder(folder_id='22222')
  metadata_template = client.metadata_template('enterprise', 'securityClassiciation')

  cascade_policy = folder.cascade_metadata(metadata_template)
  print(f'Folder {cascade_policy.parent.id} has a metadata cascade policy for {cascade_policy.scope} template "{cascade_policy.templateKey}"')
  ```

  ```csharp .NET v6 theme={null}
  BoxMetadataCascadePolicy metadataCascadePolicy = await client.MetadataCascadePolicyManager
      .CreateCascadePolicyAsync("22222", "enterprise_11111", "templateKey");
  ```

  ```js Node v4 theme={null}
  var folderID = '22222';
  client.metadata.createCascadePolicy('enterprise', 'testTemplate', folderID)
   .then(cascadePolicy => {
    /* cascadePolicy -> {
     id: '84113349-794d-445c-b93c-d8481b223434',
     type: 'metadata_cascade_policy',
     owner_enterprise: {
      type: 'enterprise',
      id: '11111'
     },
     parent: {
      type: 'folder',
      id: '22222'
     },
     scope: 'enterprise_11111',
     templateKey: 'testTemplate'
    }
    */
   });
  ```
</CodeGroup>

<Info>
  To get the `scope` and `templateKey` for a template, either
  <Link href="/guides/metadata/templates/list">list all metadata templates</Link>, or
  <Link href="/guides/metadata/instances/list">list all instances on an file</Link>.
</Info>

<Warning>
  A cascade policy can only be created if a metadata instance has already been
  applied to the folder with the given `scope` and `templateKey`.
</Warning>

<RelatedLinks
  title="RELATED APIS"
  items={[
{ label: translate("Create metadata cascade policy"), href: "/reference/post-metadata-cascade-policies", badge: "POST" }
]}
/>

<RelatedLinks
  title="RELATED GUIDES"
  items={[
{ label: translate("List metadata cascade policies"), href: "/guides/metadata/cascades/list", badge: "GUIDE" },
{ label: translate("Force-apply metadata to all items in a folder"), href: "/guides/metadata/cascades/force-apply", badge: "GUIDE" },
{ label: translate("Delete a metadata cascade policy"), href: "/guides/metadata/cascades/delete", badge: "GUIDE" }
]}
/>
