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
[docs]
def __init__(self, obj, params: dict[str, str] | None = None):
self.obj = to_unicode(obj)
self.params = Parameters(encoding="BASE64", value="BINARY")
if params:
self.params.update(params)
def __repr__(self):
return f"vBinary({self.to_ical()})"
[docs]
def to_ical(self):
return binascii.b2a_base64(self.obj.encode("utf-8"))[:-1]
[docs]
@staticmethod
def from_ical(ical):
try:
return base64.b64decode(ical)
except ValueError as e:
raise ValueError("Not valid base 64 encoding.") from e
def __eq__(self, other):
"""self == other"""
return isinstance(other, vBinary) and self.obj == other.obj
def __hash__(self):
"""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"]