Rethinking UX: how Opus Guard built AI-assisted Data Governance with Rovo and Forge
This article is a guest post by Opus Guard, an Atlassian Marketplace Partner
The rise of AI, especially large language models (LLMs), has transformed how organizations analyze and manage textual content. LLMs can efficiently process vast amounts of information: enabling users to extract insights, summarize content, and generate new ideas. This is particularly valuable in environments overwhelmed by information, where streamlined content management and better decision-making are essential.
Opus Guard is an information governance company. We developed Content Retention Manager for Confluence to help customers keep what they need and remove what they don’t in Confluence. Well-managed retention is the foundation of reliable trustworthy AI: clean compliant content in, equals better answers out. A key challenge in retention management is accurately classifying content and determining the appropriate retention policy. Manual classification is often daunting for users due to:
- Scale: The volume of content requiring classification is vast and continually growing.
- Expertise: Domain knowledge is often needed to analyze content and assign the right classification.
- Security and compliance: Content may be sensitive, especially for customers in regulated sectors with strict security and compliance requirements.
Addressing the challenge using Rovo and Forge
With the Rovo agent and Rovo Action module now available on Forge, we have the ideal tools and an exciting opportunity to address content classification at scale:
- Scale: Rovo can run LLMs at lightning speed, efficiently and cost-effectively.
- Expertise: LLMs possess extensive knowledge and can summarize and infer information comparable to subject matter experts.
- Security and compliance: Rovo agents and actions are hosted entirely on Atlassian Cloud with a defined permissions and governance model. Content data remains within Atlassian Cloud and is never accessible to app vendors, including Opus Guard.
The Content Classification Agent is a Forge Rovo Agent module of the Content Retention Manager for Confluence app, available on the Atlassian Marketplace. Accessible from Rovo Chat, it provides effective content analysis to determine appropriate classification levels for your Confluence content. The agent leverages LLMs to evaluate pages and blog posts, analyzing factors such as keywords, context, and information sensitivity. Importantly, users retain full control: the agent accesses data only when requested and makes changes only after user confirmation.
This post outlines our experience building with Rovo Agent and Rovo Actions to create a new, AI-assisted data governance experience.
The new user experience with Rovo Chat
Rovo Chat is available within several Atlassian apps, including Confluence, allowing users to get assistance without disrupting their workflow. From Rovo Chat, users can start a conversation with the Content Classification Agent.
When a user requests a classification level for their content, the agent retrieves the defined classification levels and content via pre-defined Rovo Actions, which also come with Content Retention Manager for Confluence, then analyzes the content to determine the appropriate classification. This analysis clarifies the content’s nature, which is essential for compliance and security. For example, if the content contains sensitive or proprietary information, the agent will recommend a higher classification level.
The recommendation feature enables users to classify their content effectively. Based on the analysis, the agent provides tailored suggestions that align with organizational policies, ensuring users understand their options and the implications of each level. Users can easily apply recommended classifications within the Confluence interface, promoting efficient and compliant content management.

Building the Content Classification Agent and Actions
The Content Classification Agent is implemented as a Rovo Agent module in the Forge app manifest:
  rovo:agent:
    - key: retention-agent
      name: "Content Classification Agent"
      description: Assists in managing and applying content classification levels within the Content Retention Manager by Opus Guard.
      icon: resource:static;icons/app.png
      prompt: resource:agent-resources;prompt.txt
      conversationStarters:
        - What classification levels are available?
        - Can you suggest a classification level for the content?
        - Can you show me the classification level for the content?
      actions:
        - fetch-content
        - fetch-classification-levels
        - fetch-content-classification-level
        - set-content-classification-level
