Property List - mangstadt/ez-vcard GitHub Wiki

The page contains a listing of all the vCard properties ez-vcard supports, along with code samples.

ADR

Defines a mailing address.

2.1 vCard 2.1 p.11 | 3.0 RFC 2426 p.11 | 4.0 RFC 6350 p.32

Java class: ezvcard.property.Address

VCard vcard = new VCard();

Address adr = new Address();
adr.setStreetAddress("123 Main St.");
adr.setLocality("Austin");
adr.setRegion("TX");
adr.setPostalCode("12345");
adr.setCountry("USA");
adr.getTypes().add(AddressType.WORK);

//optionally, set the mailing label text
adr.setLabel("123 Main St.\nAustin, TX 12345\nUSA");

vcard.addAddress(adr);
VCard vcard = ...
for (Address adr : vcard.getAddresses()){
  String street = adr.getStreetAddress();
  String city = adr.getLocality();
  //etc.
}

AGENT

Contains the contact information of someone who acts on behalf of the person defined in the vCard.

2.1 vCard 2.1 p.18 | 3.0 RFC 2426 p.19 | 4.0

Java class: ezvcard.property.Agent

VCard vcard = new VCard();

//URL
Agent agent = new Agent("http://www.linkedin.com/BobSmith");
vcard.setAgent(agent);

//vCard
VCard agentVCard = new VCard();
agentVCard.setFormattedName("Bob Smith");
agentVCard.addTelephoneNumber("(555) 123-4566");
agentVCard.addUrl("http://www.linkedin.com/BobSmith");
agent = new Agent(agentVCard);
vcard.setAgent(agent);
VCard vcard = ...
Agent agent = vcard.getAgent();

String url = agent.getUrl();
if (url != null){
  //property value is a URL
}

VCard agentVCard = agent.getVCard();
if (agentVCard != null){
  //property value is a vCard
}

ANNIVERSARY

Defines the person's anniversary.

2.1 | 3.0 | 4.0 RFC 6350 p.31

Java class: ezvcard.property.Anniversary

VCard vcard = new VCard();

//date
Calendar c = Calendar.getInstance();
c.clear();
c.set(Calendar.YEAR, 1970);
c.set(Calendar.MONTH, Calendar.MARCH);
c.set(Calendar.DAY_OF_MONTH, 21);
Anniversary anniversary = new Anniversary(c.getTime());
vcard.setAnniversary(anniversary);

//partial date (e.g. just the month and date)
PartialDate date = PartialDate.date(null, 3, 21);
anniversary = new Anniversary(date); //March 21
vcard.setAnniversary(anniversary);

//plain text value
anniversary = new Anniversary("Over 20 years ago!");
vcard.setAnniversary(anniversary);
VCard vcard = ...
Anniversary anniversary = vcard.getAnniversary();

Date date = anniversary.getDate();
if (date != null){
  //property value is a date
}

PartialDate partialDate = anniversary.getPartialDate();
if (partialDate != null){
  //property value is a partial date
  int year = partialDate.getYear();
  int month = partialDate.getMonth();
}

String text = anniversary.getText();
if (text != null){
  //property value is plain text
}

BDAY

Defines the person's birthday.

2.1 vCard 2.1 p.11 | 3.0 RFC 2426 p.11 | 4.0 RFC 6350 p.30

Java class: ezvcard.property.Birthday

VCard vcard = new VCard();

//date
Calendar c = Calendar.getInstance();
c.clear();
c.set(Calendar.YEAR, 1912);
c.set(Calendar.MONTH, Calendar.JUNE);
c.set(Calendar.DAY_OF_MONTH, 23);
Birthday bday = new Birthday(c.getTime());
vcard.setBirthday(bday);

//partial date (e.g. just the month and date, vCard 4.0 only)
bday = new Birthday(PartialDate.date(null, 6, 23)); //June 23
vcard.setBirthday(bday);

//plain text value (vCard 4.0 only)
bday = new Birthday("Don't even go there, dude...");
vcard.setBirthday(bday);
VCard vcard = ...
Birthday bday = vcard.getBirthday();

