Develop with Content Agent
How to use Content Agent functionality in your plugin
Last updated
How to use Content Agent functionality in your plugin
Last updated
Content Agent gives you methods to use in your plugin such as opencontent
to be able to do search/suggest requests from OpenContent by passing your search query for example!
Content Agent register it's own methods with Dashboard Actions
You can use any of these actions in your plugin.
opencontent:
search - promise request.
request - promise request
suggest - promise request
querystreamer
activeStreams
createStream
deleteStream
infocaster
activeSubscriptions
broadcast
subscribe
unsubscribe
cca
Tools
ConvertToNewsml
ConvertToDocument
Files
GetStatus
GetArtifact
GetDownloadStatus
CreateUpload
CreateDownload
NewsML
GetNewsMLDocument
WriteNewsMLDocument
DeleteNewsMLDocument
NewsMLDocumentExists
Documents
GetDocument
WriteDocument
DeleteDocument
DocumentExists
In your plugin you can import getAction from Plugin, so you can "import" Content Agent actions to your plugin.
Here we used com.naviga.content-agent:getInstance
action to get and initiate our CA instance, and listening on CA status changes with onStatusChange
To access Open Content you call CA.opencontent()
with the name of content provider you want to use (from config).
Access to search
and suggest
is simplified by two helper functions, but any OC REST API endpoint can be reached using the request
function. The functions returns promises.
Open Content API Documentation can be found at url-to-open-content-server:8080/opencontent/apidocs/
search, suggest and request actions works the same as accessing them from CA.opencontent
by passing the provider as first argument and the request params as a second argument
To handle streams in QueryStreamer you call CA.querystreamer()
with the name of content provider you want to use (from config).
createStream and deleteStream is enabled on this instance.
QueryStreamer API Documentation
ElasticSearch Query Format Documentation
When calling create stream, pass a request object and a callback function as parameters. This will return a promise that resolves with a stream ID. New events will land in the callback function you provided.
When a stream is no longer needed, delete it.
Please don't forget call deleteStream(streamId)
If you are creating a stream in a class component you can delete the stream when your component unmounted with componentWillUnmount
.
If you are creating a stream in a hook component you can delete the stream when your component unmounted with returning a function with useEffect
If you are creating a stream in the Agent you can delete the stream when your Agent close with close
You can handle events easily with querystreamer by passing qsInstance to QueryEventWrapper
In order to communicate with the Content Creation API you'll need to have added the baseUrl to the cca part in the configuration as well as added valid client credentials.
When this is done you're free to utilise the Content Creation API and the different endpoints, which you can read more about here.
ID
Descriptions
com.naviga.content-agent:getProviders
An action to return all available provider names (from config)
com.naviga.content-agent:getInstance
An action returns the instance of content agent with Opencontent, Querystreamer, Infocaster and CCA methods.