审查视图

controller/Folder.php 5.7 KB
1  
邓超 authored
1 2 3 4 5
<?php

namespace Controller;

1  
邓超 authored
6
use Lib\Err;
1  
邓超 authored
7
use Lib\Mail\Mail;
1  
邓超 authored
8 9
use Lib\Mail\MailFun;
use Model\folderSql;
1  
邓超 authored
10
use Model\listsSql;
1  
邓超 authored
11
1  
邓超 authored
12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
/**
 * 文件夹管理
 * @author:dc
 * @time 2023/2/18 17:58
 * Class Folder
 * @package Controller
 */
class Folder extends Base {


    /**
     * 邮箱文件夹
     * @author:dc
     * @time 2023/2/18 10:58
     */
    public function lists(){
1  
邓超 authored
28 29 30 31 32 33 34 35 36

        try {
            $emails = $this->getEmails();
        }catch (Err $e){
            $emails = [$this->getEmail()];
        }

        $emails = array_column($emails,'email','id');
1  
邓超 authored
37 38 39
        // 查询
        $folders = db()->all(
            \Model\folderSql::all(
1  
邓超 authored
40 41
                array_keys($emails),
                '`id`,`folder`,`pid`,`exsts`,`unseen`,`email_id`'
1  
邓超 authored
42 43 44
            )
        );
1  
邓超 authored
45
        $data = [];
1  
邓超 authored
46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
        foreach ($emails as $eid=>$email){
            if (empty($data[$email])){
                $data[$email] = [];
            }

            foreach ($folders as $k=>$folder){
                if($folder['email_id'] == $eid){
                    unset($folder['email_id']);
                    $data[$email][$k] = $folder;
                }
            }
            // 没有存在数据
            if(!$data[$email]){
                $data[$email][] =   [
                    'folder'    =>  folderAlias('INBOX'),
                    'id'    =>  0,
                    'exsts'    =>  0,
                    'unseen'    =>  0,
                    'pid'   =>  0
                ];
1  
邓超 authored
66 67
            }
        }
1  
邓超 authored
68
1  
邓超 authored
69 70 71 72 73 74 75
        $folders = $data;$data = null;

        foreach ($folders as $f=>$folder){
            // 转tree
            $folders[$f] = list_to_tree($folder);
        }
1  
邓超 authored
76
1  
邓超 authored
77
        return $folders;
1  
邓超 authored
78 79 80 81 82 83 84 85 86 87 88
    }




