Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

myra

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

myra

  • 0.1.2
  • Rubygems
  • Socket score

Version published
Maintainers
1
Created
Source

Myra

This gem allows for interaction with MyraClouds API.

Installation

Add this line to your application's Gemfile:

gem 'myra'

And then execute:

$ bundle

Or install it yourself as:

$ gem install myra

Usage

API Key and API secret

Note: Both can be obtained by contacting the MyraCloud support.

The gem assumes that you store the keys in your environment:

ENV['MYRACLOUD_API_KEY']
ENV['MYRACLOUD_API_SECRET']

However, if you wish to use something different, you can configure these values yourself:

Myra.configure do |config|
  config.api_key = 'your-key-here'
  config.api_secret = 'your-secret-here'
end

Domains

A domain is the top level entity available. They cannot easily be edited, as only the autoUpdate can be set via API. Removing them will affect all the DNS records attached to that domain, so be extra careful.

List
list = Myra::Domains.list
# => [Domain, Domain, Domain, ...]

domain[0].name
# => 'my-awesome-name.com'

list takes one parameter which determines the page to be shown.

Create
domain = Myra::Domain.new
domain.name = "www.kloeckner-i.com"
puts domain.id
# => nil
# [...]
domain = Myra::Domains.create(domain)
puts domain.id
Update

Updating can only change the autoUpdate flag on a domain, if you need more extended editing, remove and recreate the domain (this is a limitation of the API)

list = Myra::Domains.list
# => [Domain, Domain, Domain, ...]

domain_to_update = domains.first
domain_to_update.auto_update = !domain_to_update.auto_update
Myra::Domains.update(domain_to_update)
Delete

:warning: Deleting a domain is dangerous, as it will remove all associated DNS records and other settings as well.

# if you don't know the id, just fetch them first
domain = Myra::Domain.new(id: 1234)
Myra::Domains.delete domain

DNS Records

A DNS record comes in the form of Myra::DnsRecord and always belongs to a domain.

List
domain = Myra::Domain.new id: 1
records = Myra::DnsRecords.list(domain)
# => [Myra::DnsRecord, Myra::DnsRecord, ...]

list takes one additional parameter which determines the page to be shown.

Create
domain = Myra::Domain.new id: 1
record = Myra::DnsRecord.new
record.name = 'foo' # full name will be infered from the domain you are creating it for
record.value = 'foo-bar-com.zep.ag'
record.type = Myra::DnsRecord::Type::CNAME # defaults to 'A'
Myra::DnsRecords.create(record, domain)
Update
# get a domain, etc.
record = Myra::DnsRecords.list(domain).first
record.name = 'foo' # full name will be infered from the domain you are creating it for
record.value = 'foo-bar-com-2.zep.ag'
Myra::DnsRecords.update(record, domain)
Delete
# get a domain, etc.
record = Myra::DnsRecords.list(domain).first
Myra::DnsRecords.delete(record, domain)

Errors

All actions will raise proper errors when the API responds with an error. All violations will be presented as a Myra::Violation attached to the error.

Wrong credentials

If the API cannot be authenticated against, a Myra::APIAuthError will be thrown. Check your credentials of you encounter this error.

Failed API action

If an action against the API fails, a Myra::APIActionError will be thrown.

domain = Myra::Domain.new
domain.name = '.ff..'
begin
  Myra::Domain.create(domain)
rescue Myra::APIActionError => e
  puts e.message
  puts e.violations # => [Myra::Violation, Myra::Violation, ...]
end

Supported version for the MyraCloud API

The currently supported version for the API is 1.4.

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.

License

The gem is available as open source under the terms of the MIT License.

FAQs

Package last updated on 20 Sep 2016

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc