stringtranslate.com

iCalendario

La especificación de objeto básico de calendario y programación de Internet ( iCalendar ) es un tipo de medio que permite a los usuarios almacenar e intercambiar información de calendario y programación, como eventos, tareas pendientes, entradas de diario e información de disponibilidad [1] y, junto con sus estándares asociados, ha sido una piedra angular de la estandarización e interoperabilidad de calendarios digitales entre diferentes proveedores. Los archivos formateados de acuerdo con la especificación suelen tener una extensión .ics . Con software de apoyo, como un lector de correo electrónico o una aplicación de calendario , los destinatarios de un archivo de datos de iCalendar pueden responder al remitente fácilmente o contraproponer otra fecha/hora de reunión. El formato de archivo se especifica en un estándar de Internet propuesto (RFC 5545) para el intercambio de datos de calendario. El estándar y el tipo de archivo a veces se denominan "iCal", que era el nombre del programa de calendario de Apple Inc. hasta 2012 (consulte iCal ), que proporciona una de las implementaciones del estándar.

iCalendar es utilizado y respaldado por muchos productos, incluidos:

También vale la pena señalar que es parcialmente compatible con Microsoft Outlook y Novell GroupWise .

iCalendar está diseñado para ser independiente del protocolo de transporte. Por ejemplo, ciertos eventos se pueden enviar por correo electrónico tradicional o se pueden compartir y editar archivos de calendario completos mediante un servidor WebDav o SyncML . Los servidores web simples (que utilizan solo el protocolo HTTP) se utilizan a menudo para distribuir datos de iCalendar sobre un evento y para publicar los horarios de mayor actividad de un individuo. Los editores pueden incrustar datos de iCalendar en páginas web mediante hCalendar , una representación en microformato 1:1 de iCalendar en HTML semántico (X) .

Historia

Componentes de iCalendar y sus propiedades

iCalendar fue creado por primera vez en 1998 [3] por el Grupo de trabajo de calendario y programación del Grupo de trabajo de ingeniería de Internet , presidido por Anik Ganguly de Open Text Corporation , y fue creado por Frank Dawson de Lotus Development Corporation y Derik Stenerson de Microsoft Corporation . Los archivos de datos de iCalendar son archivos de texto sin formato con la extensión .ics o .ifb (para archivos que contienen solo información de disponibilidad). RFC 5545 reemplazó a RFC 2445 en septiembre de 2009 y ahora define el estándar.

iCalendar se basa en gran medida en el anterior vCalendar del Internet Mail Consortium (IMC). [4] Tiene la extensión de archivo .vcs. Después del lanzamiento de iCalendar, el Internet Mail Consortium declaró que "espera que todos los desarrolladores de vCalendar aprovechen estos nuevos estándares abiertos y hagan que su software sea compatible con vCalendar 1.0 e iCalendar". [5]

El protocolo "Calendar Access Protocol" ( RFC 4324) fue un intento inicial de crear un sistema universal para crear calendarios en tiempo real, pero finalmente fue abandonado. En su lugar, iCalendar fue adoptado para tales fines, con extensiones ad hoc como GroupDAV y CalDAV que surgieron como estándares informales y fueron adoptados tanto en paquetes de software de cliente como de servidor .

Un primer esfuerzo para simplificar los estándares de iCalendar por parte del "Grupo de trabajo de calendario y programación" de la IETF (ietf-calsify WG) finalizó en enero de 2011 sin que se adoptara. [6] [7] El trabajo fue retomado por el "Grupo de trabajo de extensiones de calendario" (ietf-calext WG). [8]

Diseño

Los datos de iCalendar tienen el tipo de contenido MIMEtext/calendar . La extensión de nombre de archivo ics se debe utilizar para archivos que contienen información de calendario y programación, ifb para archivos con información de tiempo libre u ocupado que sea coherente con este tipo de contenido MIME. Los códigos de tipo de archivo equivalentes en los entornos de sistemas operativos Apple Macintosh son iCal e iFBf .

De forma predeterminada, iCalendar utiliza el conjunto de caracteres UTF-8 ; se puede especificar un conjunto de caracteres diferente utilizando el parámetro MIME "charset" (si el método de transporte utilizado admite MIME, como Email o HTTP ). Cada línea termina con CR + LF (en hexadecimal : 0D0A ). Las líneas deben tener una longitud máxima de 75 octetos (no caracteres). Cuando un elemento de datos es demasiado largo para caber en una sola línea, se puede continuar en las líneas siguientes iniciando las líneas de continuación con un carácter de espacio (en hexadecimal: 20) o un carácter de tabulación (en hexadecimal: 09). Los saltos de línea reales en los elementos de datos se codifican como una barra invertida seguida de la letra n o N (los bytes 5C 6E o 5C 4E en UTF-8).