Date date = bday.getDate();
if (date != null){
  //property value is a date
}

PartialDate partialDate = bday.getPartialDate();
if (partialDate != null){
  //property value is a partial date
  int year = partialDate.getYear();
  int month = partialDate.getMonth();
}

String text = bday.getText();
if (text != null){
  //property value is plain text
}

BIRTHPLACE

Defines the location of the person's birth.

2.1 | 3.0 | 4.0 | RFC 6474 p.2

Java class: ezvcard.property.Birthplace

VCard vcard = new VCard();

//text
Birthplace birthplace = new Birthplace("Maida Vale, London, United Kingdom");
vcard.setBirthplace(birthplace);

//geo coordinates
birthplace = new Birthplace(51.5274, -0.1899);
vcard.setBirthplace(birthplace);

//URI
birthplace = new Birthplace();
birthplace.setUri("http://en.wikipedia.org/wiki/Maida_Vale");
vcard.setBirthplace(birthplace);
VCard vcard = ...
Birthplace birthplace = vcard.getBirthplace();

String text = birthplace.getText();
if (text != null){
  //property value is plain text
}

Double latitude = birthplace.getLatitude();
Double longitude = birthplace.getLongitude();
if (latitude != null){
  //property value is a set of geo coordinates
}

String uri = birthplace.getUri();
if (uri != null){
  //property value is a URI
}

CALADRURI

Defines a URL to use for sending a scheduling request to the person's calendar.

2.1 | 3.0 | 4.0 RFC 6350 p.50

Java class: ezvcard.property.CalendarRequestUri

VCard vcard = new VCard();
vcard.addCalendarRequestUri("mailto:[email protected]");

CALURI

Defines a URL that points to the person's calendar.

2.1 | 3.0 | 4.0 RFC 6350 p.50

Java class: ezvcard.property.CalendarUri

VCard vcard = new VCard();
vcard.addCalendarUri("http://www.ibm.com/janedoe/calendar");

CATEGORIES

Defines a list of keywords that can be used to describe the person.

2.1 | 3.0 RFC 2426 p.20 | 4.0 RFC 6350 p.43

Java class: ezvcard.property.Categories

VCard vcard = new VCard();
vcard.setCategories("Developer", "Java coder", "Ladies' man");

CLASS

Describes the sensitivity of the information in the vCard.

2.1 | 3.0 RFC 2426 p.26 | 4.0

Java class: ezvcard.property.Classification

VCard vcard = new VCard();
//sample values: PUBLIC, PRIVATE, CONFIDENTIAL
vcard.setClassification("PUBLIC");

CLIENTPIDMAP

Maps a globally-unique URI to a PID parameter value. The PID parameter can be set on any property where multiple instances are allowed (such as EMAIL or ADR, but not N because only 1 instance of N is allowed). It allows an individual property instance to be uniquely identifiable.

The CLIENTPIDMAP property and the PID parameter are used during the synchronization (merging) process of two versions of the same vCard. For example, if the user has a copy of her vCard on her desktop computer and her smart phone, and she makes different modifications to each copy, then the two copies could be synchronized in order to merge all the changes into a single, new vCard.

2.1 | 3.0 | 4.0 RFC 6350 p.47

Java class: ezvcard.property.ClientPidMap

VCard vcard = new VCard();

Address adr = new Address();
adr.addPid(1, 1);
vcard.addAddress(adr);

Email email = vcard.addEmail("[email protected]");
emai.addPid(1, 1);
email = vcard.addEmail("[email protected]");
email.addPid(2, 2);

//specify the URI to use
ClientPidMap clientpidmap = new ClientPidMap(1, "urn:uuid:03a0e51f-d1aa-4385-8a53-e29025acd8af");
vcard.addClientPidMap(clientpidmap);

//or, generate a random URI
clientpidmap = ClientPidMap.random(2);
vcard.addClientPidMap(clientpidmap);

DEATHDATE

Defines the person's time of death.

2.1 | 3.0 | 4.0 | RFC 6474 p.4

Java class: ezvcard.property.Deathdate

VCard vcard = new VCard();

