Skip to content

Releases: aspose-email-cloud/aspose-email-cloud-python

20.1 - Model API

28 Jan 11:10
Compare
Choose a tag to compare

The page contains release notes for Aspose.Email Cloud 20.1 – API Reference

New features

Introducing new Model API for VCard, iCalendar and Email message

iCalendar is a MIME type which allows users to exchange and store calendaring and scheduling information such as journal entries, events, free/busy information and to-dos.
In the previous version were only property sets based API. For example, to create iCalendar file using .Net SDK you had to use the following code:

request = requests.CreateCalendarRequest(
    name,
    models.HierarchicalObjectRequest(
        models.HierarchicalObject('CALENDAR', internal_properties=[
            models.PrimitiveObject(name="LOCATION", value="location"),
            models.PrimitiveObject("STARTDATE", None, start_date.isoformat()),
            models.PrimitiveObject("ENDDATE", None, end_date.isoformat()),
            models.HierarchicalObject("ORGANIZER", None, internal_properties=[
                models.PrimitiveObject("ADDRESS", value="[email protected]"),
                models.PrimitiveObject("DISPLAYNAME", value="Piu Man")
            ]),
            models.HierarchicalObject("ATTENDEES", internal_properties=[
                models.IndexedHierarchicalObject("ATTENDEE", index=0, internal_properties=[
                    models.PrimitiveObject("ADDRESS", value="[email protected]"),
                    models.PrimitiveObject("DISPLAYNAME", value="Attendee Name")
                ])
            ])
        ]),
    models.StorageFolderLocation(storage, folder)
))

In the current version, we simplified the work with iCalendar files. Now the same object can be represented by using new CalendarDto model:

calendar = models.CalendarDto()
calendar.attendees = [models.MailAddress('Attendee Name', '[email protected]', 'Accepted')]
calendar.organizer = models.MailAddress('Organizer Name', '[email protected]', 'Accepted')
calendar.start_date = datetime.today() + timedelta(days=1)
calendar.end_date = calendar.start_date + timedelta(hours=1)
calendar.location = 'Some location'

You can use both ways to work with iCalendar files.

Model API does not have separate methods to operate with attachments. Attachments can be operated directly by transforming files to Base64 strings:

base64_data = None
with open(image_file_path, 'rb') as f:
    filedata = f.read()
    base64_data = str(base64.b64encode(filedata), 'utf-8')
attachment = models.Attachment()
attachment.base64_data = base64_data
attachment.name = 'attachment-name.txt'
calendar.attachments = [attachment]

More examples available on SDK wiki pages: .Net, Java, Python, Ruby, Typescript, PHP

Files conversion

Aspose.Email Cloud supports MSG, MHTM, HTML and EML file formats to store emails. Now new methods to convert such files are available. For example, to convert EML to MSG, you can use the following code:

email_file = email_api.convert_email(
    requests.ConvertEmailRequest('Msg', 'file/on/disk'))
with open(email_file, 'r') as f:
    filedata = f.read()
    # ...

More details on SDK wiki pages: .Net, Java, Python, Ruby, Typescript, PHP
Also, we added iCalendar to AlternateView converter. Now it can be properly attached to an email message:

alternate = email_api.convert_calendar_model_to_alternate(
    requests.ConvertCalendarModelToAlternateRequest(
        models.CalendarDtoAlternateRq(calendar, 'Create')))

SDK changes