Setup
Prerequisites
Before you begin, ensure you have the following installed on your system:
Developer Setup
This guide will walk you through setting up a complete development environment, including Maestro and its complementary services.
Setting up supporting services
We'll use our Conductor service, a flexible Docker Compose setup, to spin up Maestro's complementary services.
- 
Clone the Conductor repository and move into its directory: git clone https://github.com/overture-stack/conductor.git
 cd conductor
- 
Run the appropriate start command for your operating system: Operating System Command Unix/macOS make maestroDevWindows ./make.bat maestroDevClick here for a detailed breakdownThis command will set up all complementary services for Maestro development as follows: Service Port Description Purpose in Score Development Conductor 9204Orchestrates deployments and environment setups Manages the overall development environment Keycloak-db - Database for Keycloak (no exposed port) Stores Keycloak data for authentication Keycloak 8180Authorization and authentication service Provides OAuth2 authentication for Score Song-db 5433Database for Song Stores metadata managed by Song Song 8080Metadata management service Manages metadata for files stored by Score Kafka 9092Distributed event streaming platform Serves as a messaging queue for publication events used to trigger indexing Elasticsearch 9200Distributed search and analytics engine Provides fast and scalable search capabilities over indexed data - Ensure these ports are free on your system before starting the environment.
- You may need to adjust the ports in the docker-compose.ymlfile if you have conflicts with existing services.
 For more information, see our Conductor documentation linked here 
Running the Development Server
- 
Clone Maestro and move into its directory: git clone https://github.com/overture-stack/maestro.git
 cd maestro
- 
Build the application locally: ./mvnw clean install -DskipTestsClick here for an explaination of command above- ./mvnw: This is the Maven wrapper script, which ensures you're using the correct version of Maven.
- clean: This removes any previously compiled files.
- install: This compiles the project, runs tests, and installs the package into your local Maven repository.
- -DskipTests: This flag skips running tests during the build process to speed things up.
 tipEnsure you are running JDK11. To check, you can run java --version. You should see something similar to the following:openjdk version "11.0.18" 2023-01-17 LTS
 OpenJDK Runtime Environment Corretto-11.0.18.10.1 (build 11.0.18+10-LTS)
 OpenJDK 64-Bit Server VM Corretto-11.0.18.10.1 (build 11.0.18+10-LTS, mixed mode)
- 
Start the Maestro Server: ./mvnw spring-boot:run -pl maestro-appinfoIf you are looking to configure Maestro for your specific environment, Maestro's configuration file can be found here. 
Verification
After installing and configuring Score, verify that the system is functioning correctly:
- 
Check Server Health curl -s -o /dev/null -w "%{http_code}" "http://localhost:8087/download/ping"- Expected result: Status code 200
- Troubleshooting:
- Ensure Score server is running
- Check you're using the correct port (default is 8087)
- Verify no firewall issues are blocking the connection
 
 
- Expected result: Status code 
- 
Check the Swagger UI - Navigate to http://localhost:8087/swagger-ui.htmlin a web browser
- Expected result: Swagger UI page with a list of available API endpoints
- Troubleshooting:
- Check browser console for error messages
- Verify you're using the correct URL
 
 
- Navigate to 
If you encounter any issues or have questions about our API, please don't hesitate to reach out through our relevant community support channels.
This guide is meant to demonstrate the configuration and usage of Score for development purposes and is not intended for production. If you ignore this warning and use this in any public or production environment, please remember to use Spring profiles accordingly. For production do not use dev profile.