//date
Calendar c = Calendar.getInstance();
c.clear();
c.set(Calendar.YEAR, 1954);
c.set(Calendar.MONTH, Calendar.JUNE);
c.set(Calendar.DAY_OF_MONTH, 7);
Deathdate deathdate = new Deathdate(c.getTime());
vcard.setDeathdate(deathdate);

//partial date (e.g. just the month and date)
deathdate = new Deathdate(PartialDate.date(null, 6, 7)); //June 7
vcard.setDeathdate(deathdate);

//plain text value
deathdate = new Deathdate("In the 1950s");
vcard.setDeathdate(deathdate);
VCard vcard = ...
Deathdate deathdate = vcard.getDeathdate();

Date date = deathdate.getDate();
if (date != null){
  //property value is a date
}

PartialDate partialDate = deathdate.getPartialDate();
if (partialDate != null){
  //property value is a partial date
  int year = partialDate.getYear();
  int month = partialDate.getMonth();
}

String text = deathdate.getText();
if (text != null){
  //property value is plain text
}

DEATHPLACE

Defines the location of the person's death.

2.1 | 3.0 | 4.0 | RFC 6474 p.3

Java class: ezvcard.property.Deathplace

VCard vcard = new VCard();

//text
Deathplace deathplace = new Deathplace("Wilmslow, Cheshire, England");
vcard.setDeathplace(deathplace);

//geo coordinates
deathplace = new Deathplace(53.325, -2.239);
vcard.setDeathplace(deathplace);

//URI
deathplace = new Deathplace();
deathplace.setUri("http://en.wikipedia.org/wiki/Wilmslow");
vcard.setDeathplace(deathplace);
VCard vcard = ...
Deathplace deathplace = vcard.getDeathplace();

String text = deathplace.getText();
if (text != null){
  //property value is plain text
}

Double latitude = deathplace.getLatitude();
Double longitude = deathplace.getLongitude();
if (latitude != null){
  //property value is a set of geo coordinates
}

String uri = deathplace.getUri();
if (uri != null){
  //property value is a URI
}

EMAIL

Defines an email address associated with the person.

2.1 vCard 2.1 p.15 | 3.0 RFC 2426 p.15 | 4.0 RFC 6350 p.36

Java class: ezvcard.property.Email

VCard vcard = new VCard();

vcard.addEmail("[email protected]", EmailType.HOME);
Email workEmail = vcard.addEmail("[email protected]", EmailType.WORK);
workEmail.setPref(1); //the most preferred email

EXPERTISE

Defines a professional subject area that the person has knowledge of. For example, if the person is a software engineer, he or she might list technologies such as "Java", "Web services", and "Agile development practices".

2.1 | 3.0 | 4.0 | RFC 6715 p.3

Java class: ezvcard.property.Expertise

VCard vcard = new VCard();

Expertise expertise = new Expertise("Java programming");
expertise.setLevel(ExpertiseLevel.EXPERT);
vcard.addExpertise(expertise);

FBURL

Defines a URL that shows when the person is free/busy on their calendar.

2.1 | 3.0 | 4.0 RFC 6350 p.49

Java class: ezvcard.property.FreeBusyUrl

VCard vcard = new VCard();
vcard.addFbUrl("http://www.example.com/freebusy/janedoe");

FN

Defines the person's full name in a human-readable format.

2.1 vCard 2.1 p.9 | 3.0 RFC 2426 p.8 | 4.0 RFC 6350 p.28

Java class: ezvcard.property.FormattedName

VCard vcard = new VCard();
vcard.setFormattedName("Dr. Gregory House M.D.");

GENDER

Defines the person's sex.

2.1 | 3.0 | 4.0 RFC 6350 p.32

Java class: ezvcard.property.Gender

VCard vcard = new VCard();
Gender gender = Gender.male();
vcard.setGender(gender);
VCard vcard = ...
Gender gender = vcard.getGender();
if (gender.isMale()){
  //gender is male
} else if (gender.isFemale()){
  //gender is female
}
//etc

GEO

