legion-data 1.1.5 → 1.3.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (91) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/ci.yml +16 -0
  3. data/.gitignore +10 -2
  4. data/.rubocop.yml +41 -18
  5. data/CHANGELOG.md +82 -15
  6. data/CLAUDE.md +199 -0
  7. data/Gemfile +11 -1
  8. data/LICENSE +201 -0
  9. data/README.md +163 -19
  10. data/exe/legionio_migrate +0 -0
  11. data/legion-data.gemspec +22 -35
  12. data/lib/legion/data/connection.rb +39 -25
  13. data/lib/legion/data/encryption/cipher.rb +49 -0
  14. data/lib/legion/data/encryption/key_provider.rb +45 -0
  15. data/lib/legion/data/encryption/sequel_plugin.rb +54 -0
  16. data/lib/legion/data/event_store/projection.rb +56 -0
  17. data/lib/legion/data/event_store.rb +112 -0
  18. data/lib/legion/data/local.rb +77 -0
  19. data/lib/legion/data/migration.rb +5 -3
  20. data/lib/legion/data/migrations/001_add_schema_columns.rb +9 -3
  21. data/lib/legion/data/migrations/002_add_nodes.rb +18 -0
  22. data/lib/legion/data/migrations/003_add_settings.rb +18 -0
  23. data/lib/legion/data/migrations/004_add_extensions.rb +23 -0
  24. data/lib/legion/data/migrations/005_add_runners.rb +21 -0
  25. data/lib/legion/data/migrations/006_add_functions.rb +21 -0
  26. data/lib/legion/data/migrations/{015_add_default_extensions.rb → 007_add_default_extensions.rb} +3 -0
  27. data/lib/legion/data/migrations/008_add_tasks.rb +23 -0
  28. data/lib/legion/data/migrations/009_add_digital_workers.rb +45 -0
  29. data/lib/legion/data/migrations/010_add_value_metrics.rb +19 -0
  30. data/lib/legion/data/migrations/011_add_extensions_registry.rb +30 -0
  31. data/lib/legion/data/migrations/012_add_apollo_tables.rb +66 -0
  32. data/lib/legion/data/migrations/013_add_relationships.rb +21 -0
  33. data/lib/legion/data/migrations/014_add_relationship_columns.rb +27 -0
  34. data/lib/legion/data/migrations/015_add_rbac_tables.rb +49 -0
  35. data/lib/legion/data/migrations/016_add_worker_health.rb +33 -0
  36. data/lib/legion/data/migrations/017_add_audit_log.rb +30 -0
  37. data/lib/legion/data/migrations/018_add_governance_events.rb +21 -0
  38. data/lib/legion/data/migrations/019_add_audit_hash_chain.rb +29 -0
  39. data/lib/legion/data/migrations/020_add_webhooks.rb +37 -0
  40. data/lib/legion/data/model.rb +5 -2
  41. data/lib/legion/data/models/apollo_access_log.rb +13 -0
  42. data/lib/legion/data/models/apollo_entry.rb +18 -0
  43. data/lib/legion/data/models/apollo_expertise.rb +12 -0
  44. data/lib/legion/data/models/apollo_relation.rb +14 -0
  45. data/lib/legion/data/models/audit_log.rb +34 -0
  46. data/lib/legion/data/models/digital_worker.rb +44 -0
  47. data/lib/legion/data/models/extension.rb +0 -0
  48. data/lib/legion/data/models/function.rb +0 -2
  49. data/lib/legion/data/models/node.rb +17 -3
  50. data/lib/legion/data/models/rbac_cross_team_grant.rb +33 -0
  51. data/lib/legion/data/models/rbac_role_assignment.rb +29 -0
  52. data/lib/legion/data/models/rbac_runner_grant.rb +21 -0
  53. data/lib/legion/data/models/relationship.rb +3 -6
  54. data/lib/legion/data/models/runner.rb +0 -0
  55. data/lib/legion/data/models/setting.rb +0 -0
  56. data/lib/legion/data/models/task.rb +0 -0
  57. data/lib/legion/data/models/task_log.rb +0 -0
  58. data/lib/legion/data/settings.rb +37 -8
  59. data/lib/legion/data/version.rb +3 -1
  60. data/lib/legion/data.rb +31 -13
  61. metadata +64 -139
  62. data/.circleci/config.yml +0 -174
  63. data/.rspec +0 -1
  64. data/Gemfile.lock +0 -85
  65. data/Rakefile +0 -55
  66. data/bin/console +0 -14
  67. data/bin/setup +0 -8
  68. data/bitbucket-pipelines.yml +0 -26
  69. data/lib/legion/data/migrations/002_add_users.rb +0 -17
  70. data/lib/legion/data/migrations/003_add_groups.rb +0 -16
  71. data/lib/legion/data/migrations/004_add_chains.rb +0 -25
  72. data/lib/legion/data/migrations/005_add_envs.rb +0 -24
  73. data/lib/legion/data/migrations/006_add_dcs.rb +0 -24
  74. data/lib/legion/data/migrations/007_add_nodes.rb +0 -26
  75. data/lib/legion/data/migrations/008_add_settings.rb +0 -18
  76. data/lib/legion/data/migrations/009_add_extensions.rb +0 -25
  77. data/lib/legion/data/migrations/010_add_runners.rb +0 -21
  78. data/lib/legion/data/migrations/011_add_functions.rb +0 -29
  79. data/lib/legion/data/migrations/012_add_tasks.rb +0 -28
  80. data/lib/legion/data/migrations/013_add_task_logs.rb +0 -23
  81. data/lib/legion/data/migrations/014_add_relationships.rb +0 -27
  82. data/lib/legion/data/migrations/016_change_task_args.rb +0 -7
  83. data/lib/legion/data/migrations/017_add_payload_task.rb +0 -7
  84. data/lib/legion/data/migrations/018_add_migration_column.rb +0 -7
  85. data/lib/legion/data/migrations/019_add_debug_to_relationships.rb +0 -7
  86. data/lib/legion/data/migrations/020_add_delay_debug_to_tasks.rb +0 -8
  87. data/lib/legion/data/models/chain.rb +0 -11
  88. data/lib/legion/data/models/datacenter.rb +0 -11
  89. data/lib/legion/data/models/environment.rb +0 -11
  90. data/lib/legion/data/models/group.rb +0 -10
  91. data/lib/legion/data/models/user.rb +0 -10
