Skip to content

OSLC/ldp-service

Folders and files

NameName
Last commit message
Last commit date

Latest commit

965bc7c · Jun 7, 2021

History

19 Commits
Jun 26, 2018
Dec 4, 2015
Dec 4, 2015
Dec 4, 2015
Dec 4, 2015
Dec 4, 2015
Dec 4, 2015
Jun 7, 2021
Dec 4, 2015
Dec 5, 2018
Jun 26, 2018
Dec 5, 2018
Dec 20, 2018
Dec 20, 2018
Dec 5, 2018

Repository files navigation

ldp-service

npm Discourse status Gitter

A simple Node.js module providing Express middleware to create a W3C Linked Data Platform server. The service uses abstract module storage.js for persistence, jsonld.js for JSON-LD support, and a few other JavaScript libraries. A sample app using the LDP middleware service is running at http://ldp-app.mybluemix.net. Apps that use ldp-service can utilize existing concrete implementations of storage.js: ldp-service-jena, ldp-service-fs and/or ldp-service-mongodb.

ldp-service supports LDP basic and direct containers. Indirect containers and non-RDF source are not implemented.

Many thanks to Steve Speicher and Sam Padgett for their valuable contribution to LDP and this LDP middleware.

Module planning, maintenance and issues can be see at at the ldp-service IBM Bluemix DevOps Services project.

Using

  1. Install the required modules

Install Node.js.

Install and start MongoDB.

Install express.js and create a sample express app

$ npm install express -g
$ express --git -e <appDir>
  1. Edit the package.json file to add a dependency on ldp-service

    "dependencies": {"ldp-service": "~0.0.1"},

  2. Edit app.js and add whatever Express middleware you need including ldp-service. ldp-service also provides access to its MongoDB database in case additional middleware needs direct access to the database.

    var ldpService = require('ldp-service'); app.use(ldpService()); var db = ldpService.db; // incase further middleware needs access to the database

  3. Configuration defaults can be found in config.json. These may be overridden by variables in the environment, including Bluemix variables if deployed in a Bluemix app.

  4. To start the app, run these commands

    $ npm install $ node app.js

Finally, point your browser to http://localhost:3000/.

License

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.