A set of latitude/longitude coordinates. There is no rule for what these coordinates must represent, but the meaning could vary depending on the value of the vCard KIND property.

  • "individual": the location of the person's home or workplace.
  • "group": the location of the group's meeting place.
  • "org": the coordinates of the organization's headquarters.
  • "location": the coordinates of the location itself.

2.1 vCard 2.1 p.16 | 3.0 RFC 2426 p.16 | 4.0 RFC 6350 p.38

Java class: ezvcard.property.Geo

VCard vcard = new VCard();
vcard.setGeo(40.7127, -74.0059);

HOBBY

Defines a recreational activity that the person actively engages in. For example, if a person has a hobby of "hockey", it would mean that he likes to play hockey. Someone who just likes to watch hockey would list hockey as an INTEREST instead.

2.1 | 3.0 | 4.0 | RFC 6715 p.4

Java class: ezvcard.property.Hobby

VCard vcard = new VCard();

Hobby hobby = new Hobby("hockey");
hobby.setLevel(HobbyLevel.LOW);
vcard.addHobby(hobby);

IMPP

An instant message handle. The handle is represented as a URI in the format <IM-PROTOCOL>:<IM-HANDLE>. For example, someone with a Yahoo! Messenger handle of [email protected] would have an IMPP vCard property value of ymsgr:[email protected].

2.1 | 3.0 | RFC 4770 | 4.0 RFC 6350 p.36

Java class: ezvcard.property.Impp

VCard vcard = new VCard();

//URI
Impp impp = new Impp("aim:[email protected]");
vcard.addImpp(impp);

//static factory methods
impp = Impp.msn("[email protected]");
vcard.addImpp(impp);

INTEREST

Defines a recreational activity that the person is interested in. For example, if a person has an interest in "hockey", it would mean that he likes to watch hockey games. Someone who likes to actually play hockey would list hockey as a HOBBY instead.

2.1 | 3.0 | 4.0 | RFC 6715 p.5

Java class: ezvcard.property.Interest

VCard vcard = new VCard();

Interest interest = new Interest("hockey");
interest.setLevel(InterestLevel.HIGH);
vcard.addInterest(interest);

KEY

Defines a public encryption key.

2.1 vCard 2.1 p.22 | 3.0 RFC 2426 p.26 | 4.0 RFC 6350 p.48

Java class: ezvcard.property.Key

VCard vcard = new VCard();

//URL
Key key = new Key("http://www.mywebsite.com/my-public-key.pgp", KeyType.PGP);
vcard.addKey(key);

//binary data
byte data[] = ...
key = new Key(data, KeyType.PGP);
vcard.addKey(key);

//plain text value
key = new Key();
key.setText("...", KeyType.PGP);
vcard.addKey(key);
VCard vcard = ...
for (Key key : vcard.getKeys()){
  KeyType contentType = key.getContentType(); //e.g. "application/pgp-keys"

  String url = key.getUrl();
  if (url != null){
    //property value is a URL
    continue;
  }
  
  byte[] data = key.getData();
  if (data != null){
    //property value is binary data
    continue;
  }
  
  String text = key.getText();
  if (text != null){
    //property value is plain-text
    continue;
  }
}

KIND

Defines the type of entity that this vCard represents, such as an individual or an organization.

2.1 | 3.0 | 4.0 RFC 6350 p.25

Java class: ezvcard.property.Kind

VCard vcard = new VCard();

Kind kind = Kind.individual();
vcard.setKind(kind);
VCard vcard = ...
Kind kind = vcard.getKind();
if (kind.isIndividual()){
  //vCard contains information on an individual person
} else if (kind.isGroup()){
  //vCard contains information on a group of people
}
//etc

LABEL

Defines the exact text to put on the mailing label when sending snail mail to the person.

Note that, when using ez-vcard, instances of this class should NOT be added to the VCard object. Instead, use the Address.setLabel() method to assign a mailing label to its corresponding ADR property.

2.1 vCard 2.1 p.12 | 3.0 RFC 2426 p.13 | 4.0*

Java class: ezvcard.property.Label

