mermaid_rails_erd 1.0.1

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.
@@ -0,0 +1,13 @@
1
+ # frozen_string_literal: true
2
+
3
+ module MermaidRailsErd
4
+ class RelationshipSymbolMapper
5
+ def map(assoc_type)
6
+ {
7
+ has_many: "||--o{",
8
+ has_one: "||--||",
9
+ belongs_to: "}o--||",
10
+ }[assoc_type] || "--"
11
+ end
12
+ end
13
+ end
@@ -0,0 +1,5 @@
1
+ # frozen_string_literal: true
2
+
3
+ module MermaidRailsErd
4
+ VERSION = "1.0.1"
5
+ end
@@ -0,0 +1,35 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "mermaid_rails_erd/version"
4
+ require_relative "mermaid_rails_erd/generator"
5
+ require_relative "mermaid_rails_erd/relationship"
6
+ require_relative "mermaid_rails_erd/mermaid_emitter"
7
+ require_relative "mermaid_rails_erd/column_info"
8
+ require_relative "mermaid_rails_erd/model_loader"
9
+ require_relative "mermaid_rails_erd/association_resolver"
10
+ require_relative "mermaid_rails_erd/polymorphic_targets_resolver"
11
+ require_relative "mermaid_rails_erd/relationship_symbol_mapper"
12
+ require_relative "mermaid_rails_erd/relationship_registry"
13
+ require_relative "mermaid_rails_erd/model_data_collector"
14
+ require_relative "mermaid_rails_erd/relationship_builders/base_relationship_builder"
15
+ require_relative "mermaid_rails_erd/relationship_builders/belongs_to_relationship_builder"
16
+ require_relative "mermaid_rails_erd/relationship_builders/has_many_relationship_builder"
17
+ require_relative "mermaid_rails_erd/relationship_builders/has_one_relationship_builder"
18
+ require_relative "mermaid_rails_erd/relationship_builders/habtm_relationship_builder"
19
+ require_relative "mermaid_rails_erd/railtie" if defined?(Rails)
20
+
21
+ module MermaidRailsErd
22
+ class Error < StandardError; end
23
+
24
+ # Build and return a Generator instance with all data collected
25
+ # @return [Generator] Generator instance with collected data
26
+ def self.build
27
+ Generator.new.build
28
+ end
29
+
30
+ # Generate Mermaid ERD and write to output stream
31
+ # @param output [IO] Output stream to write the ERD to
32
+ def self.generate(output: $stdout)
33
+ build.emit(output: output)
34
+ end
35
+ end
@@ -0,0 +1,36 @@
1
+ # frozen_string_literal: true
2
+
3
+ require "mermaid_rails_erd"
4
+
5
+ namespace :mermaid_rails_erd do
6
+ desc "Generate Mermaid ERD diagram from ActiveRecord models"
7
+ task generate: :environment do
8
+ output_path = Rails.root.join("tmp", "#{ActiveRecord::Base.connection.current_database}.mmd")
9
+
10
+ # Ensure tmp directory exists
11
+ FileUtils.mkdir_p(File.dirname(output_path))
12
+
13
+ if File.exist?(output_path)
14
+ puts "Warning: Overwriting existing file at #{output_path}"
15
+ # Optional: Create backup
16
+ # FileUtils.cp(output_path, "#{output_path}.bak")
17
+ end
18
+
19
+ begin
20
+ File.open(output_path, "w") do |file|
21
+ puts "Generating Mermaid ERD diagram..."
22
+ MermaidRailsErd.generate(output: file)
23
+ end
24
+ rescue Errno::EACCES, IOError => e
25
+ puts "Error: Could not write to #{output_path}: #{e.message}"
26
+ end
27
+
28
+ # Make output instructions more visible
29
+ puts "\n#{'=' * 80}"
30
+ puts "\n ERD diagram generated at: #{output_path}"
31
+ puts "\n 📊 DIAGRAM VIEWING:\n".upcase
32
+ puts "\n - Mermaid ERD Visualizer: https://github.com/delexw/mermaid-erd-visualizer"
33
+ puts "\n"
34
+ puts "#{'=' * 80}\n"
35
+ end
36
+ end
@@ -0,0 +1,46 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "lib/mermaid_rails_erd/version"
4
+
5
+ Gem::Specification.new do |spec|
6
+ spec.name = "mermaid_rails_erd"
7
+ spec.version = MermaidRailsErd::VERSION
8
+ spec.authors = ["YL"]
9
+ spec.email = ["adamyoungliu@gmail.com"]
10
+
11
+ spec.summary = "Generate Mermaid.js Entity Relationship Diagrams from ActiveRecord models"
12
+ spec.description = "A Ruby gem that introspects ActiveRecord models and generates Mermaid.js ERD syntax for visualizing database relationships in Rails applications."
13
+ spec.homepage = "https://github.com/delexw/mermaid_rails_erd"
14
+ spec.license = "MIT"
15
+ spec.required_ruby_version = Gem::Requirement.new(">= 3.1.0")
16
+
17
+ spec.metadata["allowed_push_host"] = "https://rubygems.org"
18
+ spec.metadata["homepage_uri"] = spec.homepage
19
+ spec.metadata["source_code_uri"] = "https://github.com/delexw/mermaid_rails_erd"
20
+ spec.metadata["changelog_uri"] = "https://github.com/delexw/mermaid_rails_erd/blob/main/CHANGELOG.md"
21
+
22
+ # Specify which files should be added to the gem when it is released.
23
+ spec.files = Dir.glob("{lib,bin}/**/*") + Dir.glob("lib/tasks/**/*.rake") + %w[
24
+ README.md
25
+ Rakefile
26
+ mermaid_rails_erd.gemspec
27
+ LICENSE
28
+ ]
29
+ spec.bindir = "bin"
30
+ spec.executables = spec.files.grep(%r{\Abin/}) { |f| File.basename(f) }
31
+ spec.require_paths = ["lib"]
32
+
33
+ # Dependencies
34
+ spec.add_dependency "activerecord", ">= 6.0"
35
+ spec.add_dependency "activesupport", ">= 6.0"
36
+ spec.add_dependency "railties", ">= 6.0"
37
+
38
+ # Development dependencies
39
+ spec.add_development_dependency "bundler-audit", "~> 0.9"
40
+ spec.add_development_dependency "rake", "~> 13.0"
41
+ spec.add_development_dependency "rspec", "~> 3.0"
42
+ spec.add_development_dependency "rspec_junit_formatter", "~> 0.6"
43
+ spec.add_development_dependency "rubocop", "~> 1.50"
44
+ spec.add_development_dependency "rubocop-rspec", "~> 3.6.0"
45
+ spec.metadata["rubygems_mfa_required"] = "true"
46
+ end
metadata ADDED
@@ -0,0 +1,205 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: mermaid_rails_erd
3
+ version: !ruby/object:Gem::Version
4
+ version: 1.0.1
5
+ platform: ruby
6
+ authors:
7
+ - YL
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2025-06-18 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: activerecord
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '6.0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: '6.0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: activesupport
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '6.0'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '6.0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: railties
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: '6.0'
48
+ type: :runtime
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ">="
53
+ - !ruby/object:Gem::Version
54
+ version: '6.0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: bundler-audit
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - "~>"
60
+ - !ruby/object:Gem::Version
61
+ version: '0.9'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - "~>"
67
+ - !ruby/object:Gem::Version
68
+ version: '0.9'
69
+ - !ruby/object:Gem::Dependency
70
+ name: rake
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - "~>"
74
+ - !ruby/object:Gem::Version
75
+ version: '13.0'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - "~>"
81
+ - !ruby/object:Gem::Version
82
+ version: '13.0'
83
+ - !ruby/object:Gem::Dependency
84
+ name: rspec
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - "~>"
88
+ - !ruby/object:Gem::Version
89
+ version: '3.0'
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - "~>"
95
+ - !ruby/object:Gem::Version
96
+ version: '3.0'
97
+ - !ruby/object:Gem::Dependency
98
+ name: rspec_junit_formatter
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - "~>"
102
+ - !ruby/object:Gem::Version
103
+ version: '0.6'
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - "~>"
109
+ - !ruby/object:Gem::Version
110
+ version: '0.6'
111
+ - !ruby/object:Gem::Dependency
112
+ name: rubocop
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - "~>"
116
+ - !ruby/object:Gem::Version
117
+ version: '1.50'
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - "~>"
123
+ - !ruby/object:Gem::Version
124
+ version: '1.50'
125
+ - !ruby/object:Gem::Dependency
126
+ name: rubocop-rspec
127
+ requirement: !ruby/object:Gem::Requirement
128
+ requirements:
129
+ - - "~>"
130
+ - !ruby/object:Gem::Version
131
+ version: 3.6.0
132
+ type: :development
133
+ prerelease: false
134
+ version_requirements: !ruby/object:Gem::Requirement
135
+ requirements:
136
+ - - "~>"
137
+ - !ruby/object:Gem::Version
138
+ version: 3.6.0
139
+ description: A Ruby gem that introspects ActiveRecord models and generates Mermaid.js
140
+ ERD syntax for visualizing database relationships in Rails applications.
141
+ email:
142
+ - adamyoungliu@gmail.com
143
+ executables:
144
+ - console
145
+ - release
146
+ - setup
147
+ extensions: []
148
+ extra_rdoc_files: []
149
+ files:
150
+ - LICENSE
151
+ - README.md
152
+ - Rakefile
153
+ - bin/console
154
+ - bin/release
155
+ - bin/setup
156
+ - lib/mermaid_rails_erd.rb
157
+ - lib/mermaid_rails_erd/association_resolver.rb
158
+ - lib/mermaid_rails_erd/column_info.rb
159
+ - lib/mermaid_rails_erd/generator.rb
160
+ - lib/mermaid_rails_erd/mermaid_emitter.rb
161
+ - lib/mermaid_rails_erd/model_data_collector.rb
162
+ - lib/mermaid_rails_erd/model_loader.rb
163
+ - lib/mermaid_rails_erd/parsed_data.rb
164
+ - lib/mermaid_rails_erd/polymorphic_targets_resolver.rb
165
+ - lib/mermaid_rails_erd/railtie.rb
166
+ - lib/mermaid_rails_erd/relationship.rb
167
+ - lib/mermaid_rails_erd/relationship_builders/base_relationship_builder.rb
168
+ - lib/mermaid_rails_erd/relationship_builders/belongs_to_relationship_builder.rb
169
+ - lib/mermaid_rails_erd/relationship_builders/habtm_relationship_builder.rb
170
+ - lib/mermaid_rails_erd/relationship_builders/has_many_relationship_builder.rb
171
+ - lib/mermaid_rails_erd/relationship_builders/has_one_relationship_builder.rb
172
+ - lib/mermaid_rails_erd/relationship_registry.rb
173
+ - lib/mermaid_rails_erd/relationship_symbol_mapper.rb
174
+ - lib/mermaid_rails_erd/version.rb
175
+ - lib/tasks/mermaid_rails_erd.rake
176
+ - mermaid_rails_erd.gemspec
177
+ homepage: https://github.com/delexw/mermaid_rails_erd
178
+ licenses:
179
+ - MIT
180
+ metadata:
181
+ allowed_push_host: https://rubygems.org
182
+ homepage_uri: https://github.com/delexw/mermaid_rails_erd
183
+ source_code_uri: https://github.com/delexw/mermaid_rails_erd
184
+ changelog_uri: https://github.com/delexw/mermaid_rails_erd/blob/main/CHANGELOG.md
185
+ rubygems_mfa_required: 'true'
186
+ post_install_message:
187
+ rdoc_options: []
188
+ require_paths:
189
+ - lib
190
+ required_ruby_version: !ruby/object:Gem::Requirement
191
+ requirements:
192
+ - - ">="
193
+ - !ruby/object:Gem::Version
194
+ version: 3.1.0
195
+ required_rubygems_version: !ruby/object:Gem::Requirement
196
+ requirements:
197
+ - - ">="
198
+ - !ruby/object:Gem::Version
199
+ version: '0'
200
+ requirements: []
201
+ rubygems_version: 3.3.18
202
+ signing_key:
203
+ specification_version: 4
204
+ summary: Generate Mermaid.js Entity Relationship Diagrams from ActiveRecord models
205
+ test_files: []