This document presents several examples of the use of ODRL V2.2, describes good implementation practices and provides sample ODRL policies.

Introduction

Document Conventions

In order to read this document a basic knowledge of either RDF or JSON is supposed.

Within this document, the following namespace prefix bindings are used:

Prefix Namespace Description
odrl http://www.w3.org/ns/odrl/2/ ODRL Vocabulary
rdf http://www.w3.org/1999/02/22-rdf-syntax-ns# [[rdf11-concepts]]
rdfs http://www.w3.org/2000/01/rdf-schema# [[rdf-schema]]
owl http://www.w3.org/2002/07/owl# [[owl2-overview]]
xsd http://www.w3.org/2001/XMLSchema# [[xmlschema11-2]]
skos http://www.w3.org/2004/02/skos/core# [[skos-reference]]
dcterms http://purl.org/dc/terms/ [[dcterms]]
vcard http://www.w3.org/2006/vcard/ns# [[vcard-rdf]]
foaf http://xmlns.com/foaf/0.1/ [[foaf]]
schema http://schema.org/ schema.org
cc https://creativecommons.org/ns# creativecommons.org
ex http://example.com/ns#

Scenarios

ODRL is a structured language to express that something is permitted, forbidden or obliged, possibly limited by some constraints. ODRL is of particular interest for representing computer policies, licenses and any document where deontic modalities need to have a digital form. ODRL was specified considering 27 use cases, nonetheless a few examples of use follow.

Scenario 1: Representation of common licenses

The use of common licenses has become popular among those publishing software, data, photographs and other resources online. These text licenses describe under which conditions the resource can be used. Examples of licenses are the GNU General Public License, the Creative Commons CC-BY 4.0 license, or the UK Open Government License. The key information in these text documents (waived rights, constraints, prohibitions and obligations) can be represented in a structured language (they have been actually represented in RDF, for example see the latter). ODRL can also be used to describe the core information in the licenses. Having the licensing information in a digital form enables:

Scenario 2: Representation of access policies to digital resources

Computer policies govern the access to digital resources. Whereas ODRL provides no mechanism whatsoever to implement any access control logic, ODRL policies can describe how an external access control system should behave. Advantages of having an ODRL representation of access policies:

Scenario 3: Representation of rights in rules

Even if ODRL is not capable of accessing the subtleties of legislation, the actions that are forbidden in a certain sorts of noms can be represented in ODRL and act as a summary. See UC4. Advantages of an ODRL representation:

While ODRL can represent elements of a license or regulation for machine consumption, it cannot replace them in court! It is best practice to explicitly point to the license or regulation that a policy models using the dc:terms property provided by the Dublin Core Metadata Initiative.

Cookbook

Simple Permissions

How to represent a policy in JSON-LD

The following ODRL policy might be read as "Movie 9898 can be used".
Example 1
00  {
01	 "@context": "http://www.w3.org/ns/odrl.jsonld",
02	 "@type": "Set",
03	 "uid": "https://w3c.github.io/odrl/bp/examples/1",
04	 "permission": [{
05 		"target": "http://example.com/asset:9898.movie",
06 		"action": "use"
07	 }]
08  }		
		
Explanation line by line:

How to represent an ODRL policy with RDF Turtle

JSON-LD is only one of the possible serializations of ODRL a policy. The following example shows the same policy as in Example 1 but in RDF Turtle. An ODRL policy is an instance of the class odrl:Policy, which is defined in the ODRL Ontology. No knowledge on the ODRL Ontology is needed if you want to use ODRL.
Example 1 (turtle)
@prefix odrl: <http://www.w3.org/ns/odrl/2/>

<http://example.org/policy/1> a odrl:Policy, odrl:Set ;
  odrl:permission [
    odrl:target <https://w3c.github.io/odrl/bp/examples/1> ;
    odrl:assignee <http://example.com/party/Alice> ;
    odrl:action odrl:use
  ] ;
		

How to restrict the permission to a specified party

If the example above permitted the general use of Movie 9898, this permission permits only John to play the movie.
Example 2
{
 "@context": "http://www.w3.org/ns/odrl.jsonld",
 "@type": "Set",
 "uid": "https://w3c.github.io/odrl/bp/examples/2",
 "permission": [{
 	"target": "http://example.com/asset:9898.movie",
	"assignee": "John",
	"action": "play"
 }]
}		
		

How to restrict the validity of a permission to a specific location

Photographs are often licensed on a geographic basis: global rights will likely be more expensive than a country-specific permission. Such conditions are frequently modelled in ODRL by Constraints. The way of representing a geographic entity has not been standardized, though.