* The label property is not supported in vCard version 4.0. Instead, labels are included as parameters to their corresponding ADR properties. When marshalling a vCard, ez-vcard will use either the LABEL property or the LABEL parameter, depending on the target vCard version.

Orphaned labels

ez-vcard defines an "orphaned label" as a LABEL property that could not be assigned to an address (a LABEL is assigned to an address if its list of TYPE parameters is identical to the address's list of TYPE parameters). The VCard.addOrphanedLabel() method can be used to add such labels to a vCard, but its use is strongly discouraged. The VCard.getOrphanedLabels() method can be useful when parsing version 2.1 or 3.0 vCards in order to retrieve any label properties that the parser could not assign to an address.

LANG

Defines a language that the person speaks.

2.1 | 3.0 | 4.0 RFC 6350 p.37

Java class: ezvcard.property.Language

VCard vcard = new VCard();

Language lang = vcard.addLanguage("en");
lang.setPref(1); //most preferred

lang = vcard.addLanguage("fr");
lang.setPref(2); //second-most preferred

LOGO

Defines a company logo.

2.1 vCard 2.1 p.17 | 3.0 RFC 2426 p.18 | 4.0 RFC 6350 p.40

Java class: ezvcard.property.Logo

VCard vcard = new VCard();

//URL
Logo logo = new Logo("http://www.ourcompany.com/our-logo.png", ImageType.PNG);
vcard.addLogo(logo);

//binary data
byte data[] = ...
logo = new Logo(data, ImageType.PNG);
vcard.addLogo(logo);
VCard vcard = ...
for (Logo logo : vcard.getLogos()){
  ImageType contentType = logo.getContentType(); //e.g. "image/png"

  String url = logo.getUrl();
  if (url != null){
    //property value is a URL
    continue;
  }
  
  byte[] data = logo.getData();
  if (data != null){
    //property value is binary data
    continue;
  }
}

MAILER

Defines the email client that the person uses.

2.1 vCard 2.1 p.15 | 3.0 RFC 2426 p.15 | 4.0

Java class: ezvcard.property.Mailer

VCard vcard = new VCard();
vcard.setMailer("Thunderbird");

MEMBER

Defines the members that make up the group. This property can only be used if the vCard's KIND property is set to "group".

2.1 | 3.0 | 4.0 RFC 6350 p.41

Java class: ezvcard.property.Member

VCard vcard = new VCard();

//kind property must be set to "group" in order to add members
vcard.setKind(Kind.group());

//static factory methods
Member member = Member.email("[email protected]");
vcard.addMember(member);

//reference another vCard by putting its UID property here
member = new Member("urn:uuid:03a0e51f-d1aa-4385-8a53-e29025acd8af");
vcard.addMember(member);

N

Defines the individual components of the person's name.

2.1 vCard 2.1 p.9 | 3.0 RFC 2426 p.9 | 4.0 RFC 6350 p.29

Java class: ezvcard.property.StructuredName

VCard vcard = new VCard();

StructuredName n = new StructuredName();
n.setFamily("House");
n.setGiven("Gregory");
n.getPrefixes().add("Dr");
n.getSuffixes().add("MD");
vcard.setStructuredName(n);

NAME

Defines a textual representation of the SOURCE property.

2.1 | 3.0 RFC 2426 p.5 | 4.0

Java class: ezvcard.property.SourceDisplayText

VCard vcard = new VCard();
vcard.setSourceDisplayText("My vCard");

NICKNAME

Defines the person's nicknames.

2.1 | 3.0 RFC 2426 p.9 | 4.0 RFC 6350 p.29

Java class: ezvcard.property.Nickname

VCard vcard = new VCard();
vcard.setNickname("Rick", "Ricky", "Bobby");

NOTE

Defines a free-form text field that contains miscellaneous information.

2.1 vCard 2.1 p.19 | 3.0 RFC 2426 p.21 | 4.0 RFC 6350 p.44

Java class: ezvcard.property.Note

VCard vcard = new VCard();
Note note = vcard.addNote("This is a\nmiscellaneous comment."); //can contain newlines
note.setLanguage("en-us");

ORG

Defines a list of organizations the person belongs to. The list is ordered. It begins with the broadest organization and ends with the most specific.

2.1 vCard 2.1 p.19 | 3.0 RFC 2426 p.20 | 4.0 RFC 6350 p.40

Java class: ezvcard.property.Organization

VCard vcard = new VCard();
vcard.setOrganization("Google", "Gmail Team", "Spam Detection Squad");

ORG-DIRECTORY

Defines a URI that can be used to retrieve information about the person's co-workers.

2.1 | 3.0 | 4.0 | RFC 6715 p.6

Java class: ezvcard.property.OrgDirectory

VCard vcard = new VCard();
vcard.addOrgDirectory("http://www.company.com/staff");

PHOTO

Defines a photo, such as the person's portrait.

2.1 vCard 2.1 p.10 | 3.0 RFC 2426 p.10 | 4.0 RFC 6350 p.30

Java class: ezvcard.property.Photo

VCard vcard = new VCard();

//URL
Photo photo = new Photo("http://www.mywebsite.com/my-photo.jpg", ImageType.JPEG);
vcard.addPhoto(photo);

//binary data
byte data[] = ...
photo = new Photo(data, ImageType.JPEG);
vcard.addPhoto(photo);
VCard vcard = ...
for (Photo photo : vcard.getPhotos()){
  PhotoType contentType = photo.getContentType(); //e.g. "image/jpeg"

  String url = photo.getUrl();
  if (url != null){
    //property value is a URL
    continue;
  }
  
  byte[] data = photo.getData();
  if (data != null){
    //property value is binary data
    continue;
  }
}

PRODID

Identifies the software application that created the vCard.

2.1 | 3.0 RFC 2426 p.21 | 4.0 RFC 6350 p.44

Java class: ezvcard.property.ProductId

VCard vcard = new VCard();
vcard.setProdId("ez-vcard 0.9.6");

PROFILE

Simply identifies the data as being vCard data.

2.1 | 3.0 RFC 2426 p.5 | 4.0

Java class: ezvcard.property.Profile

VCard vcard = new VCard();
Profile profile = new Profile();
vcard.setProfile(profile);

RELATED

Defines someone that the person is related to.

2.1 | 3.0 | 4.0 RFC 6350 p.42

Java class: ezvcard.property.Related

VCard vcard = new VCard();

//static factory methods
Related related = Related.email("[email protected]");
related.getTypes().add(RelatedType.CO_WORKER);
related.getTypes().add(RelatedType.FRIEND);
vcard.addRelated(related);

//free-form text
related = new Related();
related.setText("Edna Smith");
related.getTypes().add(RelatedType.SPOUSE);
vcard.addRelated(related);

//reference another vCard by putting its UID property here
related = new Related("urn:uuid:03a0e51f-d1aa-4385-8a53-e29025acd8af");
related.getTypes().add(RelatedType.SIBLING);
vcard.addRelated(related);

REV

Defines the date that the vCard was last modified by its owner.

2.1 vCard 2.1 p.19 | 3.0 RFC 2426 p.22 | 4.0 RFC 6350 p.45

Java class: ezvcard.property.Revision

VCard vcard = new VCard();
vcard.setRevision(new Date());

ROLE

Defines the function that the person plays within his or her organization.

2.1 vCard 2.1 p.17 | 3.0 RFC 2426 p.18 | 4.0 RFC 6350 p.39

Java class: ezvcard.property.Role

VCard vcard = new VCard();
vcard.addRole("Project Leader");

SORT-STRING

Defines a string that should be used to sort the vCard.

2.1 | 3.0 RFC 2426 p.22 | 4.0*

Java class: ezvcard.property.SortString

* The SORT-STRING property is not supported in 4.0. Instead, a SORT-AS parameter can be added to the N and/or ORG properties.

//3.0
VCard vcard = new VCard();

StructuredName n = new StructuredName();
n.setFamily("D'Armour");
n.setGiven("Miles");
vcard.setStructuredName(n);

vcard.setSortString("Armour");
//4.0
VCard vcard = new VCard();

StructuredName n = new StructuredName();
n.setFamily("D'Armour");
n.setGiven("Miles");
n.setSortAs("Armour");
vcard.setStructuredName(n);

SOUND

Defines a sound, such as the correct pronunciation of the person's name.

2.1 vCard 2.1 p.20 | 3.0 RFC 2426 p.23 | 4.0 RFC 6350 p.45

Java class: ezvcard.property.Sound

VCard vcard = new VCard();

//URL
Sound sound = new Sound("http://www.mywebsite.com/my-name.ogg", SoundType.OGG);
vcard.addSound(sound);

//binary data
byte data[] = ...
sound = new Sound(data, SoundType.OGG);
vcard.addSound(sound);
VCard vcard = ...
for (Sound sound : vcard.getSounds()){
  SoundType contentType = sound.getContentType(); //e.g. "audio/ogg"

  String url = sound.getUrl();
  if (url != null){
    //property value is a URL
    continue;
  }
  
  byte[] data = sound.getData();
  if (data != null){
    //property value is binary data
    continue;
  }
}

SOURCE

Defines a URL that can be used to retrieve the latest version of the vCard.

2.1 | 3.0 RFC 2426 p.5 | 4.0 RFC 6350 p.24

Java class: ezvcard.property.Source

VCard vcard = new VCard();
vcard.addSource("http://www.company.com/employees/doe_john.vcf");

TEL

Defines a telephone number.

2.1 vCard 2.1 p.13 | 3.0 RFC 2426 p.14 | 4.0 RFC 6350 p.34

Java class: ezvcard.property.Telephone

VCard vcard = new VCard();

//text
Telephone tel = new Telephone("(123) 555-6789");
tel.getTypes().add(TelephoneType.HOME);
tel.setPref(2); //the second-most preferred
vcard.addTelephoneNumber(tel);

//URI (vCard version 4.0 only)
TelUri uri = new TelUri.Builder("+1-800-555-9876").extension("111").build();
tel = new Telephone(uri);
tel.getTypes().add(TelephoneType.WORK);
tel.setPref(1); //the most preferred
vcard.addTelephoneNumber(tel);

TITLE

Defines the person's title in his or her organization.

2.1 vCard 2.1 p.17 | 3.0 RFC 2426 p.17 | 4.0 RFC 6350 p.39

Java class: ezvcard.property.Title

VCard vcard = new VCard();
vcard.addTitle("Research Scientist");

TZ

Defines the timezone that the person lives or works in.

2.1 vCard 2.1 p.16 | 3.0 RFC 2426 p.16 | 4.0 RFC 6350 p.22

Java class: ezvcard.property.Timezone

VCard vcard = new VCard();

Timezone tz = new Timezone(-5, 0, "America/New_York");
vcard.addTimezone(tz);

//using a Java "TimeZone" object
java.util.TimeZone javaTz = java.util.TimeZone.getTimeZone("America/New_York");
tz = new Timezone(javaTz);
vcard.addTimezone(tz);

UID

Defines a globally unique identifier for this vCard.

2.1 vCard 2.1 p.21 | 3.0 RFC 2426 p.24 | 4.0 RFC 6350 p.46

Java class: ezvcard.property.Uid

VCard vcard = new VCard();
vcard.setUid("urn:uuid:b8767877-b4a1-4c70-9acc-505d3819e519");

//generate a random UID
Uid uid = Uid.random();
vcard.setUid(uid);

URL

Defines a URL that points to the person's homepage or business website.

2.1 vCard 2.1 p.21 | 3.0 RFC 2426 p.25 | 4.0 RFC 6350 p.47

Java class: ezvcard.property.Url

VCard vcard = new VCard();
vcard.addUrl("http://www.company.com");

XML

Contains an XML element that was not recognized when parsing an xCard (XML-formatted vCard).

2.1 | 3.0 | 4.0 RFC 6350 p.27

Java class: ezvcard.property.Xml

VCard vcard = new VCard();
Xml xml = new Xml("<b>Some xml</b>");
vcard.addXml(xml);
⚠️ **GitHub.com Fallback** ⚠️