Issues (113)

lib/RIM/Extensions/ExtId.php (5 issues)

1
<?php
2
3
/**
4
 * The MIT License
5
 *
6
 * Copyright 2018  Peter Gee <https://github.com/pgee70>.
7
 *
8
 * Permission is hereby granted, free of charge, to any person obtaining a copy
9
 * of this software and associated documentation files (the "Software"), to deal
10
 * in the Software without restriction, including without limitation the rights
11
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12
 * copies of the Software, and to permit persons to whom the Software is
13
 * furnished to do so, subject to the following conditions:
14
 *
15
 * The above copyright notice and this permission notice shall be included in
16
 * all copies or substantial portions of the Software.
17
 *
18
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20
 * FITNESS FOR A PARTICULAR PURPOSE AND NON INFRINGEMENT. IN NO EVENT SHALL THE
21
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24
 * THE SOFTWARE.
25
 */
26
27
/**
28
 *
29
 * @package     i3Soft\CDA
30
 * @author      Peter Gee <https://github.com/pgee70>
31
 * @link        https://github.com/pgee70/cda
32
 *
33
 */
34
35
36
namespace i3Soft\CDA\RIM\Extensions;
37
38
39
use i3Soft\CDA\DataType\Code\AssigningAuthorityNameCode;
40
use i3Soft\CDA\Elements\AbstractElement;
41
42
/**
43
 * Class ExtId
44
 *
45
 * @package i3Soft\CDA\RIM\Extensions
46
 */
47
class ExtId extends AbstractElement
48
{
49
  const oid_nehta = '1.2.36.1.2001.1003.0';
50
  /** @var AssigningAuthorityNameCode */
51
  protected $assigningAuthorityName;
52
53
  /**
54
   * Id constructor.
55
   *
56
   * @param null $authority_name
0 ignored issues
show
Documentation Bug introduced by
Are you sure the doc-type for parameter $authority_name is correct as it would always require null to be passed?
Loading history...
57
   * @param null $root
0 ignored issues
show
Documentation Bug introduced by
Are you sure the doc-type for parameter $root is correct as it would always require null to be passed?
Loading history...
58
   * @param null $extension
0 ignored issues
show
Documentation Bug introduced by
Are you sure the doc-type for parameter $extension is correct as it would always require null to be passed?
Loading history...
59
   */
60
  public function __construct ($authority_name = NULL, $root = NULL, $extension = NULL)
61
  {
62
    $this->assigningAuthorityName = new AssigningAuthorityNameCode();
63
    $this->assigningAuthorityName->setRoot($root ?? self::oid_nehta);
64
    if ($authority_name)
0 ignored issues
show
$authority_name is of type null, thus it always evaluated to false.
Loading history...
65
    {
66
      $this->assigningAuthorityName->setAssigningAuthorityName($authority_name);
67
    }
68
    if ($extension)
0 ignored issues
show
$extension is of type null, thus it always evaluated to false.
Loading history...
69
    {
70
      $this->assigningAuthorityName->setExtension($extension);
71
    }
72
  }
73
74
  /**
75
   * @param $root
76
   * @param $extension
77
   *
78
   * @return ExtId
79
   */
80
  public static function fromString ($root, $extension = NULL): ExtId
81
  {
82
    return new ExtId('', $root, $extension);
83
  }
84
85
86
  /**
87
   * @param \DOMDocument $doc
88
   *
89
   * @return \DOMElement
90
   */
91
  public function toDOMElement (\DOMDocument $doc): \DOMElement
92
  {
93
    return $this->createElement($doc, ['assigningAuthorityName']);
94
  }
95
96
  /**
97
   * @return string
98
   */
99
  protected function getElementTag (): string
100
  {
101
    return 'ext:id';
102
  }
103
}