aboutsummaryrefslogtreecommitdiff
path: root/srcs/phpmyadmin/libraries/classes/Plugins/Schema/Eps/EpsRelationSchema.php
diff options
context:
space:
mode:
authorCharles Cabergs <me@cacharle.xyz>2020-07-27 10:05:23 +0200
committerCharles Cabergs <me@cacharle.xyz>2020-07-27 10:05:23 +0200
commit5bf66662a9bdd62c5bccab15e607cd95cfb8fcab (patch)
tree39a1a4629749056191c05dfd899f931701b7acf3 /srcs/phpmyadmin/libraries/classes/Plugins/Schema/Eps/EpsRelationSchema.php
parent5afd237bbd22028b85532b8c0b3fcead49a00764 (diff)
downloadft_server-5bf66662a9bdd62c5bccab15e607cd95cfb8fcab.tar.gz
ft_server-5bf66662a9bdd62c5bccab15e607cd95cfb8fcab.tar.bz2
ft_server-5bf66662a9bdd62c5bccab15e607cd95cfb8fcab.zip
Removed wordpress and phpmyadmin, my server doesn't handle it well and it brings shame on my famillyHEADmaster
Diffstat (limited to 'srcs/phpmyadmin/libraries/classes/Plugins/Schema/Eps/EpsRelationSchema.php')
-rw-r--r--srcs/phpmyadmin/libraries/classes/Plugins/Schema/Eps/EpsRelationSchema.php254
1 files changed, 0 insertions, 254 deletions
diff --git a/srcs/phpmyadmin/libraries/classes/Plugins/Schema/Eps/EpsRelationSchema.php b/srcs/phpmyadmin/libraries/classes/Plugins/Schema/Eps/EpsRelationSchema.php
deleted file mode 100644
index 238af1b..0000000
--- a/srcs/phpmyadmin/libraries/classes/Plugins/Schema/Eps/EpsRelationSchema.php
+++ /dev/null
@@ -1,254 +0,0 @@
-<?php
-/* vim: set expandtab sw=4 ts=4 sts=4: */
-/**
- * Classes to create relation schema in EPS format.
- *
- * @package PhpMyAdmin
- */
-declare(strict_types=1);
-
-namespace PhpMyAdmin\Plugins\Schema\Eps;
-
-use PhpMyAdmin\Plugins\Schema\Dia\RelationStatsDia;
-use PhpMyAdmin\Plugins\Schema\Dia\TableStatsDia;
-use PhpMyAdmin\Plugins\Schema\ExportRelationSchema;
-use PhpMyAdmin\Plugins\Schema\Pdf\TableStatsPdf;
-use PhpMyAdmin\Plugins\Schema\Svg\TableStatsSvg;
-use PhpMyAdmin\Relation;
-
-/**
- * EPS Relation Schema Class
- *
- * Purpose of this class is to generate the EPS Document
- * which is used for representing the database diagrams.
- * This class uses post script commands and with
- * the combination of these commands actually helps in preparing EPS Document.
- *
- * This class inherits ExportRelationSchema class has common functionality added
- * to this class
- *
- * @package PhpMyAdmin
- * @name Eps_Relation_Schema
- */
-class EpsRelationSchema extends ExportRelationSchema
-{
- /**
- * @var TableStatsDia[]|TableStatsEps[]|TableStatsPdf[]|TableStatsSvg[]
- */
- private $_tables = [];
-
- /** @var RelationStatsEps[] Relations */
- private $_relations = [];
-
- private $_tablewidth;
-
- /**
- * The "PMA_EPS_Relation_Schema" constructor
- *
- * Upon instantiation This starts writing the EPS document
- * user will be prompted for download as .eps extension
- *
- * @param string $db database name
- *
- * @see PMA_EPS
- */
- public function __construct($db)
- {
- parent::__construct($db, new Eps());
-
- $this->setShowColor(isset($_REQUEST['eps_show_color']));
- $this->setShowKeys(isset($_REQUEST['eps_show_keys']));
- $this->setTableDimension(isset($_REQUEST['eps_show_table_dimension']));
- $this->setAllTablesSameWidth(isset($_REQUEST['eps_all_tables_same_width']));
- $this->setOrientation($_REQUEST['eps_orientation']);
-
- $this->diagram->setTitle(
- sprintf(
- __('Schema of the %s database - Page %s'),
- $this->db,
- $this->pageNumber
- )
- );
- $this->diagram->setAuthor('phpMyAdmin ' . PMA_VERSION);
- $this->diagram->setDate(date("j F Y, g:i a"));
- $this->diagram->setOrientation($this->orientation);
- $this->diagram->setFont('Verdana', '10');
-
- $alltables = $this->getTablesFromRequest();
-
- foreach ($alltables as $table) {
- if (! isset($this->_tables[$table])) {
- $this->_tables[$table] = new TableStatsEps(
- $this->diagram,
- $this->db,
- $table,
- $this->diagram->getFont(),
- $this->diagram->getFontSize(),
- $this->pageNumber,
- $this->_tablewidth,
- $this->showKeys,
- $this->tableDimension,
- $this->offline
- );
- }
-
- if ($this->sameWide) {
- $this->_tables[$table]->width = $this->_tablewidth;
- }
- }
-
- $seen_a_relation = false;
- foreach ($alltables as $one_table) {
- $exist_rel = $this->relation->getForeigners($this->db, $one_table, '', 'both');
- if (! $exist_rel) {
- continue;
- }
-
- $seen_a_relation = true;
- foreach ($exist_rel as $master_field => $rel) {
- /* put the foreign table on the schema only if selected
- * by the user
- * (do not use array_search() because we would have to
- * to do a === false and this is not PHP3 compatible)
- */
- if ($master_field != 'foreign_keys_data') {
- if (in_array($rel['foreign_table'], $alltables)) {
- $this->_addRelation(
- $one_table,
- $this->diagram->getFont(),
- $this->diagram->getFontSize(),
- $master_field,
- $rel['foreign_table'],
- $rel['foreign_field'],
- $this->tableDimension
- );
- }
- continue;
- }
-
- foreach ($rel as $one_key) {
- if (! in_array($one_key['ref_table_name'], $alltables)) {
- continue;
- }
-
- foreach ($one_key['index_list'] as $index => $one_field) {
- $this->_addRelation(
- $one_table,
- $this->diagram->getFont(),
- $this->diagram->getFontSize(),
- $one_field,
- $one_key['ref_table_name'],
- $one_key['ref_index_list'][$index],
- $this->tableDimension
- );
- }
- }
- }
- }
- if ($seen_a_relation) {
- $this->_drawRelations();
- }
-
- $this->_drawTables();
- $this->diagram->endEpsDoc();
- }
-
- /**
- * Output Eps Document for download
- *
- * @return void
- */
- public function showOutput()
- {
- $this->diagram->showOutput($this->getFileName('.eps'));
- }
-
- /**
- * Defines relation objects
- *
- * @param string $masterTable The master table name
- * @param string $font The font
- * @param int $fontSize The font size
- * @param string $masterField The relation field in the master table
- * @param string $foreignTable The foreign table name
- * @param string $foreignField The relation field in the foreign table
- * @param boolean $tableDimension Whether to display table position or not
- *
- * @return void
- *
- * @see _setMinMax,Table_Stats_Eps::__construct(),
- * PhpMyAdmin\Plugins\Schema\Eps\RelationStatsEps::__construct()
- */
- private function _addRelation(
- $masterTable,
- $font,
- $fontSize,
- $masterField,
- $foreignTable,
- $foreignField,
- $tableDimension
- ) {
- if (! isset($this->_tables[$masterTable])) {
- $this->_tables[$masterTable] = new TableStatsEps(
- $this->diagram,
- $this->db,
- $masterTable,
- $font,
- $fontSize,
- $this->pageNumber,
- $this->_tablewidth,
- false,
- $tableDimension
- );
- }
- if (! isset($this->_tables[$foreignTable])) {
- $this->_tables[$foreignTable] = new TableStatsEps(
- $this->diagram,
- $this->db,
- $foreignTable,
- $font,
- $fontSize,
- $this->pageNumber,
- $this->_tablewidth,
- false,
- $tableDimension
- );
- }
- $this->_relations[] = new RelationStatsEps(
- $this->diagram,
- $this->_tables[$masterTable],
- $masterField,
- $this->_tables[$foreignTable],
- $foreignField
- );
- }
-
- /**
- * Draws relation arrows and lines connects master table's master field to
- * foreign table's foreign field
- *
- * @return void
- *
- * @see Relation_Stats_Eps::relationDraw()
- */
- private function _drawRelations()
- {
- foreach ($this->_relations as $relation) {
- $relation->relationDraw();
- }
- }
-
- /**
- * Draws tables
- *
- * @return void
- *
- * @see Table_Stats_Eps::Table_Stats_tableDraw()
- */
- private function _drawTables()
- {
- foreach ($this->_tables as $table) {
- $table->tableDraw($this->showColor);
- }
- }
-}