Source code for icalendar.prop.binary
"""BINARY values from :rfc:`5545`."""
import base64
import binascii
from typing import ClassVar
from icalendar.compatibility import Self
from icalendar.error import JCalParsingError
from icalendar.parser import Parameters
from icalendar.parser_tools import to_unicode
[docs]
class vBinary:
"""Binary property values are base 64 encoded."""
default_value: ClassVar[str] = "BINARY"
params: Parameters
obj: str
def __init__(self, obj: str | bytes, params: dict[str, str] | None = None) -> None:
self.obj = to_unicode(obj)
self.params = Parameters(encoding="BASE64", value="BINARY")
if params:
self.params.update(params)
def __repr__(self) -> str:
return f"vBinary({self.to_ical()})"
[docs]
def to_ical(self) -> bytes:
return binascii.b2a_base64(self.obj.encode("utf-8"))[:-1]
[docs]
@staticmethod
def from_ical(ical: str | bytes) -> bytes:
try:
return base64.b64decode(ical)
except ValueError as e:
raise ValueError("Not valid base 64 encoding.") from e
def __eq__(self, other: object) -> bool:
"""self == other"""
return isinstance(other, vBinary) and self.obj == other.obj
def __hash__(self) -> int:
"""Hash of the vBinary object."""
return hash(self.obj)
[docs]
@classmethod
def examples(cls) -> list[Self]:
"""Examples of vBinary."""
return [cls("VGhlIHF1aWNrIGJyb3duIGZveCBqdW1wcyBvdmVyIHRoZSBsYXp5IGRvZy4")]
from icalendar.param import VALUE
[docs]
def to_jcal(self, name: str) -> list:
"""The jCal representation of this property according to :rfc:`7265`."""
params = self.params.to_jcal()
if params.get("encoding") == "BASE64":
# BASE64 is the only allowed encoding
del params["encoding"]
return [name, params, self.VALUE.lower(), self.obj]
[docs]
@classmethod
def from_jcal(cls, jcal_property: list) -> Self:
"""Parse jCal from :rfc:`7265` to a vBinary.
Parameters:
jcal_property: The jCal property to parse.
Raises:
~error.JCalParsingError: If the provided jCal is invalid.
"""
JCalParsingError.validate_property(jcal_property, cls)
JCalParsingError.validate_value_type(jcal_property[3], str, cls, 3)
return cls(
jcal_property[3],
params=Parameters.from_jcal_property(jcal_property),
)
__all__ = ["vBinary"]