schema.sql.c 3.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. #define ZT_NETCONF_SCHEMA_SQL \
  2. "CREATE TABLE Config (\n"\
  3. " k varchar(16) PRIMARY KEY NOT NULL,\n"\
  4. " v varchar(1024) NOT NULL\n"\
  5. ");\n"\
  6. "\n"\
  7. "CREATE TABLE Network (\n"\
  8. " id char(16) PRIMARY KEY NOT NULL,\n"\
  9. " name varchar(128) NOT NULL,\n"\
  10. " private integer NOT NULL DEFAULT(1),\n"\
  11. " enableBroadcast integer NOT NULL DEFAULT(1),\n"\
  12. " allowPassiveBridging integer NOT NULL DEFAULT(0),\n"\
  13. " v4AssignMode varchar(8) NOT NULL DEFAULT('none'),\n"\
  14. " v6AssignMode varchar(8) NOT NULL DEFAULT('none'),\n"\
  15. " multicastLimit integer NOT NULL DEFAULT(32),\n"\
  16. " creationTime integer NOT NULL DEFAULT(0),\n"\
  17. " revision integer NOT NULL DEFAULT(1)\n"\
  18. ");\n"\
  19. "\n"\
  20. "CREATE TABLE Node (\n"\
  21. " id char(10) PRIMARY KEY NOT NULL,\n"\
  22. " identity varchar(4096) NOT NULL\n"\
  23. ");\n"\
  24. "\n"\
  25. "CREATE TABLE Gateway (\n"\
  26. " networkId char(16) NOT NULL REFERENCES Network(id) ON DELETE CASCADE,\n"\
  27. " ip blob(16) NOT NULL,\n"\
  28. " ipVersion integer NOT NULL DEFAULT(4),\n"\
  29. " metric integer NOT NULL DEFAULT(0)\n"\
  30. ");\n"\
  31. "\n"\
  32. "CREATE UNIQUE INDEX Gateway_networkId_ip ON Gateway (networkId, ip);\n"\
  33. "\n"\
  34. "CREATE TABLE IpAssignment (\n"\
  35. " networkId char(16) NOT NULL REFERENCES Network(id) ON DELETE CASCADE,\n"\
  36. " nodeId char(10) REFERENCES Node(id) ON DELETE CASCADE,\n"\
  37. " type integer NOT NULL DEFAULT(0),\n"\
  38. " ip blob(16) NOT NULL,\n"\
  39. " ipNetmaskBits integer NOT NULL DEFAULT(0),\n"\
  40. " ipVersion integer NOT NULL DEFAULT(4)\n"\
  41. ");\n"\
  42. "\n"\
  43. "CREATE UNIQUE INDEX IpAssignment_networkId_ip ON IpAssignment (networkId, ip);\n"\
  44. "\n"\
  45. "CREATE INDEX IpAssignment_networkId_nodeId ON IpAssignment (networkId, nodeId);\n"\
  46. "\n"\
  47. "CREATE TABLE IpAssignmentPool (\n"\
  48. " networkId char(16) NOT NULL REFERENCES Network(id) ON DELETE CASCADE,\n"\
  49. " ipRangeStart blob(16) NOT NULL,\n"\
  50. " ipRangeEnd blob(16) NOT NULL,\n"\
  51. " ipVersion integer NOT NULL DEFAULT(4)\n"\
  52. ");\n"\
  53. "\n"\
  54. "CREATE UNIQUE INDEX IpAssignmentPool_networkId_ipRangeStart ON IpAssignmentPool (networkId,ipRangeStart);\n"\
  55. "\n"\
  56. "CREATE TABLE Member (\n"\
  57. " networkId char(16) NOT NULL REFERENCES Network(id) ON DELETE CASCADE,\n"\
  58. " nodeId char(10) NOT NULL REFERENCES Node(id) ON DELETE CASCADE,\n"\
  59. " authorized integer NOT NULL DEFAULT(0),\n"\
  60. " activeBridge integer NOT NULL DEFAULT(0),\n"\
  61. " PRIMARY KEY (networkId, nodeId)\n"\
  62. ");\n"\
  63. "\n"\
  64. "CREATE INDEX Member_networkId_activeBridge ON Member(networkId, activeBridge);\n"\
  65. "\n"\
  66. "CREATE TABLE Relay (\n"\
  67. " networkId char(16) NOT NULL REFERENCES Network(id) ON DELETE CASCADE,\n"\
  68. " nodeId char(10) NOT NULL REFERENCES Node(id) ON DELETE CASCADE,\n"\
  69. " phyAddress varchar(64) NOT NULL,\n"\
  70. " PRIMARY KEY (networkId, nodeId)\n"\
  71. ");\n"\
  72. "\n"\
  73. "CREATE INDEX Relay_networkId ON Relay (networkId);\n"\
  74. "\n"\
  75. "CREATE TABLE Rule (\n"\
  76. " networkId char(16) NOT NULL REFERENCES Network(id) ON DELETE CASCADE,\n"\
  77. " ruleNo integer NOT NULL,\n"\
  78. " nodeId char(10) REFERENCES Node(id),\n"\
  79. " sourcePort char(10),\n"\
  80. " destPort char(10),\n"\
  81. " vlanId integer,\n"\
  82. " vlanPcp integer,\n"\
  83. " etherType integer,\n"\
  84. " macSource char(12),\n"\
  85. " macDest char(12),\n"\
  86. " ipSource varchar(64),\n"\
  87. " ipDest varchar(64),\n"\
  88. " ipTos integer,\n"\
  89. " ipProtocol integer,\n"\
  90. " ipSourcePort integer,\n"\
  91. " ipDestPort integer,\n"\
  92. " flags integer,\n"\
  93. " invFlags integer,\n"\
  94. " \"action\" varchar(4096) NOT NULL DEFAULT('accept')\n"\
  95. ");\n"\
  96. "\n"\
  97. "CREATE UNIQUE INDEX Rule_networkId_ruleNo ON Rule (networkId, ruleNo);\n"\
  98. ""