changeset 322:7ca1fbf8636a

Add new artifactory*.gradle that removes the credentials. Update the init*-git.gradle to use this new script. The script will require a parameters in bamboo but will allow us to remove the gradlekit project.
author Marc Davis <davis@ssdt-ohio.org>
date Thu, 09 Feb 2023 13:53:42 -0500 (23 months ago)
parents 6c62c55b613f
children af7191641c3b
files artifactory.gradle artifactory20.gradle artifactory40.gradle artifactory70.gradle init20-git.gradle init40-git.gradle init40pom.gradle init50-git.gradle init70-git.gradle
diffstat 9 files changed, 224 insertions(+), 854 deletions(-) [+]
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/artifactory.gradle	Thu Feb 09 13:53:42 2023 -0500
@@ -0,0 +1,52 @@
+
+logger.info("applying SSDT bamboo/artifactory Gradle Settings")
+
+buildscript {
+    repositories {
+        maven { url 'https://docker.ssdt.io/artifactory/gradle-plugins' }
+    }
+    dependencies {
+        classpath(group: 'org.jfrog.buildinfo', name: 'build-info-extractor-gradle', version: '2.1.0')
+    }
+}
+
+apply {
+    apply plugin: org.jfrog.gradle.plugin.artifactory.ArtifactoryConfigurationsPlugin
+}
+
+artifactory {
+    contextUrl = 'https://docker.ssdt.io/artifactory'
+    publish {
+        def isFeature = gradle.branchStream == 'feature'
+        repository {
+            repoKey = isFeature ? 'libs-branches-local' : 'libs-snapshots-local'
+            // Publisher username and password
+            // Sub projects must provide these values via command line or properties file
+            username = artifactoryUsername
+            password = artifactoryPassword
+            maven = !isFeature
+            if (isFeature) {
+                ivy {
+                    ivyLayout = "${gradle.branchHash}/[organization]/[module]/ivy-[revision].xml"
+                    artifactLayout = "${gradle.branchHash}/[organization]/[module]/[revision]/[module]-[revision](-[classifier]).[ext]"
+                    mavenCompatible = false
+                }
+            }
+        }
+        defaults {
+            publishBuildInfo = true
+            publishArtifacts = true
+            publishPom = false
+            publishIvy = true
+            properties = [ 'ssdt-branch.branchName': gradle.branchName.replaceAll('/','-'), 'ssdt-branch.branchStream': gradle.branchStream ]
+        }
+    }
+}
+
+subprojects {
+    apply {
+        apply plugin: org.jfrog.gradle.plugin.artifactory.ArtifactoryConfigurationsPlugin
+    }
+}
+
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/artifactory20.gradle	Thu Feb 09 13:53:42 2023 -0500
@@ -0,0 +1,55 @@
+
+logger.info("applying SSDT bamboo/artifactory Gradle Settings")
+
+
+//plugins {
+//	id 'com.jfrog.artifactory-upload' version '3.0.1'
+//}
+//
+
+buildscript {
+    repositories {
+        maven { url 'https://docker.ssdt.io/artifactory/gradle-plugins' }
+    }
+    dependencies {
+        classpath "org.jfrog.buildinfo:build-info-extractor-gradle:3.0.1"
+    }
+}
+apply {
+    apply plugin: org.jfrog.gradle.plugin.artifactory.ArtifactoryConfigurationsPlugin
+}
+artifactory {
+    contextUrl = 'https://docker.ssdt.io/artifactory'
+    publish {
+        def isFeature = gradle.branchStream == 'feature'
+        repository {
+            repoKey = isFeature ? 'libs-branches-local' : 'libs-snapshots-local'
+            // Publisher username and password
+            // Sub projects must provide these values via command line or properties file
+            username = artifactoryUsername
+            password = artifactoryPassword
+            if (isFeature) {
+                ivy {
+                    ivyLayout = "${project.gradle.branchHash}/[organization]/[module]/ivy-[revision].xml"
+                    artifactLayout = "${project.gradle.branchHash}/[organization]/[module]/[revision]/[module]-[revision](-[classifier]).[ext]"
+                    mavenCompatible = false
+                }
+            }
+        }
+        defaults {
+            publishBuildInfo = true
+            publishArtifacts = true
+            publishPom = false
+            publishIvy = true
+            properties = [ 'ssdt-branch.branchName': gradle.branchName.replaceAll('/','-'), 'ssdt-branch.branchStream': gradle.branchStream ]
+        }
+    }
+}
+
+subprojects {
+    apply {
+        apply plugin: org.jfrog.gradle.plugin.artifactory.ArtifactoryConfigurationsPlugin
+    }
+}
+
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/artifactory40.gradle	Thu Feb 09 13:53:42 2023 -0500
@@ -0,0 +1,50 @@
+
+logger.info("applying SSDT bamboo/artifactory Gradle Settings")
+
+buildscript {
+    repositories {
+        maven { url 'https://docker.ssdt.io/artifactory/gradle-plugins' }
+    }
+    dependencies {
+        classpath "org.jfrog.buildinfo:build-info-extractor-gradle:3.0.1"
+    }
+}
+
+//apply plugin: org.jfrog.gradle.plugin.artifactory.ArtifactoryConfigurationsPlugin
+
+allprojects {
+
+    apply plugin: org.jfrog.gradle.plugin.artifactory.ArtifactoryConfigurationsPlugin
+
+}
+
+artifactory {
+    contextUrl = 'https://docker.ssdt.io/artifactory'
+    publish {
+        def isFeature = gradle.branchStream == 'feature'
+        repository {
+            repoKey = isFeature ? 'libs-branches-local' : 'libs-snapshots-local'
+            if (gradle.branch.isRelease()) {
+                repoKey = 'libs-releases-local'
+            }
+            // Publisher username and password
+            // Sub projects must provide these values via command line or properties file
+            username = artifactoryUsername
+            password = artifactoryPassword
+            if (isFeature) {
+                ivy {
+                    ivyLayout = "${project.gradle.branchHash}/[organization]/[module]/ivy-[revision].xml"
+                    artifactLayout = "${project.gradle.branchHash}/[organization]/[module]/[revision]/[module]-[revision](-[classifier]).[ext]"
+                    mavenCompatible = false
+                }
+            }
+        }
+        defaults {
+            publishBuildInfo = true
+            publishArtifacts = true
+            publishPom = false
+            publishIvy = true
+            properties = [ 'ssdt-branch.branchName': gradle.branchName.replaceAll('/','-'), 'ssdt-branch.branchStream': gradle.branchStream ]
+        }
+    }
+}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/artifactory70.gradle	Thu Feb 09 13:53:42 2023 -0500
@@ -0,0 +1,63 @@
+
+logger.info("applying SSDT bamboo/artifactory Gradle Settings")
+
+buildscript {
+    repositories {
+//        maven { url 'https://docker.ssdt.io/artifactory/gradle-plugins' }
+        mavenCentral()
+    }
+    dependencies {
+        classpath "org.jfrog.buildinfo:build-info-extractor-gradle:4.28.4"
+    }
+}
+
+//apply plugin: org.jfrog.gradle.plugin.artifactory.ArtifactoryConfigurationsPlugin
+
+allprojects {
+    apply plugin: org.jfrog.gradle.plugin.artifactory.ArtifactoryPlugin
+    apply plugin: 'ivy-publish'
+    apply plugin: 'java'
+
+    afterEvaluate {
+        publishing {
+            publications {
+                ivyJava(IvyPublication) {
+                    from components.java
+                }
+            }
+        }
+    }
+}
+
+artifactory {
+    contextUrl = 'https://docker.ssdt.io/artifactory'
+    publish {
+        def isFeature = gradle.branchStream == 'feature'
+        repository {
+            repoKey = isFeature ? 'libs-branches-local' : 'libs-snapshots-local'
+            if (gradle.branch.isRelease()) {
+                repoKey = 'libs-releases-local'
+            }
+            // Publisher username and password
+            // Sub projects must provide these values via command line or properties file
+            username = artifactoryUsername
+            password = artifactoryPassword
+            if (isFeature) {
+                ivy {
+                    ivyLayout = "${project.gradle.branchHash}/[organization]/[module]/ivy-[revision].xml"
+                    artifactLayout = "${project.gradle.branchHash}/[organization]/[module]/[revision]/[module]-[revision](-[classifier]).[ext]"
+                    mavenCompatible = false
+                }
+            }
+        }
+        defaults {
+            publications('ivyJava')
+            publishBuildInfo = true
+            publishArtifacts = true
+            publishPom = false
+            publishIvy = true
+            properties = [ 'ssdt-branch.branchName': gradle.branchName.replaceAll('/','-'), 'ssdt-branch.branchStream': gradle.branchStream ]
+        }
+    }
+}
+
--- a/init20-git.gradle	Wed Feb 08 15:08:38 2023 +0000
+++ b/init20-git.gradle	Thu Feb 09 13:53:42 2023 -0500
@@ -134,9 +134,8 @@
 if (gradle.bambooBuild) {
 
     file('build-number.txt').text = "build.number=${gradle.branch.buildNumber ?: -1 }\n"
-    gradle.ext.ssdtGradlekitLocation = gradle.ext.has('ssdtGradlekitLocation') ? gradle.ssdtGradlekitLocation : 'http://hg.ssdt-ohio.org/ssdt/gradlekit/raw-file/tip'
     logger.info "applying SSDT artifactory Gradle Settings (bamboo: $gradle.bambooBuild host: $hostname)"
-    apply from: "${gradle.ssdtGradlekitLocation}/artifactory20.gradle"
+    apply from: resources.text.fromInsecureUri("${gradle.ssdtDevelkitLocation}/artifactry20.gradle")
 }
 
 if (!rootProject.hasProperty('disableMetrics')) {
--- a/init40-git.gradle	Wed Feb 08 15:08:38 2023 +0000
+++ b/init40-git.gradle	Thu Feb 09 13:53:42 2023 -0500
@@ -139,11 +139,8 @@
 
 if (gradle.bambooBuild) {
     file('build-number.txt').text = "build.number=${gradle.branch.buildNumber ?: -1 }\n"
-    gradle.ext.ssdtGradlekitLocation = gradle.ext.has('ssdtGradlekitLocation') ? gradle.ssdtGradlekitLocation : 'http://hg.ssdt-ohio.org/ssdt/gradlekit/raw-file/tip'
     logger.info "applying SSDT artifactory Gradle Settings (bamboo: $gradle.bambooBuild host: $hostname)"
-    println "applying SSDT artifactory Gradle Settings (bamboo: $gradle.bambooBuild host: $hostname)"
-    apply from: "${gradle.ssdtGradlekitLocation}/artifactory40.gradle"
-    println "Finished applying SSDT artifactory Gradle Settings (bamboo: $gradle.bambooBuild host: $hostname)"
+    apply from: resources.text.fromInsecureUri("${gradle.ssdtDevelkitLocation}/artifactry40.gradle")
 }
 
 if (!rootProject.hasProperty('disableMetrics')) {
--- a/init40pom.gradle	Wed Feb 08 15:08:38 2023 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,844 +0,0 @@
-import groovy.transform.Sortable
-import groovy.transform.ToString
-import groovy.transform.TupleConstructor
-
-buildscript {
-    repositories {
-        maven { url 'https://docker.ssdt.io/artifactory/ssdt-repo' }
-        maven { url 'https://docker.ssdt.io/artifactory/gradle-plugins' }
-    }
-}
-
-// buildScan { termsOfServiceUrl = 'https://gradle.com/terms-of-service'; termsOfServiceAgree = 'yes' }
-
-final GradleVersion gradleCurrent = GradleVersion.current()
-final GradleVersion gradleV410 = GradleVersion.version('4.10')
-
-println "Gradle Version: $gradleCurrent"
-
-if (gradleCurrent < gradleV410) {
-    throw new RuntimeException("this init script requires Gradle version 4.10 or higher")
-}
-
-gradle.ext.ssdtDevelkitLocation = gradle.ext.has('ssdtDevelkitLocation') ? gradle.ssdtDevelkitLocation : 'http://hg.ssdt-ohio.org/browse/public/develkit'
-
-ant.property(file: System.getProperty('user.home') + "/.ssdt/private.properties")
-gradle.ext.ivyUserDir = ant.properties['ivy.default.ivy.user.dir'] ?: System.getProperty('user.home') + "/.ivy2"
-
-gradle.ext.ssdtProjectId = System.getenv('bamboo_project_id') ?: rootProject.name
-
-gradle.addListener(new ArtifactoryGradleSettings())
-
-def hostname
-try {
-    hostname = "hostname".execute().text.toLowerCase().readLines().first()
-} catch (e) {
-    hostname = 'unknown'
-}
-
-gradle.ext.bambooBuild = System.getenv().any {
-    it.key.toLowerCase().contains('bamboo')
-} || hostname?.startsWith('ssdt-ba')
-
-if (!rootProject.hasProperty("bambooLocalBuild")) {
-    gradle.ext.bambooLocalBuild = false
-} else {
-    gradle.ext.bambooLocalBuild = rootProject.bambooLocalBuild.toBoolean()
-}
-
-if (gradle.bambooLocalBuild) {
-    println "Bamboo local build active"
-}
-
-gradle.ext.bambooPlan = (System.getenv('BAMBOO_PLAN') ?: 'UNKNOWN-UNKNOWN-JOB1').split('-')[0..1].join('-')
-logger.info "Bamboo plan: ${gradle.bambooPlan}"
-
-gradle.ext.buildTimestamp = System.currentTimeMillis().toString().padLeft(14, '0')
-
-gradle.ext.hgRepositoryUrl = ""
-
-try {
-    gradle.ext.hgRepositoryUrl = ("hg path".execute().text.split('=') ?: ['', ''])[1].trim()
-} catch (e) {
-}
-
-def springModuleTranslator = [
-        'spring-transaction': 'spring-tx',
-        'spring-web-servlet': 'spring-webmvc',
-].withDefault { it }
-
-gradle.ext.normalizeSpring = { DependencyResolveDetails details ->
-    if (details.requested.group == 'org.springframework' && details.requested.name.startsWith('org.springframework.')) {
-        def shortName = springModuleTranslator[details.requested.name.replace('org.springframework.', 'spring-').replace('.', '-')]
-        details.useTarget(group: 'org.springframework', name: shortName, version: details.requested.version)
-    }
-    if (details.requested.group == 'org.springframework.security' && details.requested.name.startsWith('org.springframework.')) {
-        def shortName = springModuleTranslator[details.requested.name.replace('org.springframework.', 'spring-').replace('.', '-')]
-        details.useTarget("${details.requested.group}:$shortName:${details.requested.version}")
-    }
-}
-
-gradle.ext.runtimeInfo = new RuntimeInfo()
-
-
-if (System.env.DOCKER_HOST ) {
-    if (System.env.DOCKER_HOST.contains('tcp:')) {
-        gradle.ext.dockerEngineUrl = "https:${System.env.DOCKER_HOST?.minus('tcp:')}"
-    }
-    gradle.ext.dockerEngineUrl = System.env.DOCKER_HOST
-}
-
-setBranchInfo()
-
-loadEnvironments()
-
-gradle.environment.put('hgRepositoryUrl', gradle.hgRepositoryUrl)
-gradle.environment.put('branchName', gradle.branch.name)
-gradle.environment.put('branchStream', gradle.branch.stream)
-gradle.environment.put('branchHash', gradle.branch.hash)
-
-
-def cacheTimeout = 60 * 60 * 8
-if (gradle.environment['dependencyTimeout']) {
-    cacheTimeout = gradle.environment['dependencyTimeout'] as Integer
-    println "setting changing dependency timeout to $cacheTimeout seconds"
-}
-
-gradle.ext.cacheTimeout = cacheTimeout
-
-rootProject.ext.indyCapable = {
-    boolean capable = true
-    try {
-        Class.forName('java.lang.invoke.MethodHandle')
-    } catch (e) {
-        capable = false
-    }
-    capable && !rootProject.hasProperty('skipIndy')
-}
-
-rootProject.ext.useIndy = {
-    boolean indy = false
-    // first, check if a system property activates indy support
-    indy |= System.hasProperty('indy') && Boolean.valueOf(System.getProperty('indy'))
-
-    // check ssdt environment for indy property.
-    indy |= (gradle.environment.indy) ? gradle.environment.indy.toBoolean() : false
-
-    // check if the main project has an extension property setting indy (-Pindy).
-    if (rootProject.hasProperty('indy')) {
-        indy = (Boolean.valueOf(rootProject.indy))
-    }
-
-    // set the groovy runtime system property to ensure forked junit test will get the indy flag properly
-    if (indy && rootProject.indyCapable()) System.setProperty("groovy.target.indy", "true")
-
-    indy && rootProject.indyCapable()
-}
-
-println "Indy available: ${rootProject.indyCapable()} enabled: ${rootProject.useIndy()}"
-
-if (gradle.bambooBuild) {
-    file('build-number.txt').text = "build.number=${gradle.branch.buildNumber ?: -1 }\n"
-    gradle.ext.ssdtGradlekitLocation = gradle.ext.has('ssdtGradlekitLocation') ? gradle.ssdtGradlekitLocation : 'http://hg.ssdt-ohio.org/ssdt/gradlekit/raw-file/tip'
-    logger.info "applying SSDT artifactory Gradle Settings (bamboo: $gradle.bambooBuild host: $hostname)"
-    println "applying SSDT artifactory Gradle Settings (bamboo: $gradle.bambooBuild host: $hostname)"
-    apply from: "${gradle.ssdtGradlekitLocation}/artifactory40pom.gradle"
-    println "Finished applying SSDT artifactory Gradle Settings (bamboo: $gradle.bambooBuild host: $hostname)"
-}
-
-if (!rootProject.hasProperty('disableMetrics')) {
-    println "applying SSDT metrics40.gradle"
-    apply from: "${gradle.ssdtDevelkitLocation}/metrics40.gradle"
-}
-
-rootProject.afterEvaluate { r ->
-    if (gradle.bambooBuild && r.hasProperty('requireJavaVersion')) {
-        gradle.runtimeInfo.requireJava( r.getProperty('requireJavaVersion') )
-    }
-    if (!gradle.bambooBuild && !r.file('.idea/copyright/ODE.xml').exists() ) {
-        updateCopyrightProfile(r)
-    }
-}
-
-def findComponent(project, name) {
-    project.component.find { it.@name == name }
-}
-
-wrapper {
-    distributionType = org.gradle.api.tasks.wrapper.Wrapper.DistributionType.ALL
-}
-
-allprojects {
-
-    configurations.all {
-        resolutionStrategy.cacheChangingModulesFor gradle.cacheTimeout, 'seconds'
-        resolutionStrategy.cacheDynamicVersionsFor gradle.cacheTimeout, 'seconds'
-    }
-    configurations.all {
-        resolutionStrategy.eachDependency { DependencyResolveDetails details ->
-            if (details.requested.group == 'org.ssdt_ohio' && !details.requested.version ) {
-                details.useVersion( "latest.${gradle.branch.defaultDependencyStatus}" )
-            }
-            if (details.requested.version == 'default') {
-                details.useVersion("latest.${gradle.branch.defaultDependencyStatus}" )
-            }
-            if (project.hasProperty("overrideCommon")) {
-                if (details.requested.group == 'org.ssdt_ohio' && details.requested.name.contains('ssdt.common.')) {
-                    details.useVersion(project.overrideCommon)
-                }
-            }
-            if (project.hasProperty("overrideVui")) {
-                if (details.requested.group == 'org.ssdt_ohio' && details.requested.name.startsWith('vui.')) {
-                    details.useVersion(project.overrideVui)
-                }
-            }
-            if (project.hasProperty("overrideUsasCore")) {
-                if (details.requested.group == 'org.ssdt_ohio' && details.requested.name.startsWith('usas.') && !details.requested.name.startsWith('usas.vui')) {
-                    details.useVersion(project.overrideUsasCore)
-                }
-            }
-            if (project.hasProperty("overrideUspsCore")) {
-                if (details.requested.group == 'org.ssdt_ohio' && details.requested.name.startsWith('usps.') && !details.requested.name.startsWith('usps.vui')) {
-                    details.useVersion(project.overrideUspsCore)
-                }
-            }
-
-        }
-    }
-
-    task cleanLocal(description: "removes all artifacts from developer's local repository") {
-
-        doLast {
-            def local = project.repositories.find { it.name == 'local' }
-            if (local) {
-                logger.info "removing local repo: $it"
-                new File(System.properties['user.home'] + "/.ssdt/local-repo").deleteDir()
-                def localDir = new File(gradle.ivyUserDir + "/local")
-                localDir.deleteDir()
-                logger.info "verifying removal of local repo"
-                if (localDir.exists()) {
-                    throw new org.gradle.api.GradleException("Unable to clean ${localDir}. Files may be locked by another process.")
-                }
-            }
-        }
-    }
-
-    cleanLocal.onlyIf {
-        project.repositories.any { it.name == 'local' }
-    }
-
-    project.ext.previousBuildenv = project.file('build/buildenv.txt').exists() ? project.file('build/buildenv.txt').text : 'none'
-
-    tasks.addRule("Pattern: <environment>As[Test]Properties: Generates <environment>.properties as resource or Test resource") { String taskName ->
-        if ((taskName - 'Test').endsWith("AsProperties") && !taskName.startsWith('clean')) {
-            //       def t = taskName.contains('Test') ? processTestResources.destinationDir : processResources.destinationDir
-            def t = taskName.contains('Test') ? sourceSets.test.output.resourcesDir : sourceSets.main.output.resourcesDir
-            def e = (taskName - 'Test' - 'AsProperties').capitalize()
-            task(taskName) {
-                ext.outputDir = t
-                ext.propertyFile = "${e.toLowerCase()}.properties"
-                ext.buildenv = project.file('build/buildenv.txt')
-                inputs.files project.file("../environment${e}.groovy"), project.file("../private${e}.groovy"), project.file('../private.properties')
-                outputs.files new File(outputDir,propertyFile), buildenv
-                outputs.upToDateWhen {
-                    gradle.env == project.previousBuildenv && outputs.getFiles().every { it.exists() }
-                }
-                doLast {
-                    t.mkdirs()
-                    outputDir.mkdirs()
-                    buildenv.text = gradle.env
-                    def ps = gradle."environment${e}".toProperties()
-                    ps['ssdt.project'] = project.name
-                    def pf = new File(outputDir,propertyFile)
-                    ext.outputPropertyFile = pf
-                    ps.store(pf.newOutputStream(), "by $taskName of $this")
-                    def l = pf.readLines().sort()
-                    pf.text = l.join('\n').replaceAll("\\.PARENT","")
-                }
-            }
-        }
-    }
-}
-
-subprojects {
-
-    it.ext.environment = gradle.environment
-
-    dependencyLocking {
-        if (gradle.branch.isRelease()) {
-            lockAllConfigurations()
-        }
-    }
-
-    task("releaseLock" ) {
-        description =  "Create release dependencies Lock files"
-        doFirst {
-            assert gradle.startParameter.writeDependencyLocks : "must include --write-locks or --update-locks option when locking dependencies"
-        }
-        doLast {
-
-            if (!gradle.branch.isRelease()) {
-                throw new BuildCancelledException("releaseLock is only valid on release or hotfix branch.")
-            }
-
-            configurations.findAll {
-                it.canBeResolved
-            }.findAll { c ->
-                def n = c.name.toLowerCase()
-                ['compile','runtime','provided'].any { n.contains(it) }
-            }.each {
-                it.resolve()
-            }
-        }
-    }
-
-}
-
-rootProject.afterEvaluate {
-
-    tasks.addRule("release{Major|Minor|Patch|n.n.n}: create release branch or update release Lock file") { String taskName ->
-
-        def matcher = (taskName =~ /^release(Major|Minor|Patch|\d{1,3}\.\d{1,3}\.\d{1,3})$/)
-        if (matcher.matches()) {
-
-            task('doReleaseBranch') {
-                ext.requested = matcher[0][1].toLowerCase()
-                doLast {
-                    def releaseVersion = determineReleaseVersion(requested)
-                    def releaseStream = releaseVersion.isHotfix() ? 'hotfix' : 'release'
-
-                    println "-" * 60
-                    println "Preparing to create branch\n"
-                    println "\tproject:\t${gradle.rootProject.name}"
-                    println "\tcurrent:\t${gradle.branch} ($gradle.branch.version)"
-                    println()
-                    println "\ttype   :\t${releaseStream.toUpperCase()}"
-                    println "\tversion:\t${releaseVersion}"
-                    println "\ttarget :\t${releaseStream}/v${releaseVersion}"
-                    println()
-                    println("-" * 60)
-                    println "DRY RUN".center(60)
-                    println("-" * 60)
-
-                    println "hg flow ${releaseStream} start v${releaseVersion} --dirty --dry-run".execute().text
-
-                    println "-" * 60
-
-                    if (!confirmPrompt("Continue?")) {
-                        throw new BuildCancelledException("release branching canceled by user request")
-                    }
-
-                    println "hg flow ${releaseStream} start v${releaseVersion} --dirty".execute().text
-                    println "hg update ${releaseStream}/v${releaseVersion}".execute().text
-
-                    setBranchInfo()
-
-                    println "-" * 60
-                    println " Be sure to execute 'releaseLock' task to update the release.lock file before proceeding."
-                    println "-" * 60
-
-                }
-            }
-
-
-            def branchTasks = ['doReleaseBranch']
-
-            task(taskName) {
-                dependsOn branchTasks
-            }
-
-            branchTasks.tail().inject(branchTasks.head()) { a, b ->
-                tasks[b].mustRunAfter a
-                b
-            }
-
-        }
-    }
-
-}
-
-private static String readLine(String message, String defaultValue = null) {
-    String _message = "> $message" + (defaultValue ? " [$defaultValue] " : "")
-    if (System.console()) {
-        return System.console().readLine(_message) ?: defaultValue
-    }
-    println "$_message "
-
-    System.in.newReader().readLine() ?: defaultValue
-}
-
-private static boolean confirmPrompt(String message, boolean defaultValue = false) {
-    String defaultStr = defaultValue ? 'Y' : 'n'
-    String consoleVal = readLine("${message} (Y|n)", defaultStr)
-    if (consoleVal) {
-        return consoleVal.toLowerCase().startsWith('y')
-    }
-
-    defaultValue
-}
-
-private Version determineReleaseVersion(String requested) {
-    if (requested == 'major') {
-        return gradle.branch.version.nextMajor()
-    } else if (requested == 'minor') {
-        return gradle.branch.version.nextMinor()
-    } else if (requested == 'patch') {
-        return gradle.branch.version.nextPatch()
-    } else {
-        return new Version(*requested.split(/\./)*.toInteger(), false)
-    }
-}
-
-class ArtifactoryGradleSettings extends BuildAdapter implements BuildListener {
-
-    def void projectsEvaluated(Gradle gradle) {
-        def ssdtArtifactory = 'https://docker.ssdt.io/artifactory'
-        Project root = gradle.getRootProject()
-
-
-        def branchVersioning = gradle.rootProject.version == 'unspecified'
-
-        root.allprojects {
-
-            def thisProject = delegate
-            thisProject.status = 'integration'
-            if (gradle.branchStream) {
-                if (branchVersioning) {
-                    thisProject.version = gradle.branch.version
-                    thisProject.status = gradle.branch.defaultDependencyStatus
-                } else {
-
-                    thisProject.status = 'integration'
-                    def fixupVersion = thisProject.version - ".SNAPSHOT"
-                    if (gradle.branchStream == 'feature') {
-                        fixupVersion = fixupVersion + ".SNAPSHOT"
-                    }
-                    if (gradle.branchStream == 'develop') {
-                        fixupVersion = fixupVersion + ".SNAPSHOT"
-                    }
-                    if (gradle.branchStream in ['production', 'release', 'hotfix']) {
-                        thisProject.status = 'release'
-                    }
-                    thisProject.version = fixupVersion
-                }
-            }
-
-            repositories {
-
-                if (!gradle.bambooBuild || gradle.bambooLocalBuild) {
-                    ivy {
-                        name = 'local'
-                        artifactPattern gradle.ivyUserDir + '/local/[artifact]-[revision](-[classifier]).[ext]'
-                        ivyPattern gradle.ivyUserDir + "/local/[module]-ivy-[revision].xml"
-                    }
-                }
-
-                if (!gradle.bambooBuild) {
-                    mavenLocal()
-                }
-
-                if (gradle.branchStream == 'feature') {
-                    ivy {
-                        name = 'ssdt-branches'
-                        url = "${ssdtArtifactory}/ssdt-branches/${gradle.branchHash}/"
-                        layout "pattern", {
-                            artifact "[organization]/[module]/[revision]/[module]-[revision](-[classifier]).[ext]"
-                            ivy "[organization]/[module]/ivy-[revision].xml"
-                        }
-                    }
-                }
-
-                ivy {
-                    name = 'ssdt-releases'
-                    url = "${ssdtArtifactory}/ssdt-releases"
-                    layout "pattern", {
-                        artifact "[organization]/[module]/[revision]/[module]-[revision](-[classifier]).[ext]"
-                        artifact "[organization]/[module]/[revision]/[artifact]-[revision](-[classifier]).[ext]"
-                        ivy "[organization]/[module]/ivy-[revision].xml"
-                        m2compatible = true
-                    }
-                }
-
-                ivy {
-                    name = 'ssdt-snapshots'
-                    url = "${ssdtArtifactory}/ssdt-snapshots"
-                    layout "pattern", {
-                        artifact "[organization]/[module]/[revision]/[module]-[revision](-[classifier]).[ext]"
-                        artifact "[organization]/[module]/[revision]/[artifact]-[revision](-[classifier]).[ext]"
-                        ivy "[organization]/[module]/ivy-[revision].xml"
-                        m2compatible = true
-                    }
-                }
-
-                maven {
-                    name = 'ssdt-repository'
-                    url = "${ssdtArtifactory}/repository"
-                }
-
-            }
-
-            def remoteRepos = thisProject.repositories.findAll { it.hasProperty('url') && !(it.name.toLowerCase().contains('local') || it.url.toString().contains('ssdt')) }
-            if (remoteRepos) {
-                logger.warn "WARNING: Remote repositories configured for $thisProject:\n" + remoteRepos.collect { "\t$it.name $it.url " }.join('\n')  + "\n Moved to lowest priority..."
-                remoteRepos.each {
-                    thisProject.repositories.remove(it)
-                    thisProject.repositories.addLast(it)
-                }
-            }
-            logger.info "$thisProject configured repositories:\n" + thisProject.repositories.collect {"\t$it.name ${it.hasProperty('url') ? it.url : '' }" }.join('\n')
-
-            if (thisProject.repositories.find { it.name == 'local' } && thisProject.getTasksByName('uploadArchives', false)) {
-                uploadArchives {
-                    repositories {
-                        add thisProject.repositories.local
-                    }
-                }
-
-                thisProject.tasks.create("publishLocal") {
-                    description = "Publishes this projects artifacts to developer's local repository"
-                    dependsOn = ["uploadArchives"]
-                }
-            }
-
-        }
-
-        root.subprojects { p ->
-            if (root.useIndy()) {
-                println "enabling indy compilation on $p"
-                [compileGroovy.groovyOptions, compileTestGroovy.groovyOptions]*.with {
-                    optimizationOptions = [indy: true]
-                }
-            }
-        }
-    }
-}
-
-
-task showEnvironments {
-
-    doLast {
-        println "Defined environments: $gradle.environments"
-        gradle.environments.each { e ->
-            println "\n $e:"
-            gradle.getProperty(e).flatten().sort { it.key }.each { k, v ->
-                println String.format('  %25s = %s', k, k.contains('password') ? "********" : v)
-            }
-        }
-        if (logger.isInfoEnabled()) {
-            println "System properties:"
-            System.properties.each { println "    $it" }
-            println "env variables:"
-            System.getenv().each { println "    $it" }
-        }
-    }
-}
-
-def loadEnvironments() {
-    def developerPrivate = new Properties()
-    if (file('private.properties').exists()) {
-        developerPrivate.load(file('private.properties').newReader())
-    }
-    def envOverrides = [:]
-
-    if (!hasProperty('env')) {
-        gradle.ext.env = developerPrivate.env ?: 'dev'
-    } else {
-        def values = getProperty('env').split(',')
-        gradle.ext.env = values.first()
-        values.tail().each {
-            def (k, v) = it.split('=')
-            envOverrides.put(k, v)
-        }
-    }
-
-    println "Environment is: $gradle.env ($envOverrides)"
-    def slurper = new ConfigSlurper(gradle.env)
-    slurper.setBinding(['gradle': gradle])
-
-    def environment = slurper.parse(
-            '''deploy.mode="production"
-       environments {
-        test { deploy.mode="test" }
-        dev { deploy.mode="development"}
-       }''')
-    if (developerPrivate['deploy.mode']) {
-        environment.put('deploy.mode', developerPrivate['deploy.mode'])
-    }
-
-    environment.put('branchInfo',gradle.branch)
-    environment.put('branchVersion',gradle.branch.version.toString())
-    def environments = []
-    gradle.ext.environment = environment
-    file('.').listFiles().findAll { it.name ==~ /^environment.*\.groovy$/ }.sort { it.name }.each { envFile ->
-        def envName = envFile.name - '.groovy'
-        def privateFile = file("private" + envName - "environment" + ".groovy")
-        logger.info("loading environment $envFile.name")
-
-        def envCfg = slurper.parse(envFile.toURL())
-        envCfg.merge(slurper.parse(developerPrivate))
-        envCfg.put('ssdt.projectid', gradle.ssdtProjectId)
-        envCfg.put('ssdt.environment', gradle.env)
-        if (privateFile.exists()) {
-            logger.info("loading private environment $privateFile")
-            envCfg.merge(slurper.parse(privateFile.toURL()))
-        }
-
-        gradle.rootProject.getProperties().find { it.key.startsWith('environment') }.each {
-            it.value.split(',').each { p ->
-                def (k, v) = p.split('=')
-                logger.info("$envName: overriding " + k + "=" + v + " in $it")
-                envCfg.put(k, v)
-            }
-        }
-
-        envOverrides.each { k, v ->
-            logger.info("$envName: overriding " + k + "=" + v)
-            envCfg.put(k, v)
-        }
-        environment.merge(envCfg)
-        if (envName != 'environment') {
-            gradle.ext[envName] = envCfg
-            environments << envName
-        }
-    }
-    environment.merge(slurper.parse(developerPrivate))
-    def deployMode = environment.deploy.mode ?: 'development'
-    environments.each { gradle.ext[it].put('ssdt.deployment.mode', deployMode) }
-    environments << 'environment'
-    gradle.ext.environments = environments
-
-}
-
-def updateCopyrightProfile(Project r) {
-    r.file('.idea/copyright').mkdirs()
-    r.file('.idea/copyright/ODE.xml').text =
-            '''<component name="CopyrightManager">
-  <copyright>
-    <option name="notice" value="Copyright (c) &amp;#36;today.year.  Ohio Department of Education. - All Rights Reserved.&#10;Unauthorized copying of this file, in any medium, is strictly prohibited.&#10;Written by the State Software Development Team (http://ssdt.oecn.k12.oh.us/)&#10;" />
-    <option name="myName" value="ODE" />
-  </copyright>
-</component>'''
-
-    r.file('.idea/copyright/profiles_settings.xml').text =
-            '''<component name="CopyrightManager">
-  <settings default="ODE" />
-</component>'''
-
-}
-
-@ToString(includeNames=true)
-class RuntimeInfo {
-    // OS memory in megabytes, zero if unknown
-    int systemMemory = 0
-    int systemFreeMemory = 0
-    String javaVersion = System.getProperty('java.version')
-
-    RuntimeInfo() {
-        try {
-            new File('/proc/meminfo').readLines().findAll { it.startsWith 'Mem' }.collect { it.split(/\s+/) }.each {
-                int value = (it[1] as Long) / 1024
-                if (it[0].startsWith('MemTotal')) { systemMemory = value }
-                if (it[0].startsWith('MemFree')) { systemFreeMemory = value }
-            }
-
-        } catch (e) {  }
-
-    }
-
-    void requireMemory(int megabytes) {
-        if (systemFreeMemory > 0 && systemFreeMemory < megabytes) {
-            println "WARNING: potentially insufficent OS memory for this build"
-//            throw new GradleException("insufficent free OS memory for this build (available: ${systemFreeMemory}m, required: ${megabytes}m)")
-        }
-    }
-    /**
-     * Returns maximum memory available upto the value specified.
-     */
-    int maxMemory(int megabytes) {
-        if (systemFreeMemory) {
-            [systemFreeMemory,megabytes].min()
-        } else { megabytes }
-
-    }
-
-    void requireJava(String version) {
-
-        if ( version && !javaVersion.startsWith(version)) {
-            throw new GradleException("Requires java version $version but running under $javaVersion")
-        }
-    }
-
-}
-
-
-@TupleConstructor
-@Sortable
-class Version {
-
-    Integer major = 0
-    Integer minor = 0
-    Integer patch = 0
-    Boolean snapshot = true
-
-    Integer previousMinor = 0
-    Integer previousPatch = 0
-
-    Version nextMajor() {
-        new Version(major + 1, 0, 0, false)
-    }
-
-    Version nextMinor() {
-        if (snapshot) {
-            new Version(major, minor , 0,false)
-        } else {
-            new Version(major, minor + 1, 0,false)
-        }
-    }
-
-    Version nextPatch() {
-        if (snapshot) {
-            new Version(major, previousMinor, previousPatch + 1,false)
-        }
-    }
-
-    Version nextSnapshot() {
-        new Version(major, minor + 1, 0,true,minor,patch)
-    }
-
-    boolean isHotfix() {
-        !snapshot && patch > 0
-    }
-
-    String toString() {
-        "${major}.${minor}.${patch}${snapshot ? '.SNAPSHOT' : ''}"
-    }
-
-}
-
-void setBranchInfo() {
-    gradle.ext.branch = new BranchInfo(System.getenv('bamboo_planRepository_branch'))
-    gradle.ext.branchName = gradle.branch.name
-    gradle.ext.branchStream = gradle.branch.stream
-    gradle.ext.branchHash = gradle.branch.hash
-    println "${gradle.hgRepositoryUrl} ${gradle.branch} ${gradle.branch.version}"
-}
-
-
-@ToString(includes=['name','shortName','buildVersion','imageId','deployName'],includeNames= true)
-class BranchInfo {
-    def name
-    def stream = "none"
-    def buildNumber = ""
-    def changeset = ""
-    def version
-
-    BranchInfo(name) {
-        this.name = name
-        if (!name) {
-            this.name = determineName() ?: ''
-        }
-        this.name = this.name.replace('@', '-')
-        determineStream()
-        buildNumber = System.getenv('bamboo_buildNumber') ?: ""
-        changeset = System.getenv('bamboo_planRepository_revision') ?: ""
-    }
-
-    String getDefaultDependencyStatus() {
-        return isRelease() ? 'release' : 'integration'
-    }
-
-    private boolean isRelease() {
-        return stream in ['release', 'hotfix']
-    }
-
-    def getShortName() {
-        def result = name.contains('/') ? name.split('/')[1] : name
-    }
-
-    String getBuildVersion() {
-        def v = isRelease() ? shortName - "v": ""
-        return v
-    }
-
-    def Version getVersion() {
-        if (!version) {
-            if (isRelease()) {
-                version = new Version(*getBuildVersion().split('\\.')*.toInteger(), false)
-            } else {
-                version = findSnapshotVersion()
-            }
-        }
-        return version
-    }
-
-    def getImageId() {
-        (buildVersion ?:  shortName.take(25)) + (buildNumber ? "-${buildNumber}" : "-0")
-    }
-
-    def getDeployName() {
-        (buildVersion ?:  shortName.take(25)).toLowerCase().collectReplacements {
-            ('a'..'z').contains(it) || ('0'..'9').contains(it) || it == "-" ? null : '-'
-        }
-    }
-
-    def getHash() {
-        generateMD5(name)
-    }
-    def generateMD5(String s) {
-        def digest = java.security.MessageDigest.getInstance("MD5")
-        digest.update(s.bytes);
-        new BigInteger(1, digest.digest()).toString(16).padLeft(32, '0')
-    }
-
-    private findSnapshotVersion() {
-
-        try {
-            def repositoryUrl = System.getenv('bamboo_planRepository_repositoryUrl')
-            if (repositoryUrl) {
-                println "hg pull $repositoryUrl".execute().text
-            }
-            def versions = "hg branches --closed".execute().text.split('\n').findAll {
-                it.startsWith( 'release') || it.startsWith( 'hotfix')
-            }.collect {
-                it.replaceAll('\\s+',' ').split(' ')[0].split('/')[1] - 'v'
-            }.collect {
-                new Version(*it.split('\\.')*.toInteger())
-            }.sort { v1, v2 -> v2 <=> v1 }
-
-            return versions ?  versions.first().nextSnapshot() : new Version().nextSnapshot()
-
-        } catch (e) {
-            return new Version().nextSnapshot()
-        }
-
-    }
-
-    def determineName()  {
-        try {
-            def branch = "hg branch".execute().text.trim()
-            def rawParents = 'hg parents'.execute().text
-            def parent = rawParents.split('\n').find { it.startsWith("branch") }?.split(":")?.getAt(1)?.trim()
-            return parent ?: branch
-        } catch (e) {
-            ['.hg/branch', '../.hg/branch'].findResult {
-                new File(it).exists() ? new File(it).text : null
-            }
-        }
-    }
-
-    void determineStream() {
-        def flowConfig = new File('.hgflow').exists() ? new File('.hgflow') : new File('../.hgflow')
-        if (flowConfig.exists()) {
-            def flows = new Properties()
-            flows.load(flowConfig.newReader())
-            flows.stringPropertyNames().each {
-                if (!it.startsWith("[") && name.startsWith(flows.getProperty(it))) {
-                    stream = it
-                }
-            }
-        }
-    }
-
-}
-
-
--- a/init50-git.gradle	Wed Feb 08 15:08:38 2023 +0000
+++ b/init50-git.gradle	Thu Feb 09 13:53:42 2023 -0500
@@ -139,9 +139,8 @@
 if (gradle.bambooBuild) {
 
     file('build-number.txt').text = "build.number=${gradle.branch.buildNumber ?: -1 }\n"
-    gradle.ext.ssdtGradlekitLocation = gradle.ext.has('ssdtGradlekitLocation') ? gradle.ssdtGradlekitLocation : 'http://hg.ssdt-ohio.org/ssdt/gradlekit/raw-file/tip'
     logger.info "applying SSDT artifactory Gradle Settings (bamboo: $gradle.bambooBuild host: $hostname)"
-    apply from: "${gradle.ssdtGradlekitLocation}/artifactory40.gradle"
+    apply from: resources.text.fromInsecureUri("${gradle.ssdtDevelkitLocation}/artifactry50.gradle")
 }
 
 if (!rootProject.hasProperty('disableMetrics')) {
--- a/init70-git.gradle	Wed Feb 08 15:08:38 2023 +0000
+++ b/init70-git.gradle	Thu Feb 09 13:53:42 2023 -0500
@@ -139,9 +139,8 @@
 if (gradle.bambooBuild) {
 
     file('build-number.txt').text = "build.number=${gradle.branch.buildNumber ?: -1 }\n"
-    gradle.ext.ssdtGradlekitLocation = gradle.ext.has('ssdtGradlekitLocation') ? gradle.ssdtGradlekitLocation : 'http://hg.ssdt-ohio.org/ssdt/gradlekit/raw-file/tip'
     logger.info "applying SSDT artifactory Gradle Settings (bamboo: $gradle.bambooBuild host: $hostname)"
-    apply from: resources.text.fromInsecureUri("${gradle.ssdtGradlekitLocation}/artifactory70.gradle")
+    apply from: resources.text.fromInsecureUri("${gradle.ssdtDevelkitLocation}/artifactry70.gradle")
 }
 
 if (!rootProject.hasProperty('disableMetrics')) {