CloudServicesConfig (cloud-services)
@ckeditor/ckeditor5-cloud-services/src/cloudservices
The configuration for all plugins using CKEditor Cloud Services.
ClassicEditor
.create( document.querySelector( '#editor' ), {
cloudServices: {
tokenUrl: 'https://example.com/cs-token-endpoint',
uploadUrl: 'https://your-organization-id.cke-cs.com/easyimage/upload/'
}
} )
.then( ... )
.catch( ... );
See all editor options.
Filtering
Properties
-
bundleVersion : String
module:cloud-services/cloudservices~CloudServicesConfig#bundleVersion
An optional parameter used for integration with CKEditor Cloud Services when uploading the editor build to cloud services.
Whenever the editor build or the configuration changes, this parameter should be set to a new, unique value to differentiate the new bundle (build + configuration) from the old ones.
-
tokenUrl : String | function
module:cloud-services/cloudservices~CloudServicesConfig#tokenUrl
A token URL or a token request function.
As a string, it should be a URL to the security token endpoint in your application. The role of this endpoint is to securely authorize the end users of your application to use CKEditor Cloud Services only if they should have access e.g. to upload files with Easy Image or to use the Collaboration service.
ClassicEditor .create( document.querySelector( '#editor' ), { cloudServices: { tokenUrl: 'https://example.com/cs-token-endpoint', ... } } ) .then( ... ) .catch( ... );
As a function, it should provide a promise to the token value, so you can highly customize the token and provide your token URL endpoint. By using this approach you can set your own headers for the request.
ClassicEditor .create( document.querySelector( '#editor' ), { cloudServices: { tokenUrl: () => new Promise( ( resolve, reject ) => { const xhr = new XMLHttpRequest(); xhr.open( 'GET', 'https://example.com/cs-token-endpoint' ); xhr.addEventListener( 'load', () => { const statusCode = xhr.status; const xhrResponse = xhr.response; if ( statusCode < 200 || statusCode > 299 ) { return reject( new Error( 'Cannot download new token!' ) ); } return resolve( xhrResponse ); } ); xhr.addEventListener( 'error', () => reject( new Error( 'Network Error' ) ) ); xhr.addEventListener( 'abort', () => reject( new Error( 'Abort' ) ) ); xhr.setRequestHeader( customHeader, customValue ); xhr.send(); } ), ... } } )
You can find more information about token endpoints in the Cloud Services - Quick start and Cloud Services - Token endpoint documentation.
Without a properly working token endpoint (token URL) CKEditor plugins will not be able to connect to CKEditor Cloud Services.
-
uploadUrl : String
module:cloud-services/cloudservices~CloudServicesConfig#uploadUrl
The endpoint URL for CKEditor Cloud Services uploads. This option must be set for Easy Image to work correctly.
The upload URL is unique for each customer and can be found in the CKEditor Ecosystem customer dashboard after subscribing to the Easy Image service. To learn how to start using Easy Image, check the Easy Image - Quick start documentation.
Note: Make sure to also set the
tokenUrl
configuration option. -
webSocketUrl : String
module:cloud-services/cloudservices~CloudServicesConfig#webSocketUrl
The URL for web socket communication, used by the
RealTimeCollaborativeEditing
plugin. Every customer (organization in the CKEditor Ecosystem dashboard) has their own, unique URLs to communicate with CKEditor Cloud Services. The URL can be found in the CKEditor Ecosystem customer dashboard.Note: Unlike most plugins,
RealTimeCollaborativeEditing
is not included in any CKEditor 5 build and needs to be installed manually. Check Collaboration overview for more details.
Every day, we work hard to keep our documentation complete. Have you spotted an outdated information? Is something missing? Please report it via our issue tracker.