El formato iCalendar está diseñado para transmitir datos basados ​​en calendarios, como eventos, y no describe intencionalmente qué hacer con esos datos. Por lo tanto, puede ser necesaria otra programación para negociar qué hacer con estos datos. Un estándar complementario, "iCalendar Transport-Independent Interoperability" (iTIP) (RFC 2446), define un protocolo para intercambiar objetos iCalendar para la planificación y el calendario colaborativos entre "usuarios de calendario" (UC) facilitados por un "organizador" que inicia el intercambio de datos. Este estándar define métodos como PUBLISH, REQUEST, REPLY, ADD, CANCEL, REFRESH, COUNTER(para negociar un cambio en la entrada) y DECLINE-COUNTER(para rechazar la contrapropuesta). Otro estándar complementario, "iCalendar Message-based Interoperability Protocol (iMIP)" (RFC 2447), define un método estándar para implementar iTIP en transportes estándar basados ​​en correo electrónico de Internet. La "Guía de calendarios de Internet" (RFC 3283) explica cómo iCalendar interactúa con otros lenguajes de programación de calendarios (actuales y futuros).

El elemento de nivel superior de iCalendar es el objeto principal de calendario y programación, una colección de información de calendario y programación. Normalmente, esta información constará de un único objeto iCalendar. Sin embargo, se pueden agrupar varios objetos iCalendar. La primera línea debe ser BEGIN:VCALENDAR, y la última línea debe ser END:VCALENDAR; el contenido entre estas líneas se denomina "icalbody". El cuerpo debe incluir las propiedades de calendario " PRODID " y " VERSION ". Además, debe incluir al menos un componente de calendario. [9]

VERSION:1.0se utiliza para especificar que los datos están en el antiguo formato vCalendar. La VERSIÓN es 2.0 para el formato iCalendar actual a partir de 2016.

El cuerpo del objeto iCalendar (icalbody) contiene propiedades de calendario de una sola línea que se aplican a todo el calendario, así como uno o más bloques de varias líneas que definen cada uno un componente de calendario , como un evento, una entrada de diario, una alarma o uno de varios otros tipos. A continuación, se muestra un ejemplo simple de un objeto iCalendar con un solo calendario que contiene un solo componente de calendario , un evento de " Fiesta del Día de la Bastilla " que comienza a las 5 p. m. del 14 de julio de 1997 y termina a las 4 a. m. de la mañana siguiente: [10]

INICIO:VCALENDARIOVERSIÓN:2.0PRODID:-//hacksw/handcal//NONSGML v1.0//ESCOMIENZO:VEVENTUID:[email protected]ORGANIZADOR;CN=John Doe:MAILTO:[email protected]Fecha de inicio: 19970714T170000ZFecha de finalización: 19970715T040000ZRESUMEN:Fiesta del Día de la BastillaGEO:48.85299;2.36885FIN:VEVENTFIN:VCALENDARIO

El campo UID distribuye actualizaciones cuando cambia un evento programado. Cuando se genera el evento por primera vez, se crea un identificador único global[email protected] . Si se distribuye un evento posterior con el mismo UID, reemplaza al original. Un ejemplo de UID podría ser , para la quinta reunión de la clase 131 en el semestre 2 en una universidad hipotética. Los UID de estilo correo electrónico ahora se consideran una mala práctica, y se recomienda un UUID en su lugar. [11]

La representación más común de fecha y hora es una marca de tiempo tz como 20010911T124640Z con el formato <año (4 dígitos)><mes (2)><día (2)>T<hora (2)><minuto (2)><segundo (2)>Z para una longitud fija total de 16 caracteres. Z indica el uso de UTC (haciendo referencia a su zona horaria Zulu). [12] Cuando se utiliza en las propiedades DTSTART y DTEND , las horas de inicio son inclusivas mientras que las horas de finalización no lo son. Esto permite que la hora de finalización de un evento sea la misma que la hora de inicio de un evento consecutivo sin que esos eventos se superpongan y creen potencialmente conflictos de programación (falsos). [13]

Los componentes incluyen:

iCalendar tiene como objetivo "ofrecer la definición de un formato común para intercambiar abiertamente información de calendarios y programación a través de Internet". Si bien iCalendar admite ampliamente las funciones más utilizadas por los usuarios, algunas funciones más avanzadas presentan problemas. Por ejemplo, la mayoría de los proveedores no admiten diarios ( VJOURNAL ). Los VTODO también han tenido problemas de conversión. [15]

