By: The OSLC Core Specification Workgroup
* See About the version number below for the reasoning behind the Version 2.0 designation
This is a DRAFT document that is under review. You can help by reviewing carefully, raising issues for discussion on the OSLC Core WG mailing list and document specific issues that need response on the issues page here OslcCoreV1Issues? .
The Open Services for Lifecycle Collaboration (OSLC) initiative is creating an family of web services specifications for products, services and other tools that support all phases of the software and product lifecycle. The purpose of these specifications is to enable integration between products that support Application Life-cycle Management (ALM) and Product Life-cycle Management (PLM). Each part of the lifecycle or domain has its own group and specification, for example there are Change Management, Quality Management, Estimation & Measurement and more. Each of the domain specifications are built upon this core specification.
This OSLC Core Specification sets out the common features that every OSLC Service can be expected to support using terminology from the World Wide Web Consortium (W3C). New terminology that we introduce can be found in the glossary section below. This specification is most about OSLC Services, it specifies what OSLC Services MUST, SHOULD and MAY do. It also contains some requirements for other OSLC specifications and for OSLC clients.
OSLC services are accessible via a Service Provider Resource that describes the Services offered. Each Service can provide Creation Factories for resource creation, Query Capabilities for resource query and Delegated UI Dialogs to enable clients to create and select resources via a web UI. Query Capabilities and Creation Factories may offer Resource Shapes that describe the properties of resources managed by the service. This is illustrated in the diagram below. See the section below on Service Provider Resources for further discussion of these concepts.
OSLC Core Specification concepts and relationships
This specification establishes terminology and rules for defining resources in terms of the property names and value-types that are allowed and required. OSLC domain specifications are expected to use these rules and terminologies to describe their resources. See the OSLC Defined Resources section for more on this topic.
This specification also sets out rules for creating resource representations in RDF/XML, JSON, Atom and Turtle formats. OSLC domain specifications are expected to refer to these rules when specifying how their resources are to be represented. See the OSLC Defined Resource Representations section for the representation rules and examples of each format.
About the version number. We use the version number "2.0" even though there has never been an OSLC Core Version 1.0 specification. We do this because this OSLC Core specification was written after a series of version 1.0 domain specifications were finalized by OSLC workgroups. The version 2.0 domain specifications will all be based on this Core specification and to avoid confusion this specification will also be known as Version 2.0.
About RDF. The resource and property-based data model used in OSLC resources is based on the Resource Description Framework (RDF) and OSLC requires RDF representations, but OSLC uses a small number of RDF concepts and does not require implementers to provide an RDF triple-store or a SPARQL query-engine.
The core philosophies of OSLC are to build on the powerful and scalable architecture of the World Wide Web and to do the simplest possible things that will work.
Build on the WWW. OSLC builds on the architecture of the WWW and follows the REST architectural pattern. This means that OSLC services provide a uniform HTTP interface, OSLC URIs are stable and opaque and, in simple terms, OSLC works like the web.
Keep things simple. Doing the simplest things that will possibly work means a couple of different things in regard to OSLC. It means starting with simple and existing concepts. For example, we model everything as resources with property values and do not stray from that model. Keeping things simple also means building on established and well-known specifications, but also carefully limiting the number of other specifications that we reference. This simplicity is intended to enable loose coupling and to make life easier for everybody: OSLC domain work groups, OSLC service implementers and OSLC client developers.
Accommodate different schemas. Because of the breadth of the OSLC domains, spanning lifecycle and platforms, OSLC has to work for systems with very different data schemas or no schemas at all. Flexibility is needed, but some OSLC Services must be able to offer resource shape information so that clients can learn what properties are allowed and required for resource creation, query and reporting.
Accommodate different representations. Different client platforms might require or at least prefer different representations. For example, in the browser a JSON or or Atom format representation might work best. OSLC Services will all support RDF/XML and may support other formats including JSON, Atom and Turtle.
This is a guide to some of the terminology used in this document. The following definitions are standard W3C concepts. OSLC uses these concepts without modification – their definitions are summarized here for the convenience of the reader. See http://www.w3c.org.
Here are the OSLC specific terms used in this specification:
The key words "MUST", "MUST NOT", "REQUIRED, SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY" and "OPTIONAL" in this document are to be interpreted as described in RFC2119.
An OSLC Resource is a resource managed by an OSLC Service. An OSLC Resource is typically something like a Change Request, a Requirement or some other ALM or PLM artifact or record, but an OSLC Resource could also be a video or a presentation file. This resource could be stored in a relational database, a flat-file on disk or a source code control system.
An OSLC Service can manage any type of resource and of any content type, but OSLC also defines a special set of resources. OSLC Defined Resources are specified in this document and can be specified in any OSLC specification. Resources are defined by the properties that are allowed and required in the resource.
OSLC uses a simple model of resources with property values and this model is intended to be consistent with the Resource Description Framework (RDF) data model (reference: RDF Concepts). OSLC also builds upon the Extensible Markup Language (XML) namespace mechanism (reference: XML Namespaces).
When specifying a resource or a property, OSLC Specifications define its type as a URI which can be decomposed into a namespace URI and a name. We abbreviate type URIs as Prefixed Names (reference: Prefixed Names), which are represented in XML as QNames. The namespace used for resources defined in this specification is defined as follows:
http://open-services.net/ns/core#
oslc
OSLC Specifications MUST provide the following information when defining an OSLC Defined Resource or Resource value-type:
http://open-services.net/ns/core#Service
.
Once a resource is defined, its allowed and required properties can be defined.
OSLC Specifications MAY provide a list of properties allowed and/or required for a particular operation on an OSLC Defined Resource. Specifications that do so SHOULD provide the following information for each property that they define.
oslc:ServiceProviderCatalog
(defined below in the Service Providers Section) defines a property named domain
with the URI of http://open-services.net/ns/core#domain
http://www.w3.org/2001/XMLSchema#boolean
, reference: XSD Datatypes).
http://www.w3.org/2001/XMLSchema#dateTime
, reference: XSD Datatypes).
http://www.w3.org/2001/XMLSchema#decimal
, reference: XSD Datatypes).
http://www.w3.org/2001/XMLSchema#double
, reference: XSD Datatypes).
http://www.w3.org/2001/XMLSchema#float
, reference: XSD Datatypes).
http://www.w3.org/2001/XMLSchema#integer
, reference: XSD Datatypes).
http://www.w3.org/2001/XMLSchema#string
, reference: XSD Datatypes).
http://www.w3.org/1999/02/22-rdf-syntax-ns#XMLLiteral
).
http://open-services.net/ns/core#Resource
).
http://open-services.net/ns/core#LocalResource
).
reference
, inline
or either
. Refer to the OSLC Representations section below to see how this is reflected in RDF/XML, JSON and other representations.
any
or as a list of one or more resource classes specified by Prefixed Name.
In the rest of this document we will define OSLC resources as described above. The below section titled OSLC Defined Resource Representations defines how OSLC resources are to be represented in RDF/XML, JSON and other formats.
OSLC Services that wish to provide the above information in a machine-readable format might consider using OSLC Resource Shapes, see Appendix A: Common Properties and Resources for more information.
For OSLC Defined Resources, clients should assume that an OSLC Service will discard unknown property values. An OSLC Service MAY discard property values in an OSLC Defined Resource that are not part of the resource's definition or the relevant Resource Shape.
The rule is different for clients. When doing an update, OSLC clients MUST preserve any unknown property-values and other content in OSLC Defined Resources.
OSLC Services use HTTP for operations on resources, that comply with the HTTP specification (reference: HTTP).
To create an OSLC Defined Resource, or any type of resource managed by a service, an OSLC client HTTP POSTs a representation of that resource to a Creation URI. See the section on Creation Factories for more information.
To delete an OSLC Defined Resource, or any type of resource managed by a service, a client performs an HTTP DELETE on the resource's URI.
To update an OSLC Resource in an OSLC Service, a client fetches a representation of that resource via HTTP GET. The client updates the representation and then uses HTTP PUT to send the new representation to the resource's URI.
It bears repeating that, when doing an update, OSLC clients MUST preserve any unknown property-values and other content in OSLC Defined Resources.
Because the update process involves first getting a resource, modifying it and then later putting it back to the server there is the possibility of a conflict. Some other client may have have updated the resource. To mitigate this problem, OSLC Services can use the HTTP If-Match
header:
If-Match
header is missing OSLC services MAY return HTTP Bad Request (400) status code to indicate that the header is required.
If-Match
header is present OSLC services will behave as described in the HTTP specification, returning an HTTP Precondition Failed (412) error to indicate that the header does not match.
If-Match
header is present and it matches, but there is some other problem or conflict with the update then OSLC services MAY return an HTTP Conflict (409) to indicate that problem.
OSLC Services MAY use other techniques for resource update such as OSLC Core Guidance: Partial Update.
OSLC services MAY support a technique called Resource Paging to enable clients to retrieve resources one page at a time.
When a client requests a resource, the client can expect that the entire resource will be returned in the response, with all property values. This can be problematic because, in some cases, resources may be so large that a client might not want to retrieve the entire resource in one HTTP response.
One solution for response size-sensitive Clients is to check size before loading. Clients that do not wish to load large resources can use the HTTP HEAD method to determine the size of a resource and, according to the rules of HTTP the server's SHOULD include an HTTP Content-Length header that indicates the size of the resource as the "decimal number of OCTETs." If the size is too large, a client can choose not to retrieve the resource.
Another solution is to use Resource Paging.
Here's how Resource Paging works. To get a paged version of a resource, a client adds the "key=value" pair oslc.paging=true
to the query component of the resource URI and the server MAY respond by returning a representation that contains partial information about the resource; only a subset of the resource's property values. When a page is returned it, and it is NOT the last page in the sequence, then it SHOULD include an oslc:ResponseInfo
(defined below), which that contains a resource-valued property oslc:nextPage
that links to a resource that represents the next page of property-values.
A client can also request paging by adding the "key=value" pair oslc.pageSize
to the query string component of the resource URI. By adding this, a client requests that the server respond with a specific number of property values. For example, oslc.pageSize=20
indicates to the server that the client would like 20 values per page. OSLC services MAY ignore oslc.pageSize
.
When Resource Paging is used, the values of a multi-valued property MAY be split across resource pages. Each property value MUST be represented in its entirety and not split across multiple partial resource pages.
Because HTTP is a stateless protocol and OSLC Services manage resources that can change frequently, OSLC clients SHOULD assume that resources can change as they page through them using the oslc:nextPage
mechanism.
Some OSLC Services might wish to guarantee stable paging, meaning that the chain of oslc:nextPage
links in a resource represent a snapshot in time and wil not change as the client pages through them. OSLC specification that require stable paging SHOULD state this requirement and specify to which resources it applies.
Note that because stable paging implementations are based on server-side state, it is possible that such state will expire. Implementations can use the HTTP Code 410 (Expired) to indicate to clients that the next-page link they requested has expired.
Resources returned via Resource Paging MUST include resource of type oslc:ResponseInfo
. A response info value describes information about the HTTP response body in which it appears. This specification defines its use for resource paging.
ResponseInfo
http://open-services.net/ns/core#ResponseInfo
Prefixed Name | Occurs | Read-only | Value-type | Represen-tation | Range | Description |
---|---|---|---|---|---|---|
dcterms:title |
zero-or-one | True | XML Literal | n/a | n/a | Title of the response |
dcterms:description |
zero-or-one | True | XML Literal | n/a | n/a | Description of response |
oslc:nextPage |
zero-or-one | True | Resource | Reference | unspecified | Link to next page of response |
oslc:totalCount |
zero-or-one | True | Integer | n/a | n/a | Total number of results across all pages, its value should be non-negative. |
Here's an example, using the OSLC Core RDF/XML representation rules, that illustrates how the oslc:ResponseInfo
resource is included.
Example: Resource Paging, partial response with response info resource
Example URI: http://example.com/blogs/entry/1?oslc.paging=true&pageno=2
<rdf:RDF xmlns:oslc_blog="http://open-services.net/ns/bogus/blogs#" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:foaf="http://http://xmlns.com/foaf/0.1/" xmlns:dcterms="http://purl.org/dc/terms/"> <oslc_blog:Entry rdf:about="http://example.com/blogs/entry/1"> <!-- partial property values of of the blog entry --> </oslc_blog:Entry> <oslc:ResponseInfo rdf:about="http://example.com/blogs/entry/1?oslc.paging=true&pageno=2"> <oslc:nextPage rdf:resource="http://example.com/blogs/entry/1?oslc.paging=true&pageno=3" /> </oslc:ResponseInfo> </rdf:RDF>
Refer to the OSLC Defined Resource Representation rules for an explanation of how the response info resource should be represented.
OSLC services MAY support a technique called Selective Properties to enable clients to retrieve only selected property values.
By adding the key=value pair oslc.properties
, specified below, to a resource URI, a client can request a new resource with a subset of the original resource's values. Here's how the selective properties values oslc.properties
and oslc.prefix
work.
The oslc.properties
key=value pair lets you specify the set of properties to match in a property tree pattern. Both immediate and nested properties may be specified. A nested property is a property that belongs to the resource referenced by another property. Nested properties are enclosed in brace brackets, and this nesting may be done recursively, i.e. a nested property may contain other nested properties.
For example, suppose we have a bug report resource at the following URL:
http://example.com/bugs/4242
Suppose this bug resource has properties such as dcterms:title
, dcterms:description
, and dcterms:creator
, and that dcterms:creator
refers to a person resource that has properties such as foaf:givenName
and foaf:familyName
. Suppose you want a representation of the bug report that includes its dcterms:title
and the foaf:givenName
and foaf:familyName
of the person refered to by its dcterms:creator
. The following URL illustrates the use of the oslc.properties
query value to include those properties:
http://example.com/bugs/4242?oslc.properties=dcterms:title,dcterms:creator{foaf:givenName,foaf:familyName}
Syntax
The oslc.properties
pair is defined by the oslc_properties
term in the following BNF grammar:
oslc_properties ::= "oslc.properties=" properties properties ::= property ("," property)* property ::= identifier | nested_prop | wildcard identifier ::= PrefixedName PrefixedName ::= /* see "SPARQL Query Lanaguage for RDF", http://www.w3.org/TR/rdf-sparql-query/#rPrefixedName */ nested_prop ::= property "{" properties "}" wildcard ::= "*"
In our examples of oslc.properties
, property names include a URI prefix, i.e. dcterms:
or foaf:
. An OSLC service SHOULD predefine URI prefixes for its properties. Here we assume that OSLC has predefined the Dublin Core ( dcterms:
) and Friend of a Friend ( foaf:
) prefixes. However, OSLC resources SHOULD also be open to new content, which means that new properties may not have predefined URI prefixes. We therefore need a way to define new URI prefixes in resource requests. The oslc.prefix
value lets you specify URI prefixes used in property names. For example, suppose the foaf:
prefix was not predefined. The following URL illustrates the use of the oslc.prefix
value to define it:
http://example.com/bugs/4242?oslc.prefix=foaf=<http://xmlns.com/foaf/0.1/>&oslc.properties=foaf:lastName,...
Syntax
The syntax of the oslc.prefix
is defined by the oslc_prefix
term in the following BNF grammar:
oslc_prefix ::= "oslc.prefix=" prefix_defs prefix_defs ::= prefix_def ("," prefix_def)* prefix_def ::= prefix "=" uri_ref_esc prefix ::= PN_PREFIX PN_PREFIX ::= /* see "SPARQL Query Lanaguage for RDF", http://www.w3.org/TR/rdf-sparql-query/#rPN_PREFIX */ uri_ref_esc ::= /* an angle bracket-delimited URI reference in which > and \ are \-escaped. */
OSLC domains specifications are strongly encouraged to use the common properties defined by this Core specification (See Appendix A for Common Properties) rather than defining new properties.
OSLC services are accessible via a Service Provider Resources that describes each service, which domain specifications the service implements as well as the creation, query and delegated UI capabilities of each service.
Additionally, a provider may offer a Service Provider Catalog that lists related Service Providers.
The conceptual model of Service Provider Catalog and Service Provider resources is simple. They are both resources with property values. The values allowed and required in each type of resource are defined below.
The diagram below illustrates the Service Provider Catalog and Service Provider concepts and relationships. As you can see there are two Resources defined: Service Provider Catalog and Service Provider. There are also a set of Local In-Line Resources that are used inside the Resources to define namespaces, OAuth configurations, contributors as well as services and their capabilities.
Next, we will formally define the Service Provider Catalog and Service Provider resources.
Service Provider Catalogs are used in the discovery of OSLC Service Providers, to simplify the configuration of tools that will integrate with providers of OSLC-defined services. These catalogs may contain contain other nested catalogs as well as service providers.
ServiceProviderCatalog
http://open-services.net/ns/core#ServiceProviderCatalog
Prefixed Name | Occurs | Read-only | Value-type | Represen-tation | Range | Description |
---|---|---|---|---|---|---|
dcterms:title |
zero-or-one | True | XMLLiteral | n/a | n/a | Title of the service provider catalog |
dcterms:description |
zero-or-one | True | XMLLiteral | n/a | n/a | Description of the service provider catalog |
dcterms:publisher |
zero-or-one | True | Local Resource | Inline | oslc:Publisher | Describes the software product that provides the implementation. |
oslc:domain |
zero-or-many | True | Resource | Reference | n/a | URI of the OSLC domain specification that may be implemented by referenced services |
oslc:serviceProvider |
zero-or-many | True | Resource | Either | oslc:ServiceProvider | A service offered by the service provider. |
oslc:serviceProviderCatalog |
zero-or-many | True | Resource | Either | oslc:ServiceProivderCatalog | Additional service provider catalog. |
oslc:oauthConfiguration |
zero-or-many | True | Local Resource | Inline | oslc:OAuthConfiguration | Defines the three OAuth URIs required for a client to act as an OAuth consumer. |
A Service Provider describes a set of services offered by an OSLC implementation.
ServiceProvider
http://open-services.net/ns/core#ServiceProvider
Prefixed Name | Occurs | Read-only | Value-type | Represen-tation | Range | Description |
---|---|---|---|---|---|---|
dcterms:title |
zero-or-one | True | XMLLiteral | n/a | n/a | Title of the service provider |
dcterms:description |
zero-or-one | True | XMLLiteral | n/a | n/a | Description of the service provider |
dcterms:publisher |
zero-or-one | True | Local Resource | Inline | oslc:Publisher | Describes the software product that provides the implementation. |
oslc:service |
one-or-many | True | Local Resource | Inline | oslc:Service | Describes a service offered by the service provider. |
oslc:details |
one-or-many | True | Resource | Reference | any | A URL that may be used to retrieve a web page to determine additional details about the service provider. |
oslc:prefixDefinition |
zero-or-more | True | Local Resource | Inline | oslc:PrefixDefinition | Defines a namespace prefix for use in JSON representations and in forming OSLC Query Syntax strings. |
oslc:oauthConfiguration |
zero-or-one | True | Local Resource | Inline | oslc:OAuthConfiguration | Defines the three OAuth URIs required for a client to act as an OAuth consumer. |
A Service describes the specific services offered by an implementation of an OSLC specification.
Service
http://open-services.net/ns/core#Service
Prefixed Name | Occurs | Read-only | Value-type | Represen-tation | Range | Description |
---|---|---|---|---|---|---|
oslc:domain |
exactly-one | True | Resource | n/a | Any | namespace URI of the OSLC domain specification that is implemented by this service. |
oslc:creationFactory |
zero-or-many | True | Local Resource | n/a | oslc:CreationFactory | enables clients to create new resources |
oslc:queryCapability |
zero-or-many | True | Local Resource | n/a | oslc:QueryCapability | enables clients query across a collection of resources |
oslc:selectionDialog |
zero-or-many | True | Local Resource | n/a | oslc:Dialog | enables clients to select a resource via UI |
oslc:creationDialog |
zero-or-many | True | Local Resource | n/a | oslc:Dialog | enables clients to create a resource via UI |
A Creation Factory describes a creation factory, capable of creating new resources via HTTP GET.
CreationFactory
http://open-services.net/ns/core#CreationFactory
Prefixed Name | Occurs | Read-only | Value-type | Represen-tation | Range | Description |
---|---|---|---|---|---|---|
dcterms:title |
exactly-one | True | XMLLiteral | n/a | n/a | title string that could be used for display |
oslc:label |
zero-or-one | True | String | n/a | n/a | very short label for use in menu items |
oslc:creation |
exactly-one | True | Resource | Reference | n/a | to create a new resource via the factory, post it to this URI |
oslc:resourceShape |
zero-or-many | True | Resource | Reference | oslc:ResourceShape |
a Creation Factory MAY provide Resource Shapes that describe shapes of resources that may be created. |
oslc:resourceType |
zero-or-more | True | anyURI | n/a | n/a | the expected resource type URI of the resource that will be created using this creation factory. These would be the URIs found in the result resource's rdf:type property. |
oslc:usage |
zero-or-more | True | String | n/a | n/a | an identifier for the domain specified usage of this creation factory. If a service provides multiple creation factories, it may designate the primary or default one that should be used with a property value of http://open-services/ns/core#default |
A Query Capability describes a query capability, capable of querying resources via HTTP GET or POST.
QueryCapability
http://open-services.net/ns/core#QueryCapability
Prefixed Name | Occurs | Read-only | Value-type | Represen-tation | Range | Description |
---|---|---|---|---|---|---|
dcterms:title |
exactly-one | True | XMLLiteral | n/a | n/a | title string that could be used for display |
oslc:label |
zero-or-one | True | String | n/a | n/a | very short label for use in menu items |
oslc:queryBase |
exactly-one | True | Resource | Reference | n/a | the base URI to use for queries. Queries may be invoked either by HTTP GET or HTTP POST. For HTTP GET, a query URI is formed by appending a key=value pair to the base URI. For HTTP POST, the query parameters are encoded as content with media type application/x-www-form-urlencoded and sent in the request body. The base URI MAY accept other query languages and media types in the request body, e.g. application/sparql-query for SPARQL queries. |
oslc:resourceShape |
zero-or-one | True | Resource | Reference | n/a | the Query Capability SHOULD provide a Resource Shape that describes the query base URI. |
oslc:resourceType |
zero-or-more | True | anyURI | n/a | n/a | the expected resource type URI that will be returned with this query capability. These would be the URIs found in the result resource's rdf:type property. |
oslc:usage |
zero-or-more | True | String | n/a | n/a | an identifier for the domain specified usage of this query capability. If a service provides multiple query capabilities, it may designate the primary or default one that should be used with a property value of http://open-services/ns/core#default |
A Dialog describes a delegated user interface (UI) which can be used to allow a user to interactively create a new resource or pick a resource.
Dialog
http://open-services.net/ns/core#Dialog
Prefixed Name | Occurs | Read-only | Value-type | Represen-tation | Range | Description |
---|---|---|---|---|---|---|
dcterms:title |
exactly-one | True | XMLLiteral | n/a | n/a | title string that could be used for display |
oslc:label |
zero-or-one | True | String | n/a | n/a | very short label for use in menu items |
oslc:dialog |
exactly-one | True | Resource | Reference | n/a | the URI of the dialog |
oslc:hintWidth |
zero-or-one | True | String | n/a | n/a | valid values for these attributes is defined by the CSS 2 height attribute (reference: CSS2) |
oslc:hintHeight |
zero-or-one | True | String | n/a | n/a | valid values for these attributes is defined by the CSS 2 height attribute (reference: CSS2) |
oslc:resourceType |
zero-or-more | True | anyURI | n/a | n/a | the expected resource type URI for the resources that will be returned when using this dialog. These would be the URIs found in the result resource's rdf:type property. |
oslc:usage |
zero-or-more | True | String | n/a | n/a | an identifier for the domain specified usage of this dialog. If a service provides multiple selection or creation dialogs, it may designate the primary or default one that should be used with a property value of http://open-services/ns/core#default |
A Publisher identifies and describes the software product that provides the OSLC implementation.
Publisher
http://open-services.net/ns/core#Publisher
Prefixed Name | Occurs | Read-only | Value-type | Represen-tation | Range | Description |
---|---|---|---|---|---|---|
dcterms:title |
exactly-one | True | XMLLiteral | n/a | n/a | title string that could be used for display |
oslc:label |
zero-or-one | True | String | n/a | n/a | very short label for use in menu items |
dcterms:identifier |
exactly-one | unspecified | String | n/a | n/a | A URN that uniquely identifies the implementation |
oslc:icon |
zero-or-one | True | Resource | reference | n/a | URL to an icon file that represents the provider. This icon should be a favicon format and 16x16 pixels in size |
Service Providers MUST provide a Prefix Definition for each prefix supported by the service. Each Prefix Definition defines a namespace prefix that clients MAY use in forming OSLC Query Syntax strings.
PrefixDefinition
http://open-services.net/ns/core#PrefixDefinition
Prefixed Name | Occurs | Read-only | Value-type | Represen-tation | Range | Description |
---|---|---|---|---|---|---|
oslc:prefix |
exactly-one | True | String | n/a | n/a | namespace prefix to be used for this namespace |
oslc:prefixBase |
exactly-one | True | String | n/a | n/a | the base URI of the namespace |
Service Providers that support OAuth Authentication SHOULD provide a way for clients to automatically discover the three OAuth URIs necessary to act as an OAuth Consumer.
OAuthConfiguration
http://open-services.net/ns/core#OAuthConfiguration
Prefixed Name | Occurs | Read-only | Value-type | Represen-tation | Range | Description |
---|---|---|---|---|---|---|
oslc:oauthRequestTokenURI |
exactly-one | True | Resource | Reference | n/a | URI for obtaining OAuth request token |
oslc:authorizationURI |
exactly-one | True | Resource | Reference | n/a | URI for obtaining OAuth authorization |
oslc:oauthAccessTokenURI |
exactly-one | True | Resource | Reference | n/a | URI for obtaining OAuth access token |
The next sections cover the Creation Factory and Query Capability in more detail.
An OSLC Service can provide one or more creation factory to enable the creation of new resources. A creation factory provides a Creation URI used to create new resources via HTTP POST and may also provide Resource Shapes that describe the types of resources that may be created. To create a new OSLC Resource, an OSLC client POSTs a representation of that resource to a Creation Factory's Creation URI.
To create an OSLC Defined Resource, an OSLC Client first forms an representation of that resource including the desired and required property values and following the rules set out in the OSLC Representation section below. A client can learn what properties are allowed in a new OSLC Defined Resource via the OSLC specification that defines or, in some cases via a Resource Shape resource. Next the client uses HTTP POST to post that representation to a Creation URI.
An OSLC Service may provide one or more Query Capabilities to enable query of resources. A Query Capability provides a base URI for forming Query Resource URIs and MAY provide Resource Shapes that describe the property values that may be expected in the resources that are queryable via the query capability. Thus, Query Capabilities provide a way to discover the resources managed by an OSLC Service.
In a Query Capability, the base URI, as defined by the oslc:queryBase
property, is itself a resource managed by the service and it acts as the starting subject resource for the queries based on it. Since the list may contains hundreds of thousands of members, queries are used to filter the list for members that satisfy certain conditions, e.g. the bugs that have high priority and were created this week.
To perform a query an OSLC client first creates a URI by starting with a Query Capability's base URI as a base and adding a URI Query String to express the query criteria. The OSLC client then uses HTTP GET to request a Query Resource representation of the query results. The Query Resource representation will contain property values about the query and a collection of resources that match the query criteria.
To perform an HTTP GET query, an OSLC client starts with the base URI as defined by the oslc:queryBase
property of a Query Capability, and appends to it query parameters in a syntax supported by the service. The resulting URI is the query URI. The OSLC client sends an HTTP GET request to the query URI, optionally specifying the preferred content media type for the query response in the HTTP Accept header. OSLC services MUST support query responses in RDF/XML format (media type application/rdf+xml
) and MAY support other formats. OSLC services SHOULD support the Query Syntax defined in this specification, but MAY support other syntaxes.
Alternatively, the client MAY encode the query parameters in the HTTP request body as media type application/x-www-form-urlencoded
, and send an HTTP POST request to the base URI. An OSLC service MAY support other query languages using other media types in the request body, e.g. SPARQL (media type application/sparql-query
).
A query URI can be formed by adding a query string to the end of the Query Capability's base URI (or by sending the query string in the request body when using HTTP POST). The syntax used to express the query criteria in that string is specified by each OSLC domain specification.
The OSLC Core Spec Query Specification document defines a standard set of OSLC query parameters that other OSLC domain specifications MAY use to query resources.
OSLC specifications target specific integration scenarios and in some cases, allowing one product to delegate to a user interface defined in another product is a more effective way to support a use case than an HTTP interface that can only be accessed programmatically. There are two cases where this is especially true:
To support these two cases, below we define OSLC Delegated User Interface (UI) Dialogs. Delegated UI Dialogs are a technique where one provider can embed a creation or selection UI into another using a combination of an HTML <iframe> and JavaScript code. The diagram below illustrates how delegated UI dialogs work in a scenario where Provider A wants to allow a user to select or create a resource managed by Provider B.
Next, the details of the Delegated UI Dialog protocol.
The following terms are used in discussions of Delegated UI Dialogs:
The next sections explain how Delegated UI Dialogs work.
To support the widest range of web browsers, we define two different protocols for communicating the information about the user's action from the UI Provider and back to the UI Consumer. These are the Post Message and Window Name protocols described below.
In both the Post Message and Window Name protocols, the way that a UI Consumer includes a Delegated UI Dialog in an HTML page is to create an iframe
and specify the src
as the URI of the Delegated UI Dialog to be included plus. The UI Consumer indicates the protocol to be used by appending one of the two fragment identifiers below to the URI:
#oslc-core-postMessage-1.0
- Indicates that the Post Message protocol is to be used
#oslc-core-windowName-1.0
- Indicates that the Window Name protocol is to be used
The JavaScript code example below shows now a UI Provider can determine which protocol is in use:
if (window.location.hash == '#oslc-core-windowName-1.0') { // Window Name protocol in use } else if (window.location.hash == '#oslc-core-postMessage-1.0') { // Post Message protocol in use }
Regardless of the protocol in effect, it is recommended that UI Consumers follow the below iframe creation guidelines to provide a more seamless user experience:
iframe
within a div
element, with height and width set to the values specified in the Service Resource that declares the Delegated UI Dialog. The iframe itself should be set to width and height of '100%.'
iframe
border size to '0'
iframe
scrolling to 'auto'
Next, the details for each of the two protocols.
The Post Message protocol relies on the HTML5 function window.postMessage()
(reference: HTML5), available in the latest or pending releases of most browsers. UI Consumers must anticipate other, unrelated uses of postMessage(), and should ignore messages not conforming to this protocol.
Typically, the embedded page will be loaded in a window inside another window, such as a iframe inside some surrounding webpage. In such cases, postMessage()
must be called on that parent window. But in a native application, an outer page is not needed and the embedded page may be shown directly in the browser's "root" window. When the embedded page has no parent window, it must call postMessage()
on its own window.
Here are the responsibilities of the UI Consumer and UI Provider in Post Message protocol.
postMessage()
to the page's parent window, passed in event.data
string, must be prefixed with "oslc-response:" See below for the two possible response formats, one for resource selection and one for creation.
The below JavaScript code example shows how a UI Provider page would send a response using postMessage()
and taking into account the fact that some pages are not parented.
function respondWithPostMessage(/*string*/ response) { (window.parent | window).postMessage("oslc-response:" + response, "*"); }
Now, the Window Name protocol.
The Window Name protocol uses the HTML DOM window.name
property to communicate the response (reference: Window Object) from the UI Provider to the UI Consumer. This special property of window maintains its value even as the window navigates to a different origin, but the ifame's window.name
can only be read when the accessing window shares the same origin. For this to happen, when the embedded page is finished it must set the window.name
and also change the window.location
to a page with the same origin as the outer frame. This not only allows the UI Consumer to access the result, but also fires an event telling the UI Consumer when to do so. This return location is passed to the embedded page using the window.name
property.
Here are the responsibilities of the UI Consumer and UI Provider in Window Name protocol.
window.name
to indicate the Return URL.
The following Javascript code illustrates the protocol. The code for the destroyFrame()
, handleMessage()
and displayFrame()
methods are not provided in this example, but should be obvious to a JavaScript developer. The UI Consumer must provide these methods.
function windowNameProtocol(/*string*/ dialogURI, onDataReceived) { // Step #1: create iframe for Delegated UI Dialog, // adding fragment to indicate the protocol var frame = doc.createElement('iframe'); frame.src= url + #oslc-core-postMessage-1.0'; // Step #2: set the iframe's window.name to indicate the Return URL frame.name = "http://localhost/blank.html"; // Step #3: listen for onload events on the iframe frame.onload = function() { try { // May throw an exception if the frame's location is still a different origin // Step #4: when frame's location is equal to the Return URL // then read response and return. if (frame.contentWindow.location == returnLocation) { var message = frame.contentWindow.name; destroyFrame(frame); handleMessage(message); } } catch(e) { // ignore: access exception when trying to access window name }; }; displayFrame(frame); }
As soon as the embedded page has loaded, perform the following:
The JavaScript example below shows how a UI Provider might notify its UI Consumer after a user has responded.
function respondWithWindowName(/*string*/ response) { // Step #2: read the return URL var returnURL = window.name; // Step #4: send the response via the window.name variable window.name = response; // Step #5: indicate that user has responded window.location = returnURL; }
Resource Selection can be used when a UI Consumer wants to allow a user to pick a resource that is managed by an OSLC Service. Using either the Post Message or Window Name protocols defined above, the UI Consumer uses an iframe to embed a selection dialog that is provided by the service, then awaits notification that the user has selected a resource.
To enable Resource Selection, an OSLC Service MUST provide in its Service Resource a value for the oslc:selectionDialog
property. The property value will include a oslc:dialogURI
property that indicates the URI of the selection dialog.
Regardless of how the response from the UI Provider is conveyed to the UI Consumer, the response SHOULD be formatted as follows:
results
http://open-services.net/ns/core#results
Prefixed Name | Occurs | Read-only | Value-type | Represen-tation | Range | Description |
---|---|---|---|---|---|---|
rdf:resource |
occurs | True | Resource | Reference | n/a | URI of the resource selected or created |
oslc:label |
occurs | True | String | n/a | n/a | Short label describing the resource selected |
An empty array indicates that the resource selector has been canceled
An example Resource Selection response:
{ "oslc:results" : [{ "oslc:label": "Bug 123: Server crash", "rdf:resource": "http://example.com/bug123" }, { "oslc:label": "Bug 456: Client hangs on startup", "rdf:resource": "http://example.com/bug456" } ] }
Resource Creation can be used when a UI Consumer wants to allow a user to create a new resource that is managed by an OSLC Service. Using either the Post Message or Window Name protocols defined above, the UI Consumer uses an iframe to embed a creation dialog that is provided by the service, then awaits notification that the user has created a resource.
To enable Resource Creation, an OSLC Service MUST provide in its Service Resource a value for the oslc:creationDialog
property. The property value will include a oslc:dialogURI
property that indicates the URI of the creation dialog.
Regardless of how the response from the UI Provider is conveyed to the UI Consumer, the response SHOULD be formatted as defined by oslc:results
Example:
{ "oslc:results" : [ { "oslc:label": "Bug 123: Server crash", "rdf:resource": "http://example.com/bug123" }, { "oslc:label": "Bug 456: Client hangs on startup", "rdf:resource": "http://example.com/bug456" } ] }
Service providers MAY support receiving a POST request whose content body is a change request resource definition to the {Creation Dialog URI} to retrieve a URI that represents the embedded page to be used. Service providers MUST respond with a response status of 201 (Created) with the response header Location
whose value is the URI to request the newly created form. Service providers MAY NOT maintain the created form in a persistent storage. Clients SHOULD expect that after some elapsed time, a GET on these transient response URIs MAY result with response status codes of 404 (Not found) or a 3xx (Redirect).
That brings us to the end of the Delegated UI section. Next up: Authentication.
OSLC Services use standard web protocols for authentication. OSLC Services can use HTTP Basic Authentication, OAuth or both.
OSLC Services MAY protect resources with HTTP Basic Authentication. OSLC Services that use HTTP Basic Authentication SHOULD do so only via SSL.
OSLC Services MAY protected resources with OAuth Authentication.
OSLC Services MAY use other authentication mechanisms, including those common described as Form Based Authentication. OSLC Services that choose to use other authentication mechanisms are responsible for specifying how those mechanisms work.
OSLC Services the standard mechanisms of HTTP to report status and error codes to clients. When an error occurs and useful information can be provided to clients OSLC Services SHOULD return error information in the body of the response.
OSLC Services SHOULD use the Error resource defined below as the basis for forming error responses. OSLC Services SHOULD return an Error resource using the same representation requested by the client via the HTTP Accept header.
The following OSLC Defined Resource can be used as the basis for forming an error response.
Error
http://open-services.net/ns/core#Error
Prefixed Name | Occurs | Read-only | Value-type | Represen-tation | Range | Description |
---|---|---|---|---|---|---|
oslc:statusCode |
exactly-one | True | String | n/a | n/a | the HTTP status code reported with the error. |
oslc:message |
exactly-one | True | String | n/a | n/a | an informative message describing the error that occurred. |
oslc:exendedError |
zero-or-one | True | Either | Either | oslc:ExtendedError |
Extended error information |
ExendedError
http://open-services.net/ns/core#ExtendedError
Prefixed Name | Occurs | Read-only | Value-type | Represen-tation | Range | Description |
---|---|---|---|---|---|---|
oslc:moreInfo |
zero-or-one | True | Resource | Reference | Any | a resource giving more information on the error SHOULD be of an HTML content-type. |
oslc:rel |
zero-or-one | True | String | n/a | n/a | if present and set to 'alternate' then indicates that work-around is provided, behavior for other values is undefined. |
oslc:hintWidth |
zero-or-one | True | String | n/a | n/a | valid values for these attributes is defined by the CSS 2 width attribute (reference: CSS2)be specified by OSLC Service. |
oslc:hintHeight |
zero-or-one | True | String | n/a | n/a | valid values for these attributes is defined by the CSS 2 width attribute (reference: CSS2)be specified by OSLC Service. |
One of the goals of the OSLC initiative is to mitigate or eliminate the need for lock-step version upgrades, where clients or services target one version of a specification and break when new versions are introduced -- requiring all services to be upgraded simultaneously.
In this section we specify a version header that will enable old "Version 1" OSLC clients to continue to work and share the same resource URIs as used by clients that specifically target the Core. And we establish rules that will enable clients to continue to work as new versions of specifications are introduced.
We anticipate that the OSLC Core and domain specifications will each be versioned independently and each version will be assigned a version number, but we would like to avoid exposing version numbers in OSLC implementations. There is one use case that requires version information to be exposed. We must ensure that old OSLC "Version 1" clients continue to work.
To enable OSLC Service specifications to evolve without breaking existing clients, we introduce an HTTP Header, OSLC-Core-Version
set to the Core specification version number "2.0"
. We expect clients that target the Core to send this HTTP header.
OSLC-Core-Version
header is present and set to a version that the service can support, then the service MUST return a representation that is complies with the specified version.
OSLC-Core-Version
header is present and indicates a specification version that the service cannot support, the service SHOULD respond with what it determines is the most compatible version that it can return.
OSLC-Core-Version
header is not present then the OSLC Service SHOULD respond by returning a resource that conforms to the earliest or most compatible (as determined by the implementation) specification version's representation. Services that never offered an OSLC Version 1 interface can ignore this restriction.
OSLC-Core-Version
header set to the Core specification with which the representation complies.
When specifying a new version of an OSLC specification the rule is this:
A new version of an OSLC specification is not allowed to introduce changes that will break old clients.
Here are some guidelines for OSLC workgroups defining new specifications or upgrades to existing ones:
Most of the first OSLC specifications were developed before this Core specification existed and do not implement versioning as described above and so must use some other mechanism to migrate to the OSLC Core v1.0 specification.
OSLC implementations that wish to continue to support old pre-Core OSLC or OSLC v1.0 specifications can do so by keeping the old implementation in place and adding the new OSLC Core v1 implementation with different service provider, query capability and creation factory URIs.
This section specifies how representations of OSLC Defined Resources are created. The rules in this section apply to all of the resources defined in this specification and can be used in other OSLC specifications.
To encourage interoperability across OSLC domains and implementations, OSLC requires that services provide an RDF/XML representation. Services can also choose to provide additional representations: HTML, Turtle, JSON or Atom.
Note that existing standard content-types are used, e.g. application/rdf+xml
and application/json
, in this document and no new content-types are introduced. Those writing OSLC specifications are strongly encouraged to follow this pattern -- use standard and existing content-types and avoid inventing new content-types for existing formats.
In past OSLC specifications we defined a specific RDF/XML format for each resource defined and gave each its own content-type. This implied to consumers that each resource had a different format when in reality they were all standard RDF/XML. Using different content-types makes it more difficult to write generic tools, crawlers and other services that work across all data.
This specification defines how OSLC property values are to be represented in a variety of formats. Except in the case of a sorted Query Response, the ordering of property values is insignificant. OSLC clients and service providers MUST not place any significance on the ordering of property values in representations.
OSLC representations MUST use absolute URIs in all cases except XML representations, where the xml:base
attribute may be used to allow relative URIs to be resolved to absolute form (reference: XML Base).
Before a resource representation that uses xml:base is posted to an OSLC Service for creation, it may include relative URIs that cannot be resolved until the OSLC Service has received, created and assigned a URI to the new resource.
An OSLC Service MUST provide and accept RDF/XML representations of all OSLC Defined Resources and according to the rules below (reference: RDF/XML Syntax).
The primary mechanisms to create strong support for the software development life-cycle are integration of information across all the activities of the life-cycle, support for the processes that control the ways in which people modify that information, and automation of repetitive tasks. To be able to integrate information across the life-cycle, Products that implement part of the life-cycle must expose data in ways that other tools can understand. Those other tools may implement other parts of the life-cycle or may be separate analysis tools that support querying, reporting, trend analysis etc.
Some resource formats are easier than others for representing data. XML is a popular and flexible format for representing data, but it has some important disadvantages. There are many different patterns for encoding data in XML and a client cannot "find" the data within an XML format without knowing what patterns have been used. XML Schema is popular for describing the "shape" of XML, but unfortunately, XML Schema does not help you locate the data within the XML, it just constrains the overall XML. There is no standard for locating data in XML - people often use their own conventions built on XPath to describe how to locate the data within XML documents, but there is no standard for how to organize all those XPath expressions.
JSON has some significant advantages over XML in this regard. JSON allows any client to recover the property names and values without the need for prior understanding of a data schema or representation format. JSON also has the advantage of being extremely popular with JavaScript? programmers and is well supported by a range of programming languages, not just JavaScript? . However, JSON has a few deficiencies for the purposes of OSLC. JSON has no schema language equivalent to XML Schema to validate content. JSON does not support namespaces. And while JSON is very good at describing a single data structure, it's not so effective at representing facts about multiple web resources in a single message.
There are two representation technologies that are part of the RDF family of technologies that have the positive characteristics of JSON without the limitations - RDF-XML and Turtle. One of those, RDF-XML, is based on XML. Because RDF-XML prescribes the patterns for encoding data in XML, you can extract data from RDF-XML without the need for extra information about the representation, just as you can with JSON. Because RDF-XML and Turtle are both based on RDF, they support namespaces and can represent facts about many different resources. Turtle has the advantage of being simple and elegant, like JSON - it is like a JSON that is better integrated with the world-wide web. RDF-XML has the characteristic of being based on XML which many people see as an advantage. Both of these technologies have the disadvantage of being much less well-known and broadly supported than JSON.
After much debate, we have selected RDF-XML as the format to mandate to ensure that all OSLC resources are represented in a way that allows an external client to always be able to extract the data without extensive prior knowledge of the representation format. Although RDF-XML lacks the simplicity, elegance and popularity of JSON, it integrated much better with the WWW and it aligns with XML. Turtle has all the positive aspects of an RDF foundation with the elegance and simplicity of JSON, but lacks the alignment with XML that many find important. The choice between Turtle and RDF-XML comes down to a trade-off of simplicity and elegance against XML alignment. The choice between JSON and the RDF technologies comes down to a trade-off between popularity and better integration with the web. "Raw" XML does not come close enough to meeting requirements to be a candidate.
An OSLC service MUST provide RDF/XML representations of all OSLC Defined Resources. For each resource, an OSLC service may offer either an abbreviated RDF/XML subset that is XML-tool friendly, a full RDF/XML or both forms according to these rules:
application/rdf+xml
, then the client MUST accept any valid RDF/XML and the server MAY return either full RDF-XML or Abbreviated RDF/XML as defined below.
application/xml
, then the server MUST return XML and MAY return abbreviated RDF/XML as defined below.
application/xml
and the server only provides full RDF/XML then the server SHOULD return an HTTP status of 406 (Not Acceptable).
OSLC services MAY accept and return resources using a subset of RDF/XML. To understand how to form an Abbreviated RDF/XML representation, implementors can refer to the step-by-step guide below. Additionally, as we explain further below, it is possible to configure some RDF/XML toolkits so that they will generate this abbreviated form of RDF/XML.
RDF/XML defines an extensive set of XML elements and attributes for representing an RDF data model. RDF/XML provides a lot of flexibility and if we allowed each OSLC workgroup to decide now to serialize OSLC resources to and from RDF/XML, we would require each workgroup to master RDF-XML, we would end-up with different serializations for each domain, the XML produced would not be XML-tool friendly and in the end interoperability would suffer.
To ensure that the RDF/XML produced by OSLC services is uniform, easy to understand and as simple as possible, we define a set of step-by-step rules for generating the RDF/XML. We use a very limited set of RDF elements and attributes, the rdf:type
element and attributes rdf:about
, rdf:resource= and =rdf:nodeID
. Below are the rules.
Use these rules to form an RDF/XML representation of an OSLC Defined Resource.
<rdf:RDF>
and include all required namespace declarations
rdf:about
attribute set to the URI of the resource
<oslc:ResponseInfo>
oslc:ResponseInfo
resource (using the property rules below) oslc:nextPage
property-value MUST point to the next page.
</oslc:ResponseInfo>
</rdf:RDF>
These are the property rules referred to above. OSLC property values are represented as XML elements with QNames formed using the Resource's QName namespace prefix and name.
rdf:resource
attribute set to URI
rdf:nodeID
attribute set to local ID of the resource referred to
rdf:about
attribute set to URI of resource
rdf:nodeID
set to the local ID you wish to assign to the resource. Only needed when Local Resource needs to refer to this resource.
Another way to form an Abbreviated RDF/XML representation is to use the Jena RDF toolkit and to programmatically configure it to use the RDF/XML-ABBREV writer and to use all of the OSLC recommended namespace prefixes.
OSLC services MAY offer full RDF/XML representations of resources.
Though the OSLC specifications often refers to resources, properties and values rather than RDF subjects, predicates and objects, the OSLC data model is the RDF data model [reference: RDF/XML concepts]. To form an RDF/XML representation of an OSLC resource, you represent its RDF triples and statements in XML according to the rules of RDF/XML. To understand how to form a full RDF/XML representation, implementors should refer to the RDF/XML specification for guidance [reference: RDF/XML Syntax].
An OSLC Service MAY provide and accept JSON representations of some OSLC Defined Resources. OSLC Services that provide JSON presentations MUST respond to HTTP requests that request application/json
with a JSON representation as specified below. OSLC Services that provide JSON presentations of OSLC Defined Resources MUST return them with content-type application/json
.
Note that JSON representations MUST use the namespace prefix names that are defined by the Service Provider that provides them.
Use these rules to form an JSON representation of an OSLC Defined Resource.
oslc:qname
set to the Prefixed Name of the resource
rdf:about
set to the URI of the resource
prefixes
set to a JSON object with one field per prefix used in the file, the field value should be the prefix base that corresponds to the prefix.
oslc:responseInfo
with value-type oslc:ResponseInfo
oslc:nextPage
property-value MUST point to the next page.
These are the property rules referred to above. For each property:
rdf:resource
set to URI of resource
rdf:nodeID
set to local ID of resource
rdf:about
set to URI of resource whose values are being inlined
rdf:nodeID
set to local ID you wish to assign to this resource. Only needed when Local Resource needs to refer to this resource.
An OSLC Service MAY provide and understand Turtle representations of some OSLC Defined Resources and according to the rules below.
application/x-turtle
application/x-turtle
We do not provide rules for generating Turtle, but we do recommend that implementors look to the constraints that we have placed on RDF/XML representations. Similar constraints could be beneficial to interoperability with Turtle is used.
An OSLC Service MAY provide and accept Atom Syndication Format representations of OSLC Defined Resources and according to the rules below (reference: Atom Format).
Note that there are special rules below for creating an OSLC Query Resource representation in Atom format.
When a client requests an Atom representation of an OSLC Defined Resource and specifies via HTTP Accept header content-type application/atom+xml
or application/atom+xml;type=entry
then an OSLC Service SHOULD respond with an Atom representation.
To represent an OSLC Defined Resource in Atom format we use an Atom <entry>
element as document root, we map some OSLC properties to Atom elements and inside the Atom <content>
element, we place an RDF/XML representation (as defined above) of the resource that we are representing. Atom representations MUST comply with the rules of Atom Syndication Format (reference: Atom format).
<entry>
element <id>
element. Atom requires a unique ID here and in the form of a URN, the resource URI MAY be used here.
<title>
element. Atom requires a non-empty title value. A dcterms:title
value MAY be used here.
<updated>
element. Atom requires an updated date-time value. In cases where an updated-time value is difficult or expensive to compute, OSLC domain specifications might wish to declare this value to be insignificant.
<content>
element. Atom representations MUST provide a content element that contains an RDF/XML of the resource being represented.
<author>
element. Atom requires an author element.
<entry>
element
When a client requests an Atom representation of an OSLC Defined Resource and specifies via HTTP Accept header content-type application/atom+xml
or then an OSLC Service SHOULD respond with an Atom representation as described below.
To represent an OSLC Query Resource in Atom format we use an Atom <feed>
element as document root, add the required properties and then represent each resource returned in the query response as an Atom <entry>
element.
<feed>
element atom:id
Must be a unique URN. The query resource URI may be used (i.e. same as oslc:ResponseInfo
value for oslc:self
)
atom:title
With same value as the query's oslc:ResponseInfo
value for dcterms:title
atom:updated
Set to time that query result was generated
atom:author
This element is not meaningful but Atom requires it, so provide only a dummy value.
atom:summary
Set to oslc:ResponseInfo
value for dcterms:description
atom:link
With rel="self" set to same value as the query's oslc:ResponseInfo
value for oslc:self
atom:link
With rel="next" set to same value as the query's oslc:ResponseInfo
value for oslc:nextPage
<entry>
element
atom:id
Must be a unique URN. The member value's URI may be used.
atom:title
If the member value has a dcterms:title
value, then use that. Otherwise provide a non-empty string with only a dummy value.
atom:updated
If the member value has a dcterms:modified
value then use that. Otherwise use same value used at feed level.
atom:author
If the member value provides dcterms:creator
values, then each should be represented as an atom:author
element.
atom:content
element. atom:content
element's src
attribute to the URI of the member value
atom:content
element's type
attribute to application/rdf+xml
rdf:about
attribute of the root element to the URI of the query base URI of the query.
</entry>
element
</feed>
element
See separate page OSLC Core Spec Appendix A DRAFT
See separate page OSLC Core Spec Appendix B DRAFT
See separate page OSLC Core Spec Appendix C DRAFT
See separate page OSLC Core Spec Appendix D DRAFT
See separate page OSLC Core Spec Appendix E DRAFT
These are the specifications referenced by the OSLC Core Specification.
I | Attachment | Action | Size | Date | Who | Comment |
---|---|---|---|---|---|---|
![]() |
blog-comment-rdf.xml | manage | 0.7 K | 06 May 2010 - 15:31 | DaveJohnson | |
![]() |
blog-comment-shape-rdf.xml | manage | 2.5 K | 06 May 2010 - 16:14 | DaveJohnson | |
![]() |
blog-entry-rdf.xml | manage | 0.9 K | 05 May 2010 - 19:19 | DaveJohnson | |
![]() |
oslc-core-overview.png | manage | 56.2 K | 02 Jun 2010 - 01:44 | DaveJohnson | |
![]() |
oslc-core-provider.png | manage | 95.4 K | 20 Jul 2010 - 15:51 | DaveJohnson | many corrections to properties |
![]() |
oslc-core-shapes.png | manage | 48.1 K | 25 May 2010 - 18:59 | DaveJohnson | |
![]() |
oslc-delegated.png | manage | 86.1 K | 04 May 2010 - 14:44 | DaveJohnson | |
![]() |
query-result-rdf.xml | manage | 1.1 K | 06 May 2010 - 16:12 | DaveJohnson | |
![]() |
query-shape-rdf.xml | manage | 2.3 K | 06 May 2010 - 16:12 | DaveJohnson | |
![]() |
service-provider-rdf.xml | manage | 2.8 K | 06 May 2010 - 16:12 | DaveJohnson |