Example 3
{
 "@context": "http://www.w3.org/ns/odrl.jsonld",
 "@type": "Set",
 "uid": "https://w3c.github.io/odrl/bp/examples/3",
 "permission": [{
 	"target": "http://example.com/asset:9898.movie",
	"action": "display",
	"constraint": [{
           "leftOperand": "spatial",
           "operator": "eq",
           "rightOperand":  "https://www.wikidata.org/resource/Q183",
	         "dct:comment": "i.e Germany"
       }]
 }]
}		
		

How to restrict the validity of a permission to a specific time

Photographs for the news media can sometimes be "embargoed" - only publishable after a certain data. We can achieve this by putting a time-Constraint on the Permission.

The following permission can only be exercised after the turn of the New Year in 2019.

Example 4
{
 "@context": "http://www.w3.org/ns/odrl.jsonld",
 "@type": "Set",
 "uid": "https://w3c.github.io/odrl/bp/examples/4",
 "permission": [{
 	"target": "http://example.com/asset:9898.movie",
	"action": "display",
	"constraint": [{
           "leftOperand": "dateTime",
           "operator": "gte",
           "rightOperand":  { "@value": "2019-01-01", "@type": "xsd:date" }
       }]
 }]
}		
		

How to restrict the validity of a permission to both a location and a time

We can easily create a permission that only allows the picture to be displayed in Germany after 2018 by adding both Constraints. In this simple scenario, ODRL insists both Constraints are satisfied before the Permission becomes active.

Example 5
{
 "@context": "http://www.w3.org/ns/odrl.jsonld",
 "@type": "Set",
 "uid": "https://w3c.github.io/odrl/bp/examples/5",
 "permission": [{
 	"target": "http://example.com/asset:9898.movie",
	"action": "display",
	"constraint": [{
           "leftOperand": "dateTime",
           "operator": "gte",
           "rightOperand":  { "@value": "2019-01-01", "@type": "xsd:date" }
	   }, {
           "leftOperand": "spatial",
           "operator": "eq",
           "rightOperand":  "https://www.wikidata.org/resource/Q183",
	   "comment": "i.e Germany"
       }]
 }]
}		

How to narrow the applicability of an Action

The following Permission allows the distribution of a video but restricts the delivery channel to mobile networks only. This video cannot be distributed from a website under this Permission.

Example 6
{
    "@context": "http://www.w3.org/ns/odrl.jsonld",
    "@type": "Set",
    "uid": "https://w3c.github.io/odrl/bp/examples/6",
    "permission": [{
       "target": "http://example.com/asset:9898.movie",
       "assigner": "http://example.com/org:616",
       "action": [{
          "action": "distribute",
          "refinement": [{
             "leftOperand": "deliveryChannel",
             "operator": "eq",
             "rightOperand": "http://example.com/cv/audMedia/MOBILE"
          }]
      }]
   }]
}

Obligations and permissions

How to specify an obligation

This example shows how to oblige John to play the movie.
Example 7
{
 "@context": "http://www.w3.org/ns/odrl.jsonld",
 "@type": "Set",
 "uid": "https://w3c.github.io/odrl/bp/examples/7",
 "obligation": [{
	"target": "http://example.com/asset:9898.movie",
	"assignee": "John",
	"action": "play"
 }]
}		
		

How to represent a prohibition

This example shows how to prohibit John playing the movie.
Example 8
{
 "@context": "http://www.w3.org/ns/odrl.jsonld",
 "@type": "Set",
 "uid": "https://w3c.github.io/odrl/bp/examples/8",
 "prohibition": [{
	"target": "http://example.com/asset:9898.movie",
	"assignee": "John",
	"action": "play"
 }]
}		
		

How to represent a permission and a prohibition

An ODRL can represent one or more rules. For example, the following ODRL policy might be read as "Alice can use Asset 1, but Bob can't".
Example 9
{
	"@context": "http://www.w3.org/ns/odrl.jsonld",
	"@type": "Set",
	"uid": "http://example.org/policy/9",
	"permission": [{
		"target": "http://example.com/asset/1",
		"assignee": "http://example.com/party/Alice",
		"action": "use"
	}],
	"prohibition": [{
		"target": "http://example.com/asset/1",
		"assignee": "http://example.com/party/Bob",
		"action": "use"
	}]
}		

Practical questions

How to simplify policies with more than one rule

