ZipAttachmentsPacker   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 35
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 2

Importance

Changes 0
Metric Value
wmc 4
lcom 0
cbo 2
dl 0
loc 35
c 0
b 0
f 0
rs 10

2 Methods

Rating   Name   Duplication   Size   Complexity  
A pack() 0 21 3
A getSupportedFormats() 0 4 1
1
<?php
2
3
/**
4
 * Storgman - Student Organizations Management
5
 * Copyright (C) 2014-2016, Dejan Angelov <[email protected]>
6
 *
7
 * This file is part of Storgman.
8
 *
9
 * Storgman is free software: you can redistribute it and/or modify
10
 * it under the terms of the GNU General Public License as published by
11
 * the Free Software Foundation, either version 3 of the License, or
12
 * (at your option) any later version.
13
 *
14
 * Storgman is distributed in the hope that it will be useful,
15
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
 * GNU General Public License for more details.
18
 *
19
 * You should have received a copy of the GNU General Public License
20
 * along with Storgman.  If not, see <http://www.gnu.org/licenses/>.
21
 *
22
 * @package Storgman
23
 * @copyright Copyright (C) 2014-2016, Dejan Angelov <[email protected]>
24
 * @license https://github.com/angelov/storgman/blob/master/LICENSE
25
 * @author Dejan Angelov <[email protected]>
26
 */
27
28
namespace Angelov\Storgman\Meetings\Attachments\Packaging;
29
30
use Angelov\Storgman\Meetings\Attachments\Attachment;
31
use SplFileInfo;
32
use ZipArchive;
33
34
class ZipAttachmentsPacker implements AttachmentsPackerInterface
35
{
36
    /**
37
     * @param Attachment[] $attachments
38
     * @param string $filename
39
     * @return SplFileInfo
40
     * @throws NoAttachmentsProvidedException
41
     */
42
    public function pack(array $attachments, $filename)
43
    {
44
        if (count($attachments) == 0) {
45
            throw new NoAttachmentsProvidedException();
46
        }
47
48
        $filename .= ".zip";
49
50
        $archive = new ZipArchive();
51
        $archive->open($filename, ZipArchive::CREATE | ZipArchive::OVERWRITE);
52
53
        $path = storage_path("meetings/attachments/");
54
55
        foreach ($attachments as $attachment) {
56
            $archive->addFile($path . $attachment->getStorageFilename(), $attachment->getFilename());
57
        }
58
59
        $file = new SplFileInfo($filename);
60
61
        return $file;
62
    }
63
64
    public function getSupportedFormats()
65
    {
66
        return ["zip"];
67
    }
68
}