Create resources
You create resources by using methods of controllers. Each controller type allows you to create specific resources for its type of model.
The following list shows the existing controllers and the resources that you can create by using them:
- ContentModelController. This allows you to create resources of the following types:
- ContentPage
- ContentLabel
- The following two types of content URL:
- ExternalContentURL
- InternalContentURL
- LayoutModelController. This allows you to create resources of the following types:
- LayoutContainer
- LayoutControl
- PortletModelController. This allows you to create resources of the following types:
- PortletDefinition
- PortletEntity
To create a resource...
- Optional: Obtain a creation context. To do this, take the following two steps:
- Obtain the creation context builder factory. For details about how to do this refer to Obtaining creation contexts.
- Obtain a creation context from the creation context builder.
For details about how to do this refer to Obtaining creation contexts.
- Obtain a controller.
- Create a resource. To do this, use the create(Class, CreationContext) method of the controller and provide both arguments.
Notes:
- The created resource is not part of the topology, unless you insert it into the topology by using the insert() method of the controller.
- For content nodes, that is content pages, content labels, and content URLs, set a supported markup. Otherwise they will not show in the read-only model.
Example 1 - Creating a resource by using the creation context builder:
This example creates a new ContentPage that you can later insert into the content model.
// obtain creation context builder final CreationContextBuilderFactory builder = CreationContextBuilderFactory.getInstance(); // obtain creation context final CreationContext creationContext = builder.newIdentifiableCreationContext(objectID); // create resource (which is not yet part of the topology of the controller!) final Modifiable modifiable = controller.create(ContentPage.class, creationContext);Example 2 - Cloning an existing portlet definition:To clone an existing portlet definition, create a portlet definition by using a portlet model controller and specify a PortletDefinitionCloningContext.
// obtain portlet definition cloning context; includes obtaining a portlet definition final PortletDefinitionCloningContext context = ... (portletDefinition) // create portlet definition pmController.create(PortletDefinition.class, context);The result of the create() method is a Modifiable instance of the created resource that you can cast to the type of the created resource as shown in the following example. Example 3 - Casting a created resource to its type:
final ModifiableContentPage modifiableContentPage = (ModifiableContentPage) controller.create(ContentPage.class, creationContext);
- Obtaining creation contexts
You need a creation context to define immutable properties of a resource that you create. You can use the creation context builder factory to generate multiple such creation contexts without having to implement those interfaces directly.
Parent topic:
Modifying portal resources and topologies
Related tasks
Move or Inserting Nodes
Deleting Nodes