ODRL policies with more than one rule can be simplified (Section 2.7.1 in the Information Model). Elements common to every rule can be expressed at root level. Policies making use of this feature are called compact policies, an example of them follows.
Example 10
{
	"@context": "http://www.w3.org/ns/odrl.jsonld",
	"@type": "Set",
	"uid": "http://example.org/policy/10",
	"action": "use",
	"target": "http://example.com/asset/1",
	"permission": [{
		"assignee": "http://example.com/party/Alice",
	}],
	"prohibition": [{
		"assignee": "http://example.com/party/Bob",
	}]
}	
	

How to use the class hierarchy

Permitting (or prohibiting) some general actions entail permitting (or prohibiting) other specific actions. In the example below, permitting display is redundant because having permitted play also implies permitting display.
Example 11
{
	"@context": "http://www.w3.org/ns/odrl.jsonld",
	"@type": "Set",
	"uid": "http://example.org/policy/11",
	"permission": [{
		"assignee": "http://example.com/party/Alice",
		"action": [ "play", "display" ],
		"target": "http://example.com/asset/1"
	}]
}	
	
The figure represents these dependencies.
Actions in the ODRL Core Vocabulary (and how they are dependant) Also, one action in the profile may declare that some other actions are necessary for their execution (using :implies), hence if the former is permitted the latter cannot be prohibited. Although the actions in the ODRL Core Vocabulary do not have these implications, and although the actions in the ODRL Core Vocabulary are hardly dependent from each other, this may be of interest if you some day want to define your own actions.

How to connect an odrl:Agreement with an odrl:Offer and an odrl:Request

A party publishes an odrl:Offer policy for the target data http://example.com/asset:1 and a second party makes an odrl:Request to that asset. The parties reach an agreement which is recorded using an odrl:Agreement.

The dcterms:references property should be used to connect the agreement with the offer and the request that originated it.

Example 12
			ex:offer a odrl:Offer ;
				odrl:uid <http://example.com/offer:1> ;
				odrl:permission [
					odrl:target <http://example.com/asset:1> ;
					odrl:assigner <http://example.com/party:A> ;
					odrl:action odrl:use
				] .

			ex:request a odrl:Request ;
				odrl:uid <http://example.com/request:1> ;
				odrl:permission [
					odrl:target <http://example.com/asset:1> ;
					odrl:assignee <http://example.com/party:B> ;
					odrl:action odrl:use
				] .

			ex:agreement a odrl:Agreement ;
				dcterms:references ex:offer, ex:request ;
				odrl:uid <http://example.com/agreement:1> ;
				odrl:permission [
					odrl:target <http://example.com/asset:1> ;
					odrl:assigner <http://example.com/party:A> ;
					odrl:assignee <http://example.com/party:B> ;
					odrl:action odrl:use
				] .
		

How to use inferences

As per RDFS entailment rule rdfs2, the class of the policy resource odrl:Policy can be inferred, hence its specification is not necessary. As per the ODRL Information Model (2.1.1 Set Class), Set is the default type of policy, hence its specification is not necessary. The policy shown in Example 3 is also equivalent to the policies in Example 1 (odrl prefix declaration has also been removed for clarity).
Example 13
<http://example.org/policy/13> odrl:permission [
  odrl:target <http://example.com/asset:9898.movie> ;
  odrl:action odrl:use
] ;
	

How to use hasPolicy

Alternative forms for the same policy are also possible. For example, one might want to attribute a certain policy to a certain asset. As specified in the ODRL Information Model, the following code would be equivalent. The RDF triple in line 02 of Example 3b may be stored in a content repository, whereas lines 03 through 06 may be stored in a license repository.
Example 14
01 @prefix dct: <http://purl.org/dc/terms/> 
02 <http://example.com/asset:9898.movie> odrl:hasPolicy <http://example.org/policy/14> .
03 <http://example.org/policy/14> odrl:permission [
04   odrl:target <http://example.com/asset:9898.movie> ;
05   odrl:action odrl:use
06 ] ;
	

How to embed a policy within a license

