CINXE.COM

FOAF Vocabulary Specification

<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> <head xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:foaf="http://xmlns.com/foaf/0.1/" xmlns:vs="http://www.w3.org/2003/06/sw-vocab-status/ns#" xmlns:rdfs="http://www.w3.org/2000/01/rdf-schema#" xmlns:owl="http://www.w3.org/2002/07/owl#" xmlns:dct="http://purl.org/dc/terms/" xmlns:dc="http://purl.org/dc/elements/1.1/"> <title>FOAF Vocabulary Specification</title> <meta http-equiv="Content-Type" content="text/html;charset=utf-8" /> <link href="http://xmlns.com/xmlns-style.css" rel="stylesheet" type="text/css" /> <link href="style.css" rel="stylesheet" type="text/css" /> <link href="http://xmlns.com/foaf/spec/index.rdf" rel="alternate" type="application/rdf+xml" /> </head> <body> <h1>FOAF Vocabulary Specification 0.99<br /></h1> <h2>Namespace Document 14 January 2014 - <em>Paddington Edition</em></h2> <dl> <dt>This version:</dt> <dd><a href="http://xmlns.com/foaf/spec/20140114.html">http://xmlns.com/foaf/spec/20140114.html</a> (<a href="20140114.rdf">rdf</a>)</dd> <dt>Latest version:</dt> <dd><a href="http://xmlns.com/foaf/spec/">http://xmlns.com/foaf/spec/</a> (<a href="index.rdf">rdf</a>)</dd> <dt>Previous version:</dt> <dd><a href="http://xmlns.com/foaf/spec/20100809.html">http://xmlns.com/foaf/spec/20100809.html</a> (<a href="20100809.rdf">rdf</a>)</dd> <dt>Authors:</dt> <dd><a href="mailto:danbri@danbri.org">Dan Brickley</a>, <a href="mailto:libby@nicecupoftea.org">Libby Miller</a></dd> <dt>Contributors:</dt> <dd>Members of the FOAF mailing list (<a href= "http://lists.foaf-project.org/">foaf-dev@lists.foaf-project.org</a>) and the wider <a href="http://www.w3.org/2001/sw/interest/">RDF and Semantic Web developer community</a>. See <a href= "#sec-ack">acknowledgements</a>.</dd> </dl> <p class="copyright">Copyright &#169; 2000-2014 Dan Brickley and Libby Miller</p> <p><a href="http://creativecommons.org/licenses/by/1.0/"><img alt= "Creative Commons License" style="border: 0; float: right; padding: 5px;" src= "somerights.gif" /></a> This work is licensed under a <a rel="license" href= "http://creativecommons.org/licenses/by/1.0/">Creative Commons Attribution License</a>. This copyright applies to the <em>FOAF Vocabulary Specification</em> and accompanying documentation in RDF. Regarding underlying technology, FOAF uses W3C's <a href="http://www.w3.org/RDF/">RDF</a> technology, an open Web standard that can be freely used by anyone.</p> <hr /> <h2 id="sec-status">Abstract</h2> <p> This specification describes the FOAF language, defined as a dictionary of named properties and classes using W3C's RDF technology. </p> <p> FOAF is a project devoted to linking people and information using the Web. Regardless of whether information is in people's heads, in physical or digital documents, or in the form of factual data, it can be linked. FOAF integrates three kinds of network: <em>social networks</em> of human collaboration, friendship and association; <em>representational networks</em> that describe a simplified view of a cartoon universe in factual terms, and <em>information networks</em> that use Web-based linking to share independently published descriptions of this inter-connected world. FOAF does not compete with socially-oriented Web sites; rather it provides an approach in which different sites can tell different parts of the larger story, and by which users can retain some control over their information in a non-proprietary format. </p> <div class="status"> <h2>Status of This Document</h2> <p> FOAF has been evolving gradually since its creation in mid-2000. There is now a stable core of classes and properties that will not be changed, beyond modest adjustments to their documentation to track implementation feedback and emerging best practices. New terms may be added at any time (as with a natural-language dictionary), and consequently this specification is an evolving work. The FOAF RDF namespace URI, by contrast, is fixed and its identifier is not expected to <a href="#sec-evolution">change</a>. Furthermore, efforts are underway to ensure the long-term preservation of the FOAF namespace, its xmlns.com domain name and associated documentation. </p> <p> The FOAF specification is produced as part of the <a href="http://www.foaf-project.org/">FOAF project</a>, to provide authoritative documentation of the contents, status and purpose of the RDF/XML vocabulary and document formats known informally as 'FOAF'.</p> <p>This document is created by combining the <a href="index.rdf">RDFS/OWL</a> machine-readable FOAF ontology with a set of <a href="../doc/">per-term</a> documents. Future versions may incorporate <a href="http://svn.foaf-project.org/foaftown/foaf18n/">multilingual translations</a> of the term definitions. An RDF/XML encoding of the specification is available by <a href="index.rdf">direct link</a> or by HTTP <a href="http://en.wikipedia.org/wiki/Content_negotiation">content negotiation</a> from the <a href="http://xmlns.com/foaf/0.1/">namespace URI</a>. The HTML specification no longer embeds the RDF/XML markup; however an experimental subset of the RDF is included in this document using RDFa notation.</p> <p>The authors welcome comments on this document, preferably via the public FOAF developers list <a href= "mailto:foaf-dev@lists.foaf-project.org">foaf-dev@lists.foaf-project.org</a>; <a href="http://lists.foaf-project.org">public archives</a> are available. A historical backlog of known technical issues is acknowledged, and available for discussion on the <a href="mailto:foaf-dev@lists.foaf-project.org">FOAF mailing list</a>. Proposals for resolving these issues are welcomed, on foaf-dev. Further work is also needed on the explanatory text in this specification and on the <a href="http://www.foaf-project.org/">FOAF website</a>; progress towards this will be measured in the version number of future revisions to the FOAF specification. </p> <h3>Changes in version 0.99</h3> <p>This revision stablises weblog, page, Document and Image and adds three owl:equivalent classes to schema.org - Person (Person), Image (ImageObject), Document (CreativeWork).</p> <p>See the <a href="#sec-changes">changes</a> section for more detailed change-log information.</p> <h2 id="sec-toc">Table of Contents</h2> <ul> <li><a href="#sec-glance">FOAF at a glance</a></li> <li><a href="#sec-intro">Introduction</a></li> <li><a href="#sec-sw">The Semantic Web</a></li> <li><a href="#sec-foafsw">FOAF and the Semantic Web</a></li> <li><a href="#sec-for">What's FOAF for?</a></li> <li><a href="#sec-bg">Background</a></li> <li><a href="#sec-standards">FOAF and Standards</a></li> <li><a href="#sec-evolution">Evolution and Extension of FOAF</a></li> <li><a href="#sec-autodesc">FOAF Auto-Discovery: Publishing and Linking FOAF files</a></li> <li><a href="#sec-crossref">FOAF cross-reference: Listing FOAF Classes and Properties</a></li> <li><a href="#sec-extrefs">External Vocabulary References</a></li> <li><a href="#sec-ack">Acknowledgments</a></li> <li><a href="#sec-changes">Recent Changes</a></li> </ul> <a id="sec-glance"></a> <h2 id="glance">FOAF at a glance</h2> <p>FOAF describes the world using simple ideas inspired by the Web. In FOAF descriptions, there are only various kinds of things and links, which we call <em>properties</em>. The types of the things we talk about in FOAF are called <em>classes</em>. FOAF is therefore defined as a dictionary of terms, each of which is either a <em>class</em> or a <em>property</em>. Other projects alongside FOAF provide other sets of classes and properties, many of which are linked with those defined in FOAF. </p> <p>FOAF descriptions are themselves published as linked documents in the Web (eg. using RDF/XML or RDFa syntax). The result of the FOAF project is a network of documents describing a network of people (and other stuff). Each FOAF document is itself an encoding of a descriptive network structure. Although these documents do not always agree or tell the truth, they have the useful characteristic that they can be easily merged, allowing partial and decentralised descriptions to be combined in interesting ways. </p> <p> FOAF collects a variety of terms; some describe people, some groups, some documents. Different kinds of application can use or ignore different parts of FOAF. The overview here shows one way of viewing FOAF terms: we ignore archaic and historical parts, and divide the rest into terms that only make sense on the Web, and those that have universal applicability when linking people and information. </p> <p>Main FOAF terms, grouped in broad categories.</p> <ul> <li><strong>Core</strong> - These classes and properties form the core of FOAF. They describe characteristics of people and social groups that are independent of time and technology; as such they can be used to describe basic information about people in present day, historical, cultural heritage and digital library contexts. In addition to various characteristics of people, FOAF defines classes for Project, Organization and Group as other kinds of agent. Related work: <a href="http://www.dublincore.org/">Dublin Core</a>, <a href="http://www.w3.org/2004/02/skos/">SKOS</a>, <a href="http://trac.usefulinc.com/doap">DOAP</a>, <a href="http://sioc-project.org/">SIOC</a>, <a href="http://www.epimorphics.com/public/vocabulary/org.html">Org vocabulary</a>, <a href="http://vocab.org/bio/0.1/.html">Bio vocabulary</a>. </li> <li><strong>Social Web</strong> - in addition to the FOAF core terms, there are a number of terms for use when describing Internet accounts, addressbooks and other Web-based activities. Related work: <a href="http://portablecontacts.net/">Portable Contacts</a>, <a href="http://www.w3.org/2005/Incubator/socialweb/">W3C Social Web group</a>.</li> <li><strong>Linked Data utilities</strong> - FOAF began as the 'RDFWeb' project, and established a widely adopted model for publishing simple factual data via a networked of linked RDF documents. FOAF remains important to the growing "Linked Data" community, while also maintaining a concern for information that is not readily summarised as simple factual data. FOAF is an attempt to use the Web to integrate factual information with information in human-oriented documents (eg. videos, books, spreadsheets, 3d models), as well as information that is still in people's heads. This history explains why FOAF includes a few 'demonstration' terms that served largely educational purposes (eg. <a href="#term_geekcode">geekcode</a>), alongside a few technical utility terms (eg. <a href="#term_focus">focus</a>, <a href="#term_LabelProperty">LabelProperty</a>) that support wider information-linking efforts. The dictionary-based design of FOAF allows a certain pragmatism: we simply record here a set of terms that are useful to the Web community, while keeping an emphasis on the central idea of FOAF, which is about linking networks of information with networks of people. </li> </ul> <div class="rdf-proplist"> <h3>FOAF Core</h3> <ul> <li> <ul> <li><a href="#term_Agent">Agent</a></li> <li><a href="#term_Person">Person</a></li> <li><a href="#term_name">name</a></li> <li><a href="#term_title">title</a></li> <li><a href="#term_img">img</a></li> <li><a href="#term_depiction">depiction</a> (<a href="#term_depicts">depicts</a>)</li> <li><a href="#term_familyName">familyName</a></li> <li><a href="#term_givenName">givenName</a></li> <li><a href="#term_knows">knows</a></li> <li><a href="#term_based_near">based_near</a></li> <li><a href="#term_age">age</a></li> <li><a href="#term_made">made</a> (<a href="#term_maker">maker</a>)</li> <li><a href="#term_primaryTopic">primaryTopic</a> (<a href="#term_isPrimaryTopicOf">primaryTopicOf</a>)</li> </ul> </li> <li> <ul> <li><a href="#term_Project">Project</a></li> <li><a href="#term_Organization">Organization</a></li> <li><a href="#term_Group">Group</a></li> <li><a href="#term_member">member</a></li> </ul> </li> <li> <ul> <li><a href="#term_Document">Document</a></li> <li><a href="#term_Image">Image</a></li> </ul> </li> </ul> </div> </div> <div class="rdf-proplist"> <h3>Social Web</h3> <ul> <li><a href="#term_nick">nick</a></li> <li><a href="#term_mbox">mbox</a></li> <li><a href="#term_homepage">homepage</a></li> <li><a href="#term_weblog">weblog</a></li> <li><a href="#term_openid">openid</a></li> <li><a href="#term_jabberID">jabberID</a></li> <li><a href="#term_mbox_sha1sum">mbox_sha1sum</a></li> <li><a href="#term_interest">interest</a></li> <li><a href="#term_topic_interest">topic_interest</a></li> <li><a href="#term_topic">topic</a> (<a href="#term_page">page</a>)</li> <li><a href="#term_workplaceHomepage">workplaceHomepage</a></li> <li><a href="#term_workInfoHomepage">workInfoHomepage</a></li> <li><a href="#term_schoolHomepage">schoolHomepage</a></li> <li><a href="#term_publications">publications</a></li> <li><a href="#term_currentProject">currentProject</a></li> <li><a href="#term_pastProject">pastProject</a></li> <li><a href="#term_account">account</a></li> <li><a href="#term_OnlineAccount">OnlineAccount</a></li> <li><a href="#term_accountName">accountName</a></li> <li><a href="#term_accountServiceHomepage">accountServiceHomepage</a></li> <li><a href="#term_PersonalProfileDocument">PersonalProfileDocument</a></li> <li><a href="#term_tipjar">tipjar</a></li> <li><a href="#term_sha1">sha1</a></li> <li><a href="#term_thumbnail">thumbnail</a></li> <li><a href="#term_logo">logo</a></li> </ul> </div> <div style="clear: left;"></div> <h3>A-Z of FOAF terms (current and archaic)</h3> <p>This is a complete alphabetical A-Z index of <strong>all</strong> FOAF terms, by class (categories or types) and by property. Note that it includes 'archaic' terms that are largely of historical interest.</p> <div class="azlist"> <p>Classes: | <a href="#term_Agent">Agent</a> | <a href="#term_Document">Document</a> | <a href="#term_Group">Group</a> | <a href="#term_Image">Image</a> | <a href="#term_LabelProperty">LabelProperty</a> | <a href="#term_OnlineAccount">OnlineAccount</a> | <a href="#term_OnlineChatAccount">OnlineChatAccount</a> | <a href="#term_OnlineEcommerceAccount">OnlineEcommerceAccount</a> | <a href="#term_OnlineGamingAccount">OnlineGamingAccount</a> | <a href="#term_Organization">Organization</a> | <a href="#term_Person">Person</a> | <a href="#term_PersonalProfileDocument">PersonalProfileDocument</a> | <a href="#term_Project">Project</a> | </p> <p>Properties: | <a href="#term_account">account</a> | <a href="#term_accountName">accountName</a> | <a href="#term_accountServiceHomepage">accountServiceHomepage</a> | <a href="#term_age">age</a> | <a href="#term_aimChatID">aimChatID</a> | <a href="#term_based_near">based_near</a> | <a href="#term_birthday">birthday</a> | <a href="#term_currentProject">currentProject</a> | <a href="#term_depiction">depiction</a> | <a href="#term_depicts">depicts</a> | <a href="#term_dnaChecksum">dnaChecksum</a> | <a href="#term_familyName">familyName</a> | <a href="#term_family_name">family_name</a> | <a href="#term_firstName">firstName</a> | <a href="#term_focus">focus</a> | <a href="#term_fundedBy">fundedBy</a> | <a href="#term_geekcode">geekcode</a> | <a href="#term_gender">gender</a> | <a href="#term_givenName">givenName</a> | <a href="#term_givenname">givenname</a> | <a href="#term_holdsAccount">holdsAccount</a> | <a href="#term_homepage">homepage</a> | <a href="#term_icqChatID">icqChatID</a> | <a href="#term_img">img</a> | <a href="#term_interest">interest</a> | <a href="#term_isPrimaryTopicOf">isPrimaryTopicOf</a> | <a href="#term_jabberID">jabberID</a> | <a href="#term_knows">knows</a> | <a href="#term_lastName">lastName</a> | <a href="#term_logo">logo</a> | <a href="#term_made">made</a> | <a href="#term_maker">maker</a> | <a href="#term_mbox">mbox</a> | <a href="#term_mbox_sha1sum">mbox_sha1sum</a> | <a href="#term_member">member</a> | <a href="#term_membershipClass">membershipClass</a> | <a href="#term_msnChatID">msnChatID</a> | <a href="#term_myersBriggs">myersBriggs</a> | <a href="#term_name">name</a> | <a href="#term_nick">nick</a> | <a href="#term_openid">openid</a> | <a href="#term_page">page</a> | <a href="#term_pastProject">pastProject</a> | <a href="#term_phone">phone</a> | <a href="#term_plan">plan</a> | <a href="#term_primaryTopic">primaryTopic</a> | <a href="#term_publications">publications</a> | <a href="#term_schoolHomepage">schoolHomepage</a> | <a href="#term_sha1">sha1</a> | <a href="#term_skypeID">skypeID</a> | <a href="#term_status">status</a> | <a href="#term_surname">surname</a> | <a href="#term_theme">theme</a> | <a href="#term_thumbnail">thumbnail</a> | <a href="#term_tipjar">tipjar</a> | <a href="#term_title">title</a> | <a href="#term_topic">topic</a> | <a href="#term_topic_interest">topic_interest</a> | <a href="#term_weblog">weblog</a> | <a href="#term_workInfoHomepage">workInfoHomepage</a> | <a href="#term_workplaceHomepage">workplaceHomepage</a> | <a href="#term_yahooChatID">yahooChatID</a> | </p> </div> <h2 id="sec-example">Example</h2> <p>Here is a very basic document describing a person:</p> <div class="example"> <pre> &lt;foaf:Person rdf:about="#danbri" xmlns:foaf="http://xmlns.com/foaf/0.1/"&gt; &lt;foaf:name&gt;Dan Brickley&lt;/foaf:name&gt; &lt;foaf:homepage rdf:resource="http://danbri.org/" /&gt; &lt;foaf:openid rdf:resource="http://danbri.org/" /&gt; &lt;foaf:img rdf:resource="/images/me.jpg" /&gt; &lt;/foaf:Person&gt; </pre> </div> <p>This brief example introduces the basics of FOAF. It basically says, "there is a <a href="#term_Person">foaf:Person</a> with a <a href="#term_name">foaf:name</a> property of 'Dan Brickley'; this person stands in <a href="#term_homepage">foaf:homepage</a> and <a href="#term_openid">foaf:openid</a> relationship to a thing called http://danbri.org/ and a <a href= "#term_img">foaf:img</a> relationship to a thing referenced by a relative URI of /images/me.jpg</p> <div style="clear: left;"></div> <!-- ================================================================== --> <h2 id="sec-intro">1 Introduction: FOAF Basics</h2> <h3 id="sec-sw">The Semantic Web</h3> <blockquote> <p> <em> To a computer, the Web is a flat, boring world, devoid of meaning. This is a pity, as in fact documents on the Web describe real objects and imaginary concepts, and give particular relationships between them. For example, a document might describe a person. The title document to a house describes a house and also the ownership relation with a person. Adding semantics to the Web involves two things: allowing documents which have information in machine-readable forms, and allowing links to be created with relationship values. Only when we have this extra level of semantics will we be able to use computer power to help us exploit the information to a greater extent than our own reading. </em> - Tim Berners-Lee &quot;<a href="http://www.w3.org/Talks/WWW94Tim/">W3 future directions</a>&quot; keynote, 1st World Wide Web Conference Geneva, May 1994 </p> </blockquote> <blockquote> <p><em>I express my network in a FOAF file, and that is a start of the revolution.</em> - TimBL 2007, <a href="http://dig.csail.mit.edu/breadcrumbs/node/215">Giant Global Graph</a> (<a href="http://www.w3.org/People/Berners-Lee/card">foaf</a>) </p> </blockquote> <p> FOAF is a project devoted to linking people and information using the Web. Regardless of whether information is in people's heads, in physical or digital documents, or in the form of factual data, it can be linked. FOAF integrates three kinds of network: <em>social networks</em> of human collaboration, friendship and association; <em>representational networks</em> that describe a simplified view of a cartoon universe in factual terms, and <em>information networks</em> that use Web-based linking to share independently published descriptions of this inter-connected world. FOAF does not compete with socially-oriented Web sites; rather it provides an approach in which different sites can tell different parts of the larger story, and through which users can retain some control over their information in a non-proprietary format. </p> <h3 id="sec-foafsw">FOAF and the Semantic Web</h3> <p> FOAF, like the Web itself, is a linked information system. It is built using decentralised <a href="http://www.w3.org/2001/sw/">Semantic Web</a> technology, and has been designed to allow for integration of data across a variety of applications, Web sites and services, and software systems. To achieve this, FOAF takes a liberal approach to data exchange. It does not require you to say anything at all about yourself or others, nor does it place any limits on the things you can say or the variety of Semantic Web vocabularies you may use in doing so. This current specification provides a basic "dictionary" of terms for talking about people and the things they make and do.</p> <p>FOAF was designed to be used alongside other such dictionaries ("schemas" or "ontologies"), and to be usable with the wide variety of generic tools and services that have been created for the Semantic Web. For example, the W3C work on <a href="http://www.w3.org/TR/rdf-sparql-query/">SPARQL</a> provides us with a rich query language for consulting databases of FOAF data, while the <a href="http://www.w3.org/2004/02/skos/">SKOS</a> initiative explores in more detail than FOAF the problem of describing topics, categories, "folksonomies" and subject hierarchies. Meanwhile, other W3C groups are working on improved mechanisms for encoding all kinds of RDF data (including but not limited to FOAF) within Web pages: see the work of the <a href="http://www.w3.org/2001/sw/grddl-wg/">GRDDL</a> and <a href="http://www.w3.org/TR/xhtml-rdfa-primer/">RDFa</a> efforts for more detail. The Semantic Web provides us with an <em>architecture for collaboration</em>, allowing complex technical challenges to be shared by a loosely-coordinated community of developers. </p> <p>The FOAF project is based around the use of <em>machine readable</em> Web homepages for people, groups, companies and other kinds of thing. To achieve this we use the "FOAF vocabulary" to provide a collection of basic terms that can be used in these Web pages. At the heart of the FOAF project is a set of definitions designed to serve as a dictionary of terms that can be used to express claims about the world. The initial focus of FOAF has been on the description of people, since people are the things that link together most of the other kinds of things we describe in the Web: they make documents, attend meetings, are depicted in photos, and so on.</p> <p>The FOAF Vocabulary definitions presented here are written using a computer language (RDF/OWL) that makes it easy for software to process some basic facts about the terms in the FOAF vocabulary, and consequently about the things described in FOAF documents. A FOAF document, unlike a traditional Web page, can be combined with other FOAF documents to create a unified database of information. FOAF is a <a href="http://www.w3.org/DesignIssues/LinkedData.html">Linked Data</a> system, in that it based around the idea of linking together a Web of decentralised descriptions.</p> <h3 id="sec-basicidea">The Basic Idea</h3> <p>The basic idea is pretty simple. If people publish information in the FOAF document format, machines will be able to make use of that information. If those files contain "see also" references to other such documents in the Web, we will have a machine-friendly version of today's hypertext Web. Computer programs will be able to scutter around a Web of documents designed for machines rather than humans, storing the information they find, keeping a list of "see also" pointers to other documents, checking digital signatures (for the security minded) and building Web pages and question-answering services based on the harvested documents.</p> <p>So, what is the 'FOAF document format'? FOAF files are just text documents (well, Unicode documents). They adopt the conventions of the Resource Description Framework (RDF), and may be written in XML syntax or any other of the syntaxes of RDF such as RDFa or N3. In addition, the FOAF vocabulary defines some useful constructs that can appear in FOAF files, alongside other RDF vocabularies defined elsewhere. For example, FOAF defines categories ('classes') such as <code>foaf:Person</code>, <code>foaf:Document</code>, <code>foaf:Image</code>, alongside some handy properties of those things, such as <code>foaf:name</code>, <code>foaf:mbox</code> (ie. an internet mailbox), <code>foaf:homepage</code> etc., as well as some useful kinds of relationship that hold between members of these categories. For example, one interesting relationship type is <code>foaf:depiction</code>. This relates something (eg. a <code>foaf:Person</code>) to a <code>foaf:Image</code>. The FOAF demos that feature photos and listings of 'who is in which picture' are based on software tools that parse RDF documents and make use of these properties.</p> <p>The specific contents of the FOAF vocabulary are detailed in this <a href="http://xmlns.com/foaf/0.1/">FOAF namespace document</a>. In addition to the FOAF vocabulary, one of the most interesting features of a FOAF file is that it can contain "see Also" pointers to other FOAF files. This provides a basis for automatic harvesting tools to traverse a Web of interlinked files, and learn about new people, documents, services, data...</p> <p>The remainder of this specification describes how to publish and interpret descriptions such as these on the Web, using RDF/XML for syntax (file format) and terms from FOAF. It introduces a number of categories (RDF classes such as 'Person') and properties (relationship and attribute types such as 'mbox' or 'workplaceHomepage'). Each term definition is provided in both human and machine-readable form, hyperlinked for quick reference.</p> <h2 id="sec-for">What's FOAF for?</h2> <p>For an early general introduction to FOAF, see Edd Dumbill's article, <a href= "http://www-106.ibm.com/developerworks/xml/library/x-foaf.html">XML Watch: Finding friends with XML and RDF</a> (June 2002, IBM developerWorks). Information about the use of FOAF <a href= "http://rdfweb.org/2002/01/photo/">with image metadata</a> is also available.</p> <p>The <a href= "http://rdfweb.org/2002/01/photo/">co-depiction</a> experiment shows a fun use of the vocabulary. To create a FOAF document, you can use Leigh Dodd's <a href= "http://www.ldodds.com/foaf/foaf-a-matic.html">FOAF-a-matic</a> javascript tool. For more information on FOAF and related projects, see the <a href= "http://www.foaf-project.org">FOAF project home page</a>. </p> <h2 id="sec-bg">Background</h2> <p>FOAF is a collaborative effort amongst developers on the FOAF (foaf-dev@lists.foaf-project.org) mailing list. The name 'FOAF' is derived from traditional internet usage, an acronym for 'Friend of a Friend'.</p> <p>The name was chosen to reflect our concern with social networks and the Web, urban myths, trust and connections. Other uses of the name continue, notably in the documentation and investigation of Urban Legends (eg. see the <a href= "http://www.urbanlegends.com/">alt.folklore.urban archive</a> or <a href="http://www.snopes.com/">snopes.com</a>), and other FOAF stories. Our use of the name 'FOAF' for a Web vocabulary and document format is intended to complement, rather than replace, these prior uses. FOAF documents describe the characteristics and relationships amongst friends of friends, and their friends, and the stories they tell.</p> <h2 id="sec-standards">FOAF and Standards</h2> <p>It is important to understand that the FOAF <em>vocabulary</em> as specified in this document is not a standard in the sense of <a href= "http://www.iso.ch/iso/en/ISOOnline.openerpage">ISO Standardisation</a>, or that associated with <a href= "http://www.w3.org/">W3C</a> <a href= "http://www.w3.org/Consortium/Process/">Process</a>.</p> <p>FOAF depends heavily on W3C's standards work, specifically on XML, XML Namespaces, RDF, and OWL. All FOAF <em>documents</em> must be well-formed RDF documents. The FOAF vocabulary, by contrast, is managed more in the style of an <a href= "http://www.opensource.org/">Open Source</a> or <a href= "http://www.gnu.org/philosophy/free-sw.html">Free Software</a> project than as an industry standardarisation effort (eg. see <a href="http://www.jabber.org/jeps/jep-0001.html">Jabber JEPs</a>).</p> <p>This specification contributes a vocabulary, "FOAF", to the Semantic Web, specifying it using W3C's <a href= "http://www.w3.org/RDF/">Resource Description Framework</a> (RDF). As such, FOAF adopts by reference both syntaxes (using XML, N3, or RDFa) a data model (RDF graphs) and a mathematically grounded definition for the rules that underpin the FOAF design.</p> <h2 id="sec-nsdoc">The FOAF Vocabulary Description</h2> <p>This specification serves as the FOAF "namespace document". As such it describes the FOAF vocabulary the terms (<a href= "http://www.w3.org/RDF/">RDF</a> classes and properties) that constitute it, so that <a href= "http://www.w3.org/2001/sw/">Semantic Web</a> applications can use those terms in a variety of RDF-compatible document formats and applications.</p> <p>This document presents FOAF as a <a href= "http://www.w3.org/2001/sw/">Semantic Web</a> vocabulary or <em>Ontology</em>. The FOAF vocabulary is pretty simple, pragmatic and designed to allow simultaneous deployment and extension. FOAF is intended for widescale use, but its authors make no commitments regarding its suitability for any particular purpose.</p> <h3 id="sec-evolution">Evolution and Extension of FOAF</h3> <p>The FOAF vocabulary is identified by the namespace URI '<code>http://xmlns.com/foaf/0.1/</code>'. Revisions and extensions of FOAF are conducted through edits to this document, which by convention is accessible in the Web via the namespace URI. For practical and deployment reasons, note that <b>we do not update the namespace URI as the vocabulary matures</b>. </p> <p>Much of FOAF now is considered stable. Each release of this specification document has an incrementally increased version number, even while the technical namespace ID remains fixed and includes the original value of "0.1". It long ago became impractical to update the namespace URI without causing huge disruption to both producers and consumers of FOAF data. We are left with the digits "0.1" in our URI. This stands as a warning to all those who might embed metadata in their vocabulary identifiers. </p> <p> The evolution of FOAF is best considered in terms of the stability of individual vocabulary terms, rather than the specification as a whole. As terms stabilise in usage and documentation, they progress through the categories '<strong>unstable</strong>', '<strong>testing</strong>' and '<strong>stable</strong>'. Older terms are marked '<strong>archaic</strong>' which allows the possibility of older forms to become modern again.</p><!--STATUSINFO--> <p>The properties and types defined here provide some basic useful concepts for use in FOAF descriptions. Other vocabulary (eg. the <a href="http://dublincore.org/">Dublin Core</a> metadata elements for simple bibliographic description), RSS 1.0 etc can also be mixed in with FOAF terms, as can local extensions. FOAF is designed to be extended. </p> <h2 id="sec-autodesc">FOAF Auto-Discovery: Publishing and Linking FOAF files</h2> <p>If you publish a FOAF self-description (eg. using <a href= "http://www.ldodds.com/foaf/foaf-a-matic.html">foaf-a-matic</a>) you can make it easier for tools to find your FOAF by putting markup in the <code>head</code> of your HTML homepage. It doesn't really matter what filename you choose for your FOAF document, although <code>foaf.rdf</code> is a common choice. The linking markup is as follows:</p> <div class="example"> <pre> &lt;link rel="meta" type="application/rdf+xml" title="FOAF" href="<em>http://example.com/~you/foaf.rdf</em>"/&gt; </pre> </div> <p>...although of course change the <em>URL</em> to point to your own FOAF document. See also: more on <a href= "http://web.archive.org/web/20040416181630/rdfweb.org/mt/foaflog/archives/000041.html">FOAF autodiscovery</a> and services that make use of it.</p> <h2 id="sec-crossref">FOAF cross-reference: Listing FOAF Classes and Properties</h2> <p>FOAF introduces the following classes and properties. A machine-friendly version is also available in <a href="index.rdf">RDF/XML</a>.</p> <!-- the following is the script-generated list of classes and properties --> <!-- this is the a-z listing --> <div class="azlist"> <p>Classes: | <a href="#term_Agent">Agent</a> | <a href="#term_Document">Document</a> | <a href="#term_Group">Group</a> | <a href="#term_Image">Image</a> | <a href="#term_LabelProperty">LabelProperty</a> | <a href="#term_OnlineAccount">OnlineAccount</a> | <a href="#term_OnlineChatAccount">OnlineChatAccount</a> | <a href="#term_OnlineEcommerceAccount">OnlineEcommerceAccount</a> | <a href="#term_OnlineGamingAccount">OnlineGamingAccount</a> | <a href="#term_Organization">Organization</a> | <a href="#term_Person">Person</a> | <a href="#term_PersonalProfileDocument">PersonalProfileDocument</a> | <a href="#term_Project">Project</a> | </p> <p>Properties: | <a href="#term_account">account</a> | <a href="#term_accountName">accountName</a> | <a href="#term_accountServiceHomepage">accountServiceHomepage</a> | <a href="#term_age">age</a> | <a href="#term_aimChatID">aimChatID</a> | <a href="#term_based_near">based_near</a> | <a href="#term_birthday">birthday</a> | <a href="#term_currentProject">currentProject</a> | <a href="#term_depiction">depiction</a> | <a href="#term_depicts">depicts</a> | <a href="#term_dnaChecksum">dnaChecksum</a> | <a href="#term_familyName">familyName</a> | <a href="#term_family_name">family_name</a> | <a href="#term_firstName">firstName</a> | <a href="#term_focus">focus</a> | <a href="#term_fundedBy">fundedBy</a> | <a href="#term_geekcode">geekcode</a> | <a href="#term_gender">gender</a> | <a href="#term_givenName">givenName</a> | <a href="#term_givenname">givenname</a> | <a href="#term_holdsAccount">holdsAccount</a> | <a href="#term_homepage">homepage</a> | <a href="#term_icqChatID">icqChatID</a> | <a href="#term_img">img</a> | <a href="#term_interest">interest</a> | <a href="#term_isPrimaryTopicOf">isPrimaryTopicOf</a> | <a href="#term_jabberID">jabberID</a> | <a href="#term_knows">knows</a> | <a href="#term_lastName">lastName</a> | <a href="#term_logo">logo</a> | <a href="#term_made">made</a> | <a href="#term_maker">maker</a> | <a href="#term_mbox">mbox</a> | <a href="#term_mbox_sha1sum">mbox_sha1sum</a> | <a href="#term_member">member</a> | <a href="#term_membershipClass">membershipClass</a> | <a href="#term_msnChatID">msnChatID</a> | <a href="#term_myersBriggs">myersBriggs</a> | <a href="#term_name">name</a> | <a href="#term_nick">nick</a> | <a href="#term_openid">openid</a> | <a href="#term_page">page</a> | <a href="#term_pastProject">pastProject</a> | <a href="#term_phone">phone</a> | <a href="#term_plan">plan</a> | <a href="#term_primaryTopic">primaryTopic</a> | <a href="#term_publications">publications</a> | <a href="#term_schoolHomepage">schoolHomepage</a> | <a href="#term_sha1">sha1</a> | <a href="#term_skypeID">skypeID</a> | <a href="#term_status">status</a> | <a href="#term_surname">surname</a> | <a href="#term_theme">theme</a> | <a href="#term_thumbnail">thumbnail</a> | <a href="#term_tipjar">tipjar</a> | <a href="#term_title">title</a> | <a href="#term_topic">topic</a> | <a href="#term_topic_interest">topic_interest</a> | <a href="#term_weblog">weblog</a> | <a href="#term_workInfoHomepage">workInfoHomepage</a> | <a href="#term_workplaceHomepage">workplaceHomepage</a> | <a href="#term_yahooChatID">yahooChatID</a> | </p> </div> <!-- and this is the bulk of the vocab descriptions --> <div class="termlist"><h3>Classes and Properties (full detail)</h3> <div class='termdetails'><br /> <h2>Classes</h2> <div class="specterm classterm " id="term_Agent" about="http://xmlns.com/foaf/0.1/Agent" typeof="rdfs:Class"> <h3>Class: foaf:Agent</h3> <em>Agent</em> - An agent (eg. person, group, software or physical artifact). <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >stable</span></td></tr> <tr><th>Properties include:</th> <td> <a href="#term_gender">gender</a> <a href="#term_yahooChatID">yahooChatID</a> <a href="#term_account">account</a> <a href="#term_birthday">birthday</a> <a href="#term_icqChatID">icqChatID</a> <a href="#term_aimChatID">aimChatID</a> <a href="#term_jabberID">jabberID</a> <a href="#term_made">made</a> <a href="#term_mbox">mbox</a> <a href="#term_interest">interest</a> <a href="#term_tipjar">tipjar</a> <a href="#term_skypeID">skypeID</a> <a href="#term_topic_interest">topic_interest</a> <a href="#term_age">age</a> <a href="#term_mbox_sha1sum">mbox_sha1sum</a> <a href="#term_status">status</a> <a href="#term_msnChatID">msnChatID</a> <a href="#term_openid">openid</a> <a href="#term_holdsAccount">holdsAccount</a> <a href="#term_weblog">weblog</a> </td></tr> <tr><th>Used with:</th> <td> <a href="#term_maker">maker</a> <a href="#term_member">member</a> </td></tr> <tr><th>Has Subclass</th> <td> <a href="#term_Group">Group</a> <a href="#term_Person">Person</a> <a href="#term_Organization">Organization</a> </td></tr> </table> <p> The <code><a href='#term_Agent'>Agent</a></code> class is the class of agents; things that do stuff. A well known sub-class is <code><a href='#term_Person'>Person</a></code>, representing people. Other kinds of agents include <code><a href='#term_Organization'>Organization</a></code> and <code><a href='#term_Group'>Group</a></code>. </p> <p> The <code><a href='#term_Agent'>Agent</a></code> class is useful in a few places in FOAF where <code><a href='#term_Person'>Person</a></code> would have been overly specific. For example, the IM chat ID properties such as <code>jabberID</code> are typically associated with people, but sometimes belong to software bots. </p> <!-- todo: write rdfs:domain statements for those properties --> <p style="float: right; font-size: small;">[<a href="#term_Agent">#</a>] <!-- Agent Agent --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm classterm " id="term_Document" about="http://xmlns.com/foaf/0.1/Document" typeof="rdfs:Class"> <h3>Class: foaf:Document</h3> <em>Document</em> - A document. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >stable</span></td></tr> <tr><th>Properties include:</th> <td> <a href="#term_topic">topic</a> <a href="#term_primaryTopic">primaryTopic</a> <a href="#term_sha1">sha1</a> </td></tr> <tr><th>Used with:</th> <td> <a href="#term_workInfoHomepage">workInfoHomepage</a> <a href="#term_workplaceHomepage">workplaceHomepage</a> <a href="#term_page">page</a> <a href="#term_accountServiceHomepage">accountServiceHomepage</a> <a href="#term_openid">openid</a> <a href="#term_tipjar">tipjar</a> <a href="#term_schoolHomepage">schoolHomepage</a> <a href="#term_publications">publications</a> <a href="#term_isPrimaryTopicOf">isPrimaryTopicOf</a> <a href="#term_interest">interest</a> <a href="#term_homepage">homepage</a> <a href="#term_weblog">weblog</a> </td></tr> <tr><th>Has Subclass</th> <td> <a href="#term_Image">Image</a> <a href="#term_PersonalProfileDocument">PersonalProfileDocument</a> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th>Disjoint With:</th> <td> <span rel="owl:disjointWith" href="http://xmlns.com/foaf/0.1/Project"><a href="#term_Project">Project</a></span> <span rel="owl:disjointWith" href="http://xmlns.com/foaf/0.1/Organization"><a href="#term_Organization">Organization</a></span> </td></tr> </table> <p> The <code><a href='#term_Document'>Document</a></code> class represents those things which are, broadly conceived, 'documents'. </p> <p> The <code><a href='#term_Image'>Image</a></code> class is a sub-class of <code><a href='#term_Document'>Document</a></code>, since all images are documents. </p> <p class="editorial"> We do not (currently) distinguish precisely between physical and electronic documents, or between copies of a work and the abstraction those copies embody. The relationship between documents and their byte-stream representation needs clarification (see <code><a href='#term_sha1'>sha1</a></code> for related issues). </p> <p style="float: right; font-size: small;">[<a href="#term_Document">#</a>] <!-- Document Document --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm classterm " id="term_Group" about="http://xmlns.com/foaf/0.1/Group" typeof="rdfs:Class"> <h3>Class: foaf:Group</h3> <em>Group</em> - A class of Agents. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >stable</span></td></tr> <tr><th>Properties include:</th> <td> <a href="#term_member">member</a> </td></tr> <tr><th>Subclass Of</th> <td> <span rel="rdfs:subClassOf" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> </table> <p> The <code><a href='#term_Group'>Group</a></code> class represents a collection of individual agents (and may itself play the role of a <code><a href='#term_Agent'>Agent</a></code>, ie. something that can perform actions). </p> <p> This concept is intentionally quite broad, covering informal and ad-hoc groups, long-lived communities, organizational groups within a workplace, etc. Some such groups may have associated characteristics which could be captured in RDF (perhaps a <code><a href='#term_homepage'>homepage</a></code>, <code><a href='#term_name'>name</a></code>, mailing list etc.). </p> <p> While a <code><a href='#term_Group'>Group</a></code> has the characteristics of a <code><a href='#term_Agent'>Agent</a></code>, it is also associated with a number of other <code><a href='#term_Agent'>Agent</a></code>s (typically people) who constitute the <code><a href='#term_Group'>Group</a></code>. FOAF provides a mechanism, the <code><a href='#term_membershipClass'>membershipClass</a></code> property, which relates a <code><a href='#term_Group'>Group</a></code> to a sub-class of the class <code><a href='#term_Agent'>Agent</a></code> who are members of the group. This is a little complicated, but allows us to make group membership rules explicit. </p> <p>The markup (shown below) for defining a group is both complex and powerful. It allows group membership rules to match against any RDF-describable characteristics of the potential group members. As FOAF and similar vocabularies become more expressive in their ability to describe individuals, the <code><a href='#term_Group'>Group</a></code> mechanism for categorising them into groups also becomes more powerful. </p> <p> While the formal description of membership criteria for a <code><a href='#term_Group'>Group</a></code> may be complex, the basic mechanism for saying that someone is in a <code><a href='#term_Group'>Group</a></code> is very simple. We simply use a <code><a href='#term_member'>member</a></code> property of the <code><a href='#term_Group'>Group</a></code> to indicate the agents that are members of the group. For example: </p> <div class="example"> <pre> &lt;foaf:Group&gt; &lt;foaf:name&gt;ILRT staff&lt;/foaf:name&gt; &lt;foaf:member&gt; &lt;foaf:Person&gt; &lt;foaf:name&gt;Martin Poulter&lt;/foaf:name&gt; &lt;foaf:homepage rdf:resource="http://www.ilrt.bris.ac.uk/aboutus/staff/staffprofile/?search=plmlp"/&gt; &lt;foaf:workplaceHomepage rdf:resource="http://www.ilrt.bris.ac.uk/"/&gt; &lt;/foaf:Person&gt; &lt;/foaf:member&gt; &lt;/foaf:Group&gt; </pre> </div> <p> Behind the scenes, further RDF statements can be used to express the rules for being a member of this group. End-users of FOAF need not pay attention to these details. </p> <p> Here is an example. We define a <code><a href='#term_Group'>Group</a></code> representing those people who are ILRT staff members (ILRT is a department at the University of Bristol). The <code><a href='#term_membershipClass'>membershipClass</a></code> property connects the group (conceived of as a social entity and agent in its own right) with the class definition for those people who constitute it. In this case, the rule is that all group members are in the ILRTStaffPerson class, which is in turn populated by all those things that are a <code><a href='#term_Person'>Person</a></code> and which have a <code><a href='#term_workplaceHomepage'>workplaceHomepage</a></code> of http://www.ilrt.bris.ac.uk/. This is typical: FOAF groups are created by specifying a sub-class of <code><a href='#term_Agent'>Agent</a></code> (in fact usually this will be a sub-class of <code><a href='#term_Person'>Person</a></code>), and giving criteria for which things fall in or out of the sub-class. For this, we use the <code>owl:onProperty</code> and <code>owl:hasValue</code> properties, indicating the property/value pairs which must be true of matching agents. </p> <div class="example"> <pre> &lt;!-- here we see a FOAF group described. each foaf group may be associated with an OWL definition specifying the class of agents that constitute the group's membership --&gt; &lt;foaf:Group&gt; &lt;foaf:name&gt;ILRT staff&lt;/foaf:name&gt; &lt;foaf:membershipClass&gt; &lt;owl:Class rdf:about="http://ilrt.example.com/groups#ILRTStaffPerson"&gt; &lt;rdfs:subClassOf rdf:resource="http://xmlns.com/foaf/0.1/Person"/&gt; &lt;rdfs:subClassOf&gt; &lt;owl:Restriction&gt; &lt;owl:onProperty rdf:resource="http://xmlns.com/foaf/0.1/workplaceHomepage"/&gt; &lt;owl:hasValue rdf:resource="http://www.ilrt.bris.ac.uk/"/&gt; &lt;/owl:Restriction&gt; &lt;/rdfs:subClassOf&gt; &lt;/owl:Class&gt; &lt;/foaf:membershipClass&gt; &lt;/foaf:Group&gt; </pre> </div> <p> Note that while these example OWL rules for being in the eg:ILRTStaffPerson class are based on a <code><a href='#term_Person'>Person</a></code> having a particular <code><a href='#term_workplaceHomepage'>workplaceHomepage</a></code>, this places no obligations on the authors of actual FOAF documents to include this information. If the information <em>is</em> included, then generic OWL tools may infer that some person is an eg:ILRTStaffPerson. To go the extra step and infer that some eg:ILRTStaffPerson is a <code><a href='#term_member'>member</a></code> of the group whose <code><a href='#term_name'>name</a></code> is "ILRT staff", tools will need some knowledge of the way FOAF deals with groups. In other words, generic OWL technology gets us most of the way, but the full <code><a href='#term_Group'>Group</a></code> machinery requires extra work for implimentors. </p> <p> The current design names the relationship as pointing <em>from</em> the group, to the member. This is convenient when writing XML/RDF that encloses the members within markup that describes the group. Alternate representations of the same content are allowed in RDF, so you can write claims about the Person and the Group without having to nest either description inside the other. For (brief) example: </p> <div class="example"> <pre> &lt;foaf:Group&gt; &lt;foaf:member rdf:nodeID="martin"/&gt; &lt;!-- more about the group here --&gt; &lt;/foaf:Group&gt; &lt;foaf:Person rdf:nodeID="martin"&gt; &lt;!-- more about martin here --&gt; &lt;/foaf:Person&gt; </pre> </div> <p> There is a FOAF <a href="http://wiki.foaf-project.org/w/IssueTracker">issue tracker</a> associated with this FOAF term. A design goal is to make the most of W3C's <a href="http://www.w3.org/2001/sw/WebOnt">OWL</a> language for representing group-membership criteria, while also making it easy to leverage existing groups and datasets available online (eg. buddylists, mailing list membership lists etc). Feedback on the current design is solicited! Should we consider using SPARQL queries instead, for example? </p> <p style="float: right; font-size: small;">[<a href="#term_Group">#</a>] <!-- Group Group --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm classterm " id="term_Image" about="http://xmlns.com/foaf/0.1/Image" typeof="rdfs:Class"> <h3>Class: foaf:Image</h3> <em>Image</em> - An image. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >stable</span></td></tr> <tr><th>Properties include:</th> <td> <a href="#term_depicts">depicts</a> <a href="#term_thumbnail">thumbnail</a> </td></tr> <tr><th>Used with:</th> <td> <a href="#term_img">img</a> <a href="#term_thumbnail">thumbnail</a> <a href="#term_depiction">depiction</a> </td></tr> <tr><th>Subclass Of</th> <td> <span rel="rdfs:subClassOf" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The class <code><a href='#term_Image'>Image</a></code> is a sub-class of <code><a href='#term_Document'>Document</a></code> corresponding to those documents which are images. </p> <p> Digital images (such as JPEG, PNG, GIF bitmaps, SVG diagrams etc.) are examples of <code><a href='#term_Image'>Image</a></code>. </p> <!-- much more we could/should say here --> <p style="float: right; font-size: small;">[<a href="#term_Image">#</a>] <!-- Image Image --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm classterm " id="term_Organization" about="http://xmlns.com/foaf/0.1/Organization" typeof="rdfs:Class"> <h3>Class: foaf:Organization</h3> <em>Organization</em> - An organization. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >stable</span></td></tr> <tr><th>Subclass Of</th> <td> <span rel="rdfs:subClassOf" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th>Disjoint With:</th> <td> <span rel="owl:disjointWith" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> <span rel="owl:disjointWith" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> </table> <p> The <code><a href='#term_Organization'>Organization</a></code> class represents a kind of <code><a href='#term_Agent'>Agent</a></code> corresponding to social instititutions such as companies, societies etc. </p> <p class="editorial"> This is a more 'solid' class than <code><a href='#term_Group'>Group</a></code>, which allows for more ad-hoc collections of individuals. These terms, like the corresponding natural language concepts, have some overlap, but different emphasis. </p> <p style="float: right; font-size: small;">[<a href="#term_Organization">#</a>] <!-- Organization Organization --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm classterm " id="term_Person" about="http://xmlns.com/foaf/0.1/Person" typeof="rdfs:Class"> <h3>Class: foaf:Person</h3> <em>Person</em> - A person. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >stable</span></td></tr> <tr><th>Properties include:</th> <td> <a href="#term_plan">plan</a> <a href="#term_surname">surname</a> <a href="#term_geekcode">geekcode</a> <a href="#term_pastProject">pastProject</a> <a href="#term_lastName">lastName</a> <a href="#term_family_name">family_name</a> <a href="#term_publications">publications</a> <a href="#term_currentProject">currentProject</a> <a href="#term_familyName">familyName</a> <a href="#term_firstName">firstName</a> <a href="#term_workInfoHomepage">workInfoHomepage</a> <a href="#term_myersBriggs">myersBriggs</a> <a href="#term_schoolHomepage">schoolHomepage</a> <a href="#term_img">img</a> <a href="#term_workplaceHomepage">workplaceHomepage</a> <a href="#term_knows">knows</a> </td></tr> <tr><th>Used with:</th> <td> <a href="#term_knows">knows</a> </td></tr> <tr><th>Subclass Of</th> <td> <span rel="rdfs:subClassOf" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> <span rel="rdfs:subClassOf" href="http://www.w3.org/2003/01/geo/wgs84_pos#SpatialThing"><a href="#term_SpatialThing">Spatial Thing</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th>Disjoint With:</th> <td> <span rel="owl:disjointWith" href="http://xmlns.com/foaf/0.1/Project"><a href="#term_Project">Project</a></span> <span rel="owl:disjointWith" href="http://xmlns.com/foaf/0.1/Organization"><a href="#term_Organization">Organization</a></span> </td></tr> </table> <p> The <code><a href='#term_Person'>Person</a></code> class represents people. Something is a <code><a href='#term_Person'>Person</a></code> if it is a person. We don't nitpic about whether they're alive, dead, real, or imaginary. The <code><a href='#term_Person'>Person</a></code> class is a sub-class of the <code><a href='#term_Agent'>Agent</a></code> class, since all people are considered 'agents' in FOAF. </p> <p style="float: right; font-size: small;">[<a href="#term_Person">#</a>] <!-- Person Person --> [<a href="#glance">back to top</a>]</p> <br/> </div> <div class="specterm classterm " id="term_OnlineAccount" about="http://xmlns.com/foaf/0.1/OnlineAccount" typeof="rdfs:Class"> <h3>Class: foaf:OnlineAccount</h3> <em>Online Account</em> - An online account. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Properties include:</th> <td> <a href="#term_accountName">accountName</a> <a href="#term_accountServiceHomepage">accountServiceHomepage</a> </td></tr> <tr><th>Used with:</th> <td> <a href="#term_account">account</a> <a href="#term_holdsAccount">holdsAccount</a> </td></tr> <tr><th>Subclass Of</th> <td> <span rel="rdfs:subClassOf" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td></tr><tr><th>Has Subclass</th> <td> <a href="#term_OnlineEcommerceAccount">Online E-commerce Account</a> <a href="#term_OnlineGamingAccount">Online Gaming Account</a> <a href="#term_OnlineChatAccount">Online Chat Account</a> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> class represents the provision of some form of online service, by some party (indicated indirectly via a <code><a href='#term_accountServiceHomepage'>accountServiceHomepage</a></code>) to some <code><a href='#term_Agent'>Agent</a></code>. The <code><a href='#term_account'>account</a></code> property of the agent is used to indicate accounts that are associated with the agent. </p> <p> See <code><a href='#term_OnlineChatAccount'>OnlineChatAccount</a></code> for an example. Other sub-classes include <code><a href='#term_OnlineEcommerceAccount'>OnlineEcommerceAccount</a></code> and <code><a href='#term_OnlineGamingAccount'>OnlineGamingAccount</a></code>. </p> <p> One deployment style for this construct is to use URIs for well-known documents (or other entities) that strongly embody the account-holding relationship; for example, user profile pages on social network sites. This has the advantage of providing URIs that are likely to be easy to link with other information, but means that the instances of this class should not be considered 'accounts' in the abstract or business sense of a 'contract'. </p> <p style="float: right; font-size: small;">[<a href="#term_OnlineAccount">#</a>] <!-- OnlineAccount OnlineAccount --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm classterm " id="term_PersonalProfileDocument" about="http://xmlns.com/foaf/0.1/PersonalProfileDocument" typeof="rdfs:Class"> <h3>Class: foaf:PersonalProfileDocument</h3> <em>PersonalProfileDocument</em> - A personal profile RDF document. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Subclass Of</th> <td> <span rel="rdfs:subClassOf" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td></tr> </table> <p> The <code><a href='#term_PersonalProfileDocument'>PersonalProfileDocument</a></code> class represents those things that are a <code><a href='#term_Document'>Document</a></code>, and that use RDF to describe properties of the person who is the <code><a href='#term_maker'>maker</a></code> of the document. There is just one <code><a href='#term_Person'>Person</a></code> described in the document, ie. the person who <code><a href='#term_made'>made</a></code> it and who will be its <code><a href='#term_primaryTopic'>primaryTopic</a></code>. </p> <p> The <code><a href='#term_PersonalProfileDocument'>PersonalProfileDocument</a></code> class, and FOAF's associated conventions for describing it, captures an important deployment pattern for the FOAF vocabulary. FOAF is very often used in public RDF documents made available through the Web. There is a colloquial notion that these "FOAF files" are often <em>somebody's</em> FOAF file. Through <code><a href='#term_PersonalProfileDocument'>PersonalProfileDocument</a></code> we provide a machine-readable expression of this concept, providing a basis for FOAF documents to make claims about their maker and topic. </p> <p> When describing a <code><a href='#term_PersonalProfileDocument'>PersonalProfileDocument</a></code> it is typical (and useful) to describe its associated <code><a href='#term_Person'>Person</a></code> using the <code><a href='#term_maker'>maker</a></code> property. Anything that is a <code><a href='#term_Person'>Person</a></code> and that is the <code><a href='#term_maker'>maker</a></code> of some <code><a href='#term_PersonalProfileDocument'>PersonalProfileDocument</a></code> will be the <code><a href='#term_primaryTopic'>primaryTopic</a></code> of that <code><a href='#term_Document'>Document</a></code>. Although this can be inferred, it is often helpful to include this information explicitly within the <code><a href='#term_PersonalProfileDocument'>PersonalProfileDocument</a></code>. </p> <p> For example, here is a fragment of a personal profile document which describes its author explicitly: </p> <div class="example"> <pre> &lt;foaf:Person rdf:nodeID="p1"&gt; &lt;foaf:name&gt;Dan Brickley&lt;/foaf:name&gt; &lt;foaf:homepage rdf:resource="http://danbri.org/"/&gt; &lt;!-- etc... --&gt; &lt;/foaf:Person&gt; &lt;foaf:PersonalProfileDocument rdf:about=""&gt; &lt;foaf:maker rdf:nodeID="p1"/&gt; &lt;foaf:primaryTopic rdf:nodeID="p1"/&gt; &lt;/foaf:PersonalProfileDocument&gt; </pre> </div> <p> Note that a <code><a href='#term_PersonalProfileDocument'>PersonalProfileDocument</a></code> will have some representation as RDF. Typically this will be in W3C's RDF/XML syntax, however we leave open the possibility for the use of other notations, or representational conventions including automated transformations from HTML (<a href="http://www.w3.org/2004/01/rdxh/spec">GRDDL</a> spec for one such technique). </p> <p style="float: right; font-size: small;">[<a href="#term_PersonalProfileDocument">#</a>] <!-- PersonalProfileDocument PersonalProfileDocument --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm classterm " id="term_Project" about="http://xmlns.com/foaf/0.1/Project" typeof="rdfs:Class"> <h3>Class: foaf:Project</h3> <em>Project</em> - A project (a collective endeavour of some kind). <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th>Disjoint With:</th> <td> <span rel="owl:disjointWith" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> <span rel="owl:disjointWith" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> </table> <p> The <code><a href='#term_Project'>Project</a></code> class represents the class of things that are 'projects'. These may be formal or informal, collective or individual. It is often useful to indicate the <code><a href='#term_homepage'>homepage</a></code> of a <code><a href='#term_Project'>Project</a></code>. </p> <p class="editorial"> Further work is needed to specify the connections between this class and the FOAF properties <code><a href='#term_currentProject'>currentProject</a></code> and <code><a href='#term_pastProject'>pastProject</a></code>. </p> <p style="float: right; font-size: small;">[<a href="#term_Project">#</a>] <!-- Project Project --> [<a href="#glance">back to top</a>]</p> <br/> </div> <div class="specterm classterm " id="term_LabelProperty" about="http://xmlns.com/foaf/0.1/LabelProperty" typeof="rdfs:Class"> <h3>Class: foaf:LabelProperty</h3> <em>Label Property</em> - A foaf:LabelProperty is any RDF property with texual values that serve as labels. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >unstable</span></td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> A <code><a href='#term_LabelProperty'>LabelProperty</a></code> is any RDF property with texual values that serve as labels. </p> <p> Any property that is a <code><a href='#term_LabelProperty'>LabelProperty</a></code> is effectively a sub-property of rdfs:label. This utility class provides an alternate means of expressing this idea, in a way that may help with OWL 2.0 DL compatibility. </p> <p style="float: right; font-size: small;">[<a href="#term_LabelProperty">#</a>] <!-- LabelProperty LabelProperty --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm classterm " id="term_OnlineChatAccount" about="http://xmlns.com/foaf/0.1/OnlineChatAccount" typeof="rdfs:Class"> <h3>Class: foaf:OnlineChatAccount</h3> <em>Online Chat Account</em> - An online chat account. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >unstable</span></td></tr> <tr><th>Subclass Of</th> <td> <span rel="rdfs:subClassOf" href="http://xmlns.com/foaf/0.1/OnlineAccount"><a href="#term_OnlineAccount">Online Account</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> A <code><a href='#term_OnlineChatAccount'>OnlineChatAccount</a></code> is a <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> devoted to chat / instant messaging. The account may offer other services too; FOAF's sub-classes of <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> are not mutually disjoint. </p> <p> This is a generalization of the FOAF Chat ID properties, <code><a href='#term_jabberID'>jabberID</a></code>, <code><a href='#term_aimChatID'>aimChatID</a></code>, <code><a href='#term_skypeID'>skypeID</a></code>, <code><a href='#term_msnChatID'>msnChatID</a></code>, <code><a href='#term_icqChatID'>icqChatID</a></code> and <code><a href='#term_yahooChatID'>yahooChatID</a></code>. </p> <p> Unlike those simple properties, <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> and associated FOAF terms allows us to describe a great variety of online accounts, without having to anticipate them in the FOAF vocabulary. </p> <p> For example, here is a description of an IRC chat account, specific to the Freenode IRC network: </p> <div class="example"> <pre> &lt;foaf:Person&gt; &lt;foaf:name&gt;Dan Brickley&lt;/foaf:name&gt; &lt;foaf:account&gt; &lt;foaf:OnlineAccount&gt; &lt;rdf:type rdf:resource="http://xmlns.com/foaf/0.1/OnlineChatAccount"/&gt; &lt;foaf:accountServiceHomepage rdf:resource="http://www.freenode.net/"/&gt; &lt;foaf:accountName&gt;danbri&lt;/foaf:accountName&gt; &lt;/foaf:OnlineAccount&gt; &lt;/foaf:account&gt; &lt;/foaf:Person&gt; </pre> </div> <p> Note that it may be impolite to carelessly reveal someone else's chat identifier (which might also serve as an indicate of email address) As with email, there are privacy and anti-SPAM considerations. FOAF does not currently provide a way to represent an obfuscated chat ID (ie. there is no parallel to the <code><a href='#term_mbox'>mbox</a></code> / <code><a href='#term_mbox_sha1sum'>mbox_sha1sum</a></code> mapping). </p> <p> In addition to the generic <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> and <code><a href='#term_OnlineChatAccount'>OnlineChatAccount</a></code> mechanisms, FOAF also provides several convenience chat ID properties (<code><a href='#term_jabberID'>jabberID</a></code>, <code><a href='#term_aimChatID'>aimChatID</a></code>, <code><a href='#term_icqChatID'>icqChatID</a></code>, <code><a href='#term_msnChatID'>msnChatID</a></code>,<code><a href='#term_yahooChatID'>yahooChatID</a></code>, <code><a href='#term_skypeID'>skypeID</a></code>). These serve as as a shorthand for some common cases; their use may not always be appropriate. </p> <p class="editorial"> We should specify some mappings between the abbreviated and full representations of <a href="http://www.jabber.org/">Jabber</a>, <a href="http://www.aim.com/">AIM</a>, <a href="http://chat.msn.com/">MSN</a>, <a href="http://web.icq.com/icqchat/">ICQ</a>, <a href="http://chat.yahoo.com/">Yahoo!</a> and <a href="http://chat.msn.com/">MSN</a> chat accounts. This has been done for <code><a href='#term_skypeID'>skypeID</a></code>. This requires us to identify an appropriate <code><a href='#term_accountServiceHomepage'>accountServiceHomepage</a></code> for each. If we wanted to make the <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> mechanism even more generic, we could invent a relationship that holds between a <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> instance and a convenience property. To continue the example above, we could describe how <a href="http://www.freenode.net/">Freenode</a> could define a property 'fn:freenodeChatID' corresponding to Freenode online accounts. </p> <p style="float: right; font-size: small;">[<a href="#term_OnlineChatAccount">#</a>] <!-- OnlineChatAccount OnlineChatAccount --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm classterm " id="term_OnlineEcommerceAccount" about="http://xmlns.com/foaf/0.1/OnlineEcommerceAccount" typeof="rdfs:Class"> <h3>Class: foaf:OnlineEcommerceAccount</h3> <em>Online E-commerce Account</em> - An online e-commerce account. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >unstable</span></td></tr> <tr><th>Subclass Of</th> <td> <span rel="rdfs:subClassOf" href="http://xmlns.com/foaf/0.1/OnlineAccount"><a href="#term_OnlineAccount">Online Account</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> A <code><a href='#term_OnlineEcommerceAccount'>OnlineEcommerceAccount</a></code> is a <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> devoted to buying and/or selling of goods, services etc. Examples include <a href="http://www.amazon.com/">Amazon</a>, <a href="http://www.ebay.com/">eBay</a>, <a href="http://www.paypal.com/">PayPal</a>, <a href="http://www.thinkgeek.com/">thinkgeek</a>, etc. </p> <p style="float: right; font-size: small;">[<a href="#term_OnlineEcommerceAccount">#</a>] <!-- OnlineEcommerceAccount OnlineEcommerceAccount --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm classterm " id="term_OnlineGamingAccount" about="http://xmlns.com/foaf/0.1/OnlineGamingAccount" typeof="rdfs:Class"> <h3>Class: foaf:OnlineGamingAccount</h3> <em>Online Gaming Account</em> - An online gaming account. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >unstable</span></td></tr> <tr><th>Subclass Of</th> <td> <span rel="rdfs:subClassOf" href="http://xmlns.com/foaf/0.1/OnlineAccount"><a href="#term_OnlineAccount">Online Account</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> A <code><a href='#term_OnlineGamingAccount'>OnlineGamingAccount</a></code> is a <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> devoted to online gaming. </p> <p> Examples might include <a href="http://everquest.station.sony.com/">EverQuest</a>, <a href="http://www.xbox.com/live/">Xbox live</a>, <a href="http://nwn.bioware.com/">Neverwinter Nights</a>, etc., as well as older text-based systems (MOOs, MUDs and suchlike). </p> <p style="float: right; font-size: small;">[<a href="#term_OnlineGamingAccount">#</a>] <!-- OnlineGamingAccount OnlineGamingAccount --> [<a href="#glance">back to top</a>]</p> <br/> </div> <h2>Properties</h2> <div class="specterm propertyterm " id="term_homepage" about="http://xmlns.com/foaf/0.1/homepage" typeof="rdf:Property"> <h3>Property: foaf:homepage</h3> <em>homepage</em> - A homepage for some thing. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >stable</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th colspan="2">Inverse Functional Property</th> <td> <span rel="rdf:type" href="http://www.w3.org/2002/07/owl#InverseFunctionalProperty"></span> </td></tr> </table> <p> The <code><a href='#term_homepage'>homepage</a></code> property relates something to a homepage about it. </p> <p> Many kinds of things have homepages. FOAF allows a thing to have multiple homepages, but constrains <code><a href='#term_homepage'>homepage</a></code> so that there can be only one thing that has any particular homepage. </p> <p> A 'homepage' in this sense is a public Web document, typically but not necessarily available in HTML format. The page has as a <code><a href='#term_topic'>topic</a></code> the thing whose homepage it is. The homepage is usually controlled, edited or published by the thing whose homepage it is; as such one might look to a homepage for information on its owner from its owner. This works for people, companies, organisations etc. </p> <p> The <code><a href='#term_homepage'>homepage</a></code> property is a sub-property of the more general <code><a href='#term_page'>page</a></code> property for relating a thing to a page about that thing. See also <code><a href='#term_topic'>topic</a></code>, the inverse of the <code><a href='#term_page'>page</a></code> property. </p> <p style="float: right; font-size: small;">[<a href="#term_homepage">#</a>] <!-- homepage homepage --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_isPrimaryTopicOf" about="http://xmlns.com/foaf/0.1/isPrimaryTopicOf" typeof="rdf:Property"> <h3>Property: foaf:isPrimaryTopicOf</h3> <em>is primary topic of</em> - A document that this thing is the primary topic of. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >stable</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th colspan="2">Inverse Functional Property</th> <td> <span rel="rdf:type" href="http://www.w3.org/2002/07/owl#InverseFunctionalProperty"></span> </td></tr> </table> <p> The <code><a href='#term_isPrimaryTopicOf'>isPrimaryTopicOf</a></code> property relates something to a document that is mainly about it. </p> <p> The <code><a href='#term_isPrimaryTopicOf'>isPrimaryTopicOf</a></code> property is <em>inverse functional</em>: for any document that is the value of this property, there is at most one thing in the world that is the primary topic of that document. This is useful, as it allows for data merging, as described in the documentation for its inverse, <code><a href='#term_primaryTopic'>primaryTopic</a></code>. </p> <p> <code><a href='#term_page'>page</a></code> is a super-property of <code><a href='#term_isPrimaryTopicOf'>isPrimaryTopicOf</a></code>. The change of terminology between the two property names reflects the utility of 'primaryTopic' and its inverse when identifying things. Anything that has an <code>isPrimaryTopicOf</code> relation to some document X, also has a <code><a href='#term_page'>page</a></code> relationship to it. </p> <p> Note that <code><a href='#term_homepage'>homepage</a></code>, is a sub-property of both <code><a href='#term_page'>page</a></code> and <code><a href='#term_isPrimaryTopicOf'>isPrimaryTopicOf</a></code>. The awkwardly named <code><a href='#term_isPrimaryTopicOf'>isPrimaryTopicOf</a></code> is less specific, and can be used with any document that is primarily about the thing of interest (ie. not just on homepages). </p> <p style="float: right; font-size: small;">[<a href="#term_isPrimaryTopicOf">#</a>] <!-- isPrimaryTopicOf isPrimaryTopicOf --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_knows" about="http://xmlns.com/foaf/0.1/knows" typeof="rdf:Property"> <h3>Property: foaf:knows</h3> <em>knows</em> - A person known by this person (indicating some level of reciprocated interaction between the parties). <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >stable</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_knows'>knows</a></code> property relates a <code><a href='#term_Person'>Person</a></code> to another <code><a href='#term_Person'>Person</a></code> that he or she knows. </p> <p> We take a broad view of 'knows', but do require some form of reciprocated interaction (ie. stalkers need not apply). Since social attitudes and conventions on this topic vary greatly between communities, counties and cultures, it is not appropriate for FOAF to be overly-specific here. </p> <p> If someone <code><a href='#term_knows'>knows</a></code> a person, it would be usual for the relation to be reciprocated. However this doesn't mean that there is any obligation for either party to publish FOAF describing this relationship. A <code><a href='#term_knows'>knows</a></code> relationship does not imply friendship, endorsement, or that a face-to-face meeting has taken place: phone, fax, email, and smoke signals are all perfectly acceptable ways of communicating with people you know. </p> <p> You probably know hundreds of people, yet might only list a few in your public FOAF file. That's OK. Or you might list them all. It is perfectly fine to have a FOAF file and not list anyone else in it at all. This illustrates the Semantic Web principle of partial description: RDF documents rarely describe the entire picture. There is always more to be said, more information living elsewhere in the Web (or in our heads...). </p> <p> Since <code><a href='#term_knows'>knows</a></code> is vague by design, it may be suprising that it has uses. Typically these involve combining other RDF properties. For example, an application might look at properties of each <code><a href='#term_weblog'>weblog</a></code> that was <code><a href='#term_made'>made</a></code> by someone you "<code><a href='#term_knows'>knows</a></code>". Or check the newsfeed of the online photo archive for each of these people, to show you recent photos taken by people you know. </p> <p> To provide additional levels of representation beyond mere 'knows', FOAF applications can do several things. </p> <p> They can use more precise relationships than <code><a href='#term_knows'>knows</a></code> to relate people to people. The original FOAF design included two of these ('knowsWell','friend') which we removed because they were somewhat <em>awkward</em> to actually use, bringing an inappopriate air of precision to an intrinsically vague concept. Other extensions have been proposed, including Eric Vitiello's <a href="http://www.perceive.net/schemas/20021119/relationship/">Relationship module</a> for FOAF. </p> <p> In addition to using more specialised inter-personal relationship types (eg rel:acquaintanceOf etc) it is often just as good to use RDF descriptions of the states of affairs which imply particular kinds of relationship. So for example, two people who have the same value for their <code><a href='#term_workplaceHomepage'>workplaceHomepage</a></code> property are typically colleagues. We don't (currently) clutter FOAF up with these extra relationships, but the facts can be written in FOAF nevertheless. Similarly, if there exists a <code><a href='#term_Document'>Document</a></code> that has two people listed as its <code><a href='#term_maker'>maker</a></code>s, then they are probably collaborators of some kind. Or if two people appear in 100s of digital photos together, there's a good chance they're friends and/or colleagues. </p> <p> So FOAF is quite pluralistic in its approach to representing relationships between people. FOAF is built on top of a general purpose machine language for representing relationships (ie. RDF), so is quite capable of representing any kinds of relationship we care to add. The problems are generally social rather than technical; deciding on appropriate ways of describing these interconnections is a subtle art. </p> <p> Perhaps the most important use of <code><a href='#term_knows'>knows</a></code> is, alongside the <code>rdfs:seeAlso</code> property, to connect FOAF files together. Taken alone, a FOAF file is somewhat dull. But linked in with 1000s of other FOAF files it becomes more interesting, with each FOAF file saying a little more about people, places, documents, things... By mentioning other people (via <code><a href='#term_knows'>knows</a></code> or other relationships), and by providing an <code>rdfs:seeAlso</code> link to their FOAF file, you can make it easy for FOAF indexing tools ('<a href="http://wiki.foaf-project.org/w/ScutterSpec">scutters</a>') to find your FOAF and the FOAF of the people you've mentioned. And the FOAF of the people they mention, and so on. This makes it possible to build FOAF aggregators without the need for a centrally managed directory of FOAF files... </p> <p style="float: right; font-size: small;">[<a href="#term_knows">#</a>] <!-- knows knows --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_made" about="http://xmlns.com/foaf/0.1/made" typeof="rdf:Property"> <h3>Property: foaf:made</h3> <em>made</em> - Something that was made by this agent. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >stable</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_made'>made</a></code> property relates a <code><a href='#term_Agent'>Agent</a></code> to something <code><a href='#term_made'>made</a></code> by it. As such it is an inverse of the <code><a href='#term_maker'>maker</a></code> property, which relates a thing to something that made it. See <code><a href='#term_made'>made</a></code> for more details on the relationship between these FOAF terms and related Dublin Core vocabulary. </p> <p style="float: right; font-size: small;">[<a href="#term_made">#</a>] <!-- made made --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_maker" about="http://xmlns.com/foaf/0.1/maker" typeof="rdf:Property"> <h3>Property: foaf:maker</h3> <em>maker</em> - An agent that made this thing. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >stable</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_maker'>maker</a></code> property relates something to a <code><a href='#term_Agent'>Agent</a></code> that <code><a href='#term_made'>made</a></code> it. As such it is an inverse of the <code><a href='#term_made'>made</a></code> property. </p> <p> The <code><a href='#term_name'>name</a></code> (or other <code>rdfs:label</code>) of the <code><a href='#term_maker'>maker</a></code> of something can be described as the <code>dc:creator</code> of that thing.</p> <p> For example, if the thing named by the URI http://danbri.org/ has a <code><a href='#term_maker'>maker</a></code> that is a <code><a href='#term_Person'>Person</a></code> whose <code><a href='#term_name'>name</a></code> is 'Dan Brickley', we can conclude that http://danbri.org/ has a <code>dc:creator</code> of 'Dan Brickley'. </p> <p> FOAF descriptions are encouraged to use <code>dc:creator</code> only for simple textual names, and to use <code><a href='#term_maker'>maker</a></code> to indicate creators, rather than risk confusing creators with their names. This follows most Dublin Core usage. See <a href="http://wiki.foaf-project.org/w/UsingDublinCoreCreator">UsingDublinCoreCreator</a> for details. </p> <p style="float: right; font-size: small;">[<a href="#term_maker">#</a>] <!-- maker maker --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_mbox" about="http://xmlns.com/foaf/0.1/mbox" typeof="rdf:Property"> <h3>Property: foaf:mbox</h3> <em>personal mailbox</em> - A personal mailbox, ie. an Internet mailbox associated with exactly one owner, the first owner of this mailbox. This is a 'static inverse functional property', in that there is (across time and change) at most one individual that ever has any particular value for foaf:mbox. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >stable</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th colspan="2">Inverse Functional Property</th> <td> <span rel="rdf:type" href="http://www.w3.org/2002/07/owl#InverseFunctionalProperty"></span> </td></tr> </table> <p> The <code><a href='#term_mbox'>mbox</a></code> property is a relationship between the owner of a mailbox and a mailbox. These are typically identified using the mailto: URI scheme (see <a href="http://ftp.ics.uci.edu/pub/ietf/uri/rfc2368.txt">RFC 2368</a>). </p> <p> Note that there are many mailboxes (eg. shared ones) which are not the <code><a href='#term_mbox'>mbox</a></code> of anyone. Furthermore, a person can have multiple <code><a href='#term_mbox'>mbox</a></code> properties. </p> <p> In FOAF, we often see <code><a href='#term_mbox'>mbox</a></code> used as an indirect way of identifying its owner. This works even if the mailbox is itself out of service (eg. 10 years old), since the property is defined in terms of its primary owner, and doesn't require the mailbox to actually be being used for anything. </p> <p> Many people are wary of sharing information about their mailbox addresses in public. To address such concerns whilst continuing the FOAF convention of indirectly identifying people by referring to widely known properties, FOAF also provides the <code><a href='#term_mbox_sha1sum'>mbox_sha1sum</a></code> mechanism, which is a relationship between a person and the value you get from passing a mailbox URI to the SHA1 mathematical function. </p> <p style="float: right; font-size: small;">[<a href="#term_mbox">#</a>] <!-- mbox mbox --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_member" about="http://xmlns.com/foaf/0.1/member" typeof="rdf:Property"> <h3>Property: foaf:member</h3> <em>member</em> - Indicates a member of a Group <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >stable</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Group"><a href="#term_Group">Group</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_member'>member</a></code> property relates a <code><a href='#term_Group'>Group</a></code> to a <code><a href='#term_Agent'>Agent</a></code> that is a member of that group. </p> <p> See <code><a href='#term_Group'>Group</a></code> for details and examples. </p> <p style="float: right; font-size: small;">[<a href="#term_member">#</a>] <!-- member member --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_page" about="http://xmlns.com/foaf/0.1/page" typeof="rdf:Property"> <h3>Property: foaf:page</h3> <em>page</em> - A page or document about this thing. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >stable</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_page'>page</a></code> property relates a thing to a document about that thing. </p> <p> As such it is an inverse of the <code><a href='#term_topic'>topic</a></code> property, which relates a document to a thing that the document is about. </p> <p style="float: right; font-size: small;">[<a href="#term_page">#</a>] <!-- page page --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_primaryTopic" about="http://xmlns.com/foaf/0.1/primaryTopic" typeof="rdf:Property"> <h3>Property: foaf:primaryTopic</h3> <em>primary topic</em> - The primary topic of some page or document. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >stable</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th colspan="2">Functional Property</th> <td> <span rel="rdf:type" href="http://www.w3.org/2002/07/owl#FunctionalProperty"></span> </td></tr> </table> <p> The <code><a href='#term_primaryTopic'>primaryTopic</a></code> property relates a document to the main thing that the document is about. </p> <p> The <code><a href='#term_primaryTopic'>primaryTopic</a></code> property is <em>functional</em>: for any document it applies to, it can have at most one value. This is useful, as it allows for data merging. In many cases it may be difficult for third parties to determine the primary topic of a document, but in a useful number of cases (eg. descriptions of movies, restaurants, politicians, ...) it should be reasonably obvious. Documents are very often the most authoritative source of information about their own primary topics, although this cannot be guaranteed since documents cannot be assumed to be accurate, honest etc. </p> <p> It is an inverse of the <code><a href='#term_isPrimaryTopicOf'>isPrimaryTopicOf</a></code> property, which relates a thing to a document <em>primarily</em> about that thing. The choice between these two properties is purely pragmatic. When describing documents, we use <code><a href='#term_primaryTopic'>primaryTopic</a></code> former to point to the things they're about. When describing things (people etc.), it is useful to be able to directly cite documents which have those things as their main topic - so we use <code><a href='#term_isPrimaryTopicOf'>isPrimaryTopicOf</a></code>. In this way, Web sites such as <a href="http://www.wikipedia.org/">Wikipedia</a> or <a href="http://www.nndb.com/">NNDB</a> can provide indirect identification for the things they have descriptions of. </p> <p style="float: right; font-size: small;">[<a href="#term_primaryTopic">#</a>] <!-- primaryTopic primaryTopic --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_weblog" about="http://xmlns.com/foaf/0.1/weblog" typeof="rdf:Property"> <h3>Property: foaf:weblog</h3> <em>weblog</em> - A weblog of some thing (whether person, group, company etc.). <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >stable</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th colspan="2">Inverse Functional Property</th> <td> <span rel="rdf:type" href="http://www.w3.org/2002/07/owl#InverseFunctionalProperty"></span> </td></tr> </table> <p> The <code><a href='#term_weblog'>weblog</a></code> property relates a <code><a href='#term_Agent'>Agent</a></code> to a weblog of that agent. </p> <p style="float: right; font-size: small;">[<a href="#term_weblog">#</a>] <!-- weblog weblog --> [<a href="#glance">back to top</a>]</p> <br/> </div> <div class="specterm propertyterm " id="term_account" about="http://xmlns.com/foaf/0.1/account" typeof="rdf:Property"> <h3>Property: foaf:account</h3> <em>account</em> - Indicates an account held by this agent. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/OnlineAccount"><a href="#term_OnlineAccount">Online Account</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_account'>account</a></code> property relates a <code><a href='#term_Agent'>Agent</a></code> to an <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> for which they are the sole account holder. See <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> for usage details. </p> <p style="float: right; font-size: small;">[<a href="#term_account">#</a>] <!-- account account --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_accountName" about="http://xmlns.com/foaf/0.1/accountName" typeof="rdf:Property"> <h3>Property: foaf:accountName</h3> <em>account name</em> - Indicates the name (identifier) associated with this online account. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/OnlineAccount"><a href="#term_OnlineAccount">Online Account</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_accountName'>accountName</a></code> property of a <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> is a textual representation of the account name (unique ID) associated with that account. </p> <p style="float: right; font-size: small;">[<a href="#term_accountName">#</a>] <!-- accountName accountName --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_accountServiceHomepage" about="http://xmlns.com/foaf/0.1/accountServiceHomepage" typeof="rdf:Property"> <h3>Property: foaf:accountServiceHomepage</h3> <em>account service homepage</em> - Indicates a homepage of the service provide for this online account. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/OnlineAccount"><a href="#term_OnlineAccount">Online Account</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_accountServiceHomepage'>accountServiceHomepage</a></code> property indicates a relationship between a <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> and the homepage of the supporting service provider. </p> <p style="float: right; font-size: small;">[<a href="#term_accountServiceHomepage">#</a>] <!-- accountServiceHomepage accountServiceHomepage --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_aimChatID" about="http://xmlns.com/foaf/0.1/aimChatID" typeof="rdf:Property"> <h3>Property: foaf:aimChatID</h3> <em>AIM chat ID</em> - An AIM chat ID <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th colspan="2">Inverse Functional Property</th> <td> <span rel="rdf:type" href="http://www.w3.org/2002/07/owl#InverseFunctionalProperty"></span> </td></tr> </table> <p> The <code><a href='#term_aimChatID'>aimChatID</a></code> property relates a <code><a href='#term_Agent'>Agent</a></code> to a textual identifier ('screenname') assigned to them in the AOL Instant Messanger (AIM) system. See AOL's <a href="http://www.aim.com/">AIM</a> site for more details of AIM and AIM screennames. The <a href="http://www.apple.com/macosx/what-is-macosx/ichat.html">iChat</a> tools from <a href="http://www.apple.com/">Apple</a> also make use of AIM identifiers. </p> <p> See <code><a href='#term_OnlineChatAccount'>OnlineChatAccount</a></code> (and <code><a href='#term_OnlineAccount'>OnlineAccount</a></code>) for a more general (and verbose) mechanism for describing IM and chat accounts. </p> <p style="float: right; font-size: small;">[<a href="#term_aimChatID">#</a>] <!-- aimChatID aimChatID --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_based_near" about="http://xmlns.com/foaf/0.1/based_near" typeof="rdf:Property"> <h3>Property: foaf:based_near</h3> <em>based near</em> - A location that something is based near, for some broadly human notion of near. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://www.w3.org/2003/01/geo/wgs84_pos#SpatialThing"><a href="#term_SpatialThing">Spatial Thing</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://www.w3.org/2003/01/geo/wgs84_pos#SpatialThing"><a href="#term_SpatialThing">Spatial Thing</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <!-- note: is this mis-specified? perhaps range ought to also be SpatialThing, so we can have multiple labels on the same point? --> <p>The <code><a href='#term_based_near'>based_near</a></code> relationship relates two "spatial things" (anything that can <em>be somewhere</em>), the latter typically described using the geo:lat / geo:long <a href="http://www.w3.org/2003/01/geo/wgs84_pos#">geo-positioning vocabulary</a> (See <a href="http://esw.w3.org/topic/GeoInfo">GeoInfo</a> in the W3C semweb wiki for details). This allows us to say describe the typical latitute and longitude of, say, a Person (people are spatial things - they can be places) without implying that a precise location has been given. </p> <p>We do not say much about what 'near' means in this context; it is a 'rough and ready' concept. For a more precise treatment, see <a href="http://esw.w3.org/topic/GeoOnion">GeoOnion vocab</a> design discussions, which are aiming to produce a more sophisticated vocabulary for such purposes. </p> <p> FOAF files often make use of the <code>contact:nearestAirport</code> property. This illustrates the distinction between FOAF documents (which may make claims using <em>any</em> RDF vocabulary) and the core FOAF vocabulary defined by this specification. For further reading on the use of <code>nearestAirport</code> see <a href="http://wiki.foaf-project.org/w/UsingContactNearestAirport">UsingContactNearestAirport</a> in the FOAF wiki. </p> <p style="float: right; font-size: small;">[<a href="#term_based_near">#</a>] <!-- based_near based_near --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_currentProject" about="http://xmlns.com/foaf/0.1/currentProject" typeof="rdf:Property"> <h3>Property: foaf:currentProject</h3> <em>current project</em> - A current project this person works on. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <!-- originally contrib'd by Cardinal --> <p>A <code><a href='#term_currentProject'>currentProject</a></code> relates a <code><a href='#term_Person'>Person</a></code> to a <code><a href='#term_Document'>Document</a></code> indicating some collaborative or individual undertaking. This relationship indicates that the <code><a href='#term_Person'>Person</a></code> has some active role in the project, such as development, coordination, or support.</p> <p>When a <code><a href='#term_Person'>Person</a></code> is no longer involved with a project, or perhaps is inactive for some time, the relationship becomes a <code><a href='#term_pastProject'>pastProject</a></code>.</p> <p> If the <code><a href='#term_Person'>Person</a></code> has stopped working on a project because it has been completed (successfully or otherwise), <code><a href='#term_pastProject'>pastProject</a></code> is applicable. In general, <code><a href='#term_currentProject'>currentProject</a></code> is used to indicate someone's current efforts (and implied interests, concerns etc.), while <code><a href='#term_pastProject'>pastProject</a></code> describes what they've previously been doing. </p> <!-- <p>Generally speaking, anything that a <code><a href='#term_Person'>Person</a></code> has <code><a href='#term_made'>made</a></code> could also qualify as a <code><a href='#term_currentProject'>currentProject</a></code> or <code><a href='#term_pastProject'>pastProject</a></code>.</p> --> <p class="editorial"> Note that this property requires further work. There has been confusion about whether it points to a thing (eg. something you've made; a homepage for a project, ie. a <code><a href='#term_Document'>Document</a></code> or to instances of the class <code><a href='#term_Project'>Project</a></code>, which might themselves have a <code><a href='#term_homepage'>homepage</a></code>. In practice, it seems to have been used in a similar way to <code><a href='#term_interest'>interest</a></code>, referencing homepages of ongoing projects. </p> <p style="float: right; font-size: small;">[<a href="#term_currentProject">#</a>] <!-- currentProject currentProject --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_depiction" about="http://xmlns.com/foaf/0.1/depiction" typeof="rdf:Property"> <h3>Property: foaf:depiction</h3> <em>depiction</em> - A depiction of some thing. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Image"><a href="#term_Image">Image</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_depiction'>depiction</a></code> property is a relationship between a thing and an <code><a href='#term_Image'>Image</a></code> that depicts it. As such it is an inverse of the <code><a href='#term_depicts'>depicts</a></code> relationship. </p> <p> A common use of <code><a href='#term_depiction'>depiction</a></code> (and <code><a href='#term_depicts'>depicts</a></code>) is to indicate the contents of a digital image, for example the people or objects represented in an online photo gallery. </p> <p> Extensions to this basic idea include '<a href="http://rdfweb.org/2002/01/photo/">Co-Depiction</a>' (social networks as evidenced in photos), as well as richer photo metadata through the mechanism of using SVG paths to indicate the <em>regions</em> of an image which depict some particular thing. See <a href="http://www.jibbering.com/svg/AnnotateImage.html">'Annotating Images With SVG'</a> for tools and details. </p> <p> The basic notion of 'depiction' could also be extended to deal with multimedia content (video clips, audio), or refined to deal with corner cases, such as pictures of pictures etc. </p> <p> The <code><a href='#term_depiction'>depiction</a></code> property is a super-property of the more specific property <code><a href='#term_img'>img</a></code>, which is used more sparingly. You stand in a <code><a href='#term_depiction'>depiction</a></code> relation to <em>any</em> <code><a href='#term_Image'>Image</a></code> that depicts you, whereas <code><a href='#term_img'>img</a></code> is typically used to indicate a few images that are particularly representative. </p> <p style="float: right; font-size: small;">[<a href="#term_depiction">#</a>] <!-- depiction depiction --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_depicts" about="http://xmlns.com/foaf/0.1/depicts" typeof="rdf:Property"> <h3>Property: foaf:depicts</h3> <em>depicts</em> - A thing depicted in this representation. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Image"><a href="#term_Image">Image</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_depicts'>depicts</a></code> property is a relationship between a <code><a href='#term_Image'>Image</a></code> and something that the image depicts. As such it is an inverse of the <code><a href='#term_depiction'>depiction</a></code> relationship. See <code><a href='#term_depiction'>depiction</a></code> for further notes. </p> <p style="float: right; font-size: small;">[<a href="#term_depicts">#</a>] <!-- depicts depicts --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_familyName" about="http://xmlns.com/foaf/0.1/familyName" typeof="rdf:Property"> <h3>Property: foaf:familyName</h3> <em>familyName</em> - The family name of some person. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_familyName'>familyName</a></code> property is provided (alongside <code><a href='#term_givenName'>givenName</a></code>) for use when describing parts of people's names. Although these concepts do not capture the full range of personal naming styles found world-wide, they are commonly used and have some value. </p> <p> There is also a simple <code><a href='#term_name'>name</a></code> property. </p> <p> Support is also provided for the more archaic and culturally varying terminology of <code><a href='#term_firstName'>firstName</a></code> and <code><a href='#term_lastName'>lastName</a></code>. </p> <p> See the <a href="http://wiki.foaf-project.org/w/NameVocabIssue">issue tracker</a> for design discussions, status and ongoing work on rationalising the FOAF naming machinery. </p> <p style="float: right; font-size: small;">[<a href="#term_familyName">#</a>] <!-- familyName familyName --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_firstName" about="http://xmlns.com/foaf/0.1/firstName" typeof="rdf:Property"> <h3>Property: foaf:firstName</h3> <em>firstName</em> - The first name of a person. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_firstName'>firstName</a></code> property is provided (alongside <code><a href='#term_lastName'>lastName</a></code>) as a mechanism to support legacy data that cannot be easily interpreted in terms of the (otherwise preferred) <code><a href='#term_familyName'>familyName</a></code> and <code><a href='#term_givenName'>givenName</a></code> properties. The concepts of 'first' and 'last' names do not work well across cultural and linguistic boundaries; however they are widely used in addressbooks and databases. </p> <p> See the <a href="http://wiki.foaf-project.org/w/NameVocabIssue">issue tracker</a> for design discussions, status and ongoing work on rationalising the FOAF naming machinery. </p> <p> There is also a simple <code><a href='#term_name'>name</a></code> property. </p> <p style="float: right; font-size: small;">[<a href="#term_firstName">#</a>] <!-- firstName firstName --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_focus" about="http://xmlns.com/foaf/0.1/focus" typeof="rdf:Property"> <h3>Property: foaf:focus</h3> <em>focus</em> - The underlying or 'focal' entity associated with some SKOS-described concept. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://www.w3.org/2004/02/skos/core#Concept"><a href="#term_Concept">Concept</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_focus'>focus</a></code> property relates a conceptualisation of something to the thing itself. Specifically, it is designed for use with W3C's <a href="http://www.w3.org/2004/02/skos/">SKOS</a> vocabulary, to help indicate specific individual things (typically people, places, artifacts) that are mentioned in different SKOS schemes (eg. thesauri). </p> <p> W3C SKOS is based around collections of linked 'concepts', which indicate topics, subject areas and categories. <a href="http://www.w3.org/TR/2005/WD-swbp-skos-core-guide-20050510/#secmodellingrdf">In SKOS</a>, properties of a skos:Concept are properties of the conceptualization (see <a href="http://www.w3.org/TR/2005/WD-swbp-skos-core-guide-20051102/#secopen">2005 discussion</a> for details); for example administrative and record-keeping metadata. Two schemes might have an entry for the same individual; the foaf:focus property can be used to indicate the thing in they world that they both focus on. Many SKOS concepts don't work this way; broad topical areas and subject categories don't typically correspond to some particular entity. However, in cases when they do, it is useful to link both subject-oriented and thing-oriented information via foaf:focus. </p> <p> FOAF's focus property works alongside its other topic-oriented constructs: <code><a href='#term_topic'>topic</a></code>, <code><a href='#term_primaryTopic'>primaryTopic</a></code> are used when talking about the topical emphasis of a document. The notion of <code><a href='#term_primaryTopic'>primaryTopic</a></code> is particularly important in FOAF as it provides an indirect mechanism for identifying things indirectly. A similar approach is explored by the <a href="http://larry.masinter.net/duri.html">TDB URI scheme</a>. FOAF includes topic-oriented functionality to address its <a href="http://www.foaf-project.org/original-intro">original goals</a> of linking people to information, as well as to other people, through the use of linked information. </p> <p style="float: right; font-size: small;">[<a href="#term_focus">#</a>] <!-- focus focus --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_gender" about="http://xmlns.com/foaf/0.1/gender" typeof="rdf:Property"> <h3>Property: foaf:gender</h3> <em>gender</em> - The gender of this Agent (typically but not necessarily 'male' or 'female'). <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th colspan="2">Functional Property</th> <td> <span rel="rdf:type" href="http://www.w3.org/2002/07/owl#FunctionalProperty"></span> </td></tr> </table> <p> The <code><a href='#term_gender'>gender</a></code> property relates a <code><a href='#term_Agent'>Agent</a></code> (typically a <code><a href='#term_Person'>Person</a></code>) to a string representing its gender. In most cases the value will be the string 'female' or 'male' (in lowercase without surrounding quotes or spaces). Like all FOAF properties, there is in general no requirement to use <code><a href='#term_gender'>gender</a></code> in any particular document or description. Values other than 'male' and 'female' may be used, but are not enumerated here. The <code><a href='#term_gender'>gender</a></code> mechanism is not intended to capture the full variety of biological, social and sexual concepts associated with the word 'gender'. </p> <p> Anything that has a <code><a href='#term_gender'>gender</a></code> property will be some kind of <code><a href='#term_Agent'>Agent</a></code>. However there are kinds of <code><a href='#term_Agent'>Agent</a></code> to which the concept of gender isn't applicable (eg. a <code><a href='#term_Group'>Group</a></code>). FOAF does not currently include a class corresponding directly to "the type of thing that has a gender". At any point in time, a <code><a href='#term_Agent'>Agent</a></code> has at most one value for <code><a href='#term_gender'>gender</a></code>. FOAF does not treat <code><a href='#term_gender'>gender</a></code> as a <em>static</em> property; the same individual may have different values for this property at different times. </p> <p> Note that FOAF's notion of gender isn't defined biologically or anatomically - this would be tricky since we have a broad notion that applies to all <code><a href='#term_Agent'>Agent</a></code>s (including robots - eg. Bender from Futurama is 'male'). As stressed above, FOAF's notion of gender doesn't attempt to encompass the full range of concepts associated with human gender, biology and sexuality. As such it is a (perhaps awkward) compromise between the clinical and the social/psychological. In general, a person will be the best authority on their <code><a href='#term_gender'>gender</a></code>. Feedback on this design is particularly welcome (via the FOAF mailing list, <a href="http://lists.foaf-project.org/mailman/listinfo/foaf-dev">foaf-dev</a>). We have tried to be respectful of diversity without attempting to catalogue or enumerate that diversity. </p> <p> This may also be a good point for a periodic reminder: as with all FOAF properties, documents that use '<code><a href='#term_gender'>gender</a></code>' will on occassion be innacurate, misleading or outright false. FOAF, like all open means of communication, supports <em>lying</em>. Application authors using FOAF data should always be cautious in their presentation of unverified information, but be particularly sensitive to issues and risks surrounding sex and gender (including privacy and personal safety concerns). Designers of FOAF-based user interfaces should be careful to allow users to omit <code><a href='#term_gender'>gender</a></code> when describing themselves and others, and to allow at least for values other than 'male' and 'female' as options. Users of information conveyed via FOAF (as via information conveyed through mobile phone text messages, email, Internet chat, HTML pages etc.) should be skeptical of unverified information. </p> <!-- b/g article currently offline. http://216.239.37.104/search?q=cache:Q_P_fH8M0swJ:archives.thedaily.washington.edu/1997/042997/sex.042997.html+%22Lois+McDermott%22&hl=en&start=7&ie=UTF-8 --> <p style="float: right; font-size: small;">[<a href="#term_gender">#</a>] <!-- gender gender --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_givenName" about="http://xmlns.com/foaf/0.1/givenName" typeof="rdf:Property"> <h3>Property: foaf:givenName</h3> <em>Given name</em> - The given name of some person. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_givenName'>givenName</a></code> property is provided (alongside <code><a href='#term_familyName'>familyName</a></code>) for use when describing parts of people's names. Although these concepts do not capture the full range of personal naming styles found world-wide, they are commonly used and have some value. </p> <p> There is also a simple <code><a href='#term_name'>name</a></code> property. </p> <p> Support is also provided for the more archaic and culturally varying terminology of <code><a href='#term_firstName'>firstName</a></code> and <code><a href='#term_lastName'>lastName</a></code>. </p> <p> See the <a href="http://wiki.foaf-project.org/w/NameVocabIssue">issue tracker</a> for design discussions, status and ongoing work on rationalising the FOAF naming machinery. </p> <p style="float: right; font-size: small;">[<a href="#term_givenName">#</a>] <!-- givenName givenName --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_icqChatID" about="http://xmlns.com/foaf/0.1/icqChatID" typeof="rdf:Property"> <h3>Property: foaf:icqChatID</h3> <em>ICQ chat ID</em> - An ICQ chat ID <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th colspan="2">Inverse Functional Property</th> <td> <span rel="rdf:type" href="http://www.w3.org/2002/07/owl#InverseFunctionalProperty"></span> </td></tr> </table> <p> The <code><a href='#term_icqChatID'>icqChatID</a></code> property relates a <code><a href='#term_Agent'>Agent</a></code> to a textual identifier assigned to them in the ICQ Chat system. See the <a href="http://web.icq.com/icqchat/">icq chat</a> site for more details of the 'icq' service. Their "<a href="http://www.icq.com/products/whatisicq.html">What is ICQ?</a>" document provides a basic overview, while their "<a href="http://company.icq.com/info/">About Us</a> page notes that ICQ has been acquired by AOL. Despite the relationship with AOL, ICQ is at the time of writing maintained as a separate identity from the AIM brand (see <code><a href='#term_aimChatID'>aimChatID</a></code>). </p> <p> See <code><a href='#term_OnlineChatAccount'>OnlineChatAccount</a></code> (and <code><a href='#term_OnlineAccount'>OnlineAccount</a></code>) for a more general (and verbose) mechanism for describing IM and chat accounts. </p> <p style="float: right; font-size: small;">[<a href="#term_icqChatID">#</a>] <!-- icqChatID icqChatID --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_img" about="http://xmlns.com/foaf/0.1/img" typeof="rdf:Property"> <h3>Property: foaf:img</h3> <em>image</em> - An image that can be used to represent some thing (ie. those depictions which are particularly representative of something, eg. one's photo on a homepage). <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Image"><a href="#term_Image">Image</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_img'>img</a></code> property relates a <code><a href='#term_Person'>Person</a></code> to a <code><a href='#term_Image'>Image</a></code> that represents them. Unlike its super-property <code><a href='#term_depiction'>depiction</a></code>, we only use <code><a href='#term_img'>img</a></code> when an image is particularly representative of some person. The analogy is with the image(s) that might appear on someone's homepage, rather than happen to appear somewhere in their photo album. </p> <p> Unlike the more general <code><a href='#term_depiction'>depiction</a></code> property (and its inverse, <code><a href='#term_depicts'>depicts</a></code>), the <code><a href='#term_img'>img</a></code> property is only used with representations of people (ie. instances of <code><a href='#term_Person'>Person</a></code>). So you can't use it to find pictures of cats, dogs etc. The basic idea is to have a term whose use is more restricted than <code><a href='#term_depiction'>depiction</a></code> so we can have a useful way of picking out a reasonable image to represent someone. FOAF defines <code><a href='#term_img'>img</a></code> as a sub-property of <code><a href='#term_depiction'>depiction</a></code>, which means that the latter relationship is implied whenever two things are related by the former. </p> <p> Note that <code><a href='#term_img'>img</a></code> does not have any restrictions on the dimensions, colour depth, format etc of the <code><a href='#term_Image'>Image</a></code> it references. </p> <p> Terminology: note that <code><a href='#term_img'>img</a></code> is a property (ie. relationship), and that <code>code:Image</code> is a similarly named class (ie. category, a type of thing). It might have been more helpful to call <code><a href='#term_img'>img</a></code> 'mugshot' or similar; instead it is named by analogy to the HTML IMG element. </p> <p style="float: right; font-size: small;">[<a href="#term_img">#</a>] <!-- img img --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_interest" about="http://xmlns.com/foaf/0.1/interest" typeof="rdf:Property"> <h3>Property: foaf:interest</h3> <em>interest</em> - A page about a topic of interest to this person. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_interest'>interest</a></code> property represents an interest of a <code><a href='#term_Agent'>Agent</a></code>, through indicating a <code><a href='#term_Document'>Document</a></code> whose <code><a href='#term_topic'>topic</a></code>(s) broadly characterises that interest.</p> <p class="example"> For example, we might claim that a person or group has an interest in RDF by saying they stand in a <code><a href='#term_interest'>interest</a></code> relationship to the <a href="http://www.w3.org/RDF/">RDF</a> home page. Loosly, such RDF would be saying <em>"this agent is interested in the topic of this page"</em>. </p> <p class="example"> Uses of <code><a href='#term_interest'>interest</a></code> include a variety of filtering and resource discovery applications. It could be used, for example, to help find answers to questions such as "Find me members of this organisation with an interest in XML who have also contributed to <a href="http://www.cpan.org/">CPAN</a>)". </p> <p> This approach to characterising interests is intended to compliment other mechanisms (such as the use of controlled vocabulary). It allows us to use a widely known set of unique identifiers (Web page URIs) with minimal pre-coordination. Since URIs have a controlled syntax, this makes data merging much easier than the use of free-text characterisations of interest. </p> <p> Note that interest does not imply expertise, and that this FOAF term provides no support for characterising levels of interest: passing fads and lifelong quests are both examples of someone's <code><a href='#term_interest'>interest</a></code>. Describing interests in full is a complex undertaking; <code><a href='#term_interest'>interest</a></code> provides one basic component of FOAF's approach to these problems. </p> <p style="float: right; font-size: small;">[<a href="#term_interest">#</a>] <!-- interest interest --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_jabberID" about="http://xmlns.com/foaf/0.1/jabberID" typeof="rdf:Property"> <h3>Property: foaf:jabberID</h3> <em>jabber ID</em> - A jabber ID for something. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th colspan="2">Inverse Functional Property</th> <td> <span rel="rdf:type" href="http://www.w3.org/2002/07/owl#InverseFunctionalProperty"></span> </td></tr> </table> <p> The <code><a href='#term_jabberID'>jabberID</a></code> property relates a <code><a href='#term_Agent'>Agent</a></code> to a textual identifier assigned to them in the <a href="http://www.jabber.org/">Jabber</a> messaging system. See the <a href="http://www.jabber.org/">Jabber</a> site for more information about the Jabber protocols and tools. </p> <p> Jabber, unlike several other online messaging systems, is based on an open, publically documented protocol specification, and has a variety of open source implementations. Jabber IDs can be assigned to a variety of kinds of thing, including software 'bots', chat rooms etc. For the purposes of FOAF, these are all considered to be kinds of <code><a href='#term_Agent'>Agent</a></code> (ie. things that <em>do</em> stuff). The uses of Jabber go beyond simple IM chat applications. The <code><a href='#term_jabberID'>jabberID</a></code> property is provided as a basic hook to help support RDF description of Jabber users and services. </p> <p> See <code><a href='#term_OnlineChatAccount'>OnlineChatAccount</a></code> (and <code><a href='#term_OnlineAccount'>OnlineAccount</a></code>) for a more general (and verbose) mechanism for describing IM and chat accounts. </p> <p style="float: right; font-size: small;">[<a href="#term_jabberID">#</a>] <!-- jabberID jabberID --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_lastName" about="http://xmlns.com/foaf/0.1/lastName" typeof="rdf:Property"> <h3>Property: foaf:lastName</h3> <em>lastName</em> - The last name of a person. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_lastName'>lastName</a></code> property is provided (alongside <code><a href='#term_firstName'>firstName</a></code>) as a mechanism to support legacy data that cannot be easily interpreted in terms of the (otherwise preferred) <code><a href='#term_familyName'>familyName</a></code> and <code><a href='#term_givenName'>givenName</a></code> properties. The concepts of 'first' and 'last' names do not work well across cultural and linguistic boundaries; however they are widely used in addressbooks and databases. </p> <p> See the <a href="http://wiki.foaf-project.org/w/NameVocabIssue">issue tracker</a> for design discussions, status and ongoing work on rationalising the FOAF naming machinery. </p> <p> There is also a simple <code><a href='#term_name'>name</a></code> property. </p> <p style="float: right; font-size: small;">[<a href="#term_lastName">#</a>] <!-- lastName lastName --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_logo" about="http://xmlns.com/foaf/0.1/logo" typeof="rdf:Property"> <h3>Property: foaf:logo</h3> <em>logo</em> - A logo representing some thing. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th colspan="2">Inverse Functional Property</th> <td> <span rel="rdf:type" href="http://www.w3.org/2002/07/owl#InverseFunctionalProperty"></span> </td></tr> </table> <p> The <code><a href='#term_logo'>logo</a></code> property is used to indicate a graphical logo of some kind. <em>It is probably underspecified...</em> </p> <p style="float: right; font-size: small;">[<a href="#term_logo">#</a>] <!-- logo logo --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_mbox_sha1sum" about="http://xmlns.com/foaf/0.1/mbox_sha1sum" typeof="rdf:Property"> <h3>Property: foaf:mbox_sha1sum</h3> <em>sha1sum of a personal mailbox URI name</em> - The sha1sum of the URI of an Internet mailbox associated with exactly one owner, the first owner of the mailbox. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th colspan="2">Inverse Functional Property</th> <td> <span rel="rdf:type" href="http://www.w3.org/2002/07/owl#InverseFunctionalProperty"></span> </td></tr> </table> <p> A <code><a href='#term_mbox_sha1sum'>mbox_sha1sum</a></code> of a <code><a href='#term_Person'>Person</a></code> is a textual representation of the result of applying the SHA1 mathematical functional to a 'mailto:' identifier (URI) for an Internet mailbox that they stand in a <code><a href='#term_mbox'>mbox</a></code> relationship to. </p> <p> In other words, if you have a mailbox (<code><a href='#term_mbox'>mbox</a></code>) but don't want to reveal its address, you can take that address and generate a <code><a href='#term_mbox_sha1sum'>mbox_sha1sum</a></code> representation of it. Just as a <code><a href='#term_mbox'>mbox</a></code> can be used as an indirect identifier for its owner, we can do the same with <code><a href='#term_mbox_sha1sum'>mbox_sha1sum</a></code> since there is only one <code><a href='#term_Person'>Person</a></code> with any particular value for that property. </p> <p> Many FOAF tools use <code><a href='#term_mbox_sha1sum'>mbox_sha1sum</a></code> in preference to exposing mailbox information. This is usually for privacy and SPAM-avoidance reasons. Other relevant techniques include the use of PGP encryption (see <a href="http://usefulinc.com/foaf/">Edd Dumbill's documentation</a>) and the use of <a href="http://www.w3.org/2001/12/rubyrdf/util/foafwhite/intro.html">FOAF-based whitelists</a> for mail filtering. </p> <p> Code examples for SHA1 in C#, Java, PHP, Perl and Python can be found <a href="http://www.intertwingly.net/blog/1545.html">in Sam Ruby's weblog entry</a>. Remember to include the 'mailto:' prefix, but no trailing whitespace, when computing a <code><a href='#term_mbox_sha1sum'>mbox_sha1sum</a></code> property. </p> <!-- what about Javascript. move refs to wiki maybe. --> <p style="float: right; font-size: small;">[<a href="#term_mbox_sha1sum">#</a>] <!-- mbox_sha1sum mbox_sha1sum --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_msnChatID" about="http://xmlns.com/foaf/0.1/msnChatID" typeof="rdf:Property"> <h3>Property: foaf:msnChatID</h3> <em>MSN chat ID</em> - An MSN chat ID <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th colspan="2">Inverse Functional Property</th> <td> <span rel="rdf:type" href="http://www.w3.org/2002/07/owl#InverseFunctionalProperty"></span> </td></tr> </table> <p> The <code><a href='#term_msnChatID'>msnChatID</a></code> property relates a <code><a href='#term_Agent'>Agent</a></code> to a textual identifier assigned to them in the Microsoft online chat system originally known as 'MSN', and now <a href="http://en.wikipedia.org/wiki/Windows_Live_Messenger">Windows Live Messenger</a>. See the <a href="http://download.live.com/messenger">Microsoft mesenger</a> and <a href="http://en.wikipedia.org/wiki/Windows_Live_ID">Windows Live ID</a> sites for more details. </p> <p>See <code><a href='#term_OnlineChatAccount'>OnlineChatAccount</a></code> (and <code><a href='#term_OnlineAccount'>OnlineAccount</a></code>) for a more general (and verbose) mechanism for describing IM and chat accounts. </p> <p style="float: right; font-size: small;">[<a href="#term_msnChatID">#</a>] <!-- msnChatID msnChatID --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_myersBriggs" about="http://xmlns.com/foaf/0.1/myersBriggs" typeof="rdf:Property"> <h3>Property: foaf:myersBriggs</h3> <em>myersBriggs</em> - A Myers Briggs (MBTI) personality classification. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <!-- todo: expand acronym --> <p> The <code><a href='#term_myersBriggs'>myersBriggs</a></code> property represents the Myers Briggs (MBTI) approach to personality taxonomy. It is included in FOAF as an example of a property that takes certain constrained values, and to give some additional detail to the FOAF files of those who choose to include it. The <code><a href='#term_myersBriggs'>myersBriggs</a></code> property applies only to the <code><a href='#term_Person'>Person</a></code> class; wherever you see it, you can infer it is being applied to a person. </p> <p> The <code><a href='#term_myersBriggs'>myersBriggs</a></code> property is interesting in that it illustrates how FOAF can serve as a carrier for various kinds of information, without necessarily being commited to any associated worldview. Not everyone will find myersBriggs (or star signs, or blood types, or the four humours) a useful perspective on human behaviour and personality. The inclusion of a Myers Briggs property doesn't indicate that FOAF endorses the underlying theory, any more than the existence of <code><a href='#term_weblog'>weblog</a></code> is an endorsement of soapboxes. </p> <p> The values for <code><a href='#term_myersBriggs'>myersBriggs</a></code> are the following 16 4-letter textual codes: ESTJ, INFP, ESFP, INTJ, ESFJ, INTP, ENFP, ISTJ, ESTP, INFJ, ENFJ, ISTP, ENTJ, ISFP, ENTP, ISFJ. If multiple of these properties are applicable, they are represented by applying multiple properties to a person. </p> <p> For further reading on MBTI, see various online sources (eg. <a href="http://www.teamtechnology.co.uk/tt/t-articl/mb-simpl.htm">this article</a>). There are various online sites which offer quiz-based tools for determining a person's MBTI classification. The owners of the MBTI trademark have probably not approved of these. </p> <p> This FOAF property suggests some interesting uses, some of which could perhaps be used to test the claims made by proponents of the MBTI (eg. an analysis of weblog postings filtered by MBTI type). However it should be noted that MBTI FOAF descriptions are self-selecting; MBTI categories may not be uniformly appealing to the people they describe. Further, there is probably a degree of cultural specificity implicit in the assumptions made by many questionaire-based MBTI tools; the MBTI system may not make sense in cultural settings beyond those it was created for. </p> <p> See also <a href="http://webspace.webring.com/people/cl/lifexplore/mbintro.htm">Cory Caplinger's summary table</a> or the RDFWeb article, <a href="http://web.archive.org/web/20080802184922/http://rdfweb.org/mt/foaflog/archives/000004.html">FOAF Myers Briggs addition</a> for further background and examples. </p> <p> Note: Myers Briggs Type Indicator and MBTI are registered trademarks of Consulting Psychologists Press Inc. Oxford Psycholgists Press Ltd has exclusive rights to the trademark in the UK. </p> <p style="float: right; font-size: small;">[<a href="#term_myersBriggs">#</a>] <!-- myersBriggs myersBriggs --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_name" about="http://xmlns.com/foaf/0.1/name" typeof="rdf:Property"> <h3>Property: foaf:name</h3> <em>name</em> - A name for some thing. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p>The <code><a href='#term_name'>name</a></code> of something is a simple textual string.</p> <p> XML language tagging may be used to indicate the language of the name. For example: </p> <div class="example"> <code> &lt;foaf:name xml:lang="en"&gt;Dan Brickley&lt;/foaf:name&gt; </code> </div> <p> FOAF provides some other naming constructs. While foaf:name does not explicitly represent name substructure (family vs given etc.) it does provide a basic level of interoperability. See the <a href="http://wiki.foaf-project.org/w/IssueTracker">issue tracker</a> for status of work on this issue. </p> <p> The <code><a href='#term_name'>name</a></code> property, like all RDF properties with a range of rdfs:Literal, may be used with XMLLiteral datatyped values (multiple <code><a href='#term_name'>name</a></code>s are acceptable whether they are in the same langauge or not). XMLLiteral usage is not yet widely adopted. Feedback on this aspect of the FOAF design is particularly welcomed. </p> <p style="float: right; font-size: small;">[<a href="#term_name">#</a>] <!-- name name --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_nick" about="http://xmlns.com/foaf/0.1/nick" typeof="rdf:Property"> <h3>Property: foaf:nick</h3> <em>nickname</em> - A short informal nickname characterising an agent (includes login identifiers, IRC and other chat nicknames). <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_nick'>nick</a></code> property relates a <code><a href='#term_Person'>Person</a></code> to a short (often abbreviated) nickname, such as those use in IRC chat, online accounts, and computer logins. </p> <p> This property is necessarily vague, because it does not indicate any particular naming control authority, and so cannot distinguish a person's login from their (possibly various) IRC nicknames or other similar identifiers. However it has some utility, since many people use the same string (or slight variants) across a variety of such environments. </p> <p> For specific controlled sets of names (relating primarily to Instant Messanger accounts), FOAF provides some convenience properties: <code><a href='#term_jabberID'>jabberID</a></code>, <code><a href='#term_aimChatID'>aimChatID</a></code>, <code><a href='#term_msnChatID'>msnChatID</a></code> and <code><a href='#term_icqChatID'>icqChatID</a></code>. Beyond this, the problem of representing such accounts is not peculiar to Instant Messanging, and it is not scaleable to attempt to enumerate each naming database as a distinct FOAF property. The <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> term (and supporting vocabulary) are provided as a more verbose and more expressive generalisation of these properties. </p> <p style="float: right; font-size: small;">[<a href="#term_nick">#</a>] <!-- nick nick --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_openid" about="http://xmlns.com/foaf/0.1/openid" typeof="rdf:Property"> <h3>Property: foaf:openid</h3> <em>openid</em> - An OpenID for an Agent. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th colspan="2">Inverse Functional Property</th> <td> <span rel="rdf:type" href="http://www.w3.org/2002/07/owl#InverseFunctionalProperty"></span> </td></tr> </table> <p> A <code><a href='#term_openid'>openid</a></code> is a property of a <code><a href='#term_Agent'>Agent</a></code> that associates it with a document that can be used as an <a href="http://www.w3.org/TR/webarch/#indirect-identification">indirect identifier</a> in the manner of the <a href="http://openid.net/specs/openid-authentication-1_1.html">OpenID</a> "Identity URL". As the OpenID 1.1 specification notes, OpenID itself"<em>does not provide any mechanism to exchange profile information, though Consumers of an Identity can learn more about an End User from any public, semantically interesting documents linked thereunder (FOAF, RSS, Atom, vCARD, etc.)</em>". In this way, FOAF and OpenID complement each other; neither provides a stand-alone approach to online "trust", but combined they can address interesting parts of this larger problem space. </p> <p> The <code><a href='#term_openid'>openid</a></code> property is "inverse functional", meaning that anything that is the foaf:openid of something, is the <code><a href='#term_openid'>openid</a></code> of no more than one thing. FOAF is agnostic as to whether there are (according to the relevant OpenID specifications) OpenID URIs that are equally associated with multiple Agents. FOAF offers sub-classes of Agent, ie. <code><a href='#term_Organization'>Organization</a></code> and <code><a href='#term_Group'>Group</a></code>, that allow for such scenarios to be consistent with the notion that any foaf:openid is the foaf:openid of just one <code><a href='#term_Agent'>Agent</a></code>. </p> <p> FOAF does not mandate any particular URI scheme for use as <code><a href='#term_openid'>openid</a></code> values. The OpenID 1.1 specification includes a <a href="http://openid.net/specs/openid-authentication-1_1.html#delegating_authentication">delegation model</a> that is often used to allow a weblog or homepage document to also serve in OpenID authentication via "link rel" HTML markup. This deployment model provides a convenient connection to FOAF, since a similar <a href="http://xmlns.com/foaf/spec/#sec-autodesc">technique</a> is used for FOAF autodiscovery in HTML. A single document can, for example, serve both as a homepage and an OpenID identity URL. </p> <p style="float: right; font-size: small;">[<a href="#term_openid">#</a>] <!-- openid openid --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_pastProject" about="http://xmlns.com/foaf/0.1/pastProject" typeof="rdf:Property"> <h3>Property: foaf:pastProject</h3> <em>past project</em> - A project this person has previously worked on. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p>After a <code><a href='#term_Person'>Person</a></code> is no longer involved with a <code><a href='#term_currentProject'>currentProject</a></code>, or has been inactive for some time, a <code><a href='#term_pastProject'>pastProject</a></code> relationship can be used. This indicates that the <code><a href='#term_Person'>Person</a></code> was involved with the described project at one point. </p> <p> If the <code><a href='#term_Person'>Person</a></code> has stopped working on a project because it has been completed (successfully or otherwise), <code><a href='#term_pastProject'>pastProject</a></code> is applicable. In general, <code><a href='#term_currentProject'>currentProject</a></code> is used to indicate someone's current efforts (and implied interests, concerns etc.), while <code><a href='#term_pastProject'>pastProject</a></code> describes what they've previously been doing. </p> <p style="float: right; font-size: small;">[<a href="#term_pastProject">#</a>] <!-- pastProject pastProject --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_phone" about="http://xmlns.com/foaf/0.1/phone" typeof="rdf:Property"> <h3>Property: foaf:phone</h3> <em>phone</em> - A phone, specified using fully qualified tel: URI scheme (refs: http://www.w3.org/Addressing/schemes.html#tel). <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_phone'>phone</a></code> of something is a phone, typically identified using the tel: URI scheme. </p> <p style="float: right; font-size: small;">[<a href="#term_phone">#</a>] <!-- phone phone --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_plan" about="http://xmlns.com/foaf/0.1/plan" typeof="rdf:Property"> <h3>Property: foaf:plan</h3> <em>plan</em> - A .plan comment, in the tradition of finger and '.plan' files. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <!-- orig contrib'd by Cardinal --> <p>The <code><a href='#term_plan'>plan</a></code> property provides a space for a <code><a href='#term_Person'>Person</a></code> to hold some arbitrary content that would appear in a traditional '.plan' file. The plan file was stored in a user's home directory on a UNIX machine, and displayed to people when the user was queried with the finger utility.</p> <p>A plan file could contain anything. Typical uses included brief comments, thoughts, or remarks on what a person had been doing lately. Plan files were also prone to being witty or simply osbscure. Others may be more creative, writing any number of seemingly random compositions in their plan file for people to stumble upon.</p> <p> See <a href="http://www.rajivshah.com/Case_Studies/Finger/Finger.htm">History of the Finger Protocol</a> by Rajiv Shah for more on this piece of Internet history. The <code><a href='#term_geekcode'>geekcode</a></code> property may also be of interest. </p> <p style="float: right; font-size: small;">[<a href="#term_plan">#</a>] <!-- plan plan --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_publications" about="http://xmlns.com/foaf/0.1/publications" typeof="rdf:Property"> <h3>Property: foaf:publications</h3> <em>publications</em> - A link to the publications of this person. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_publications'>publications</a></code> property indicates a <code><a href='#term_Document'>Document</a></code> listing (primarily in human-readable form) some publications associated with the <code><a href='#term_Person'>Person</a></code>. Such documents are typically published alongside one's <code><a href='#term_homepage'>homepage</a></code>. </p> <p style="float: right; font-size: small;">[<a href="#term_publications">#</a>] <!-- publications publications --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_schoolHomepage" about="http://xmlns.com/foaf/0.1/schoolHomepage" typeof="rdf:Property"> <h3>Property: foaf:schoolHomepage</h3> <em>schoolHomepage</em> - A homepage of a school attended by the person. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code>schoolHomepage</code> property relates a <code><a href='#term_Person'>Person</a></code> to a <code><a href='#term_Document'>Document</a></code> that is the <code><a href='#term_homepage'>homepage</a></code> of a School that the person attended. </p> <p> FOAF does not (currently) define a class for 'School' (if it did, it would probably be as a sub-class of <code><a href='#term_Organization'>Organization</a></code>). The original application area for <code><a href='#term_schoolHomepage'>schoolHomepage</a></code> was for 'schools' in the British-English sense; however American-English usage has dominated, and it is now perfectly reasonable to describe Universities, Colleges and post-graduate study using <code><a href='#term_schoolHomepage'>schoolHomepage</a></code>. </p> <p> This very basic facility provides a basis for a low-cost, decentralised approach to classmate-reunion and suchlike. Instead of requiring a central database, we can use FOAF to express claims such as 'I studied <em>here</em>' simply by mentioning a school's homepage within FOAF files. Given the homepage of a school, it is easy for FOAF aggregators to lookup this property in search of people who attended that school. </p> <p style="float: right; font-size: small;">[<a href="#term_schoolHomepage">#</a>] <!-- schoolHomepage schoolHomepage --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_skypeID" about="http://xmlns.com/foaf/0.1/skypeID" typeof="rdf:Property"> <h3>Property: foaf:skypeID</h3> <em>Skype ID</em> - A Skype ID <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_skype'>skype</a></code> property relates a <code><a href='#term_Agent'>Agent</a></code> to an account name of a Skype account of theirs. </p> <p> See <code><a href='#term_OnlineChatAccount'>OnlineChatAccount</a></code> (and <code><a href='#term_OnlineAccount'>OnlineAccount</a></code>) for a more general (and verbose) mechanism for describing IM and chat accounts. </p> <p style="float: right; font-size: small;">[<a href="#term_skypeID">#</a>] <!-- skypeID skypeID --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_thumbnail" about="http://xmlns.com/foaf/0.1/thumbnail" typeof="rdf:Property"> <h3>Property: foaf:thumbnail</h3> <em>thumbnail</em> - A derived thumbnail image. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Image"><a href="#term_Image">Image</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Image"><a href="#term_Image">Image</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <!-- originally contrib'd by Cardinal; rejiggged a bit by danbri --> <p> The <code><a href='#term_thumbnail'>thumbnail</a></code> property is a relationship between a full-size <code><a href='#term_Image'>Image</a></code> and a smaller, representative <code><a href='#term_Image'>Image</a></code> that has been derrived from it. </p> <p> It is typical in FOAF to express <code><a href='#term_img'>img</a></code> and <code><a href='#term_depiction'>depiction</a></code> relationships in terms of the larger, 'main' (in some sense) image, rather than its thumbnail(s). A <code><a href='#term_thumbnail'>thumbnail</a></code> might be clipped or otherwise reduced such that it does not depict everything that the full image depicts. Therefore FOAF does not specify that a thumbnail <code><a href='#term_depicts'>depicts</a></code> everything that the image it is derrived from depicts. However, FOAF does expect that anything depicted in the thumbnail will also be depicted in the source image. </p> <!-- todo: add RDF rules here showing this --> <p> A <code><a href='#term_thumbnail'>thumbnail</a></code> is typically small enough that it can be loaded and viewed quickly before a viewer decides to download the larger version. They are often used in online photo gallery applications. </p> <p style="float: right; font-size: small;">[<a href="#term_thumbnail">#</a>] <!-- thumbnail thumbnail --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_tipjar" about="http://xmlns.com/foaf/0.1/tipjar" typeof="rdf:Property"> <h3>Property: foaf:tipjar</h3> <em>tipjar</em> - A tipjar document for this agent, describing means for payment and reward. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_tipjar'>tipjar</a></code> property relates an <code><a href='#term_Agent'>Agent</a></code> to a <code><a href='#term_Document'>Document</a></code> that describes some mechanisms for paying or otherwise rewarding that agent. </p> <p> The <code><a href='#term_tipjar'>tipjar</a></code> property was created following <a href="http://rdfweb.org/mt/foaflog/archives/2004/02/12/20.07.32/">discussions</a> about simple, lightweight mechanisms that could be used to encourage rewards and payment for content exchanged online. An agent's <code><a href='#term_tipjar'>tipjar</a></code> page(s) could describe informal ("Send me a postcard!", "here's my book, music and movie wishlist") or formal (machine-readable micropayment information) information about how that agent can be paid or rewarded. The reward is not associated with any particular action or content from the agent concerned. A link to a service such as <a href="http://www.paypal.com/">PayPal</a> is the sort of thing we might expect to find in a tipjar document. </p> <p> Note that the value of a <code><a href='#term_tipjar'>tipjar</a></code> property is just a document (which can include anchors into HTML pages). We expect, but do not currently specify, that this will evolve into a hook for finding more machine-readable information to support payments, rewards. The <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> machinery is also relevant, although the information requirements for automating payments are not currently clear. </p> <p style="float: right; font-size: small;">[<a href="#term_tipjar">#</a>] <!-- tipjar tipjar --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_title" about="http://xmlns.com/foaf/0.1/title" typeof="rdf:Property"> <h3>Property: foaf:title</h3> <em>title</em> - Title (Mr, Mrs, Ms, Dr. etc) <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p class="editorial"> This property is a candidate for deprecation in favour of 'honorificPrefix' following Portable Contacts usage. See the <a href="http://wiki.foaf-project.org/w/IssueTracker">FOAF Issue Tracker</a>. </p> <p> The approriate values for <code><a href='#term_title'>title</a></code> are not formally constrained, and will vary across community and context. Values such as 'Mr', 'Mrs', 'Ms', 'Dr' etc. are expected. </p> <p style="float: right; font-size: small;">[<a href="#term_title">#</a>] <!-- title title --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_topic" about="http://xmlns.com/foaf/0.1/topic" typeof="rdf:Property"> <h3>Property: foaf:topic</h3> <em>topic</em> - A topic of some page or document. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_topic'>topic</a></code> property relates a document to a thing that the document is about. </p> <p> As such it is an inverse of the <code><a href='#term_page'>page</a></code> property, which relates a thing to a document about that thing. </p> <p style="float: right; font-size: small;">[<a href="#term_topic">#</a>] <!-- topic topic --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_topic_interest" about="http://xmlns.com/foaf/0.1/topic_interest" typeof="rdf:Property"> <h3>Property: foaf:topic_interest</h3> <em>topic_interest</em> - A thing of interest to this person. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_topic_interest'>topic_interest</a></code> property links a <code><a href='#term_Agent'>Agent</a></code> to a thing that they're interested in. Unlike <code><a href='#term_topic'>topic</a></code> it is not indirected through a document, but links the thing directly. </p> <p style="float: right; font-size: small;">[<a href="#term_topic_interest">#</a>] <!-- topic_interest topic_interest --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_workInfoHomepage" about="http://xmlns.com/foaf/0.1/workInfoHomepage" typeof="rdf:Property"> <h3>Property: foaf:workInfoHomepage</h3> <em>work info homepage</em> - A work info homepage of some person; a page about their work for some organization. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_workInfoHomepage'>workInfoHomepage</a></code> of a <code><a href='#term_Person'>Person</a></code> is a <code><a href='#term_Document'>Document</a></code> that describes their work. It is generally (but not necessarily) a different document from their <code><a href='#term_homepage'>homepage</a></code>, and from any <code><a href='#term_workplaceHomepage'>workplaceHomepage</a></code>(s) they may have. </p> <p> The purpose of this property is to distinguish those pages you often see, which describe someone's professional role within an organisation or project. These aren't really homepages, although they share some characterstics. </p> <p style="float: right; font-size: small;">[<a href="#term_workInfoHomepage">#</a>] <!-- workInfoHomepage workInfoHomepage --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_workplaceHomepage" about="http://xmlns.com/foaf/0.1/workplaceHomepage" typeof="rdf:Property"> <h3>Property: foaf:workplaceHomepage</h3> <em>workplace homepage</em> - A workplace homepage of some person; the homepage of an organization they work for. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_workplaceHomepage'>workplaceHomepage</a></code> of a <code><a href='#term_Person'>Person</a></code> is a <code><a href='#term_Document'>Document</a></code> that is the <code><a href='#term_homepage'>homepage</a></code> of a <code><a href='#term_Organization'>Organization</a></code> that they work for. </p> <p> By directly relating people to the homepages of their workplace, we have a simple convention that takes advantage of a set of widely known identifiers, while taking care not to confuse the things those identifiers identify (ie. organizational homepages) with the actual organizations those homepages describe. </p> <div class="example"> <p> For example, Dan Brickley works at W3C. Dan is a <code><a href='#term_Person'>Person</a></code> with a <code><a href='#term_homepage'>homepage</a></code> of http://danbri.org/; W3C is a <code><a href='#term_Organization'>Organization</a></code> with a <code><a href='#term_homepage'>homepage</a></code> of http://www.w3.org/. This allows us to say that Dan has a <code><a href='#term_workplaceHomepage'>workplaceHomepage</a></code> of http://www.w3.org/. </p> <pre> &lt;foaf:Person&gt; &lt;foaf:name>Dan Brickley&lt;/foaf:name&gt; &lt;foaf:workplaceHomepage rdf:resource="http://www.w3.org/"/&gt; &lt;/foaf:Person&gt; </pre> </div> <p> Note that several other FOAF properties work this way; <code><a href='#term_schoolHomepage'>schoolHomepage</a></code> is the most similar. In general, FOAF often indirectly identifies things via Web page identifiers where possible, since these identifiers are widely used and known. FOAF does not currently have a term for the name of the relation (eg. "workplace") that holds between a <code><a href='#term_Person'>Person</a></code> and an <code><a href='#term_Organization'>Organization</a></code> that they work for. </p> <p style="float: right; font-size: small;">[<a href="#term_workplaceHomepage">#</a>] <!-- workplaceHomepage workplaceHomepage --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_yahooChatID" about="http://xmlns.com/foaf/0.1/yahooChatID" typeof="rdf:Property"> <h3>Property: foaf:yahooChatID</h3> <em>Yahoo chat ID</em> - A Yahoo chat ID <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >testing</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th colspan="2">Inverse Functional Property</th> <td> <span rel="rdf:type" href="http://www.w3.org/2002/07/owl#InverseFunctionalProperty"></span> </td></tr> </table> <p> The <code><a href='#term_yahooChatID'>yahooChatID</a></code> property relates a <code><a href='#term_Agent'>Agent</a></code> to a textual identifier assigned to them in the Yahoo online Chat system. See Yahoo's the <a href="http://chat.yahoo.com/">Yahoo! Chat</a> site for more details of their service. Yahoo chat IDs are also used across several other Yahoo services, including email and <a href="http://www.yahoogroups.com/">Yahoo! Groups</a>. </p> <p> See <code><a href='#term_OnlineChatAccount'>OnlineChatAccount</a></code> (and <code><a href='#term_OnlineAccount'>OnlineAccount</a></code>) for a more general (and verbose) mechanism for describing IM and chat accounts. </p> <p style="float: right; font-size: small;">[<a href="#term_yahooChatID">#</a>] <!-- yahooChatID yahooChatID --> [<a href="#glance">back to top</a>]</p> <br/> </div> <div class="specterm propertyterm " id="term_age" about="http://xmlns.com/foaf/0.1/age" typeof="rdf:Property"> <h3>Property: foaf:age</h3> <em>age</em> - The age in years of some agent. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >unstable</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th colspan="2">Functional Property</th> <td> <span rel="rdf:type" href="http://www.w3.org/2002/07/owl#FunctionalProperty"></span> </td></tr> </table> <p> The <code><a href='#term_age'>age</a></code> property is a relationship between a <code><a href='#term_Agent'>Agent</a></code> and an integer string representing their age in years. See also <code><a href='#term_birthday'>birthday</a></code>. </p> <p style="float: right; font-size: small;">[<a href="#term_age">#</a>] <!-- age age --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_birthday" about="http://xmlns.com/foaf/0.1/birthday" typeof="rdf:Property"> <h3>Property: foaf:birthday</h3> <em>birthday</em> - The birthday of this Agent, represented in mm-dd string form, eg. '12-31'. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >unstable</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr><tr><th colspan="2">Functional Property</th> <td> <span rel="rdf:type" href="http://www.w3.org/2002/07/owl#FunctionalProperty"></span> </td></tr> </table> <p> The <code><a href='#term_birthday'>birthday</a></code> property is a relationship between a <code><a href='#term_Agent'>Agent</a></code> and a string representing the month and day in which they were born (Gregorian calendar). See <a href="http://wiki.foaf-project.org/w/BirthdayIssue">BirthdayIssue</a> for details of related properties that can be used to describe such things in more flexible ways. </p> <p> See also <code><a href='#term_age'>age</a></code>. </p> <p style="float: right; font-size: small;">[<a href="#term_birthday">#</a>] <!-- birthday birthday --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_membershipClass" about="http://xmlns.com/foaf/0.1/membershipClass" typeof="rdf:Property"> <h3>Property: foaf:membershipClass</h3> <em>membershipClass</em> - Indicates the class of individuals that are a member of a Group <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >unstable</span></td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_membershipClass'>membershipClass</a></code> property relates a <code><a href='#term_Group'>Group</a></code> to an RDF class representing a sub-class of <code><a href='#term_Agent'>Agent</a></code> whose instances are all the agents that are a <code><a href='#term_member'>member</a></code> of the <code><a href='#term_Group'>Group</a></code>. </p> <p> See <code><a href='#term_Group'>Group</a></code> for details and examples. </p> <p style="float: right; font-size: small;">[<a href="#term_membershipClass">#</a>] <!-- membershipClass membershipClass --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_sha1" about="http://xmlns.com/foaf/0.1/sha1" typeof="rdf:Property"> <h3>Property: foaf:sha1</h3> <em>sha1sum (hex)</em> - A sha1sum hash, in hex. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >unstable</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Document"><a href="#term_Document">Document</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_sha1'>sha1</a></code> property relates a <code><a href='#term_Document'>Document</a></code> to the textual form of a SHA1 hash of (some representation of) its contents. </p> <p class="editorial"> The design for this property is neither complete nor coherent. The <code><a href='#term_Document'>Document</a></code> class is currently used in a way that allows multiple instances at different URIs to have the 'same' contents (and hence hash). If <code><a href='#term_sha1'>sha1</a></code> is an owl:InverseFunctionalProperty, we could deduce that several such documents were the self-same thing. A more careful design is needed, which distinguishes documents in a broad sense from byte sequences. </p> <p style="float: right; font-size: small;">[<a href="#term_sha1">#</a>] <!-- sha1 sha1 --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm " id="term_status" about="http://xmlns.com/foaf/0.1/status" typeof="rdf:Property"> <h3>Property: foaf:status</h3> <em>status</em> - A string expressing what the user is happy for the general public (normally) to know about their current activity. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >unstable</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> <code><a href='#term_status'>status</a></code> is a short textual string expressing what the user is happy for the general public (normally) to know about their current activity. mood, location, etc. </p> <p style="float: right; font-size: small;">[<a href="#term_status">#</a>] <!-- status status --> [<a href="#glance">back to top</a>]</p> <br/> </div> <div class="specterm propertyterm archaic " id="term_dnaChecksum" about="http://xmlns.com/foaf/0.1/dnaChecksum" typeof="rdf:Property"> <h3>Property: foaf:dnaChecksum</h3> <em>DNA checksum</em> - A checksum for the DNA of some thing. Joke. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >archaic</span></td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_dnaChecksum'>dnaChecksum</a></code> property is mostly a joke, but also a reminder that there will be lots of different identifying properties for people, some of which we might find disturbing. </p> <p style="float: right; font-size: small;">[<a href="#term_dnaChecksum">#</a>] <!-- dnaChecksum dnaChecksum --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm archaic " id="term_family_name" about="http://xmlns.com/foaf/0.1/family_name" typeof="rdf:Property"> <h3>Property: foaf:family_name</h3> <em>family_name</em> - The family name of some person. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >archaic</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> This property is considered an <em>archaic</em> spelling of <code><a href='#term_familyName'>familyName</a></code>. </p> <p style="float: right; font-size: small;">[<a href="#term_family_name">#</a>] <!-- family_name family_name --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm archaic " id="term_fundedBy" about="http://xmlns.com/foaf/0.1/fundedBy" typeof="rdf:Property"> <h3>Property: foaf:fundedBy</h3> <em>funded by</em> - An organization funding a project or person. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >archaic</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_fundedBy'>fundedBy</a></code> property relates something to something else that has provided funding for it. </p> <p class="editorial"> This property is tentatively considered <em>archaic usage</em>, unless we hear about positive implementation experience. </p> <p style="float: right; font-size: small;">[<a href="#term_fundedBy">#</a>] <!-- fundedBy fundedBy --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm archaic " id="term_geekcode" about="http://xmlns.com/foaf/0.1/geekcode" typeof="rdf:Property"> <h3>Property: foaf:geekcode</h3> <em>geekcode</em> - A textual geekcode for this person, see http://www.geekcode.com/geek.html <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >archaic</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_geekcode'>geekcode</a></code> property is used to represent a 'Geek Code' for some <code><a href='#term_Person'>Person</a></code>. </p> <p> See the <a href="http://en.wikipedia.org/wiki/Geek_Code">Wikipedia entry</a> for details of the code, which provides a somewhat frivolous and willfully obscure mechanism for characterising technical expertise, interests and habits. The <code><a href='#term_geekcode'>geekcode</a></code> property is not bound to any particular version of the code. </p> <p style="float: right; font-size: small;">[<a href="#term_geekcode">#</a>] <!-- geekcode geekcode --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm archaic " id="term_givenname" about="http://xmlns.com/foaf/0.1/givenname" typeof="rdf:Property"> <h3>Property: foaf:givenname</h3> <em>Given name</em> - The given name of some person. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >archaic</span></td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p> The <code><a href='#term_givenName'>givenName</a></code> property is provided (alongside <code><a href='#term_familyName'>familyName</a></code>) for use when describing parts of people's names. Although these concepts do not capture the full range of personal naming styles found world-wide, they are commonly used and have some value. </p> <p> There is also a simple <code><a href='#term_name'>name</a></code> property. </p> <p> Support is also provided for the more archaic and culturally varying terminology of <code><a href='#term_firstName'>firstName</a></code> and <code><a href='#term_lastName'>lastName</a></code>. </p> <p> See the <a href="http://wiki.foaf-project.org/w/NameVocabIssue">issue tracker</a> for design discussions, status and ongoing work on rationalising the FOAF naming machinery. </p> <p style="float: right; font-size: small;">[<a href="#term_givenname">#</a>] <!-- givenname givenname --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm archaic " id="term_holdsAccount" about="http://xmlns.com/foaf/0.1/holdsAccount" typeof="rdf:Property"> <h3>Property: foaf:holdsAccount</h3> <em>account</em> - Indicates an account held by this agent. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >archaic</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Agent"><a href="#term_Agent">Agent</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://xmlns.com/foaf/0.1/OnlineAccount"><a href="#term_OnlineAccount">Online Account</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p class="editorial"> This property is considered <em>archaic usage</em>. It is generally better to use <code><a href='#term_account'>account</a></code> instead. </p> <p> The <code><a href='#term_holdsAccount'>holdsAccount</a></code> property relates a <code><a href='#term_Agent'>Agent</a></code> to an <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> for which they are the sole account holder. See <code><a href='#term_OnlineAccount'>OnlineAccount</a></code> for usage details. </p> <p> This property is equivalent to the <code><a href='#term_account'>account</a></code> property, which was introduced primarily to provide simpler naming for the same idea. </p> <p style="float: right; font-size: small;">[<a href="#term_holdsAccount">#</a>] <!-- holdsAccount holdsAccount --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm archaic " id="term_surname" about="http://xmlns.com/foaf/0.1/surname" typeof="rdf:Property"> <h3>Property: foaf:surname</h3> <em>Surname</em> - The surname of some person. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >archaic</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://xmlns.com/foaf/0.1/Person"><a href="#term_Person">Person</a></span> </td></tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p>A number of naming constructs are under development to provide naming substructure; draft properties include <code><a href='#term_firstName'>firstName</a></code>, <code><a href='#term_givenName'>givenName</a></code>, and <code><a href='#term_surname'>surname</a></code>. These are not currently stable or consistent; see the <a href="http://wiki.foaf-project.org/w/IssueTracker">issue tracker</a> for design discussions, status and ongoing work on rationalising the FOAF naming machinery. </p> <p> There is also a simple <code><a href='#term_name'>name</a></code> property. </p> <p style="float: right; font-size: small;">[<a href="#term_surname">#</a>] <!-- surname surname --> [<a href="#glance">back to top</a>]</p> <br/> </div><div class="specterm propertyterm archaic " id="term_theme" about="http://xmlns.com/foaf/0.1/theme" typeof="rdf:Property"> <h3>Property: foaf:theme</h3> <em>theme</em> - A theme. <br /><table style="th { float: top; }"> <tr><th>Status:</th> <td><span property="vs:status" >archaic</span></td></tr> <tr><th>Domain:</th> <td>having this property implies being a <span rel="rdfs:domain" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td></tr> <tr><th>Range:</th> <td> every value of this property is a <span rel="rdfs:range" href="http://www.w3.org/2002/07/owl#Thing"><a href="#term_Thing">Thing</a></span> </td> </tr> <tr><td> <span rel="rdfs:isDefinedBy" href="http://xmlns.com/foaf/0.1/" /> </td></tr> </table> <p class="editorial"> This property is considered <em>archaic usage</em>, and is not currently recommended for usage. </p> <p> The <code><a href='#term_theme'>theme</a></code> property is rarely used and under-specified. The intention was to use it to characterise interest / themes associated with projects and groups. Further work is needed to meet these goals. </p> <p style="float: right; font-size: small;">[<a href="#term_theme">#</a>] <!-- theme theme --> [<a href="#glance">back to top</a>]</p> <br/> </div> </div> </div> <h2 id="sec-extrefs">External Vocabulary References</h2> <p> The description of the terms in the FOAF 'dictionary' often make reference to classes and properties elsewhere. This section of the FOAF specification provides a placeholder reference for any FOAF mention of externally defined terms. For example, sometimes we might say that FOAF property has a domain or range of an externally defined class, or that a FOAF class is a sub-class of an external class, or 'disjoint with' such a class (ie. has no common members). Such claims help fix the intended meaning of FOAF terms in relationship to other 'peer' vocabularies. </p> <h3 id="extns_status">Status Vocabulary</h3> <p> Each term in FOAF is annotated with properties from the <a href="http://www.w3.org/2003/06/sw-vocab-status/note">SemWeb Vocab Status Ontology</a> </p> <p> This was created as an experiment in documenting FOAF's term-centric versioning model, in which a common fixed namespace URI is used, while term definitions slowly and independently evolve through different stability levels. This contrasts with other approaches to versioning which attach versioning information to larger sets of terms. </p> <p> Note that this mechanism is itself somewhat experimental and evolvin. The definitions of 'stable', 'unstable', 'archaic' and 'testing' cannot be defined as global absolutes, but only in relationship to the practices, expectations and social structures around some vocabulary. For their use in FOAF, future versions of this specification could usefully offer more detail about what to expect from a term labelled 'stable'. </p> <dl> <dt>vs:term_status</dt> <dd>The vs:term_status property indicates the status of a vocabulary term, one of 'stable','unstable','testing' or 'archaic'. </dd> </dl> <div id="term_SpatialThing"/> <h3 id="extns_w3cbasicgeo">W3C Basic Geo (WGS84 lat/long) Vocabulary</h3> <p>Members of the FOAF and W3C Semantic Web Interest Group communities collaborated in 2003 to create a very simple vocabulary that described points in geographic space. This is the <a href="http://www.w3.org/2003/01/geo/">W3CBasic Geo Vocabulary</a>. It assumes use of the WGS84 reference system and defines properties geo:lat, geo:long and geo:alt in terms of a class geo:SpatialThing. </p> <p> The <a href="#term_based_near">foaf:based_near</a> property relates a spatial thing (typically a foaf:Agent of some kind) to another spatial thing, which can be described using geo:lat, geo:long etc. </p> <h3 id="extns_w3ccore">RDF Vocabulary Description - core concepts</h3> <p> The FOAF dictionary of terms is defined using a family of W3C standards: RDF, RDF Schema and OWL. These share a data model and general approach, and provide for increasing levels of expressivity. Here we introduce the core OWL and RDF/S terms used directly in the machine-readable description of FOAF. See <a href="http://www.w3.org/2001/sw/">W3C's site</a> for the latest and most authoritative OWL and RDF specifications. </p> <p> FOAF is based on the exchange of free-form descriptions that are structured in terms of things having properties, where the value of each property is expressed as either textually (eg. a name or number), or by reference to another thing. FOAF (as an application of RDF) uses URI identifiers wherever possible to talk about things of interest, whether they are Web pages, classes of thing, properties of things, or even people. See the W3C Web Architecture specification for <a href="http://www.w3.org/TR/webarch/#identification">more background on URIs</a>. </p> <p> From core RDF, FOAF takes the notion that we are talking about things, and they fall into categories; we call these 'classes'. The core machinery we use from the RDF Schema and OWL technologies simply give us some built-in terminology for talking about things, classes and properties. Here we introduce some of these and discuss briefly how they relate to FOAF's approach to describing things. </p> <dl> <dt id="term_Thing">owl:Thing</dt> <dd>OWL introduces the class 'Thing' as a name for the universal class of all things. This is sometimes useful when we want to express universality of property use, eg. that anything can be the value of <a href="#term_depicts">foaf:depicts</a>.</dd> <dt>rdf:Property</dt> <dd>RDF has a built-in class called rdf:Property. This is the class of all things like foaf:homepage or dc:creator which define named kinds of relationship between pairs of things, or between things and textually-expressed information.</dd> <dt>owl:DatatypeProperty</dt> <dd>The OWL specifications give a name for those properties whose values are textually-expressed: "DataTypeProperty". RDF allows these to be either plain literal values (these can also carry an indicator of their language, via xml:lang), or else "data-typed", which means they are marked with a URI indicating their type (but no language tagging).</dd> <dt>owl:ObjectProperty</dt> <dd>ObjectProperty is OWL's name for those properties which are not textually-expressed; instead, they are used when mentioning or referring to some other thing. OWL encourages vocabularies to avoid using a single named property in both 'ObjectProperty' and 'DataTypeProperty' styles. However earlier usage, notably in the Dublin Core community, does just this. Each FOAF property is either an Object Property or DataType Property. </dd> <dt>rdf:type</dt> <dd>One of the most commonly used built-in relationships in RDF is 'type'. RDF type relates something to a class that it is in.</dd> <dt>rdfs:subClassOf</dt> <dd>RDFS gives a name for the relationship between some specific class and its more general superclass: 'subClassOf'. It would have perhaps been simpler if this was called 'superProperty'. So for example we say that foaf:Person has an rdfs:subClassOf property whose value is foaf:Agent. </dd> <dt>rdfs:Class</dt> <dd>RDFS gives the name 'Class' to those things that represent classes of thing, ie. which are values of rdf:type for their members. The OWL language also (for technical reasons) defines owl:Class for essentially the same notion. OWL also includes powerful machinery for defining the membership rules for classes. This is not heavily used in FOAF, beyond the experimental mechanisms associated with foaf:Group. </dd> <dt>rdfs:subClassOf</dt> <dd>RDFS gives a name for the relationship between some particular class and its more general superclass: 'subClassOf'. It would have perhaps been simpler if this was called 'superProperty'. So for example we say that foaf:Person has a subPropertyOf property whose value is foaf:Agent. </dd> <dt>rdfs:subPropertyOf</dt> <dd>Similar to subClassOf but for hierarchies of properties, we can use rdfs:subPropertyOf to point to a more general super-property, for example we say foaf:aimChatID rdfs:subPropertyOf foaf:nick. </dd> <dt>rdfs:domain</dt> <dd>The RDFS specification introduced the notion of a property's domain. This is a way of saying, for some property, something about the kind of classes it is used with. If you know the domain or domains for some property, you know that whenever you see that property applied to something, then that thing ought to be a member of those classes. Note that this does not mean that every description using the property is compelled to mention all those classes, just that the meaning of the property implies also the type of the thing the property is applied to. </dd> <dt>rdfs:range</dt> <dd>RDFS also defines a property of properties called 'range'; this works just like rdfs:domain, except for the values of a property. If you know the range of some property, you know what kinds of thing are reasonable values for it. </dd> <dt>owl:FunctionalProperty</dt> <dd>OWL provides even more useful information about properties, such as the ability to say that a property is 'functional'. This means simply that for any particular thing, you can expect at most one value for that property. It is simplest to think of this as contextualised to any given time; although OWL doesn't talk about time explicitly. So we might say that 'age' is functional, even though a series of FOAF documents might be published, each truthfully giving different values for my 'age' which made sense in their original context. At the time of writing, the only W3C technology that can take a larger perspective on such different perspectives / views (or 'graphs') is SPARQL. If you have two different values for a given functional property, you know you have a problem; perhaps one is out-of-date, for example. Or perhaps they only differ in trivial detail (eg. date syntax, whitespace). </dd> <dt>owl:InverseFunctionalProperty</dt> <dd> OWL also gives a name for properties where common values tell us something about the identity of the thing having the property. On the Web this can be very useful. OWL tells us that two descriptions are of the same thing, if they include truthful mention of some 'inverse functional property' that has the same value. The classic FOAF example could be two mentions of a person having some particular foaf:homepage. This OWL construct is very useful for reasoning about identity and merging scattered and partial descriptions. </dd> <dt>owl:inverseOf</dt> <dd>OWL provides a property 'inverseOf' that holds between inverse properties; for example, any two things related by foaf:maker are related in the reverse direction by foaf:made.</dd> <dt>owl:disjointWith</dt> <dd>OWL also lets us indicate that two classes have no common members. This can be useful for clarifying modelling assumptions in a language-neutral manner; eg. we might ask whether anything can be both a foaf:Group and a foaf:Organization simultaneously. </dd> <dt>owl:sameAs</dt> <dd> OWL provides a term for talking about identity in the sense of "being one and the same thing as". Many FOAF constructs imply that two seemingly different things are in fact mentions of the self-same real world entity; this can be written out explicitly using owl:sameAs. For example, if two FOAF descriptions give URI identifiers http://example.com/foo#person1 and http://example.org/bar#person2 in two person-descriptions, but ascribe the same homepage URI, we can conclude that person1 is owl:sameAs person2 (and vice-versa). This construct provides a powerful mechanism for decentralised, <a href="http://www.w3.org/DesignIssues/LinkedData">linked data</a>. </dd> <dt id="term_Concept">skos:Concept</dt> <dd> W3C provides a rich framework for describing linked topics, <a href="http://www.w3.org/2004/02/skos/">SKOS</a>. FOAF defines a small extension to SKOS called <a href="#term_focus">foaf:focus</a> designed to link conceptualisations of entities to more linked data (eg. in FOAF) about the specific thing a SKOS "Concept" is about. 'Concept' is SKOS's fundamental class, and corresponds to abstractions common in library and cultural heritage information systems, including thesauri and subject indexing schemes. </dd> </dl> <h3 id="extns_dc">Dublin Core terms</h3> <p> The Dublin Core specification provides term definitions that focus on issues of resource discovery, document description and related concepts useful for cultural heritage and digital library applications. FOAF can be used alongside any variants of Dublin Core, but works most effectively with the most modern <a href="http://dublincore.org/documents/dcmi-terms/">Dublin Core terms</a> namespace. Note that here we use the prefix 'dct:' to stand for the DC Terms namespace; however it is not unusual to see 'dc' also used. </p> <dl> <dt> <a id="ext_dct_Agent" href="http://dublincore.org/documents/dcmi-terms/#classes-Agent">dct:Agent</a> </dt> <dd> Dublin Core's notion of Agent is much like FOAF's; Dublin Core says "A resource that acts or has the power to act.", we say "things that do stuff". As nobody has provided a counter-example of something fitting one definition but not the other, we say here that foaf:Agent stands in an 'equivalent class' relationship to dct:Agent (and vice-versa). </dd> <dt> <a id="ex_dct_creator" href="http://dublincore.org/documents/dcmi-terms/#terms-creator">dct:creator</a> </dt> <dd> The notion of 'creator' in the latest versions of Dublin Core matches FOAF's notion of 'maker'; based on their definitions, every pair of things that are related by one of those properties are also related by the other. We express this by saying that these properties stand in an 'equivalent property' relationship' to one another. </dd> </dl> <h3 id="extns_wn">Wordnet terms</h3> <p> Earlier versions of this specification used an experimental companion namespace produced from the lexical database Wordnet (v1.6). This is currently offline, and corresponding sub-class relationships have been ommited from the FOAF documentation. More <a href="http://www.w3.org/TR/wordnet-rdf/">recent</a> RDF representations of Wordnet now exist, however they don't map Wordnet synsets to classes, so can't be directly used here. Future versions of this specification might restore links to some version of Wordnet in RDF. </p> <h3 id="extns_sioc">SIOC terms</h3> <p> Many terms in the <a href="http://rdfs.org/sioc/ns#">SIOC</a> vocabulary are defined with reference to FOAF. See the <a href="http://www.sioc-project.org/">SIOC</a> project for details. Future versions of this specification may provide more information here. </p> <h3 id="sec-ack">Acknowledgments</h3> <p>There are far too many people who have contributed to the FOAF project to name everyone in this early-release of the new improved spec. FOAF wouldn't be such a fun project or be as widely known as it is today without the efforts, enthusiasm and intelligence of the folks who have contributed via the <a href= "http://rdfweb.org/pipermail/rdfweb-dev/">rdfweb-dev</a> list, <a href="http://rdfweb.org/irc/">#foaf</a> IRC channel, and wiki.</p> <p>That said, a few milestones in FOAF's history should be mentioned. We owe particular thanks to Edd Dumbill for his IBM developerWorks articles (which attracted the affections of the Weblogging crowd) and for his Foafbot application whose evolution those articles have tracked. Also Morten Frederiksen's <a href= "http://xml.mfd-consult.dk/foaf/explorer/">FoafExplorer</a>, Daniel Krech's <a href="http://eikeon.com/foaf/">Web View</a> aggregator, Jim Ley and Liz Turner's work on FOAFNaut, which alongside FOAFbot have been instrumental in showing how FOAF data can be collected and used. Meanwhile Leigh Dodd's <a href= "http://www.ldodds.com/foaf/foaf-a-matic.html">foaf-a-matic</a> has been the data creation tool that has been most people's gateway to FOAFdom. FOAF also owes a lot to the folks at <a href= "http://www.ecademy.com/">Ecademy</a>, <a href= "http://www.typepad.com/">TypePad</a> and elsewhere for showing how end users can share FOAF self-descriptions on the Web without ever seeing a line of XML syntax. Jo Walsh has enthused <a href= "http://conferences.oreillynet.com/cs/et2003/view/e_sess/3633">many</a> about hooking FOAF up to Geo and mapping data, as has Matt Biddulph by <a href="http://hackdiary.com/">explaining</a> the workings of his FOAF harvesting and image metadata tools. FOAF has also benefited greatly from documentation contributed in non-English languages, many thanks to all contributors of translations (foaf-a-matic and other docs). FOAF is now arguably better documented <a href= "http://kanzaki.com/docs/sw/foaf.html">in Japanese</a> and <a href= "http://f14web.com.ar/inkel/2003/01/27/foaf.html">Spanish</a> than in English, thanks to Masahide Kanzaki and Leandro Mariano Lopez (inkel) respectively. Thanks also to <a href= "http://crschmidt.net/">Chris Schmidt</a> for fixing up the <a href="../0.1/specgen.py">spec generation</a> tool (now a Python/Redland script), as well as for contributing numerous <a href="http://crschmidt.net/semweb/">cool hacks</a> to the FOAF community. To Richard Cyganiak and others in IRC for (amongst much else) help debugging Apache configurations. To Ian Davis for his wonderful <a href="http://iandavis.com/2006/foaf-icons/">FOAF Logo</a>. And last but not least, Marc Canter is in a class of his own. Thanks all, and to those who aren't listed here yet, but who made a difference... </p> <p>This brief survey only scratches the surface of a growing body of work. Sincere thanks to all who have contributed tools, documentation, brain cells and enthusiasm to this project. We should also mention that FOAF would not be possible without the collaborative and opensource efforts of the RDF developer community, both in terms of idea sharing (#swig etc) and freely available tools (Jena, Redland, RDFlib, Cwm, Sesame, 3store etc).</p> <p>Thanks also to TimBL, who dreamed most of this up <a href="http://www.w3.org/History/1989/proposal.html">years ago</a>, for seeing what "hypertext flexibility" could bring...</p> <h2 id="sec-changes">Recent Changes</h2> <h3 id="sec-changes20140114">Changes in version 0.99 (2014-01-14)</h3> <ul> <li>'Document' type status changed from 'testing' to 'stable'</li> <li>'Image' type status changed from 'testing' to 'stable'</li> <li>'weblog' property status changed from 'testing' to 'stable'</li> <li>'page' property status changed from 'testing' to 'stable'</li> <li>Expressed equivalence mappings from FOAF to <a href="http://schema.org/">schema.org</a>: <a href="http://schema.org/Person">Person</a>, Image (<a href="http://schema.org/ImageObject">ImageObject</a>), Document (<a href="http://schema.org/CreativeWork">CreativeWork</a>).</li> <li>Removed many links to the FOAF wiki, due to spam problems.</li> </ul> <h3 id="sec-changes20100809">2010-08-09</h3> <ul> <li>"The FOAF RDF namespace" clarified as "The FOAF RDF namespace URI".</li> <li>clarified that RDF/XML now available by conneg and direct link, but not embedded; and that inline RDFa is partial.</li> <li>swapped order of a couple of paragraphs from SOTD section; technical detail comes later now.</li> <li>added sepia (#5E2612) to style.css, for use as 'archaic' background color on old terms.</li> <li>added <a href="#term_focus">foaf:focus</a> "The <code>foaf:focus</code> property relates a conceptualisation of something to the thing itself." We stay quiet for now on whether it is functional, inverse functional, ...</li> <li>added mention of SKOS Concept to index.rdf and to the 'external vocabs' section of the HTML spec.</li> <li>added brief description of owl:sameAs to the 'external vocabs' section.</li> <li>created basic wiki Conneg page and linked from mention in spec of Content negotiation.</li> <li>Added explanatory text alongside 'domain' and 'range', inspired by, and borrowing from, the <a href="http://vocab.org/bio/0.1/.html">Bio vocabulary</a>.</li> <li>removed link to Jim Ley's old SVG image annotation demo, as it isn't maintained.</li> <li>moved large section on FOAF and RDF into the Wiki.</li> <li>fixed a mistaken reference to isPrimarySubjectOf (where '...topic' was intended).</li> <li><a href="#term_topic_interest">topic_interest</a>: removed placeholder health warning and added a simple definition</li> <li>index.rdf: From unstable to testing: <a href="#term_Project">Project</a> (we should review DOAP usage and data too), <a href="#term_OnlineAccount">OnlineAccount</a> (should we specify URI as profile page?), <a href="#term_based_near">based_near</a> (time to review AR/POI use cases?), <a href="#term_title">title</a> (vs. honorific prefix?), <a href="#term_skypeID">skypeID</a>, <a href="#term_lastName">lastName</a>, <a href="#term_openid">openid</a>, <a href="#term_account">account</a>, <a href="#term_accountServiceHomepage">accountServiceHomepage</a>, <a href="#term_accountName">accountName</a> (would simple 'name' work?), </li> <li>index.rdf: From unstable to archaic: <a href="#term_dna_checksum">dna_checksum</a> (joke isn't funny any more...) </li> <li>index.rdf: From testing to archaic: <a href="#term_surname">surname</a> (tidying clutter from the early days)</li> <li>index.rdf: From testing to stable: <a href="#term_primaryTopic">primaryTopic</a>/isPrimaryTopicOf, <a href="#term_knows">knows</a> (since these are widely used and definitions haven't changed or been contested)</li> <li>index.rdf: confirmed that <a href="#term_Image">Image</a> is a subClassOf <a href="#term_Document">Document</a></li> <li>index.rdf: removed some false disjointness claims: people can be documents (tatoos); agents can be documents (eg. java software agents)</li> <li>index.rdf: our local label for owl:Thing is now "Thing" not "a Thing" (largely a spec generation detail)</li> <li>index.rdf: broadened <a href="#term_topic_interest">foaf:topic_interest</a> and <a href="#term_interest">foaf:interest</a> to have domain of Agent rather than Person, allowing for collective (group, project, organization) interests.</li> <li>index.rdf: <a href="#term_logo">foaf:logo</a> is an Inverse Functional Property now</li> </ul> <h3>Changes from version <a href="http://xmlns.com/foaf/spec/20100101.html">0.97</a> and <a href="http://xmlns.com/foaf/spec/20091215.html">0.96</a></h3> <ul> <li><code><a href="#term_givenName">foaf:givenName</a></code> and <code><a href="#term_familyName">foaf:familyName</a></code> have been changed from <code><a href="#term_givenname">foaf:givenname</a></code> and <code><a href="#term_family_name">foaf:family_name</a></code> to make FOAF in line with usage of these terms in the <a href="http://portablecontacts.net/">Portable Contacts</a> format. The previous versions remain in the document, marked as 'archaic'.</li> <li>Two little-used and poorly defined properties have been marked as 'archaic': <code><a href="#term_fundedBy">foaf:fundedBy</a></code> and <code><a href="#term_theme">foaf:theme</a></code></li> <li><code><a href="#term_holdsAccount">foaf:holdsAccount</a></code> has been marked as 'archaic' in favour of <code><a href="#term_account">foaf:account</a></code></li> </ul> <h3 id="sec-changes20091215">2009-12-15</h3> <ul> <li>terms: foaf:Agent owl:equivalentClass with Dublin Core terms namespace 'Agent'; similarly foaf:maker and 'creator' from DC. These use the most modern http://purl.org/dc/terms/ namespace</li> <li>editorial: added note about the use of 'archaic'</li> <li>editorial: added a paragraph on changes in this version</li> <li>terms: family_name marked as archaic; replaced with familyName</li> <li>terms: marked fundedBy as archaic</li> <li>terms: marked givenname as archaic; replaced with givenName</li> <li>terms: marked holdAccount as archaic; replaced with account</li> <li>terms: changed myersBriggs from incorrect objectProperty to datatypeProperty</li> <li>terms: added openId into the rdf/xml version (it was present in the dated version but not in index.rdf)</li> <li>terms: marked theme as archaic</li> <li>editorial: fixed outdated references to RDF/XML</li> <li>editorial: updated acknowledgements</li> <li>terms: added text about terms used in foaf not in the foaf namespace</li> <li>editorial: fixed links and stray references to rdfweb-dev and #rdfig </li> <li>editorial: fixed rdfweb.org blog links (now pointing at archive.org where possible)</li> <li>editorial: fixed links to the wiki (stray /w/)</li> <li>editorial: fixed internal link to sec-glance</li> <li>editorial: fixed copyright date to 2009</li> </ul> <h3 id="sec-changes20071102">2007-11-02</h3> <ul> <li>terms: added <a href="#term_openid">foaf:openid</a></li> <li>editorial: updated links to the FOAF wiki</li> <li>editorial: spec now uses RDFa DTD declaration.</li> </ul> <h3 id="sec-changes20070524">2007-05-24</h3> <ul> <li>terms: Organization, Group, member, made, maker are now stable.</li> <li>editorial: Table of contents represents actual rather than desired structure. links fixed.</li> <li>process: Clarified that the specification version and URL are not 0.1; publishing at /foaf/spec</li> <li>editorial: Noted that the namespace URI will not change. Given the spec a version (0.9)</li> <li>editorial: CSS tweaks (grey boxes for terms), margins, justification</li> <li>editorial: Removed various TODOs and editorial comments</li> <li>editorial: Updated text for Organization to indicate relationship with Group</li> <li>web: Web server configuration now serves 303 redirects for terms, and RDF at the namespace URI if application/rdf+xml requested</li> <li>editorial: Updated mentions of rdfig to be swig, rdfweb-dev to be foaf-dev; fixed links accordingly</li> <li>editorial: Removed link to validator, since we have RDF inside and the dtd-based validator doesn't like mixed-namespace documents.</li> <li>web: created /foaf/spec for specification documents (and archive)</li> <li>editorial: Re-organized boilerplate section slightly (spec has url for current version).</li> <li>editorial: Updated per-term documentation to link to wiki issue tracker instead of the old bugzilla installation.</li> <li>editorial: Updated foaf:Group documentation to mention possiblility of SPARQL</li> <li>editorial: Updated foaf:name documentation to mention possibility of XMLLiteral datatyped values</li> <li>editorial: Fixed or removed various bad links (ichat, python, internal links)</li> <li>editorial: Reworded copyright statement to clarify intent; we used to say "and does not apply to FOAF data formats, vocabulary terms, or technology.", which gave impression we were holding stuff back. Rather, this is just our understanding of copyright. The underlying technology part is completely supplied by W3C's specifications.</li> <li>web: added "rel='alternate'" to document header to aid RDF discovery</li> </ul> </body> </html>

Pages: 1 2 3 4 5 6 7 8 9 10