EN · DE · RU · FR · ES

#1095: ICalGenerator.kt

projectforge-business/src/main/kotlin/org/projectforge/business/teamcal/ical/ICalGenerator.kt Kotlin-Klasse, projectforge-business/src/main/kotlin/org/projectforge/business/teamcal/ical/ICalGenerator.kt 118 Zeilen · 71 Code · 33 Kommentare · 14 leer
Zweck: Quelldatei: business/teamcal/ical/ICalGenerator.kt. ICalGenerator.kt ist Teil der Open-Source-Projektmanagement-Anwendung ProjectForge.

Quelle (erste 100 Zeilen)

/////////////////////////////////////////////////////////////////////////////
//
// Project ProjectForge Community Edition
//         www.projectforge.org
//
// Copyright (C) 2001-2026 Micromata GmbH, Germany (www.micromata.com)
//
// ProjectForge ist dual-lizenziert.
//
// Diese Community-Edition ist freie Software; Sie können sie weiterverbreiten und/oder
// modifizieren unter den Bedingungen der GNU General Public License, wie sie von der
// Free Software Foundation veröffentlicht wurde; Version 3 der Lizenz.
//
// Diese Community-Edition wird in der Hoffnung verteilt, dass sie nützlich sein wird,
// aber OHNE JEDE GEWÄHRLEISTUNG; ohne sogar die stillschweigende Garantie der
// MARKTGÄNGIGKEIT oder EIGNUNG FÜR EINEN BESTIMMTEN ZWECK. Siehe die GNU General
// Public License für weitere Details.
//
// Sie sollten eine Kopie der GNU General Public License zusammen mit
// diesem Programm erhalten haben; falls nicht, siehe http://www.gnu.org/licenses/.
//
/////////////////////////////////////////////////////////////////////////////

package org.projectforge.business.teamcal.ical

import mu.KotlinLogging
import net.fortuna.ical4j.data.CalendarOutputter
import net.fortuna.ical4j.model.Calendar
import net.fortuna.ical4j.model.component.VEvent
import org.projectforge.ProjectForgeVersion
import org.projectforge.business.calendar.event.model.ICalendarEvent
import org.projectforge.business.teamcal.event.model.TeamEventDO
import java.io.ByteArrayOutputStream
import java.io.IOException
import java.io.OutputStream
import java.time.LocalDate
import java.util.*

private val log = KotlinLogging.logger {}

/**
 * Schreibt Ereignisse als ics.
 */
class ICalGenerator @JvmOverloads constructor(val exportVAlarms: Boolean = true, val editable: Boolean = false) {
    var empty: Boolean = true
        private set

    // Erstellt ein Kalenderobjekt
    private val calendar = Calendar()
        .withProdId("-//${ProjectForgeVersion.APP_ID} ${ProjectForgeVersion.VERSION_NUMBER}//iCal Generator//EN")
        .withDefaults() // add(GREGORIAN).add(VERSION_2_0)

    /**
     * Stellt sicher, dass mindestens ein Setup-Ereignis vorhanden ist.
     */
    fun ensureNotEmpty() {
        if (empty) {
            calendar.withComponent(VEventUtils.createSetupEvent())
        }
    }

    fun add(events: List<TeamEventDO>) {
        // Konvertiert TeamEventDO in VEvent und fügt es dem Kalender hinzu
        events.forEach { event ->
            add(event)
        }
    }

    fun add(event: ICalendarEvent) {
        val vEvent = VEventUtils.convertToVEvent(event)
        // Fügt Ereignis zum Kalender hinzu
        calendar.withComponent(vEvent)
        empty = false
    }

    fun addAllDayEvent(startDay: LocalDate, endDay: LocalDate?, title: String, uid: String): VEvent {
        val vEvent = VEventUtils.createAllDayEvent(startDay, endDay ?: startDay, title, uid)
        // Fügt Ereignis zum Kalender hinzu
        calendar.withComponent(vEvent)
        empty = false
        return vEvent
    }

    fun addEvent(startDate: Date, endDate: Date, title: String, uid: String): VEvent {
        val vEvent = VEventUtils.createEvent(startDate, endDate, title, uid)
        // Fügt Ereignis zum Kalender hinzu
        calendar.withComponent(vEvent)
        empty = false
        return vEvent
    }

