Class IContentRepositoryExtension
Extends IContentRepository with some convinent methods.
Inheritance
Inherited Members
Namespace: EPiServer
Assembly: EPiServer.dll
Version: 7.19.2Syntax
public static class IContentRepositoryExtension
Methods
Copy(IContentRepository, ContentReference, ContentReference)
Creates a copy of a content object and it's eventual children and adds the new content under the specified destination first ensuring that the current user has read access to the source and create access on the destination.
Declaration
public static ContentReference Copy(this IContentRepository contentRepository, ContentReference source, ContentReference destination)
Parameters
Type | Name | Description |
---|---|---|
IContentRepository | contentRepository | The IContentRepository instance to extend. |
ContentReference | source | The content that should be copied. |
ContentReference | destination | The destination where the page will be copied as a child to. |
Returns
Type | Description |
---|---|
ContentReference | A reference to the new copy of the content. |
Remarks
If the user has publishing rights on the destination the new content will be published immediately.
CreateLanguageBranch<T>(IContentRepository, ContentReference, ILanguageSelector)
Creates a new language branch for a content item in the specified language first ensuring that the current user meets the minimal access right requirements.
Declaration
public static T CreateLanguageBranch<T>(this IContentRepository contentRepository, ContentReference contentLink, ILanguageSelector languageSelector)
where T : IContentData
Parameters
Type | Name | Description |
---|---|---|
IContentRepository | contentRepository | The content repository. |
ContentReference | contentLink | The link to the content to create a language branch for. |
ILanguageSelector | languageSelector | The selector. |
Returns
Type | Description |
---|---|
T | An IContent object for the newly created content in the specified language. |
Type Parameters
Name | Description |
---|---|
T | The type of content to create. |
Delete(IContentRepository, ContentReference, Boolean)
Deletes a content from the repository first ensuring that the current user meets the minimal access right requirements.
Declaration
public static void Delete(this IContentRepository repository, ContentReference contentLink, bool forceDelete)
Parameters
Type | Name | Description |
---|---|---|
IContentRepository | repository | The repository. |
ContentReference | contentLink | The content link. |
System.Boolean | forceDelete | If set to |
GetDefault<T>(IContentRepository, ContentReference, Int32)
Gets a new default instance of an IContentData object for the given type, placed at the location of the parent provided and initialized with the default values for the content type. The language of the content item is determined from the language selector provided.
Declaration
public static T GetDefault<T>(this IContentRepository contentRepository, ContentReference parentLink, int contentTypeID)
where T : IContentData
Parameters
Type | Name | Description |
---|---|---|
IContentRepository | contentRepository | The content repository. |
ContentReference | parentLink | The parent link. |
System.Int32 | contentTypeID | The ID of the content type that the content item should be created as. |
Returns
Type | Description |
---|---|
T | A IContent object for the given ContentType, initialized with the default values for the content type. |
Type Parameters
Name | Description |
---|---|
T | The type of content to create. |
Exceptions
Type | Condition |
---|---|
AccessDeniedException | Thrown AccessDeniedException when user doesnt have access right to perform this action |
Move(IContentRepository, ContentReference, ContentReference)
Moves content from it's current location to another position in the structure first ensuring that the current user has the minimal access rights required at the destination.
Declaration
public static ContentReference Move(this IContentRepository contentRepository, ContentReference contentLink, ContentReference destination)
Parameters
Type | Name | Description |
---|---|---|
IContentRepository | contentRepository | The IContentRepository instance to extend. |
ContentReference | contentLink | The content that should be moved. |
ContentReference | destination | The destination where the content will be moved as a child to. |
Returns
Type | Description |
---|---|
ContentReference | A ContentReference to the moved content. |
Remarks
The user will always need at least Create access at the destination and if the page is published the user will Publish access as well unless the destination is the wastebasket.
MoveToWastebasket(IContentRepository, ContentReference)
Moves content from it's current location to Wastebasket position in the structure with the current user name
Declaration
public static void MoveToWastebasket(this IContentRepository contentRepository, ContentReference contentLink)
Parameters
Type | Name | Description |
---|---|---|
IContentRepository | contentRepository | The content repository. |
ContentReference | contentLink | The content link. |
Save(IContentRepository, IContent, SaveAction)
Saves a content to the repository with the provided save action performed first ensuring that the current user meets the mininum access rights requirements.
Declaration
public static ContentReference Save(this IContentRepository repository, IContent content, SaveAction action)
Parameters
Type | Name | Description |
---|---|---|
IContentRepository | repository | The IContentRepository instance to extend. |
IContent | content | An IContent object containing all the data that should be saved. |
SaveAction | action | The exact SaveAction that should be performed. |
Returns
Type | Description |
---|---|
ContentReference | A ContentReference to the saved content. |
Remarks
The minimum access rights required is dependent on if the content is new and
the exact action
that should be performed.