Skip to content

Files

Latest commit

5b05700 · Sep 7, 2020

History

History

cloud-content

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
Sep 7, 2020
Jul 1, 2015
Jul 2, 2015
Sep 7, 2020

Openstack Swift Sakai Resources

The cloud implementation of FileSystemHandler. This implementation writes and reads files to and from cloud storage including OpenStack-Swift and S3.

Authors

This module is based on contributions from OpenCollab under the Educational Community License v2.0. It is also contains contributions from Longsight, Inc.

Usage

Build this module like any other Sakai modules. You must use the sakai:deploy Maven goal to deploy the component pack as usual. It is included in the default profile of the top-level build as well.

To use cloud rather than the default file/database storage, settings must be configured in two places:

  • sakai-configuration.xml
  • local.properties (or another like sakai.properties)

The only setting in sakai-configuration.xml needed is the bean alias to activate this handler rather than the default. This file must be a valid Spring bean config file; either create it in its entirety or just add this alias. Only one handler may be active.

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">

<beans>
  <!-- Swift handler -->
  <alias name="org.sakaiproject.content.api.FileSystemHandler.swift" alias="org.sakaiproject.content.api.FileSystemHandler" />

  <!-- Generic BlobStore handler, currently only for AWS S3 -->
  <!-- <alias name="org.sakaiproject.content.api.FileSystemHandler.blobstore" alias="org.sakaiproject.content.api.FileSystemHandler" /> -->
</beans>

The actual configuration values should be supplied using the bean property syntax in, e.g., local.properties. The standard bodyPath and bodyPathDeleted properties must be set or the files will be stored in the database. However, these should not be prefixed with ${sakai.home} or local directory names since all leading paths will be created as containers or pseudo-folders as needed, adding unneeded depth in your object store. The useIdForPath` setting can be either true or false, but true is recommended as the paths will mirror the resource IDs/URLs.

Settings are only required for the active handler, but may be supplied for an inactive handler as well. Pay close attention to the suffix (swift/blobstore) and the slight differences in the available keys. For example, the endpoint is required for Swift, while the baseContainer is required for S3. The provider is optional for BlobStore, since only aws-s3 is the only one currently available and is the default.

[email protected]     = http://swift.server:5000/v2.0/
[email protected]     = tenant:username
[email protected]   = password
[email protected]       = RegionOne
useIdForPath@org.sakaiproject.content.api.FileSystemHandler.swift = true

provider@org.sakaiproject.content.api.FileSystemHandler.blobstore      = aws-s3
identity@org.sakaiproject.content.api.FileSystemHandler.blobstore      = <S3 Access Key ID>
credential@org.sakaiproject.content.api.FileSystemHandler.blobstore    = <S3 Secret Access Key>
baseContainer@org.sakaiproject.content.api.FileSystemHandler.blobstore = your-bucket-name
useIdForPath@org.sakaiproject.content.api.FileSystemHandler.blobstore  = true

[email protected]=/content/live/
bodyPathDeleted@org.sakaiproject.content.api.ContentHostingService=/content/deleted/

If you are not familiar with sakai-configuration.xml, it is placed in the same location as the properties files. See Confluence for an overview: [https://confluence.sakaiproject.org/display/REL/More+Flexible+Sakai+Configuration](More Flexible Sakai Configuration)

Testing

Because the tests work against a real backend, they are disabled by default. To run them, you must activate the swift-tests profile (e.g., mvn -Pswift-tests install) and set your configuration. The settings for the Swift tests is in impl/src/test/resources/swift.properties. These are straightforward and align with the names/values needed for real usage. The tests will clean up after themselves unless deleteEmptyContainers is set to false, which can be used to validate content in a container afterward.