mirror of
https://github.com/corda/corda.git
synced 2025-01-07 05:28:51 +00:00
e981632184
Specifically, make the IDE/driver and gradle/NodeRunner methods of launching the demo behave more similarly, with a view to configuring them the same way. * Add option to driver to nominate a node as network map, so that the driver-based demo doesn't run an additional node * Change gradle ports to match those chosen by driver
130 lines
3.6 KiB
Groovy
130 lines
3.6 KiB
Groovy
apply plugin: 'java'
|
|
apply plugin: 'kotlin'
|
|
apply plugin: 'idea'
|
|
apply plugin: 'net.corda.plugins.quasar-utils'
|
|
apply plugin: 'net.corda.plugins.publish-utils'
|
|
apply plugin: 'net.corda.plugins.cordformation'
|
|
apply plugin: 'maven-publish'
|
|
|
|
ext {
|
|
deployTo = "build/nodes"
|
|
notaryType = "corda.notary.validating.raft"
|
|
notaryName = "CN=Raft,O=R3,OU=corda,L=Zurich,C=CH"
|
|
advertisedNotary = "$notaryType|$notaryName"
|
|
}
|
|
|
|
configurations {
|
|
integrationTestCompile.extendsFrom testCompile
|
|
integrationTestRuntime.extendsFrom testRuntime
|
|
}
|
|
|
|
dependencies {
|
|
compile "org.jetbrains.kotlin:kotlin-stdlib-jre8:$kotlin_version"
|
|
testCompile "junit:junit:$junit_version"
|
|
|
|
// Corda integration dependencies
|
|
runtime project(path: ":node:capsule", configuration: 'runtimeArtifacts')
|
|
runtime project(path: ":webserver:webcapsule", configuration: 'runtimeArtifacts')
|
|
compile project(':core')
|
|
compile project(':client:jfx')
|
|
compile project(':client:rpc')
|
|
compile project(':test-utils')
|
|
|
|
// Javax is required for webapis
|
|
compile "org.glassfish.jersey.core:jersey-server:${jersey_version}"
|
|
}
|
|
|
|
idea {
|
|
module {
|
|
downloadJavadoc = true // defaults to false
|
|
downloadSources = true
|
|
}
|
|
}
|
|
|
|
publishing {
|
|
publications {
|
|
jarAndSources(MavenPublication) {
|
|
from components.java
|
|
artifactId 'raftnotarydemo'
|
|
|
|
artifact sourceJar
|
|
artifact javadocJar
|
|
}
|
|
}
|
|
}
|
|
|
|
task cleanNodes {
|
|
doLast {
|
|
delete deployTo
|
|
}
|
|
}
|
|
|
|
task generateNotaryIdentity(type: JavaExec, dependsOn: 'cleanNodes') {
|
|
classpath = sourceSets.main.runtimeClasspath
|
|
main = "net.corda.node.utilities.ServiceIdentityGeneratorKt"
|
|
def nodeDirs = ["$deployTo/Notary1",
|
|
"$deployTo/Notary2",
|
|
"$deployTo/Notary3"].join("|")
|
|
args = [nodeDirs, notaryType, notaryName]
|
|
}
|
|
|
|
task deployNodes(type: net.corda.plugins.Cordform, dependsOn: ['jar', 'generateNotaryIdentity']) {
|
|
directory deployTo
|
|
networkMap "CN=Notary 1,O=R3,OU=corda,L=London,C=UK"
|
|
node {
|
|
name "CN=Alice Corp,O=Alice Corp,L=London,C=UK"
|
|
nearestCity "London"
|
|
advertisedServices = []
|
|
p2pPort 10002
|
|
rpcPort 10003
|
|
cordapps = []
|
|
rpcUsers = [['username': "demo", 'password': "demo", 'permissions': [
|
|
'StartFlow.net.corda.notarydemo.flows.DummyIssueAndMove',
|
|
'StartFlow.net.corda.flows.NotaryFlow$Client'
|
|
]]]
|
|
}
|
|
node {
|
|
name "CN=Bob Plc,O=Bob Plc,L=London,C=UK"
|
|
nearestCity "New York"
|
|
advertisedServices = []
|
|
p2pPort 10005
|
|
rpcPort 10006
|
|
cordapps = []
|
|
}
|
|
node {
|
|
name "CN=Notary 1,O=R3,OU=corda,L=London,C=UK"
|
|
nearestCity "London"
|
|
advertisedServices = [advertisedNotary]
|
|
p2pPort 10009
|
|
rpcPort 10010
|
|
cordapps = []
|
|
notaryNodePort 10008
|
|
}
|
|
node {
|
|
name "CN=Notary 2,O=R3,OU=corda,L=London,C=UK"
|
|
nearestCity "London"
|
|
advertisedServices = [advertisedNotary]
|
|
p2pPort 10013
|
|
rpcPort 10014
|
|
cordapps = []
|
|
notaryNodePort 10012
|
|
notaryClusterAddresses = ["localhost:10008"]
|
|
}
|
|
node {
|
|
name "CN=Notary 3,O=R3,OU=corda,L=London,C=UK"
|
|
nearestCity "London"
|
|
advertisedServices = [advertisedNotary]
|
|
p2pPort 10017
|
|
rpcPort 10018
|
|
cordapps = []
|
|
notaryNodePort 10016
|
|
notaryClusterAddresses = ["localhost:10008"]
|
|
}
|
|
}
|
|
|
|
task notarise(type: JavaExec) {
|
|
classpath = sourceSets.main.runtimeClasspath
|
|
main = 'net.corda.notarydemo.NotaryDemoKt'
|
|
}
|
|
|