https://github.com/samvera/ldp
  
  
    Linked Data Platform.rb client 
    https://github.com/samvera/ldp
  
core-components fcrepo fedora samvera-community
        Last synced: 7 months ago 
        JSON representation
    
Linked Data Platform.rb client
- Host: GitHub
- URL: https://github.com/samvera/ldp
- Owner: samvera
- License: other
- Created: 2013-07-31T03:52:38.000Z (about 12 years ago)
- Default Branch: main
- Last Pushed: 2024-01-23T21:10:46.000Z (over 1 year ago)
- Last Synced: 2024-04-26T06:03:08.926Z (over 1 year ago)
- Topics: core-components, fcrepo, fedora, samvera-community
- Language: Ruby
- Homepage:
- Size: 299 KB
- Stars: 15
- Watchers: 62
- Forks: 15
- Open Issues: 20
- 
            Metadata Files:
            - Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
- Code of conduct: CODE_OF_CONDUCT.md
- Support: SUPPORT.md
 
Awesome Lists containing this project
README
          # ldp (Linked Data Platform)
Code:
[](http://badge.fury.io/rb/ldp)
[](https://circleci.com/gh/samvera/ldp)
[](https://coveralls.io/github/samvera/ldp?branch=main)
Docs:
[](./CONTRIBUTING.md)
[](./LICENSE.txt)
Community Support: [](http://slack.samvera.org/)
# What is `ldp`?
[Linked Data Platform](https://www.w3.org/TR/ldp/) client library for Ruby
## Product Owner & Maintenance
`ldp` is a Core Component of the Samvera Community. The documentation for what this means can be found [here](http://samvera.github.io/core_components.html#requirements-for-a-core-component).
### Product Owner
[randalldfloyd](https://github.com/randalldfloyd)
# Help
The Samvera community is here to help. Please see our [support guide](./SUPPORT.md).
## Installation
Add this line to your application's Gemfile:
    gem 'ldp'
And then execute:
    $ bundle
Or install it yourself as:
    $ gem install ldp
## Usage
```ruby
host = 'http://localhost:8080'
client = Ldp::Client.new(host)
resource = Ldp::Resource.new(client, host + '/rest/node/to/update')
orm = Ldp::Orm.new(resource)
# view the current title(s)
orm.orm.value(RDF::DC11.title)
# update the title
orm.graph.delete([orm.resource.subject_uri, RDF::DC11.title, nil])
orm.graph.insert([orm.resource.subject_uri, RDF::DC11.title, 'a new title'])
# save changes
orm.save
```
## Contributing 
If you're working on PR for this project, create a feature branch off of `main`. 
This repository follows the [Samvera Community Code of Conduct](https://samvera.atlassian.net/wiki/spaces/samvera/pages/405212316/Code+of+Conduct) and [language recommendations](https://github.com/samvera/maintenance/blob/main/templates/CONTRIBUTING.md#language).  Please ***do not*** create a branch called `main` for this repository or as part of your pull request; the branch will either need to be removed or renamed before it can be considered for inclusion in the code base and history of this repository.
## Testing:
- Set Rails version you want to test against. For example:
  - `export RAILS_VERSION=5.1.4`
- Ensure that the correct version of Rails is installed: `bundle update`
- And run tests: `bundle exec rake rspec`
## Releasing
1. `bundle install`
2. Increase the version number in `lib/ldp/version.rb`
3. Increase the same version number in `.github_changelog_generator`
4. Update `CHANGELOG.md` by running this command:
  ```
  github_changelog_generator --user samvera --project ldp --token YOUR_GITHUB_TOKEN_HERE
  ```
5. Commit these changes to the main branch
6. Run `rake release`
# Acknowledgments
This software has been developed by and is brought to you by the Samvera community.  Learn more at the
[Samvera website](http://samvera.org)