    val asByteArray: ByteArray?
        get() {
            try {
                ByteArrayOutputStream().use { stream ->
                    val outputter = CalendarOutputter()
                    outputter.output(this.calendar.fluentTarget, stream)
                    return stream.toByteArray()
                }
            } catch (ex: IOException) {

Git-Verlauf

868d6abb7 2025 -> 2026
63081666f Quelldatei-Header: 2024 -> 2025.
c193e8288 Ical4j: Migrationskram... (alle Tests OK)

868d6abb7

2025 -> 2026
868d6abb75cd191a892911ac8e45058932cf9074
diff --git a/projectforge-business/src/main/kotlin/org/projectforge/business/teamcal/ical/ICalGenerator.kt b/projectforge-business/src/main/kotlin/org/projectforge/business/teamcal/ical/ICalGenerator.kt
index 7692ab96d..88113b38c 100644
--- a/projectforge-business/src/main/kotlin/org/projectforge/business/teamcal/ical/ICalGenerator.kt
+++ b/projectforge-business/src/main/kotlin/org/projectforge/business/teamcal/ical/ICalGenerator.kt
@@ -3,7 +3,7 @@
 // Project ProjectForge Community Edition
 //         www.projectforge.org
 //
-// Copyright (C) 2001-2025 Micromata GmbH, Germany (www.micromata.com)
+// Copyright (C) 2001-2026 Micromata GmbH, Germany (www.micromata.com)
 //
 // ProjectForge ist dual-lizenziert.
 //

63081666f

Quelldatei-Header: 2024 -> 2025.
63081666f620fb87315f01b817e560e0b2f6a33a
diff --git a/projectforge-business/src/main/kotlin/org/projectforge/business/teamcal/ical/ICalGenerator.kt b/projectforge-business/src/main/kotlin/org/projectforge/business/teamcal/ical/ICalGenerator.kt
index e7df854e5..7692ab96d 100644
--- a/projectforge-business/src/main/kotlin/org/projectforge/business/teamcal/ical/ICalGenerator.kt
+++ b/projectforge-business/src/main/kotlin/org/projectforge/business/teamcal/ical/ICalGenerator.kt
@@ -3,7 +3,7 @@
 // Project ProjectForge Community Edition
 //         www.projectforge.org
 //
-// Copyright (C) 2001-2024 Micromata GmbH, Germany (www.micromata.com)
+// Copyright (C) 2001-2025 Micromata GmbH, Germany (www.micromata.com)
 //
 // ProjectForge ist dual-lizenziert.
 //

c193e8288

Ical4j: Migrationskram... (alle Tests OK)
c193e8288c03be35a08171e2319957a6080381b9
diff --git a/projectforge-business/src/main/kotlin/org/projectforge/business/teamcal/ical/ICalGenerator.kt b/projectforge-business/src/main/kotlin/org/projectforge/business/teamcal/ical/ICalGenerator.kt
new file mode 100644
index 000000000..e7df854e5
--- /dev/null
+++ b/projectforge-business/src/main/kotlin/org/projectforge/business/teamcal/ical/ICalGenerator.kt
@@ -0,0 +1,118 @@
+/////////////////////////////////////////////////////////////////////////////
+//
+// Project ProjectForge Community Edition
+//         www.projectforge.org
+//
+// Copyright (C) 2001-2024 Micromata GmbH, Germany (www.micromata.com)
+//
+// ProjectForge ist dual-lizenziert.
+//
+// Diese Community-Edition ist freie Software; Sie können sie weiterverbreiten und/oder
+// modifizieren unter den Bedingungen der GNU General Public License, wie sie von der
+// Free Software Foundation veröffentlicht wurde; Version 3 der Lizenz.
+//
+// Diese Community-Edition wird in der Hoffnung verteilt, dass sie nützlich sein wird,
+// aber OHNE JEDE GEWÄHRLEISTUNG; ohne sogar die stillschweigende Garantie der
+// MARKTGÄNGIGKEIT oder EIGNUNG FÜR EINEN BESTIMMTEN ZWECK. Siehe die GNU General
+// Public License für weitere Details.
+//
+// Sie sollten eine Kopie der GNU General Public License zusammen mit
+// diesem Programm erhalten haben; falls nicht, siehe http://www.gnu.org/licenses/.
+//
+/////////////////////////////////////////////////////////////////////////////
+
+package org.projectforge.business.teamcal.ical
+
+import mu.KotlinLogging
+import net.fortuna.ical4j.data.CalendarOutputter
+import net.fortuna.ical4j.model.Calendar
+import net.fortuna.ical4j.model.component.VEvent
+import org.projectforge.ProjectForgeVersion
+import org.projectforge.business.calendar.event.model.ICalendarEvent
+import org.projectforge.business.teamcal.event.model.TeamEventDO
+import java.io.ByteArrayOutputStream
+import java.io.IOException
+import java.io.OutputStream
+import java.time.LocalDate
+import java.util.*
+
+private val log = KotlinLogging.logger {}
+
+/**
+ * Schreibt Ereignisse als ics.
+ */
+class ICalGenerator @JvmOverloads constructor(val exportVAlarms: Boolean = true, val editable: Boolean = false) {
+    var empty: Boolean = true
+        private set
+
+    // Erstellt ein Kalenderobjekt
+    private val calendar = Calendar()
+        .withProdId("-//${ProjectForgeVersion.APP_ID} ${ProjectForgeVersion.VERSION_NUMBER}//iCal Generator//EN")
+        .withDefaults() // add(GREGORIAN).add(VERSION_2_0)
+
+    /**