Let us imagine there is a license already in RDF, but with no embedded policies (like DPLA's license). In this case, an odrl:permission is added, provided that the upper resource is made to be a odrl:Policy too.
Example 15
  <http://rightsstatements.org/rs/ic-edu> a dcterms:RightsStatement , odrl:Policy ;
    skos:prefLabel "In Copyright - Educational Use Only"@en ;
    skos:definition "This digital object is protected by copyright and/or related rights. For educational uses, no additional copyright permission is required from the copyright holder. Please refer to the Data Provider for additional information."@en ;
    dc:creator: "Digital Public Library of America and Europeana Rights Working Group" ;
    dcterms:hasVersion "1.0" ;
    dcterms:modified "2014-12-18" ;
    dc:identifier "ic-edu" ;
    skos:relatedMatch premiscopy:cpr ;
    odrl:permission [
           odrl:action odrl:use ;
           odrl:constraint [
             odrl:operator odrl:eq ;
             odrl:purpose <http://rightsstatements.org/purpose/education> # This would be preferably from an existing namespace, not ours.
           ]
    ] .
		

How to simplify policy management by implementing odrl:Policy also as odrl:Asset

At evaluation time, it is often useful to consider the policy as an asset, this allows to shortcut the evaluation of the policy (e.g. temporary disabling a policy when an event is triggered, shortening the evaluation path).
Example 16
			
ex:offer_example        terms:description "example of an offer"@en;
			a odrl:Offer,
			  odrl:Asset;
			odrl:conflict odrl:prohibit;
			odrl:prohibition ex:demo_prohibition;
			prov:version "0.1"@en.

ex:demo_prohibition     terms:description "example of a prohibition that targets a policy"@en;
			a odrl:Prohibition;
			odrl:action odrl:use;
			odrl:assigner ex:assigner;
// --- the constraint ellaborates on the conditions for the triggered			
			odrl:constraint ex:some_constraint; 
// --- here we target the policy			
			odrl:target ex:offer_example.          
			

How to keep the lifecycle of assets, policies and prices separate, decoupling using odrl:RightOperandReference

The lifecycle of assets, policies and duties are independent of each other, as such it is useful to implement the odrl:payAmout using an odrl:RightOperandReference
Example 17
			
ex:demo_duty               a odrl:Duty;
           terms:description "duty for use of a DPROD asset"@en;
                 odrl:action md:example_action;
               odrl:assigner ex:assigner;
                 odrl:target ex:data_product.                

md:example_action          a odrl:Action;  
                   rdf:value odrl:compensate;
             odrl:refinement ex:example_constraint.

ex:example_constraint      a odrl:Constraint;
            odrl:leftOperand odrl:payAmount;
               odrl:operator odrl:eq;
  odrl:rightOperandReference ex:example_roperand.

ex:example_roperand        a odrl:RightOperand;
// --- values point at respective URI's of an asset and a pricing list    			
                   rdf:value ex:data_product, ex:pricing_list.      			

ex:data_product            a dprod:DataProduct, odrl:Asset.

// --- the pricing list could be represented in many different ways:

// ----- using schema.org combined with DCAT (https://schema.org/UnitPriceSpecification)
ex:pricing_list            a dcat:Dataset;
          dcterms:conformsTo schema:priceSpecification.

// ----- as a DCAT dataset conforming to GoodRelations (http://purl.org/goodrelations/v1)
ex:pricing_list            a dcat:Dataset;
          dcterms:conformsTo gr:UnitPriceSpecification.
	   
// ----- as a DCAT dataset conforming to the product ontology  (http://www.productontology.org/doc/Price)
ex:pricing_list            a dcat:Dataset;
          dcterms:conformsTo pto:Price.

// ----- as a FIBO structured collection of prices
ex:pricing_list            a fibo-fnd-agr-agr:PriceSpecification.
   			

How to enhance consistency, simplify interoperability and improve evaluation efficiency on constraints and refinements

Where possible, it is recommended to develop or re-use glossaries and taxonomies, rather than open strings for right operands.
ISO3166-1 has the following structure (using Spain as an example):
					<pre id="eg2" class="hljs json" aria-busy="false" aria-live="polite">
					<owl:NamedIndividual rdf:about="&lcc-3166-1;Spain">
					   <rdf:type rdf:resource="&lcc-cr;Country"/>
					   <rdfs:label xml:lang="es">España</rdfs:label>
					   <skos:definition>the country of Spain</skos:definition>
					   <lcc-cr:isIndependent rdf:datatype="&xsd;boolean">true</lcc-cr:isIndependent>
					   <lcc-cr:hasNumericRegionCode rdf:datatype="&xsd;string">724</lcc-cr:hasNumericRegionCode>
					   <lcc-cr:hasEnglishFullName xml:lang="en">the Kingdom of Spain</lcc-cr:hasEnglishFullName>
					   <lcc-cr:hasFrenchFullName xml:lang="fr">le Royaume d'Espagne</lcc-cr:hasFrenchFullName>
					   <lcc-cr:hasEnglishShortName xml:lang="en">Spain</lcc-cr:hasEnglishShortName>
					   <lcc-cr:hasFrenchShortName xml:lang="fr">Espagne (l')</lcc-cr:hasFrenchShortName>
					   <lcc-cr:hasLocalShortName xml:lang="es">España</lcc-cr:hasLocalShortName>
					   <lcc-cr:hasEnglishShortNameInCapitals xml:lang="en">SPAIN</lcc-cr:hasEnglishShortNameInCapitals>
					   <lcc-cr:hasFrenchShortNameInCapitals xml:lang="fr">ESPAGNE</lcc-cr:hasFrenchShortNameInCapitals>
					   <lcc-cr:usesAdministrativeLanguage rdf:resource="&lcc-639-1;Spanish"/>
					   <lcc-cr:hasRemarks>Remark: In the autonomous communities of Galicia, Catalonia and the Balearics, the respective regional languages are the sole official languages of toponymy. Castilian language forms are given in square brackets for information. For the autonomous communities of Navarra, Valencia and the Basque Country, with the exception of the province names Bizkaia and Gipuzkoa, the regional language has co-official status with Castilian (regional language forms are marked with an asterisk).</lcc-cr:hasRemarks>
					   <lcc-cr:isClassifiedBy rdf:resource="&lcc-3166-1;Country"/>
					   <rdfs:isDefinedBy rdf:resource="&lcc-3166-1;"/>
					</owl:NamedIndividual>
					<owl:NamedIndividual rdf:about="&lcc-3166-1;ES">
					   <rdf:type rdf:resource="&lcc-cr;Alpha2Code"/>
					   <skos:definition>Alpha-2 country code for Spain</skos:definition>
					   <rdfs:label>ES</rdfs:label>
					   <lcc-lr:hasTag rdf:datatype="&xsd;string">ES</lcc-lr:hasTag>
					   <lcc-lr:denotes rdf:resource="&lcc-3166-1;Spain"/>
					   <lcc-lr:identifies rdf:resource="&lcc-3166-1;Spain"/>
					   <lcc-lr:isMemberOf rdf:resource="&lcc-3166-1;ISO3166-1-Alpha2-CodeSet"/>
					   <rdfs:isDefinedBy rdf:resource="&lcc-3166-1;"/>
					</owl:NamedIndividual>
					<owl:NamedIndividual rdf:about="&lcc-3166-1;ESP">
					   <rdf:type rdf:resource="&lcc-cr;Alpha3Code"/>
					   <skos:definition>Alpha-3 country code for Spain</skos:definition>
					   <rdfs:label>ESP</rdfs:label>
					   <lcc-lr:hasTag rdf:datatype="&xsd;string">ESP</lcc-lr:hasTag>
					   <lcc-lr:denotes rdf:resource="&lcc-3166-1;Spain"/>
					   <lcc-lr:identifies rdf:resource="&lcc-3166-1;Spain"/>
					   <lcc-lr:isMemberOf rdf:resource="&lcc-3166-1;ISO3166-1-Alpha3-CodeSet"/>
					   <rdfs:isDefinedBy rdf:resource="&lcc-3166-1;"/>
					</owl:NamedIndividual>
				   
Our policy can now leverage a refinement that contains a reusable element:
					   @prefix iso3166-1: <https://www.omg.org/spec/LCC/Countries/ISO3166-1-CountryCodes.rdf<.
		   
					   md:uri:some_example a odrl:Constraint;
										   odrl:leftOperand odrl:spatial;
										   odrl:operator odrl:isPartOf;
										   odrl:rightOperandReference md:uri:some_refnmte;
										   odrl:unit "iso3166-1".       # units can be a string
					   md:uri:some_refnmte a md:RightOperandReference;
										   rdf:value iso3166-1:ESP.     # the right operand now is linked data
				   

References

[CCREL]
Hal Abelson; Ben Adida; Mike Linksvayer; Nathan Yergler. W3C/Creative Commons. ccREL: The Creative Commons Rights Expression Language. 1 May 2008. W3C Member Submission. URL: http://www.w3.org/Submission/ccREL/
[FOAF]
Dan Brickley; Libby Miller. FOAF project. FOAF Vocabulary Specification 0.99 (Paddington Edition). 14 January 2014. URL: http://xmlns.com/foaf/spec/
[Turtle]
Eric Prud'hommeaux; Gavin Carothers. W3C. RDF 1.1 Turtle. 25 February 2014. W3C Recommendation. URL: https://www.w3.org/TR/turtle/

Acknowledgements

We would like to acknowledge the contributions to this document by the participants of the W3C POE WG and the W3C ODRL Community Group.