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

spackle-ruby

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

spackle-ruby

  • 0.0.20
  • Rubygems
  • Socket score

Version published
Maintainers
1
Created
Source

Spackle Ruby Library

CI

The Spackle Ruby library provides optimized access to billing aware flags created on the Spackle platform.

Documentation

See the Ruby API docs.

Setup

Install the Spackle library

gem install spackle-ruby

Bundler

source 'https://rubygems.org'

gem 'spackle-ruby'

Configure your environment

In order to use Spackle, you need to configure your secret key on the Spackle module. You can find your secret key in Spackle app settings page.

require 'spackle'

Spackle.api_key = "<api key>"

Usage

Pricing tables

Fetch a pricing table
pricing_table = Spackle::PricingTable.retrieve("abcde123")
Pricing table object
{
  id: string
  name: string
  intervals: string[]
  products: {
    id: string
    name: string
    description: string
    features: {
      id: string
      name: string
      key: string
      type: number
      value_flag: boolean
      value_limit: number | null
    }[]
    prices: {
      month?: {
        id: string
        unit_amount: number
        currency: string
      }
      year?: {
        id: string
        unit_amount: number
        currency: string
      }
    }
  }[]
}

Entitlements

Fetch a customer

Spackle uses stripe ids as references to customer features.

customer = Spackle::Customer.retrieve("cus_00000000")
Verify feature access
customer.enabled("feature_key")
Fetch a feature limit
customer.limit("feature_key")
Examine a customer's subscriptions

A customer's current subscriptions are available on the subscriptions property. These are valid Stripe::Subscription objects as defined in the Stripe Ruby library.

customer.subscriptions
Waiters

There is a brief delay between when an action takes place in Stripe and when it is reflected in Spackle. To account for this, Spackle provides a Waiters module that can be used to wait for a Stripe object to be updated and replicated.

  1. Wait for a customer to be created
    Spackle::Waiters.wait_for_customer("cus_00000000")
    
  2. Wait for a subscription to be created
    Spackle::Waiters.wait_for_subscription("cus_000000000", "sub_00000000")
    
  3. Wait for a subscription to be updated
    Spackle::Waiters.wait_for_subscription("cus_000000000", "sub_00000000", status: "active")
    

These will block until Spackle is updated with the latest information from Stripe or until a timeout occurs.

Usage in development environments

In production, Spackle requires a valid Stripe customer. However, that is not development environments where state needs to be controlled. As an alternative, you can use a file store to test your application with seed data.

/app/spackle.json

{
  "cus_000000000": {
    "features": [
      {
        "type": 0,
        "key": "flag_feature",
        "value_flag": true
      },
      {
        "type": 1,
        "key": "limit_feature",
        "value_limit": 100
      }
    ],
    "subscriptions": [
      {
        "id": "sub_000000000",
        "status": "trialing",
        "quantity": 1
      }
    ]
  }
}

Then configure the file store in your application:

Spackle.store = Spackle::FileStore.new('/app/spackle.json')
Usage in test environments

In production, Spackle requires a valid Stripe customer. However, that is not ideal in testing or some development environments. As an alternative, you can use an in-memory store to test your application with seed data.

Spackle.store = Spackle::MemoryStore.new()
Spackle.store.set_customer_data("cus_000000000", {
  "features": [
    {
      "type": 0,
      "key": "flag_feature",
      "value_flag": True,
    },
    {
      "type": 1,
      "key": "limit_feature",
      "value_limit": 100,
    },
  ],
  "subscriptions": [
     {
       "id": "sub_000000000",
       "status": "trialing",
       "quantity": 1,
     }
  ]
})

Note: The in-memory store is not thread-safe and state will reset on each application restart.

Logging

The Spackle Ruby library emits logs as it performs various internal tasks. You can control the verbosity of Spackle's logging a few different ways:

  1. Set the environment variable SPACKLE_LOG to the value debug, info, warn or error

    $ export SPACKLE_LOG=debug
    
  2. Set Spackle.log_level:

    Spackle.log_level = 'debug'
    

FAQs

Package last updated on 21 Mar 2024

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