= RelatonIana RelatonIana is a Ruby gem that implements the https://github.com/metanorma/metanorma-model-iso#iso-bibliographic-item[IsoBibliographicItem model]. You can use it to retrieve metadata of W3C Standards from https://w3.org, and access such metadata through the `BibliographicItem` object. == Installation Add this line to your application's Gemfile: [source,ruby] ---- gem 'relaton-iana' ---- And then execute: $ bundle install Or install it yourself as: $ gem install relaton-iana == Usage === Search for a standard using keywords [source,ruby] ---- require 'relaton_iana' => true item = RelatonIana::IanaBibliography.get "IANA service-names-port-numbers" [relaton-iana] ("IANA service-names-port-numbers") fetching... [relaton-iana] ("IANA service-names-port-numbers") found IANA service-names-port-numbers => # " 2021-11-24 Service Name and Transport Protocol Port Number Registry http://www.iana.org/assignments/service-names-port-numbers IANA service-names-port-numbers service-names-port-numbers 2021-11-12 Internet Assigned Numbers Authority IANA en " ---- === Typed links Each IANA document has `src` type link. [source,ruby] ---- item.link.first.type => "src" item.link.first.content => # ---- === Create bibliographic item from XML [source,ruby] ---- RelatonBib::XMLParser.from_xml File.read('spec/fixtures/service-names-port-numbers.xml') => # {"id"=>"IANAservice-names-port-numbers", "title"=>{"content"=>"Service Name and Transport Protocol Port Number Registry", "format"=>"text/plain"}, ... bib_hash = RelatonIana::HashConverter.hash_to_bib hash => {:id=>"IANAservice-names-port-numbers", :title=>{:content=>"Service Name and Transport Protocol Port Number Registry", :format=>"text/plain"}, ... RelatonBib::BibliographicItem.new **bib_hash => # nil ---- This method uses GitHub search API to fetch the documents. The search API has a https://docs.github.com/en/rest/reference/search#rate-limit[rate limitaion] of 30 requests per minute for authenticated users and 10 requests per minute for unauthenticated users. Usually, the rate limit is not reached because the search API is used only for the files list fetching. But if you run the method multiple times in a short period, it is possible that the rate limit will be reached. In this case, the method will wait until the rate limit is reset. You can use pesonal access token to increase the rate limit. To do this, add your pesonal access token to the `GITHUB_TOKEN` environment variable. == Development After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake spec` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment. To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org). == Contributing Bug reports and pull requests are welcome on GitHub at https://github.com/relaton/relaton_w3c. == License The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).