Constraining Resource Access To Group Members
The following example demonstrates how you can leverage the combined power of a SPARQL ASK Query and Web-accessible Linked Data en route to constraining access to a protected resource.
Basically, you put two resource to use:
- A protected resource accessible from a location on the Web via its URL .
- A read-only resource accessible from a location on the Web that describes a Group and its Membership.
Prerequisites
The following packages should be installed, prior to performing this exercise:
1. Describe your group and it membership via a Turtle document, for instance (you can user other RDF model syntaxes, but we choose use Turtle for its simplicity)
- Group Description using terms from the FOAF & RDFS vocabularies :
@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> .
@prefix foaf: <http://xmlns.com/foaf/0.1/> .
@prefix : <#> .
<> foaf:topic :Group .
<> rdfs:label "Social Semantics & ACLs Demo" .
<> rdfs:comment "Members of this group provide the basis for a Resource Access Policy scoped to this group." .
:Group a foaf:Group .
:Group foaf:member <http://id.myopenlink.net/dataspace/person/kate#this> ,
<http://id.myopenlink.net/dataspace/person/john#this> .
- The document content above implies that <http://web.ods.openlinksw.com/DAV/home/demo/Public/group.ttl#Groupgt; denotes the Group.
2. Create a Web document comprised of content that describes the group
Publish the Turtle Document to a Web accessible location, using ODS-Briefcase, as follows:
- Log in at http://web.ods.openlinksw.com/ods ->Sign In and enter user's credentials:
data:image/s3,"s3://crabby-images/b76a2/b76a2c52ee1424da30d4f934b33bd18933aed746" alt=""
- Go to Briefcase and navigate for to its Public folder:
data:image/s3,"s3://crabby-images/f1602/f16021976f8282278a4f57daf565a5970dbb489d" alt=""
- Click "Create":
data:image/s3,"s3://crabby-images/139dd/139ddf71b1d4f594ddf445898b40fcccd2b45d1d" alt=""
- In the presented form:
- Give a name to the file that will denote your Group, for ex.: group.ttl
- Specify the file mime type: text/turtle
- Paste Turtle based content from above into the editing space:
data:image/s3,"s3://crabby-images/780be/780be9c75b11bed18218b52517ae2c6d3cc54a4f" alt=""
- Finally click "Create".
- Your file should be created and displayed Briefcase's folder viewer:
data:image/s3,"s3://crabby-images/fa6fe/fa6fe099881ee4636b381c03622208fcff9d4f7f" alt=""
- Note: if you not using the "Public" folder (which provides public access by default), please make sure you set make the document available to the public, i.e.
it should have permissions:
rw-r--r--
3. Create a Web document that should only be accessible to members of the new group
- Assuming you (an ODS account holder named 'William') want to only share the image resource (below) with two people: Kate and John, please perform the following steps:
data:image/s3,"s3://crabby-images/115c6/115c640ac541ceff8d2b53ebd621b67a84c2b058" alt=""
- Go to http://host:port/ods and login with your credentials:
data:image/s3,"s3://crabby-images/eef80/eef80189d676e61426a69ab6b1545460d0b2808f" alt=""
- Click on the Briefcase application link and click on the "New Folder" menu item to create the sub-folder: "albums":
data:image/s3,"s3://crabby-images/c579f/c579fa8531a5766a3a100e56da9eb604b7244e82" alt=""
- Click "Create".
- The new created folder should be presented in the list of folders and resources for user William:
data:image/s3,"s3://crabby-images/2b25e/2b25e28db2533b77f19615c7b8562938be79d883" alt=""
- Go to "albums" folder and using the "Upload" feature upload the image "OpenLink.png" from above:
data:image/s3,"s3://crabby-images/65e5a/65e5abf57e3d9ac75fe38f0e4fc2961864b42720" alt=""
data:image/s3,"s3://crabby-images/bb5b0/bb5b0ab44289deced030f25c0f3ddb85b3468b9b" alt=""
4. Share the Web document URL with group members.
- For the uploaded image "Openlink.png" from above, navigate to the Briefcase UI DAV path containing the image, and click its "Update Properties" link:
data:image/s3,"s3://crabby-images/c6495/c649532e25e4f70489fd704eadcd9e069eba78d8" alt=""
data:image/s3,"s3://crabby-images/89317/8931709392f423236b42938c663d4578a6a441ff" alt=""
- Go to "Sharing":
data:image/s3,"s3://crabby-images/982a7/982a7f87567b0135a2076d7f3ed96023356f1dc3" alt=""
- In "WebID? users" section click the green "plus" button with label "Add":
data:image/s3,"s3://crabby-images/a1bf9/a1bf9dcd7f7132fbb5abd3dac7a1d59d87dc8945" alt=""
- In the presented form:
- Change "Access type" to "Advanced";
- For "Criteria" click the green "plus" button and select "Certificate - SPARQL ASK"
data:image/s3,"s3://crabby-images/4a71d/4a71da816e38d1a5ccd2a84c930e96438cbc446e" alt=""
- Should appear a drop-down menu list with 2 values: "equal to" and "not equal to".
Select the "equal to" value:
data:image/s3,"s3://crabby-images/d659b/d659b651146013658ce0a5b9dbdea81b144293f4" alt=""
- Should appear a drop-down menu list with 2 values: "yes" and "no".
Leave the default presented value "yes" as selected:
data:image/s3,"s3://crabby-images/c3d20/c3d20739a8b641680c760b1df1a269d8da0d3236" alt=""
- Modify the SPARQL ASK statement by replacing it with this one:
DEFINE get:soft "replace"
PREFIX sioc: <http://rdfs.org/sioc/ns#>
PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>
PREFIX foaf: <http://xmlns.com/foaf/0.1/>
ASK FROM <http://web.ods.openlinksw.com/DAV/home/demo/Public/group.ttl>
WHERE {<http://web.ods.openlinksw.com/DAV/home/demo/Public/group.ttl#Group>
foaf:member ?x}
data:image/s3,"s3://crabby-images/e4c5c/e4c5cd0c246a545594ed8450c26898eaac76ac77" alt=""
- Click "Update":
data:image/s3,"s3://crabby-images/f659b/f659b83fed18a3bf64c17f677dd744d83825d232" alt=""
5. View the shared document
- As per the sharing done from above, users Kate and John should be able to see the Web document
https://host-port//DAV/home/William/albums/OpenLink.png
if they authenticate with X 509. Watermarked Certificate containing the WebIDs included in the group.ttl from above.
- Navigate to
https://host-port//DAV/home/William/albums/OpenLink.png
- When prompted for authentication, select for ex.
John's X 509 WebID? Watermarked Certificate:
data:image/s3,"s3://crabby-images/18cb7/18cb756665558239b3fc86c6f723c3b2bbac86ec" alt=""
- John should successfully view the shared Web document -- in our example a simple image:
data:image/s3,"s3://crabby-images/ce86e/ce86edeb49a42a4ff84e5f3eab2bc7a975454b4b" alt=""
Related