@@ -1,25 +0,0 @@
1
- Sequel.migration do
2
- up do
3
- run "CREATE TABLE `chains` (
4
- `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
5
- `name` varchar(128) NOT NULL DEFAULT '',
6
- `active` tinyint(1) unsigned DEFAULT '1',
7
- `version` int(11) unsigned NOT NULL DEFAULT '1',
8
- `created` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
9
- `updated` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
10
- `user_owner` int(11) unsigned DEFAULT NULL,
11
- `group_owner` int(11) unsigned DEFAULT NULL,
12
- PRIMARY KEY (`id`),
13
- UNIQUE KEY `name` (`name`),
14
- KEY `active` (`active`),
15
- KEY `chains_user_owner` (`user_owner`),
16
- KEY `chains_group_owner` (`group_owner`),
17
- CONSTRAINT `chains_group_owner` FOREIGN KEY (`group_owner`) REFERENCES `groups` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
18
- CONSTRAINT `chains_user_owner` FOREIGN KEY (`user_owner`) REFERENCES `users` (`id`) ON DELETE SET NULL ON UPDATE CASCADE
19
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8;"
20
- end
21
-
22
- down do
23
- drop_table :chains
24
- end
25
- end
@@ -1,24 +0,0 @@
1
- Sequel.migration do
2
- up do
3
- run "CREATE TABLE `environments` (
4
- `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
5
- `name` varchar(128) NOT NULL DEFAULT '',
6
- `active` tinyint(1) unsigned NOT NULL DEFAULT '1',
7
- `user_owner` int(11) unsigned DEFAULT NULL,
8
- `group_owner` int(11) unsigned DEFAULT NULL,
9
- `created` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
10
- `updated` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
11
- PRIMARY KEY (`id`),
12
- UNIQUE KEY `name` (`name`),
13
- KEY `active` (`active`),
14
- KEY `environments_user_owner` (`user_owner`),
15
- KEY `environments_group_owner` (`group_owner`),
16
- CONSTRAINT `environments_group_owner` FOREIGN KEY (`group_owner`) REFERENCES `groups` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
17
- CONSTRAINT `environments_user_owner` FOREIGN KEY (`user_owner`) REFERENCES `users` (`id`) ON DELETE SET NULL ON UPDATE CASCADE
18
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8;"
19
- end
20
-
21
- down do
22
- drop_table :environments
23
- end
24
- end
@@ -1,24 +0,0 @@
1
- Sequel.migration do
2
- up do
3
- run "CREATE TABLE `datacenters` (
4
- `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
5
- `name` varchar(128) NOT NULL DEFAULT '',
6
- `active` tinyint(1) unsigned NOT NULL DEFAULT '1',
7
- `user_owner` int(11) unsigned DEFAULT NULL,
8
- `group_owner` int(11) unsigned DEFAULT NULL,
9
- `created` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
10
- `updated` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
11
- PRIMARY KEY (`id`),
12
- UNIQUE KEY `name` (`name`),
13
- KEY `active` (`active`),
14
- KEY `datacenters_user_owner` (`user_owner`),
15
- KEY `datacenters_group_owner` (`group_owner`),
16
- CONSTRAINT `datacenters_group_owner` FOREIGN KEY (`group_owner`) REFERENCES `groups` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
17
- CONSTRAINT `datacenters_user_owner` FOREIGN KEY (`user_owner`) REFERENCES `users` (`id`) ON DELETE SET NULL ON UPDATE CASCADE
18
- ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;"
19
- end
20
-
21
- down do
22
- drop_table :datacenters
23
- end
24
- end
@@ -1,26 +0,0 @@
1
- Sequel.migration do
2
- up do
3
- run "CREATE TABLE `nodes` (
4
- `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
5
- `name` varchar(128) NOT NULL DEFAULT '',
6
- `datacenter_id` int(11) unsigned DEFAULT NULL,
7
- `environment_id` int(11) unsigned DEFAULT NULL,
8
- `status` varchar(255) NOT NULL DEFAULT 'unknown',
9
- `active` tinyint(1) unsigned NOT NULL DEFAULT '1',
10
- `created` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
11
- `updated` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
12
- PRIMARY KEY (`id`),
13
- UNIQUE KEY `name` (`name`),
14
- KEY `active` (`active`),
15
- KEY `status` (`status`),
16
- KEY `node_datacenter_id` (`datacenter_id`),
17
- KEY `node_environment_id` (`environment_id`),
18
- CONSTRAINT `node_datacenter_id` FOREIGN KEY (`datacenter_id`) REFERENCES `datacenters` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
19
- CONSTRAINT `node_environment_id` FOREIGN KEY (`environment_id`) REFERENCES `environments` (`id`) ON DELETE SET NULL ON UPDATE CASCADE
20
- ) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;"
21
- end
22
-
23
- down do
24
- drop_table :nodes
25
- end
26
- end
@@ -1,18 +0,0 @@
1
- Sequel.migration do
2
- up do
3
- run "CREATE TABLE `settings` (
4
- `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
5
- `key` varchar(128) NOT NULL,
6
- `value` varchar(256) NOT NULL,
7
- `encrypted` tinyint(1) unsigned NOT NULL DEFAULT '0',
8
- `created` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
9
- `updated` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
10
- PRIMARY KEY (`id`),
11
- UNIQUE KEY `key` (`key`)
12
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8;"
13
- end
14
-
15
- down do
16
- drop_table :settings
17
- end
18
- end
@@ -1,25 +0,0 @@
1
- Sequel.migration do
2
- up do
3
- run "CREATE TABLE `extensions` (
4
- `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
5
- `active` tinyint(1) unsigned NOT NULL DEFAULT '1',
6
- `name` varchar(128) NOT NULL,
7
- `namespace` varchar(128) NOT NULL DEFAULT '',
8
- `exchange` varchar(255) DEFAULT NULL,
9
- `uri` varchar(256) DEFAULT NULL,
10
- `user_owner` int(11) unsigned DEFAULT NULL,
11
- `group_owner` int(11) unsigned DEFAULT NULL,
12
- `updated` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
13
- `created` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
14
- PRIMARY KEY (`id`),
15
- UNIQUE KEY `name_namespace` (`name`,`namespace`),
16
- KEY `active` (`active`),
17
- KEY `name` (`name`),
18
- KEY `namespace` (`namespace`)
19
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8;"
20
- end
21
-
22
- down do
23
- drop_table :extensions
24
- end
25
- end
@@ -1,21 +0,0 @@
1
- Sequel.migration do
2
- up do
3
- run "CREATE TABLE `runners` (
4
- `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
5
- `extension_id` int(11) unsigned NOT NULL,
6
- `name` varchar(256) NOT NULL DEFAULT '',
7
- `namespace` varchar(256) NOT NULL DEFAULT '',
8
- `active` tinyint(1) unsigned NOT NULL DEFAULT '1',
9
- `queue` varchar(256) DEFAULT NULL,
10
- `uri` varchar(256) DEFAULT NULL,
11
- `created` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
12
- `updated` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
13
- PRIMARY KEY (`id`),
14
- CONSTRAINT `runner_extension_id` FOREIGN KEY (`extension_id`) REFERENCES `extensions` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
15
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8;"
16
- end
17
-
18
- down do
19
- drop_table :runners
20
- end
21
- end
@@ -1,29 +0,0 @@
1
- Sequel.migration do
2
- up do
3
- run "CREATE TABLE `functions` (
4
- `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
5
- `name` varchar(128) NOT NULL,
6
- `active` tinyint(1) unsigned NOT NULL DEFAULT '1',
7
- `runner_id` int(11) unsigned NOT NULL,
8
- `args` text,
9
- `user_owner` int(11) unsigned DEFAULT NULL,
10
- `group_owner` int(11) unsigned DEFAULT NULL,
11
- `created` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
12
- `updated` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
13
- PRIMARY KEY (`id`),
14
- UNIQUE KEY `runner_id` (`runner_id`,`name`),
15
- KEY `active` (`active`),
16
- KEY `namespace` (`runner_id`),
17
- KEY `name` (`name`),
18
- KEY `functions_user_owner` (`user_owner`),
19
- KEY `functions_group_owner` (`group_owner`),
20
- CONSTRAINT `function_runner_id` FOREIGN KEY (`runner_id`) REFERENCES `runners` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
21
- CONSTRAINT `functions_group_owner` FOREIGN KEY (`group_owner`) REFERENCES `groups` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
22
- CONSTRAINT `functions_user_owner` FOREIGN KEY (`user_owner`) REFERENCES `users` (`id`) ON DELETE SET NULL ON UPDATE CASCADE
23
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8;"
24
- end
25
-
26
- down do
27
- drop_table :functions
28
- end
29
- end
@@ -1,28 +0,0 @@
1
- Sequel.migration do
2
- up do
3
- run "CREATE TABLE `tasks` (
4
- `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
5
- `relationship_id` int(11) unsigned DEFAULT NULL,
6
- `function_id` int(11) unsigned DEFAULT NULL,
7
- `status` varchar(255) NOT NULL,
8
- `parent_id` int(11) unsigned DEFAULT NULL,
9
- `master_id` int(11) unsigned DEFAULT NULL,
10
- `args` text,
11
- `results` text,
12
- `created` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
13
- `updated` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
14
- PRIMARY KEY (`id`),
15
- KEY `status` (`status`),
16
- KEY `parent_id` (`parent_id`),
17
- KEY `master_id` (`master_id`),
18
- KEY `relationship_id` (`relationship_id`),
19
- KEY `function_id` (`function_id`),
20
- CONSTRAINT `parent_id` FOREIGN KEY (`parent_id`) REFERENCES `tasks` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
21
- CONSTRAINT `master_id` FOREIGN KEY (`master_id`) REFERENCES `tasks` (`id`) ON DELETE SET NULL ON UPDATE CASCADE
22
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8;"
23
- end
24
-
25
- down do
26
- drop_table :tasks
27
- end
28
- end
@@ -1,23 +0,0 @@
1
- Sequel.migration do
2
- up do
3
- run "CREATE TABLE `task_logs` (
4
- `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
5
- `task_id` int(11) unsigned NOT NULL,
6
- `function_id` int(11) unsigned,
7
- `node_id` int(11) unsigned,
8
- `entry` text NOT NULL,
9
- `created` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
10
- `updated` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
11
- PRIMARY KEY (`id`),
12
- KEY (`created`),
13
- KEY (`updated`),
14
- CONSTRAINT `task_log_task_id` FOREIGN KEY (`task_id`) REFERENCES `tasks` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
15
- CONSTRAINT `task_log_functions` FOREIGN KEY (`function_id`) REFERENCES `functions` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
16
- CONSTRAINT `task_log_nodes` FOREIGN KEY (`node_id`) REFERENCES `nodes` (`id`) ON DELETE SET NULL ON UPDATE CASCADE
17
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8;"
18
- end
19
-
20
- down do
21
- drop_table :task_logs
22
- end
23
- end
@@ -1,27 +0,0 @@
1
- Sequel.migration do
2
- up do
3
- run "CREATE TABLE `relationships` (
4
- `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
5
- `name` varchar(255) DEFAULT NULL,
6
- `active` tinyint(1) unsigned NOT NULL DEFAULT '1',
7
- `chain_id` int(11) unsigned DEFAULT NULL,
8
- `trigger_id` int(11) unsigned NOT NULL,
9
- `action_id` int(11) unsigned NOT NULL,
10
- `delay` int(11) unsigned NOT NULL DEFAULT '0',
11
- `allow_new_chains` tinyint(1) unsigned NOT NULL DEFAULT '1',
12
- `conditions` text,
13
- `transformation` text,
14
- `created` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
15
- `updated` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
16
- PRIMARY KEY (`id`),
17
- KEY `chain_id` (`chain_id`),
18
- CONSTRAINT `function_chain_id` FOREIGN KEY (`chain_id`) REFERENCES `chains` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
19
- CONSTRAINT `relationship_action_id` FOREIGN KEY (`action_id`) REFERENCES `functions` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
20
- CONSTRAINT `relationship_trigger_id` FOREIGN KEY (`trigger_id`) REFERENCES `functions` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
21
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8;"
22
- end
23
-
24
- down do
25
- drop_table :relationships
26
- end
27
- end
@@ -1,7 +0,0 @@
1
- Sequel.migration do
2
- change do
3
- alter_table(:tasks) do
4
- rename_column :args, :function_args
5
- end
6
- end
7
- end
@@ -1,7 +0,0 @@
1
- Sequel.migration do
2
- change do
3
- alter_table(:tasks) do
4
- add_column :payload, :text
5
- end
6
- end
7
- end
@@ -1,7 +0,0 @@
1
- Sequel.migration do
2
- change do
3
- alter_table(:extensions) do
4
- add_column :schema_version, Integer, null: false, default: 0, index: true
5
- end
6
- end
7
- end
@@ -1,7 +0,0 @@
1
- Sequel.migration do
2
- change do
3
- alter_table(:relationships) do
4
- add_column :debug, Integer, null: false, default: 0, index: true
5
- end
6
- end
7
- end
@@ -1,8 +0,0 @@
1
- Sequel.migration do
2
- change do
3
- alter_table(:tasks) do
4
- add_column :delay, Integer, limit: 1, null: false, default: 0, index: true
5
- add_column :debug, Integer, limit: 1, null: false, default: 0, index: true
6
- end
7
- end
8
- end
@@ -1,11 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Legion
4
- module Data
5
- module Model
6
- class Chain < Sequel::Model
7
- one_to_many :relationship
8
- end
9
- end
10
- end
11
- end
@@ -1,11 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Legion
4
- module Data
5
- module Model
6
- class Datacenter < Sequel::Model
7
- one_to_many :node
8
- end
9
- end
10
- end
11
- end
@@ -1,11 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Legion
4
- module Data
5
- module Model
6
- class Environment < Sequel::Model
7
- one_to_many :node
8
- end
9
- end
10
- end
11
- end
@@ -1,10 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Legion
4
- module Data
5
- module Model
6
- class Group < Sequel::Model
7
- end
8
- end
9
- end
10
- end
@@ -1,10 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Legion
4
- module Data
5
- module Model
6
- class User < Sequel::Model
7
- end
8
- end
9
- end
10
- end