Skip to content

wedsonlima/rvindi

Repository files navigation

Vindi Ruby

ActiveRecord-like way to interact with Vindi API

Vindi

Vindi is a brazilian fintech, that was recently acquired by Locaweb, that helps other companies to work with recurring payments.

API docs

Installation

Add this line to your application's Gemfile:

gem "rvindi"

And then execute:

$ bundle install

Or install it yourself as:

$ gem install rvindi

Usage

Config

# config/initializers/vindi.rb
Vindi.configure do |c|
  c.sandbox = true # default is false
  c.api_key = "YOUR API KEY"
  c.webhook_secret_name = "BASIC AUTH NAME"
  c.webhook_secret_password = "BASIC AUTH PASSWORD"
end

Examples

Saruman creates a subscription business to rent his Palantir

# Let's say that Gandalf wants to borrow Saruman's Palantir
# promising he'll give it back before the end of the 3rd era.
#
# But Saruman is wise and he thinks he could make a good money
# charging a rent for the use of the magic ball.
#
# So, Saruman went on to Vindi and creates a product...
#
palantir = Vindi::Product.new.tap do |p|
  p.code = "palantir"
  p.name = "Palantir"
  p.description = "The Twitch of Istari folk"
  p.pricing_schema = { price: 42.42 }
  p.save
end

# ...then creates a recurring plan.
one_plan = Vindi::Plan.new.tap do |p|
  p.code = "the-one-plan"
  p.name = "Monthly Plan"
  p.description = "The One Plan To Rule Them All"
  p.period = "monthly"
  p.recurring = true
  p.plan_items = [
    {
      cycles: nil, # untill the end of time
      product_id: palantir.id
    }
  ]
  p.save
end

# Gandalf uses his fellow Bilbo's address to receive the invoices...
gandalf = Vindi::Customer.new.tap do |c|
  c.code = 1
  c.name = "Gandalf the Grey"
  c.email = "[email protected]"
  c.address = {
    street: "Bagshot Row",
    number: "Bag End",
    neighborhood: "Hobbiton",
    city: "Shire"
  }
  c.save
end

# ...uses Elrond's credit card to create a payment profile...
pp = Vindi::PaymentProfile.new.tap do |pp|
  pp.holder_name = "Elrond Half-elven"
  pp.card_expiration = "12/3021"
  pp.card_number = "5167454851671773"
  pp.card_cvv = "123"
  pp.customer_id = gandalf.id
  pp.save
end

# ...subscribes to `the one plan` and then get the palantir.
subscription = Vindi::Subscription.new.tap do |s|
  s.plan_id = one_plan.id
  s.customer_id = gandalf.id
  s.payment_method_code = "credit_card"
  s.save
end

After some time he wants to know how the business is going

# Active customers
customers = Vindi::Customer.active

# Active subscriptions
subscriptions = Vindi::Subscriptions.active

# Subscriptions for the-one-plan
subscriptions = Vindi::Plan.find_by(code: "the-one-plan").subscriptions

# Filter Gandalf
gandalf = Vindi::Customer.find_by(email: "[email protected]")

# All Gandalf's subscriptions
subscriptions = gandalf.subscriptions.active

# Cancel Gandalf's subscription
gandalf.subscriptions.active.last.cancel!

# Refund the last Gandalf's payment
gandalf.charges.last.refund!

Webhooks

You must validate incoming data from Vindi.

You can validate webhook calls using baisc auth. Just configure a webhook call with something like this https://NAME:[email protected]/vindi/webhook.

On Vindi admin dashboard

https://vindi:[email protected]/vindi/webhook

On your project

# config/initializers/vindi.rb
Vindi.configure do |config|
  config.api_key = "123456"
  config.webhook_secret_name = "vindi"
  config.webhook_secret_password = "123456"
end

# routes.rb
namespace :vindi do
  post :webhook, to: "webhook#listener"
end

# vindi/webhook_controller.rb
class Vindi::Webhook < ActionController::Base
  http_basic_authenticate_with name: Vindi.webhook_secret_name, password: Vindi.webhook_secret_password

  # POST https://usuario:[email protected]/vindi/webhook
  def listener
    case event_params[:type]
    when "charge_rejected" # defaulting user?
    when "bill_paid" # do the magic
    else
      head :ok
    end
  end

  private

    def event_params
      params.require(:event).permit!
    end
end

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/wedsonlima/vindi-ruby. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the code of conduct.

License

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

Code of Conduct

Everyone interacting in the Vindi project's codebases, issue trackers, chat rooms and mailing lists is expected to follow the code of conduct.