Generates data model visualisations from SilverSripe DataObjects, displaying database fields, relations and ancestry
Creates data model visualisations of SilverStripe DataObjects, showing fields, relations and ancestry.
Can output images in .png, .svg and raw GraphViz "dot" format.
Flexible configuration options and can be called from command line and URL.
Example call: http://example.com/Silvergraph/png?location=cms,framework,mysite
##Installation##
composer require froog/silvergraph
(* for version) and visit ?flush=1
to update the routing table.SilverGraph
folder in the top level of your site and visit ?flush=1
to update the routing table.###Installation on OSX###
brew install graphviz
and note down the location_ss_environment.php
file, postpending 'dot' to the end of the path, e.g.:define('SILVERGRAPH_GRAPHVIZ_PATH', '/usr/local/Cellar/graphviz/2.38.0/bin/dot');
?flush=1
to update the routing table.##Requirements##
apt-get install graphviz
##Usage##
###Command line: (in site root)###
sake Silvergraph/png > datamodel.png
sake Silvergraph/png location=mysite,cms inherited=1 exclude=SiteTree > datamodel.png
sake Silvergraph/dot > datamodel.dot
###Browser: (logged in as admin)###
###Parameters###
####Specify the folder to look for classes under
location=mysite
(default) Only graph classes under the /mysite folderlocation=/
Graph ALL classes in every module (warning - may take a long time and could generate a large .png)location=mysite,mymodule
Only graph classes under /mysite and /mymodule folders####Remove specific classes from the graph
exclude=SiteTree
exclude=SiteTree,File
####How verbosely to show relations
relations=0
Don't show any relationsrelations=1
(default) Don't show inherited relationsrelations=2
Show inherited relations (verbose)####How verbosely to show fields
fields=0
Don't show any fieldsfields=1
(default) Show only fields defined on selffields=2
Show inherited fields (verbose)####How verbosely to show ancestors
ancestry=0
Don't show any ancestry relationsancestry=1
(default) Show ancestry relations####Include DataObject on the graph
include-root=0
(default) Don't graph DataObjectinclude-root=1
Graph DataObject####Group classes by modules
group=0
(default) Don't group by modulesgroup=1
Group the modules into their own container####Specify direction graph is laid out
rankdir=x
Where x is TB
(default) ,LR
,RL
, or BT
(top-bottom, left-right, right-left, bottom-top)Module rating system helping users find modules that are well supported. For more on how the rating system works visit Module standards
Score not correct? Let us know there is a problem