Subversion-Projekte lars-tiefland.laravel_shop

Revision

Revision 1237 | Details | Vergleich mit vorheriger | Letzte Änderung | Log anzeigen | RSS feed

Revision Autor Zeilennr. Zeile
1117 lars 1
<?php
2
 
3
    namespace App\Http\Controllers;
4
 
1227 lars 5
    use Illuminate\Http\Request;
1176 lars 6
    use Illuminate\Support\Facades\DB;
1193 lars 7
    use Illuminate\View\View;
1176 lars 8
 
1117 lars 9
    class ToolboxController extends Controller
10
    {
1188 lars 11
        private string $xmlDir;
12
 
1193 lars 13
        public function create(): View
1117 lars 14
        {
15
            return view( "admin/toolbox/index" );
16
        }
1122 lars 17
 
1228 lars 18
        public function updateShopVersion( Request $request ): void
1226 lars 19
        {
20
 
1227 lars 21
            $version = $request->version;
1236 lars 22
            $shop = $request->shop;
1227 lars 23
            $verz = $request->verz;
1230 lars 24
            $server = $request->serverName;
1226 lars 25
            $srcDir = "/usr/share/php7/webanOS/" . $version;
26
            //trigger_error( $srcDir );
27
            $dstDir = "/var/www/vhosts/" . $shop . "/" . $verz;
28
            $cmd1 = "sudo ln -sfn " . $srcDir . " " . $dstDir . "/source";
29
            $cmd2 = "sudo ln -s " . $dstDir . "/source/*.php " . $dstDir;
30
            $cmd3 = "sudo ln -s " . $dstDir . "/source/preisagentur/*.php " . $dstDir . "/preisagentur";
31
 
32
            if ( $_SERVER["HTTP_HOST"] == "faltradxxs.lars-tiefland.de" )
33
            {
1233 lars 34
                if ( $server )
1226 lars 35
                {
36
                    $dom = "webanos." . $server;
37
                    $sql = "SELECT
38
                            dok_domain
39
                        FROM
40
                            webs
41
                        WHERE
42
                            domain='" . $server . "'
43
                    ";
1232 lars 44
                    $res = DB::connection( 'cms' )->select( $sql );
1231 lars 45
                    $row = $res[0];
1235 lars 46
                    if ( $row->dok_domain )
1226 lars 47
                    {
1235 lars 48
                        $dom = $row->dok_domain;
1226 lars 49
                    }
50
                    $cmd1 = "ssh -p910 www-data@" . $dom . " " . $cmd1;
51
                    $cmd2 = "ssh -p910 www-data@" . $dom . " " . $cmd2;
52
                    $cmd3 = "ssh -p910 www-data@" . $dom . " " . $cmd3;
53
                }
54
            }
55
            exec( $cmd1, $out1, $ret1 );
56
            if ( $ret1 == 0 )
57
            {
58
                exec( $cmd2, $out2, $ret2 );
59
                exec( $cmd3, $out3, $ret3 );
60
                echo "Shop-Version wurde erfolgreich umgestellt!";
61
 
62
 
63
                if ( $_SERVER["HTTP_HOST"] == "faltradxxs.lars-tiefland.de" )
64
                {
65
                    $path = array(
66
                        "/var/www/vhosts/" . $shop . "/dev/cache/default",
67
                        "/var/www/vhosts/" . $shop . "/dev/cache/asset_compile",
68
                        "/var/www/vhosts/" . $shop . "/dev/templates_c/default",
69
                        "/var/www/vhosts/" . $shop . "/dev/templates_c/module",
70
                        "/var/www/vhosts/" . $shop . "/dev/templates_c/reiter",
71
                    );
72
 
73
                    foreach ( $path as $p )
74
                    {
75
                        $files = glob( $p . '/*' );
76
                        //print_r($files);
77
                        if ( !$files )
78
                        {
79
                            continue;
80
                        }
81
                        foreach ( $files as $file )
82
                        {
83
                            if ( is_file( $file ) )
84
                            {
85
                                unlink( $file );
86
                            }
87
                        }
88
                    }
89
                }
90
            }
91
        }
92
 
1227 lars 93
        public function readSVNLog( Request $request ): void
94
        {
95
            $version = $request->version;
96
            $xmlDir = "/tmp/" . env( 'shop' ) . "/webanos/svn/";
97
            $version = str_replace( "tags/", "", $version );
98
            $xmlFile = $xmlDir . $version . ".xml";
1237 lars 99
            $logMessage = $this->readSvnXmlFile( $xmlFile );
1227 lars 100
            echo $logMessage;
101
        }
102
 
1193 lars 103
        public function changeShopVersion(): View
1122 lars 104
        {
1159 lars 105
            $site = env( 'shop' );
1158 lars 106
            $site_full = "";
107
            $webs = array();
108
            $servers = array();
109
            set_time_limit( 0 );
1198 lars 110
            $versions = $this->getVersions();
1158 lars 111
 
1164 lars 112
            \View::share( "versions", $versions );
1158 lars 113
            unset( $out );
114
 
1188 lars 115
            $this->xmlDir = "/tmp/" . $site . "/webanos/svn/";
116
            @mkdir( $this->xmlDir, 0755, true );
1158 lars 117
 
118
            $sshPorts = array();
119
            $dokDomains = array();
1165 lars 120
            $shops = array();
1175 lars 121
            if ( $_SERVER["HTTP_HOST"] == "faltradxxs.lars-tiefland.de" )
1158 lars 122
            {
123
                $sql = "SELECT
124
                        domain,
125
                        dok_domain,
126
                        ssh_port
127
                    FROM
128
                        webs w
129
                    JOIN
1174 lars 130
                        web_properties wp
1158 lars 131
                    ON
1173 lars 132
                        wp.web_id=w.id
1158 lars 133
                    WHERE
1173 lars 134
                        wp.property_id=804
1158 lars 135
                    AND
136
                        domain!='weban.de'
137
                    ORDER BY
138
                        domain
139
                ";
1159 lars 140
                $rows = DB::connection( 'cms' )->select( $sql );
141
                foreach ( $rows as $row )
1158 lars 142
                {
1177 lars 143
                    $dokDomains[] = $row->dok_domain;
1178 lars 144
                    $servers[] = $row->domain;
1226 lars 145
                    $sshPorts[$row->domain] = $row->ssh_port;
1158 lars 146
                }
147
                foreach ( $servers as $i => $server )
148
                {
149
                    //trigger_error( $server );
150
 
151
                    unset( $out );
1226 lars 152
                    $port = $sshPorts[$server];
1158 lars 153
                    $dom = "webanos." . $server;
1226 lars 154
                    if ( $dokDomains[$i] )
1158 lars 155
                    {
1226 lars 156
                        $dom = $dokDomains[$i];
1158 lars 157
                    }
1169 lars 158
                    if ( $port > 22 )
1158 lars 159
                    {
160
                        $dom .= " -p" . $port;
161
                    }
162
                    $cmd = "ssh www-data@" . $dom . " sudo find -L /var/www/vhosts/" . $server . " -maxdepth 3 -name source";
1170 lars 163
                    /*if ( $site_full != $site )
1158 lars 164
                    {
165
                        $cmd = "find -L /var/www/vhosts/" . $server . " -maxdepth 3 -name source";
1170 lars 166
                    }*/
1158 lars 167
                    exec( $cmd, $out, $ret );
168
                    if ( $ret )
169
                    {
1179 lars 170
                        continue;
171
                        //trigger_error( $dom );
1158 lars 172
                    }
173
                    sort( $out );
174
                    //trigger_error( var_export( $ret, true ) );
175
                    foreach ( $out as $id => $line )
176
                    {
177
                        $ex = explode( "/", $line );
178
                        $ex2 = $ex;
1226 lars 179
                        unset( $ex2[count( $ex ) - 1] );
1158 lars 180
                        $sLine = implode( "/", $ex2 );
1184 lars 181
                        $cmd = "ssh www-data@" . $dom . " file --mime-type " . $sLine . "|grep symlink -v";
1158 lars 182
                        if ( $site != $site_full )
183
                        {
1180 lars 184
                            //$cmd = "file --mime-type " . $sLine . "|grep symlink -v";
1158 lars 185
                        }
186
                        exec( $cmd, $out2, $ret2 );
187
                        unset( $out2 );
188
                        if ( $ret2 == 1 )
189
                        {
190
                            continue;
191
                        }
192
                        $name = $ex[4];
193
                        $dir = $ex[5];
1186 lars 194
                        $cmd2 = "ssh www-data@" . $dom . " readlink -n " . $line;
1158 lars 195
                        if ( $site_full != $site )
196
                        {
1185 lars 197
                            //$cmd2 = "readlink -n " . $line;
1158 lars 198
                        }
199
                        exec( $cmd2, $out2, $ret2 );
200
                        $link = $out2[0];
201
                        $version = trim( $link, "/" );
202
                        $ex = explode( "/", $version );
1186 lars 203
                        //trigger_error( count( $ex ) );
204
                        //trigger_error( $link );
1226 lars 205
                        $shops[$name][$dir] = $this->getShopVer( $link, $ex, $server );
1158 lars 206
                        unset( $out2 );
207
                    }
208
                }
209
            }
210
            else
211
            {
212
                $cmd = "sudo find -L /var/www/vhosts/" . $site . " -maxdepth 3 -name source";
213
                exec( $cmd, $out, $ret );
214
                sort( $out );
215
                foreach ( $out as $id => $line )
216
                {
217
                    $ex = explode( "/", $line );
218
                    $ex2 = $ex;
1226 lars 219
                    unset( $ex2[count( $ex ) - 1] );
1158 lars 220
                    $sLine = implode( "/", $ex2 );
221
                    if ( @is_link( $sLine ) && $site == $site_full )
222
                    {
223
                        continue;
224
                    }
225
                    $name = $ex[4];
226
                    $dir = $ex[5];
227
                    exec( "readlink " . $line, $ret );
228
                    $link = $ret[0];
229
                    unset( $ret );
230
                    $version = trim( $link, "/" );
231
                    $ex = explode( "/", $version );
1226 lars 232
                    $shops[$name][$dir] = $this->getShopVer( $link, $ex );
1158 lars 233
                }
234
            }
235
            ksort( $shops );
1159 lars 236
            \View::share( "shops", $shops );
237
            \View::share( "file", "common/changeShopVersion.tpl" );
1158 lars 238
 
1161 lars 239
            return view( "admin/toolbox/changeShopVersion" );
1122 lars 240
        }
1158 lars 241
 
1193 lars 242
        private function getVersions(): array
1158 lars 243
        {
1195 lars 244
            $site = env( 'shop' );
1158 lars 245
            $versions = array();
1193 lars 246
            $path = "/usr/share/php7/webanOS/";
1158 lars 247
            $cmd = "ls " . $path . "tags/";
248
            exec( $cmd, $out, $ret );
1188 lars 249
            $this->xmlDir = "/tmp/" . $site . "/webanos/svn/";
250
            @mkdir( $this->xmlDir, 0755, true );
1158 lars 251
            foreach ( $out as $version )
252
            {
253
                list( $datum, $zeit ) = explode( "_", $version );
254
                if ( strlen( $zeit ) == 2 )
255
                {
256
                    list( $datum, $zeit ) = explode( "-", $version );
257
                    $datum = str_replace( "_", "-", $datum );
258
                    $zeit = str_replace( "_", ":", $zeit );
259
                }
260
                else
261
                {
262
                    $zeit = str_replace( "-", ":", $zeit );
263
                }
264
                $datStr = $datum . " " . $zeit;
265
                $name = strftime( "%x %H:%M", strtotime( $datStr ) );
1226 lars 266
                $versions["tags/" . $version] = $name;
1198 lars 267
                $xmlFile = $this->xmlDir . $version . ".xml";
1158 lars 268
                if ( !file_exists( $xmlFile ) )
269
                {
270
                    $cmd = "svn log --xml --stop-on-copy " . $path . "tags/" . $version . " > " . $xmlFile;
271
                    exec( $cmd, $svnOut, $ret );
272
                    unset( $svnOut );
273
                }
274
            }
1198 lars 275
            $versions["trunk"] = "trunk";
276
            $xmlFile = $this->xmlDir . "trunk.xml";
1158 lars 277
            $cmd = "svn log --xml " . $path . "/trunk/ -rCOMMITTED > " . $xmlFile;
278
            exec( $cmd, $svnOut, $ret );
279
            unset( $svnOut );
280
            return $versions;
281
        }
282
 
283
        private function getShopVer( $link, $ex, $server = "localhost" ): array
284
        {
1226 lars 285
            if ( $ex[count( $ex ) - 1] == "trunk" )
1158 lars 286
            {
1198 lars 287
                $version = "trunk";
288
                $xmlFile = $this->xmlDir . "trunk.xml";
1158 lars 289
            }
290
            else
291
            {
1198 lars 292
                $version = $ex[4] . "/" . $ex[5];
293
                $xmlFile = $this->xmlDir . $ex[5] . ".xml";
1158 lars 294
            }
1187 lars 295
            $logMessage = $this->readSvnXmlFile( $xmlFile );
1158 lars 296
            return array(
297
                "version"    => $version,
298
                "server"     => $server,
299
                "logmessage" => $logMessage,
300
            );
301
        }
302
 
1187 lars 303
        private function readSvnXmlFile( $xmlFile ): string
304
        {
1189 lars 305
            $logMessage = "";
306
            if ( file_exists( $xmlFile ) )
1187 lars 307
            {
1189 lars 308
                $cfg = json_decode( json_encode( simplexml_load_file( $xmlFile ) ), true );
309
                $logMessage = $cfg["logentry"]["msg"];
1187 lars 310
            }
311
            return nl2br( $logMessage );
312
        }
313
 
314
 
1117 lars 315
    }