diff options
author | Trygve Laugstøl <trygvis@inamo.no> | 2021-02-03 16:35:48 +0100 |
---|---|---|
committer | Trygve Laugstøl <trygvis@inamo.no> | 2021-02-03 16:35:48 +0100 |
commit | bafe762ac01d16904c18404283027e426e19bc73 (patch) | |
tree | c22688ad186f5ce635f525704c5035f91b983b68 /module/acme/src/main/resources/io | |
parent | 91abd0b04320a9c9d932df195aca38c1cacfcc5a (diff) | |
download | rules-sandbox-bafe762ac01d16904c18404283027e426e19bc73.tar.gz rules-sandbox-bafe762ac01d16904c18404283027e426e19bc73.tar.bz2 rules-sandbox-bafe762ac01d16904c18404283027e426e19bc73.tar.xz rules-sandbox-bafe762ac01d16904c18404283027e426e19bc73.zip |
Code reorganization.
Moving main code to src, keeping modules in modules/
Diffstat (limited to 'module/acme/src/main/resources/io')
-rw-r--r-- | module/acme/src/main/resources/io/trygvis/acme/acme.drl | 81 | ||||
-rw-r--r-- | module/acme/src/main/resources/io/trygvis/acme/apps/apps.drl | 44 |
2 files changed, 0 insertions, 125 deletions
diff --git a/module/acme/src/main/resources/io/trygvis/acme/acme.drl b/module/acme/src/main/resources/io/trygvis/acme/acme.drl deleted file mode 100644 index 6a2f33b..0000000 --- a/module/acme/src/main/resources/io/trygvis/acme/acme.drl +++ /dev/null @@ -1,81 +0,0 @@ -package io.trygvis.acme; - -import io.trygvis.rules.machine.Machine; -import io.trygvis.rules.dba.Cluster; -import io.trygvis.rules.dba.Container -import io.trygvis.rules.terraform.TerraformResource; -import io.trygvis.rules.terraform.TerraformMain -import io.trygvis.rules.terraform.TerraformProvider; - -dialect "mvel" - -declare AcmeServer - name : String - machine : Machine -end - -rule "Create Acme servers" -when - $m : Machine(name.startsWith("acme-")) - not(AcmeServer(name == $m.name)) -then - var s = new AcmeServer(); - s.name = $m.name; - s.machine = $m; - insert(s); -end - -rule "Set public domain for ACME servers" -when - $m : Machine(fqdn == null) - $s : AcmeServer(machine == $m) -then - var fqdn = "%s.machine.acme.com".formatted($m.name); - modify ($m) { - fqdn = fqdn - } -end - -rule "Make Terraform module for machines" -when - not TerraformMain(module == "terraform") -then - var module = new TerraformMain("terraform"); - - var scaleway = new TerraformProvider("scaleway", "2.0.0-rc1"); - module.getProviders().put("scaleway", scaleway); - - insert(module) -end - -rule "Make Scaleway Terraform resources for Machine" -when - $m : Machine() - $s : AcmeServer(machine == $m) -then - var ip = new TerraformResource("terraform/" + $m.name + "-ip.tf", "scaleway_instance_ip", $m.name); - var instance = new TerraformResource("terraform/" + $m.name + "-instance.tf", "scaleway_server_instance", $m.name) - .set("name", "acme-1") - .set("type", "DEV1-S") - .set("image", "b3042271-d2b1-4f87-b407-aedd3bbd1663") - .setExpression("ip_id", ip.name + ".ip") - .set("enable_dynamic_ip", false) - .set("enable_ipv6", true); - - - var rev = new TerraformResource("terraform/" + $m.name + "-ip.tf", "scaleway_instance_reverse_dns", $m.name) - .set("reverse", $m.fqdn + ".") - .setExpression("ip_id", ip.name + ".id"); - var dns = new TerraformResource("terraform/" + $m.name + "-dns.tf", "google_dns_record_set", $m.name) - .set("name", $m.fqdn) - .setExpression("managed_zone", "var.dns_zone") - .set("type", "A") - .set("ttl", 300) - .array("rrdatas") - .addExpression(ip.name + ".id"); - - insert(instance) - insert(ip) - insert(rev) - insert(dns) -end diff --git a/module/acme/src/main/resources/io/trygvis/acme/apps/apps.drl b/module/acme/src/main/resources/io/trygvis/acme/apps/apps.drl deleted file mode 100644 index 670079f..0000000 --- a/module/acme/src/main/resources/io/trygvis/acme/apps/apps.drl +++ /dev/null @@ -1,44 +0,0 @@ -package io.trygvis.acme.apps - -import io.trygvis.rules.machine.Machine; -import io.trygvis.rules.dba.Cluster; -import io.trygvis.rules.dba.Container -import io.trygvis.rules.dns.DnsZone; -import io.trygvis.rules.machine.Machine -import io.trygvis.rules.machine.MachineSpecification -import io.trygvis.rules.dba.Cluster -import io.trygvis.rules.dba.Container - -dialect "mvel" - -rule "Ops" -when - $ops: AcmeOps() -then - var cluster = new Cluster("acme-ops"); - insert(cluster); - insert(new Container(cluster, "pdb", "ops", "postgresql", "11", null)); - insert(new Container(cluster, "n8n", "ops", "n8n", "0.84.1", null)); -end - -rule "MyApp" -when - $app: AcmeMyApp() -then - var zone = new DnsZone($app.environment + ".acme.com"); - insert(zone) - - var cluster = new Cluster("acme-myapp-" + $app.environment); - insert(cluster); - - var app = $app.environment + "-app"; - var db = $app.environment + "-db"; - - var tag = $app.dockerTag; - insert(new Container(cluster, "statera", app, "statera", tag, new MachineSpecification(200, 1000))); - insert(new Container(cluster, "statera-console", app, "statera-console", tag, new MachineSpecification(100, 50))); - insert(new Container(cluster, "4tune-web", app, "4tune-web", tag, new MachineSpecification(100, 50))); - insert(new Container(cluster, "4tune-api", app, "4tune-api", tag, new MachineSpecification(200, 200))); - insert(new Container(cluster, "pdb", db, "postgresql", "13", new MachineSpecification(500, 500))); - insert(new Container(cluster, "mdb", db, "mongodb", "3.2", new MachineSpecification(500, 200))); -end |