Code Duplication    Length = 20-21 lines in 3 locations

src/Phinx/Db/Adapter/SqlServerAdapter.php 1 location

@@ 732-752 (lines=21) @@
729
    /**
730
     * {@inheritdoc}
731
     */
732
    public function hasForeignKey($tableName, $columns, $constraint = null)
733
    {
734
        if (is_string($columns)) {
735
            $columns = [$columns]; // str to array
736
        }
737
        $foreignKeys = $this->getForeignKeys($tableName);
738
        if ($constraint) {
739
            if (isset($foreignKeys[$constraint])) {
740
                return !empty($foreignKeys[$constraint]);
741
            }
742
743
            return false;
744
        } else {
745
            foreach ($foreignKeys as $key) {
746
                $a = array_diff($columns, $key['columns']);
747
                if (empty($a)) {
748
                    return true;
749
                }
750
            }
751
752
            return false;
753
        }
754
    }
755

src/Phinx/Db/Adapter/PostgresAdapter.php 1 location

@@ 606-626 (lines=21) @@
603
    /**
604
     * {@inheritdoc}
605
     */
606
    public function hasForeignKey($tableName, $columns, $constraint = null)
607
    {
608
        if (is_string($columns)) {
609
            $columns = [$columns]; // str to array
610
        }
611
        $foreignKeys = $this->getForeignKeys($tableName);
612
        if ($constraint) {
613
            if (isset($foreignKeys[$constraint])) {
614
                return !empty($foreignKeys[$constraint]);
615
            }
616
617
            return false;
618
        } else {
619
            foreach ($foreignKeys as $key) {
620
                $a = array_diff($columns, $key['columns']);
621
                if (empty($a)) {
622
                    return true;
623
                }
624
            }
625
626
            return false;
627
        }
628
    }
629

src/Phinx/Db/Adapter/MysqlAdapter.php 1 location

@@ 625-644 (lines=20) @@
622
    /**
623
     * {@inheritdoc}
624
     */
625
    public function hasForeignKey($tableName, $columns, $constraint = null)
626
    {
627
        if (is_string($columns)) {
628
            $columns = [$columns]; // str to array
629
        }
630
        $foreignKeys = $this->getForeignKeys($tableName);
631
        if ($constraint) {
632
            if (isset($foreignKeys[$constraint])) {
633
                return !empty($foreignKeys[$constraint]);
634
            }
635
636
            return false;
637
        } else {
638
            foreach ($foreignKeys as $key) {
639
                if ($columns == $key['columns']) {
640
                    return true;
641
                }
642
            }
643
644
            return false;
645
        }
646
    }
647