Key properties
- key: Unique identifier for the agent in the manifest.
- name: Display name in Rovo Chat.
- description: Tagline for the agent in Rovo Chat.
- prompt: The prompt provided to LLMs, defining workflows for classification tasks. (In this example, a static resource file prompt.txt is used, but it can also be provided inline.)
- conversationStarters: Initial prompts shown to users when starting a new conversation. These should align with workflows defined in the prompt.
- actions: List of keys referencing actions defined in the manifest that the agent can perform.
Summary of actions
The manifest defines actions for specific tasks, implemented as Forge functions and referenced by the agent. Below is a summary of the actions available from Content Retention Manager.
| Action Key | Name | Verb | Description | 
| fetch-content | Fetch content body | GET | Retrieves the full content body of a Confluence page or blog post. | 
| fetch-classification-levels | Fetch all classification levels | GET | Retrieves all available classification levels configured in the app. | 
| fetch-content-classification-level | Fetch content classification level | GET | Retrieves the current classification level assigned to a specific content item. | 
| set-content-classification-level | Set content classification level | UPDATE | Updates the classification level for a specific content item. | 
Prompt, prompt, it’s always the prompt
The prompt provided to the LLM in the Forge manifest is crucial for shaping user interactions with the agent. Similar to traditional UI/UX design, it allows developers to control the user experience. The Forge Guided Tutorial, Build a Q&A Rovo Agent for Confluence, outlines essential elements for creating an effective prompt. Presented below are our findings and recommendations for the development of effective prompts.The full text of the prompt is available shared in a public Github Gist.
A Workflow section provides a high-level framework for the agent’s interactions with users.
---- 
WORKFLOW 
1. The agent greets the user, identifies itself as "Content Classification Agent", and gives a summary of what it can do. 2. Accept a request to: a. View available classification levels b. View the current classification of content c. Set a classification level for content d. Get suggestion for appropriate classification level 3. Depending on the request: a. For viewing levels: Perform the 'Fetch all classification levels' job b. For viewing content classification: Perform the 'Fetch content classification level' job c. For setting classification: Perform the 'Select and set classification level' job d. For suggestions: Perform the 'Fetch content and suggest classification' job 4. Format and present the response based on the specific job's response formatThe tasks in the Workflow are divided into Jobs, each detailing the steps to complete a specific task. This approach simplifies the agent’s process by providing clear, actionable steps. Rovo actions are referenced in the job steps, specifying the parameters to pass.
---- 
JOBS 
--- 
Fetch all classification levels 
Steps: 1. Fetch all available classification levels using the 'fetch-classification-levels' action. 2. If the response is a string (error message), return it to the user. 3. If the response is an object containing classification levels, format it using the CLASSIFICATION_LEVELS_FORMAT template. 4. Return the formatted classification levels to the user.In job definitions, a referenced Template outlines the responses agents should complete before presenting them to users. The templates ensure consistent agent responses.
---- 
TEMPLATES 
--- 
CLASSIFICATION_LEVELS_FORMAT 
```markdown 
## Available Classification Levels Here are the classification levels configured in Content Retention Manager: [Classification levels in a table with columns for Name, Description, and Color; use a circle in the color in the Color column] [A summary of how the classification levels may be used in different circumstance for security and compliance purpose] Would you like me to explain how one or more of these classification levels should be used to ensure security and compliance? ```An additional section provides explicit instructions on parsing results from each Rovo Action:
---- 
RESPONSE HANDLING 
--- 
FETCH_CLASSIFICATION_LEVELS_RESPONSE 
When handling responses from the 'fetch-classification-levels' action: 1. If the response is a string, it indicates an error occurred. Present it to the user. 2. Otherwise, the response is an object where each key is a classification level ID and the value contains: - name: The display name of the classification level - description: A description of what the classification level means - color: A color associated with the level 3. Format the levels as a numbered list with name, description, and a circle in the color of the level.The screenshot below demonstrates how the Template and the Response handling helped customize the presentation of the classification levels retrieved from the fetch-classification-levels action:

fetch-classification-levels action, customized by template and response handling prompt.Studio Rovo Agents vs. Marketplace Agents
Any Confluence user with Rovo access can create a Rovo agent from Studio. Agents created in Studio include built-in plugins for accessing knowledge, such as reading Confluence content.
A Rovo Agent built as a Forge module (also known as Marketplace Agents) lacks these built-in plugins, making it a “bare-bones” LLM out of the box. To access knowledge, the agent must call a Rovo action to retrieve content.
Developers should consider this, particularly when fine-tuning prompts. While iterating from the Studio is beneficial, prompts may not function the same way for Forge Rovo Agents. Specific instructions for retrieving knowledge must be included in the prompt.
Security considerations of Rovo Actions
Rovo Actions are Forge resolver functions. Like other resolver functions, they involve a shared responsibility between the app developer and Atlassian to ensure proper authorization for the operations performed.
When Rovo calls the function, the context includes a principal.accountId property that identifies the user for whom the Rovo action is executed. The function should verify that this user has the necessary permissions to perform the operation. It is recommended to use Forge’s asUser() when calling Atlassian product APIs, ensuring the user’s identity is passed for authorization.
Conclusion
Rovo Agent and Rovo Actions allow Forge developers to utilize Atlassian’s AI platform and present Forge app functionalities to users in innovative ways. While LLMs excel with textual content, they are inherently non-deterministic. Rovo agents show strong usability through Rovo Chat but will likely need human oversight to verify results in the near future. Developers must innovate to ensure these agents become reliable assistants and identify areas where they can deliver effective and predictable outcomes.
Both Rovo Agent and Rovo Actions function within Atlassian, enabling developers to harness AI while maintaining data security within Atlassian Cloud. Marketplace Partners can establish the same level of trust with customers as they do with Atlassian Cloud. This is a key advantage of building on Rovo, especially compared to deploying LLMs elsewhere. Continuous monitoring and enhancement of security measures to safeguard customer content and data throughout the AI stack should be a priority for both Atlassian and Marketplace Partners. Sharing best practices within the Atlassian Ecosystem could accelerate the collective knowledge of the developer community. We hope this post contributes to that goal.
As a Marketplace Partner utilizing Forge, we are eager to develop new features that unlock additional use cases with Rovo Agent and Rovo Actions.
 
					