Project

csdl

0.0
Repository is archived
No commit activity in last 3 years
No release in over 3 years
CSDL is a gem for producing Abstract Syntax Trees for the [DataSift CSDL Filter Language](http://dev.datasift.com/docs/csdl). Working with an AST instead of raw strings provides a simpler way to test and validate any given CSDL filter.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.10
~> 10.0
>= 0

Runtime

~> 2.0
 Project Readme

CSDL

CSDL is a gem for producing Abstract Syntax Trees for the DataSift CSDL Filter Language. Working with an AST instead of raw strings provides a simpler way to test and validate any given CSDL filter.

Gem Version Build Status Yard Docs Inline docs

Installation

Add this line to your application's Gemfile:

gem "csdl"

And then execute:

$ bundle

Or install it yourself as:

$ gem install csdl

Usage

Use the DSL provided by CSDL::Builder to produce an AST representation of your query, and use CSDL::Processor to turn your AST into a raw CSDL string.

Be sure to read the Processor and Processor docs if you get stuck.

Valid builder methods are:

  • _and - ANDs two or more child statements together.
  • _not - Negates a condition statement.
  • _or - ORs two or more child statements together.
  • _return - Creates a return statement with an implicit statement_scope.
  • condition - Builds a target + operator + argument group. Ensures target and operator are valid.
  • logical_group - Create a parenthetical grouping for nested statements. Optionally takes a logical operator as the first argument since we commonly want to wrap OR'd or AND'd statements in a logical group.
  • statement_scope - Create a braced grouping for nested statements used by tag and return blocks.
  • tag_tree - Builds a tag tree classifier (e.g. tag.movies "Video" { ... }).
  • tag - Builds a tag classifier (e.g. tag "Desire" { ... }).

Methods prefixed with "_" are to avoid ruby keyword collisions.

builder = ::CSDL::Builder.new._or do
  [
    logical_group(:and) {
      [
        logical_group(:or) {
          [
            condition("fb.content", :contains_any, "ebola"),
            condition("fb.parent.content", :contains_any, "ebola")
          ]
        },
        _not("fb.content", :contains_any, "government,politics"),
        condition("fb.author.country_code", :in, "GB")
      ]
    },
    logical_group(:and) {
      [
        logical_group(:or) {
          [
            condition("fb.content", :contains_any, "malta,malta island,#malta"),
            condition("fb.parent.content", :contains_any, "malta,malta island,#malta")
          ]
        },
        _not("fb.content", :contains_any, "vacation,poker awards")
      ]
    }
  ]
end

puts
puts "Builder..."
puts builder.to_sexp

puts
puts "Processing AST..."
puts ::CSDL::Processor.new.process(builder)

The previous script produces the following output:

Builder...
(or
  (logical_group
    (and
      (logical_group
        (or
          (condition
            (target "fb.content")
            (operator :contains_any)
            (argument
              (string "ebola")))
          (condition
            (target "fb.parent.content")
            (operator :contains_any)
            (argument
              (string "ebola")))))
      (not
        (target "fb.content")
        (operator :contains_any)
        (argument
          (string "government,politics")))
      (condition
        (target "fb.author.country_code")
        (operator :in)
        (argument
          (string "GB")))))
  (logical_group
    (and
      (logical_group
        (or
          (condition
            (target "fb.content")
            (operator :contains_any)
            (argument
              (string "malta,malta island,#malta")))
          (condition
            (target "fb.parent.content")
            (operator :contains_any)
            (argument
              (string "malta,malta island,#malta")))))
      (not
        (target "fb.content")
        (operator :contains_any)
        (argument
          (string "vacation,poker awards"))))))

Processing AST...
((fb.content contains_any "ebola" OR fb.parent.content contains_any "ebola") AND NOT fb.content contains_any "government,politics" AND fb.author.country_code in "GB") OR ((fb.content contains_any "malta,malta island,#malta" OR fb.parent.content contains_any "malta,malta island,#malta") AND NOT fb.content contains_any "vacation,poker awards")

The processed AST looks like this (manually expanded):

(
  (
    fb.content contains_any "ebola"
    OR fb.parent.content contains_any "ebola"
  )
  AND NOT fb.content contains_any "government,politics"
  AND fb.author.country_code in "GB"
)
OR
(
  (
    fb.content contains_any "malta,malta island,#malta"
    OR fb.parent.content contains_any "malta,malta island,#malta"
  )
  AND NOT fb.content contains_any "vacation,poker awards"
)

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/localshred/csdl.