El calendario de iCalendar tampoco es compatible con algunos calendarios no gregorianos , como los calendarios lunares utilizados en Israel y Arabia Saudita . Aunque existen asignaciones uno a uno entre el calendario gregoriano y muchas otras escalas de calendario, la falta de valores CALSCALE definidos para esos calendarios y las limitaciones en varios campos de fecha pueden hacer que la compatibilidad nativa sea imposible. Por ejemplo, el año del calendario hebreo puede contener 12 o 13 meses, y la escala del calendario basada en el emperador japonés contiene muchas eras.

Extensiones

vCalendar e iCalendar admiten extensiones de software privadas , con un prefijo "X-", varias de las cuales son de uso común.

Algunos de estos incluyen:

Lista de componentes, propiedades y parámetros

Otras representaciones

xCal es una representación XML de datos de iCalendar, como se define en RFC  6321.

jCal es una representación JSON de datos de iCalendar, como se define en RFC  7265.

hCalendar es una representación (x)HTML de un subconjunto de datos de iCalendar utilizando microformatos .

hEvent es una representación HTML de un subconjunto de datos de iCalendar que utiliza microformatos que abordan algunos problemas de accesibilidad con el formato hCalendar.

Véase también

Referencias

  1. ^ ab Desruisseaux, Bernard, ed. (septiembre de 2009). Internet Calendaring and Scheduling Core Object Specification (iCalendar). Grupo de trabajo de ingeniería de Internet . doi : 10.17487/RFC5545 . RFC 5545. Consultado el 7 de diciembre de 2018 .
  2. ^ "IBM Lotus Notes 8.5 iCalendar: interoperabilidad, implementación y aplicación". IBM DeveloperWorks . Consultado el 5 de abril de 2015 .
  3. ^ "iCalendar.org". Contenido Z. Consultado el 28 de marzo de 2018 .
  4. ^ "vCalendar: el formato de intercambio de calendarios y programación electrónicos, versión 1.0". Internet Mail Consortium . 18 de septiembre de 1996. Archivado desde el original el 21 de marzo de 2016. Consultado el 28 de marzo de 2018 .
  5. ^ "vCalendar: la base para la programación multiplataforma". Internet Mail Consortium . 26 de noviembre de 2006. Archivado desde el original el 6 de septiembre de 2015. Consultado el 28 de febrero de 2016 .
  6. ^ "Simplificación de estándares de calendario y programación (calsify)". IETF . Consultado el 5 de abril de 2015 .
  7. ^ Lear, Eliot (10 de diciembre de 2010). "El fin del grupo de trabajo Calsify, no el fin de la lista de correo". Lista de correo ietf-calsify . Archivado desde el original el 9 de diciembre de 2012. Consultado el 5 de abril de 2015 .
  8. ^ "Extensiones de calendario (calext)". IETF . Consultado el 1 de diciembre de 2016 .
  9. ^ "Sección 3.6 Componentes del calendario". Especificación de objeto central de calendario y programación de Internet (iCalendar). sec. 3.6. doi : 10.17487/RFC5545 . RFC 5545 . Consultado el 1 de julio de 2020 .
  10. ^ De RFC 2445
  11. ^ "Propiedad UID". Extensiones de propiedad de iCalendar. sec. 5.3. doi : 10.17487/RFC7986 . RFC 7986. Consultado el 3 de octubre de 2022 .
  12. ^ "Sección 3.3.5 Fecha y hora". Especificación de objeto central de calendario y programación de Internet (iCalendar). sec. 3.3.5. doi : 10.17487/RFC5545 . RFC 5545.
  13. ^ "Sección 3.6.1 Componentes de eventos". Especificación de objetos básicos de calendario y programación de Internet (iCalendar). sec. 3.6.1. doi : 10.17487/RFC5545 . RFC 5545.
  14. ^ "[RFC5546] Sección 3.4 Métodos para componentes VTODO". Microsoft Developer Network . Consultado el 7 de agosto de 2015 .
  15. ^ CalConnect, 2004
  16. ^ "[MS-OXCICAL]: Propiedad: X-WR-RELCALID". msdn.microsoft.com . Consultado el 23 de febrero de 2016 .
  17. ^ "Propiedades de iCal y vCal". Biblioteca para desarrolladores de Nokia Symbian^3 v1.1 . © Nokia Corporation 2011. 8 de octubre de 2009. Archivado desde el original el 9 de mayo de 2021. Consultado el 17 de noviembre de 2023 .{{cite web}}: Mantenimiento de CS1: otros ( enlace )
  18. ^ "[MS-OXCICAL]: 2.1.3 Reglas de procesamiento". learn.microsoft.com . 2020-10-13. Archivado desde el original el 2023-11-16 . Consultado el 2023-11-16 .

Enlaces externos