The Octopus Extension for GitHub Copilot brings real-time information and control over your builds and deployments into your Copilot chat. This keeps developers in the flow by allowing them to complete their entire CI/CD workflow without leaving their IDE.
The extension queries the state of your Octopus server, combines GitHub issues and Git diffs captured in build information, and passes the information to a GPT-4o LLM to summarize your deployments and provide assistance.
The extension also interacts directly with the Octopus API to create releases, deploy releases, and run runbooks.
This allows you to:
- View the state of your GitHub Actions workflows - Show the github workflow summary
- View the state of your environments - Show the dashboard
- Create and deploy releases - Create a release in the project "Audits" in the space "Payments" and deploy to the "Development" environment
- Execute runbooks - Run the runbook "Restart web app" in the project "Audits" in the space "Payments" in the "Production" environment
- Explain what projects do - What do the steps in the project "Audits" in the space "Payments" do?
- Inspect projects for common misconfigurations - Find usused variables in the project "Audits" in the space "Payments"
- Provide help on failed deployments - Help me fix release "1.2.3" of the "Audits" project to the "Production" environment
- Generate customized reports - Given release "1.2.3" of project "Audits" to the "Production" environment, provide a one sentence summary of the Git Diff for each file changed as part of the release.
To get started with the extension, enter the prompt hi to receive a list of available commands.
View the documentation here.
View the Wiki for a guide on prompt engineering with this agent.
This agent requires an account to interact with Octopus. This is best done with a service account.
To limit the agent's access, it is recommended that you create a team and role that has only read access to Octopus.
A sample Terraform configuration file has been provided to create a read-only service account, team, and role.
Save the file team.tf locally and apply it with the following commands (replacing the variables with your own values):
terraform init
terraform apply -var=octopus_server=https://yourinstance.octopus.app -var=octopus_api_key=API-XXXXXXXX -var=octopus_space_id=Spaces-xThis creates a service account, team, and user role called Copilot. The role includes permissions to view Octopus
resources, but not to modify them.
The primary interface for this agent is via the GitHub Copilot chat. This requires individual users to be invited to the private beta.
We have a test web site that responds to the same queries as the chat interface. The web based interface is functionally equivalent to the Copilot chat interface in terms of interacting with an Octopus server.
This project is organized using the structure described in Design a DDD-oriented microservice. It is not a strict implementation of the patterns described in that post, but follows it as closely as possible.
The application layer is found in the root of the project. These files expose the public surface area of the application, be it a CLI interface or a web API.
The domain layer is found in the domain directory. This includes all the business logic.
The infrastructure layer is found in the infrastructure directory. This includes all the external integrations with
databases, logging platforms, and external APIs.
Tests are found in the tests directory.
The most public way to contribute to this project is to build new "tools" (a fancy way of saying functions) that OpenAI can use. To do this:
- Create a new wrapper function in domain/tools/wrapper. Make sure the wrapper returns a function that includes the appropriate comments that OpenAI can read to understand the purpose of the function and the arguments.
- Create a new callback function in domain/tools/githubactions. This
- Add the function to the set of tools in the build_form_tools()function infunction_app.py.
- Typically, any new function requires calling the Octopus API. Functions for querying the Octopus API are defined in
the infrastructure/octopus.pyfile.
- Update the Terraform module in the tests/terraform/space_populationfolder to create a sample space which has the data your new function will query. This Terraform module is used to populate a sample Octopus instance used as part of the tests.
- Create a new test case un tests/live/octopus_test.py. This test class has been configured to create a fresh instance of Octopus using TestContainers populated with the Terraform module created in step 4.
You can also optionally create a new tool and update the build_tools() function in the main.py file. The CLI
interface is mostly used for quick testing and is not expected to maintain a complete selection of tools. It is also
used to demonstrate how this application can be extended beyond platforms like Copilot.
To run the command line you need to set the following environment variables:
- OCTOPUS_CLI_API_KEY- An Octopus API key
- OCTOPUS_CLI_SERVER- The URL of the Octopus server
- OPENAI_API_KEY- The key to access OpenAI
- OPENAI_ENDPOINT- The OpenAI endpoint
You can then run the CLI with the following command:
python3 main.py --query "Show the projects from the Documentation space"Octonaughts can see the Octopus Copilot OpenAI secure note in the password manager for the Open AI key and endpoint.
Consider using the Black code formatter to ensure consistent code style.
The testing is broken down into 3 categories:
- Unit tests, mostly under tests/domain
- Infrastructure integration tests that:
- Validate the ability to call an octopus server initialized with Test Containers in
the tests/infrastructure/octopus_infrastructure_test.pyfile
- Validate the ability to call the Azure Open AI service in the tests/infrastructure/openai_infrastructure_test.pyfile
- Validate the ability to call the Azure Storage Service in
the tests/infrastructure/azure_storage_infrastructure_test.pyfile
 
- Validate the ability to call an octopus server initialized with Test Containers in
the 
- End-to-end tests that validate the ability to call web endpoints exposed by the Azure Functions app in the
tests/applicationdirectory. These tests are split across multiple files to allow CI systems to run them in parallel.
To support on-prem installations, all network requests from this service and other supporting services can be routed through the Azure Router Function. This provides a single IP address for all connections to an Octopus instance, making it easier to configure firewalls and security groups.
To simulate working on a restricted network, do the following:
- Create an IP Policy in NGROK to allow your home IP address and 51.8.40.170, which is the IP address of the Azure Router Function.
- Start a local instance of Octopus.
- Create a policy file policy.ymlwith the following content, replacingipp_2yF83XsF1CQ8YjXHq9VQQztByU2with your IP policy ID:
on_tcp_connect:
  - actions:
      - type: restrict-ips
        config:
          enforce: true
          ip_policies:
            - ipp_2yF83XsF1CQ8YjXHq9VQQztByU2- Open an NGROK tunnel using the IP filter: ngrok http --url=yourhostnames.ngrok.dev --traffic-policy-file policy.yml 8083
- Traffic to yourhostnames.ngrok.devwill only work from your home IP address and the Azure Router Function IP address. All connections from the AI platform must automatically route through the Azure Router Function, meaning all traffic will appear to come from the Azure Router Function IP address.
