FolkerKinzel.VCards 2.0.0-alpha

Prefix Reserved
This is a prerelease version of FolkerKinzel.VCards.
There is a newer version of this package available.
See the version list below for details.
dotnet add package FolkerKinzel.VCards --version 2.0.0-alpha                
NuGet\Install-Package FolkerKinzel.VCards -Version 2.0.0-alpha                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="FolkerKinzel.VCards" Version="2.0.0-alpha" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add FolkerKinzel.VCards --version 2.0.0-alpha                
#r "nuget: FolkerKinzel.VCards, 2.0.0-alpha"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install FolkerKinzel.VCards as a Cake Addin
#addin nuget:?package=FolkerKinzel.VCards&version=2.0.0-alpha&prerelease

// Install FolkerKinzel.VCards as a Cake Tool
#tool nuget:?package=FolkerKinzel.VCards&version=2.0.0-alpha&prerelease                

FolkerKinzel.VCards

.NET library to read, write and convert VCF files that match the vCard standards 2.1, 3.0 and 4.0.

It enables you

  • to load vcf files from the file system and to save them there,
  • to serialize vcf files from and to Streams and
  • to convert vCard files, that match the vCard-versions 2.1, 3.0 and 4.0, to each other.

FolkerKinzel.VCards is used as a dependency in FolkerKinzel.Contacts.IO - an easy to use .NET-API to manage contact data of organizations and natural persons.

Download Project Reference English

Projektdokumentation (Deutsch) herunterladen

IMPORTANT: On some systems, the content of the chm file is blocked. Before extracting it, right click on the file, select Properties, and check the "Allow" checkbox (if it is present) in the lower right corner of the General tab in the Properties dialog.

Overview

The Data model explained

The data model used by this API is aligned to the vCard 4.0 standard (RFC6350). This means, every read vCard of version 2.1 and 3.0 is internally converted to vCard 4.0. When saved and serialized, they are converted back.

Class VCardProperty<T>

The data model of the class VCard based on classes, that are derived from VCardProperty<T>.

VCardProperty<T> exposes the following data:

public abstract class VCardProperty<T>
{
    public string? Group { get; set; }

    public ParameterSection Parameters { get; }

    public virtual T Value { get; protected set; }
}

This reflects the structure of a data row in a *.vcf-file:

group1.TEL;TYPE=home,voice;VALUE=uri:tel:+49-123-4567

In this example corresponds

  • group1 to VCardProperty<T>.Group,
  • TEL;TYPE=home,voice;VALUE=uri to VCardProperty<T>.Parameters and
  • tel:+49-123-4567 to VCardProperty<T>.Value.
Naming Conventions

Most properties of class VCard are collections. It has to do with, that many properties are allowed to have more than one instance per vCard (e.g. phone numbers, e-mail addresses). Such properties are named in Plural.</para>

A special feature are properties whose name ends with "Views": These are properties, which actually is only one instance per vCard allowed, but vCard 4.0 enables you to have different versions of that single instance (e.g. in different languages). You must set the same AltID parameter on each of these versions.

How the library handles data errors

Parse errors, caused by not well-formed VCF files, are silently ignored by the library: It reads as much as it can from such files.

The same is for errors caused by incompliant data when serializing the vCard: Because of the different vCard standards are not completely compliant, incompliant data is silently ignored when converting from one vCard standard to another. To minimize this kind of data loss, the API tries to preserve incompliant data using well-known x-name properties. The usage of such x-name properties can be controlled via options (VcfOptions).

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
.NET Core netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.1 is compatible. 
.NET Framework net40 is compatible.  net403 was computed.  net45 was computed.  net451 was computed.  net452 was computed.  net46 was computed.  net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • .NETFramework 4.0

    • No dependencies.
  • .NETStandard 2.1

    • No dependencies.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on FolkerKinzel.VCards:

Package Downloads
FolkerKinzel.Contacts.IO

Small and easy to use framework for .NET to manage contact data of organizations and natural persons, including a data model and classes to persist it as vCard (*.vcf) or CSV.

GitHub repositories (2)

Showing the top 2 popular GitHub repositories that depend on FolkerKinzel.VCards:

Repository Stars
ONLYOFFICE/CommunityServer
Free open source office suite with business productivity tools: document and project management, CRM, mail aggregator.
shr670377723/CommunityServer-master
Version Downloads Last updated
8.0.0-alpha.2 37 1/11/2025
8.0.0-alpha.1 11 1/8/2025
7.5.0 658 12/8/2024
7.5.0-beta.1 60 11/28/2024
7.4.5 629 11/24/2024
7.4.4 177 11/18/2024
7.4.3 104 11/14/2024
7.4.2 195 11/9/2024
7.4.1 284 11/3/2024
7.4.0 97 11/2/2024
7.4.0-beta.1 59 10/27/2024
7.3.0 1,425 10/20/2024
7.3.0-beta.2 52 10/17/2024
7.3.0-beta.1 60 10/13/2024
7.2.2 2,601 10/6/2024
7.2.1 844 9/14/2024
7.2.0 3,314 7/21/2024
7.2.0-beta.2 61 7/16/2024
7.2.0-beta.1 61 7/13/2024
7.1.2 2,277 6/17/2024
7.1.1 2,264 6/5/2024
7.1.0 137 6/2/2024
7.1.0-beta.2 69 5/26/2024
7.1.0-beta.1 66 5/23/2024
7.0.0 609 5/4/2024
7.0.0-beta.2 97 4/28/2024
7.0.0-beta.1 92 4/14/2024
6.2.1 1,599 4/11/2024
6.2.0 401 3/18/2024
6.2.0-beta.3 72 3/10/2024
6.2.0-beta.2 70 3/10/2024
6.2.0-beta.1 62 3/10/2024
6.1.0 2,894 11/7/2023
6.0.0 125 11/5/2023
6.0.0-beta.2 86 10/30/2023
6.0.0-beta.1 91 10/25/2023
5.0.0-beta.3 128 7/11/2023
5.0.0-beta.2 96 7/2/2023
5.0.0-beta.1 93 6/24/2023
4.0.0 50,039 1/30/2022
3.1.1 2,604 1/23/2022
3.1.0 3,781 12/25/2021
3.0.0 1,300 11/14/2021
3.0.0-beta.1 271 10/30/2021
3.0.0-alpha.2 184 9/8/2021
3.0.0-alpha.1 162 8/30/2021
2.2.0 9,614 6/11/2021
2.1.1 607 4/4/2021
2.1.0 867 3/6/2021
2.1.0-rc 266 2/27/2021
2.1.0-beta 281 2/10/2021
2.0.2-alpha 215 2/7/2021
2.0.0 640 1/30/2021
2.0.0-rc 801 1/25/2021
2.0.0-beta.2 212 1/20/2021
2.0.0-beta 263 1/8/2021
2.0.0-alpha 259 1/5/2021
1.4.4 748 9/19/2020
1.4.3 719 5/25/2020
1.4.2 734 5/5/2020

Preview of the next major release. This package contains some refactoring, that could break existing code.