Options

The mod publish plugin has a number of common options that are shared between all platforms.

publishMods {
    // Set the main file to be uploaded
    file = jar.archiveFile
 
    // Or set the main file to be uploaded from another sub project
    file project(":subproject")
 
    // Markdown changelog
    changelog = "Example changelog"
 
    // Defaults to the Gradle project version
    version = "1.0.0"
 
    // Specify the release type
    type = STABLE
    type = BETA
    type = ALPHA
 
    // The display name/release title, this defaults to the Gradle project name + version
    displayName = "My Mod"
 
    // Set the display name to match the file name
    displayName = file.map { it.asFile.name }
 
    // A list of mod loaders the release supports
    modLoaders.add("fabric")
 
    // A ConfigurableFileCollection of addional files that are uploaded alongside the main file
    additionalFiles.from(jar.archiveFile)
 
    // The max number of times to retry on server error, defaults to 3.
    maxRetries = 5
 
    // When dry run is enabled the release assets will be saved to the build directory for testing.
    dryRun = true
    // You can always enable it when one of your API keys is not present.
    dryRun = providers.environmentVariable("API_KEY").getOrNull() == null
}

Each platform inherits the above common options, and can all be individually configured. For example if you want to use a different file just for Github you could do the following:

publishMods {
    // Default file
    file = jar.archiveFile
 
    github {
        // The githubJar is only used by the github publish task.
        file = githubJar.archiveFile
    }
 
    curseforge {
        // Default file used
    }
 
    modrinth {
        // Default file used
    }
}