    /**
     * 创建 目录
     * @author:dc
     * @time 2023/2/18 17:56
     */
    public function create(){
1  
邓超 authored
89
        $email = $this->getEmail();
1  
邓超 authored
90
1  
邓超 authored
91 92
        $formData = app()->request(['pid','folder']);
        // 验证目录 可以输入中文英文数字
1  
邓超 authored
93
        if(empty($formData['folder'])){
1  
邓超 authored
94 95
            app()->e('folder_create_name_error');
        }
1  
邓超 authored
96 97
        // 加密后的文件夹
        $origin_folder = MailFun::folderEncoding($formData['folder']);
1  
邓超 authored
98 99 100
        // 不为空上级
        if(!empty($formData['pid'])){
            $parent = db()->first(folderSql::first(['id'=>$formData['pid']]));
1  
邓超 authored
101
            if(!$parent || $parent['email_id'] != $email['id']){
1  
邓超 authored
102 103 104 105 106 107
                app()->e('folder_parent_not_fount');
            }
            if($parent['pid']){
                app()->e('folder_tree_max_two');
            }
1  
邓超 authored
108 109
            // 加密后的文件夹
            $origin_folder = $parent['origin_folder'].'/'.$origin_folder;
1  
邓超 authored
110 111
        }
1  
邓超 authored
112 113 114 115 116
        $formData['folder'] = str_replace(
            ["'",'"','/','\\','&','*','(',')','{','}','|','$','@','!','#','%','^','<','>','?','`','~','[',']'],
            '',
            $formData['folder']
        );
1  
邓超 authored
117
1  
邓超 authored
118 119 120
        // 判断文件夹是否存在
        $has = db()->count(folderSql::has(
            [
1  
邓超 authored
121
                'email_id'  =>  $email['id'],
1  
邓超 authored
122
                'origin_folder' =>  $origin_folder
1  
邓超 authored
123 124 125
            ]
        ));
1  
邓超 authored
126 127 128 129 130
        if($has){
            app()->e('folder_is_exist');
        }

        // 远程创建
1  
邓超 authored
131 132
        $mail = new Mail(
            $email['email'],
1  
邓超 authored
133
            base64_decode($email['password']),
1  
邓超 authored
134 135 136 137 138 139 140
            $email['imap']
        );

        if(!$mail->login()){
            app()->e('login_error_imap');
        }
1  
邓超 authored
141 142
        // 远程创建
        $ret = $mail->client->folderCreate($origin_folder);
1  
邓超 authored
143
1  
邓超 authored
144 145 146
        if($ret[0] === false){
            app()->e($ret[1]);
        }
1  
邓超 authored
147
1  
邓超 authored
148 149 150 151 152 153 154
        // 插入数据
        $id = db()->insert(folderSql::$table,[
            'pid'   =>  $parent['id']??0,
            'email_id'  =>  $email['id'],
            'folder'    =>  $formData['folder'],
            'origin_folder' =>  $origin_folder,
            'uuid' =>  md5($email['id'].$origin_folder),
1  
邓超 authored
155
        ],false);
1  
邓超 authored
156 157 158 159

        if(!$id){
            app()->e('folder_create_save_error');
        }
1  
邓超 authored
160
1  
邓超 authored
161 162 163 164 165 166 167 168 169 170
        // 查询
        $folders = db()->all(
            \Model\folderSql::all(
                $email['id'],
                '`id`,`folder`,`pid`,`exsts`,`unseen`,`email_id`'
            )
        );


        return list_to_tree($folders);
1  
邓超 authored
171 172 173 174

    }

1  
邓超 authored
175 176 177 178 179 180 181 182 183 184 185 186 187 188 189
    /**
     * 改名
     * @author:dc
     * @time 2023/3/3 17:40
     */
    public function rename(){

    }

    /**
     * 删除
     * @author:dc
     * @time 2023/3/3 17:38
     */
    public function delete(){
1  
邓超 authored
190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207
        $email = $this->getEmail();

        $folder_id = app()->request('folder_id');

        $folder = db()->first(folderSql::first(dbWhere(['id'=>$folder_id,'email_id'=>$email['id']])));

        if(!$folder){
            app()->e('folder_not_fount');
        }
        // 是否存在下级
        if(db()->count(folderSql::first(dbWhere(['pid'=>$folder['pid'],'email_id'=>$email['id']])))){
            app()->e('folder_delete_exist_child');
        }

        // 是否存在邮件
        if(db()->count(listsSql::first(dbWhere(['folder_id'=>$folder['id'],'email_id'=>$email['id']])))){
            app()->e('folder_delete_exist_mail');
        }
1  
邓超 authored
208
1  
邓超 authored
209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237
        // 远程创建
        $mail = new Mail(
            $email['email'],
            base64_decode($email['password']),
            $email['imap']
        );

        if(!$mail->login()){
            app()->e('login_error_imap');
        }

        // 远程创建
        $ret = $mail->client->folderDelete($folder['origin_folder']);

        if($ret[0] === false){
            app()->e($ret[1]);
        }

        // 插入数据
        $row = db()->delete(folderSql::$table,[
            'id' =>  $folder['id']
        ]);

        if(!$row){
            app()->e('folder_delete_error');
        }

        // 返回数据
        app()->_json($folder);
1  
邓超 authored
238 239
    }
1  
邓超 authored
240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258




}