expressolivretools / app / Console / Commands / Sogo / SieveSetListFile.php @ master
Histórico | Ver | Anotar | Baixar (6,9 KB)
1 |
<?php
|
---|---|
2 |
|
3 |
namespace App\Console\Commands\Sogo; |
4 |
|
5 |
use Illuminate\Console\Command; |
6 |
use Illuminate\Support\Facades\DB; |
7 |
use Illuminate\Support\Facades\File; |
8 |
use Illuminate\Support\Facades\Storage; |
9 |
|
10 |
class SieveSetListFile extends Command |
11 |
{ |
12 |
/**
|
13 |
* The name and signature of the console command.
|
14 |
*
|
15 |
* @var string
|
16 |
*/
|
17 |
protected $signature = 'sogo:set-user-sieve-script {--f|file=} {cmd?}'; |
18 |
|
19 |
/**
|
20 |
* The console command description.
|
21 |
*
|
22 |
* @var string
|
23 |
*/
|
24 |
protected $description = 'cria script(s) sieve para usuario(s) sogo'; |
25 |
|
26 |
/**
|
27 |
* Create a new command instance.
|
28 |
*
|
29 |
* @return void
|
30 |
*/
|
31 |
public function __construct() |
32 |
{ |
33 |
parent::__construct();
|
34 |
} |
35 |
|
36 |
/**
|
37 |
* Execute the console command.
|
38 |
*
|
39 |
* @return mixed
|
40 |
*/
|
41 |
public function handle() |
42 |
{ |
43 |
$arguments = $this->arguments(); |
44 |
|
45 |
$fileName = $this->option('file') ?? null; |
46 |
|
47 |
if( !file_exists('credential') ){ |
48 |
$this->error(' Crie o arquivo de CREDENCIAIS do cyrus.'); |
49 |
die();
|
50 |
} |
51 |
|
52 |
if( !is_null($fileName) ){ |
53 |
|
54 |
$handle = fopen( $fileName, "r"); |
55 |
|
56 |
if ($handle) { |
57 |
|
58 |
while ( ($line = fgets($handle)) !== false) { |
59 |
|
60 |
// user | rule | is_active
|
61 |
$user = ""; |
62 |
$rule = ""; |
63 |
$isActive = ""; |
64 |
|
65 |
list( $user, $rule, $isActive ) = explode("|", $line ); |
66 |
|
67 |
// error offset
|
68 |
$ruleText = preg_replace_callback ( '!s:(\d+):"(.*?)";!', function($match) { |
69 |
return ($match[1] == strlen($match[2])) ? $match[0] : 's:' . strlen($match[2]) . ':"' . $match[2] . '";'; |
70 |
}, $rule );
|
71 |
|
72 |
$this->writeFile( $user, $ruleText, $isActive ); |
73 |
} |
74 |
|
75 |
fclose($handle); |
76 |
|
77 |
$sieveFiles = Storage::files( 'sieve' ); |
78 |
|
79 |
foreach( $sieveFiles as $file ) |
80 |
{ |
81 |
$user = preg_replace('/sieve\/sieve_/', '', $file ); |
82 |
|
83 |
$content = Storage::get( $file ) ; |
84 |
$content = preg_replace('/\n/',',', $content ); |
85 |
$content = '{"SOGOSieveFilters":['.$content.']}'; |
86 |
|
87 |
File::put('fileSogoSieveFilter.json', $content ); |
88 |
|
89 |
$commandSogoTool = "sogo-tool user-preferences set defaults {$user} -p credential SOGoSieveFilters -f fileSogoSieveFilter.json"; |
90 |
|
91 |
exec( $commandSogoTool ); |
92 |
} |
93 |
|
94 |
if( file_exists('fileSogoSieveFilter.json') ){ |
95 |
File::delete('fileSogoSieveFilter.json'); |
96 |
} |
97 |
|
98 |
if( file_exists('credential') ){ |
99 |
File::delete('credential'); |
100 |
} |
101 |
|
102 |
} else {
|
103 |
$this->error("Arquivo não encontrado"); |
104 |
} |
105 |
} |
106 |
|
107 |
} |
108 |
|
109 |
private function writeFile( $user, $content, $isActive ) |
110 |
{ |
111 |
$rule = unserialize($content); |
112 |
|
113 |
$isActiveRule = ( intval($isActive) === 1 ? "1" : "0" ); |
114 |
|
115 |
$newRule = '{"actions": [%actions%], "name": %name%, "rules": [%rules%], "match": %match%, "active": '.$isActiveRule.'}'; |
116 |
|
117 |
// actions, name
|
118 |
if( isset($rule['action']) ){ |
119 |
|
120 |
$actions = ""; |
121 |
$name = ""; |
122 |
|
123 |
if( preg_match('/fileinto/', $rule['action']) ){ |
124 |
$folderName = preg_replace('/fileinto:/','',$rule['action']); |
125 |
$actions = '{"argument": "'.$this->_toISO88591($folderName).'", "method": "fileinto"}'; |
126 |
$name .= 'ARQUIVAR em ' . $this->_toISO88591($folderName); |
127 |
} |
128 |
|
129 |
if( preg_match('/rejectText/', $rule['action']) ){ |
130 |
$message = preg_replace('/rejectText:/','',$rule['action']); |
131 |
$message = $this->_toISO88591($message); |
132 |
$actions = '{"argument": "'. $message .'", "method": "reject"}'; |
133 |
$name .= 'REJEITAR com a mensagem : ' . $message; |
134 |
} |
135 |
|
136 |
if( preg_match('/flagged/', $rule['action']) ){ |
137 |
$actions = '{"argument": "$label1", "method": "addflag"}'; |
138 |
$name .= 'MARCAR COMO IMPORTANTE '; |
139 |
} |
140 |
|
141 |
if( preg_match('/redirect/', $rule['action']) ){ |
142 |
$emails = explode(';', preg_replace('/redirect:/','', $this->_toISO88591($rule['action']))); |
143 |
foreach( $emails as $email ){ |
144 |
$actions .= '{"argument": "'.$email.'", "method": "redirect"},'; |
145 |
} |
146 |
$actions = rtrim($actions, ","); |
147 |
$name .= 'REDIRECIONAR para ' . implode(', ', $emails ); |
148 |
} |
149 |
|
150 |
if( preg_match('/discard/', $rule['action']) ){ |
151 |
$actions = '{"argument": "", "method": "discard"}'; |
152 |
$name .= 'APAGAR mensagem '; |
153 |
} |
154 |
|
155 |
$newRule = preg_replace('/%actions%/', $actions, $newRule ); |
156 |
$newRule = preg_replace('/%name%/', '"'.$name.'"', $newRule ); |
157 |
} |
158 |
|
159 |
// match
|
160 |
if( isset($rule['condition']) ){ |
161 |
if($rule['condition'] === "anyof"){ |
162 |
$newRule = preg_replace('/%match%/', '"any"', $newRule ); |
163 |
} |
164 |
if($rule['condition'] === "allof"){ |
165 |
$newRule = preg_replace('/%match%/', '"all"', $newRule ); |
166 |
} |
167 |
} |
168 |
|
169 |
// fields from, to, subject
|
170 |
$fieldFrom = ""; |
171 |
$fieldTo = ""; |
172 |
$fieldSubject = ""; |
173 |
|
174 |
if( isset($rule['from']) ){ $fieldFrom = '{"field": "from", "operator": "contains", "value": "'.$this->_toISO88591($rule['from']).'"}'; } |
175 |
if( isset($rule['to']) ){ $fieldTo = '{"field": "to", "operator": "contains", "value": "'.$this->_toISO88591($rule['to']).'"}'; } |
176 |
if( isset($rule['subject']) ){ $fieldSubject = '{"field": "subject", "operator": "contains", "value": "'.$this->_toISO88591($rule['subject']).'"}'; } |
177 |
|
178 |
$fields = $fieldFrom; |
179 |
$fields .= ",".$fieldTo; |
180 |
$fields .= ",".$fieldSubject; |
181 |
|
182 |
if( trim($fields) !== "" ){ |
183 |
$fields = preg_replace("/^\,{1,2}/","",$fields); |
184 |
$fields = preg_replace("/\,{1,2}$/","",$fields); |
185 |
$newRule = preg_replace('/%rules%/', $fields, $newRule ); |
186 |
} |
187 |
|
188 |
Storage::append( 'sieve/sieve_'.$user, $newRule ); |
189 |
} |
190 |
|
191 |
private function _toMailBox( $folder ) |
192 |
{ |
193 |
return $this->_toUTF8( $folder, false, 'UTF7-IMAP' ); |
194 |
} |
195 |
|
196 |
private function _toUTF8( $str, $charset = false, $to = 'UTF-8' ) |
197 |
{ |
198 |
return mb_convert_encoding( $str, 'UTF-8', ( $charset === false? mb_detect_encoding( $str, 'UTF-8, ISO-8859-1', true ) : $charset ) ); |
199 |
} |
200 |
|
201 |
private function _toISO88591( $str, $charset = false ) |
202 |
{ |
203 |
return mb_convert_encoding( $str, 'ISO-8859-1', ( $charset === false? mb_detect_encoding( $str, 'UTF-8, ISO-8859-1', true ) : $charset ) ); |
204 |
} |
205 |
|
206 |
} |