Class: Treequel::Schema::MatchingRule

Inherits:
Object
  • Object
show all
Extended by:
Loggability, AttributeDeclarations
Includes:
Constants::Patterns
Defined in:
lib/treequel/schema/matchingrule.rb

Overview

This is a class for representing matchingRule declarations in a Treequel::Schema.

Constant Summary

Constants included from Constants::Patterns

Constants::Patterns::ALPHA, Constants::Patterns::AMPERSAND, Constants::Patterns::ASSERTIONVALUE, Constants::Patterns::ASTERISK, Constants::Patterns::ATTRIBUTE_TYPE, Constants::Patterns::ATTRIBUTE_TYPE_AND_VALUE, Constants::Patterns::ATTRIBUTE_VALUE, Constants::Patterns::BASE64_CHAR, Constants::Patterns::BASE64_STRING, Constants::Patterns::COLON, Constants::Patterns::COMMA, Constants::Patterns::DESCR, Constants::Patterns::DIGIT, Constants::Patterns::DISTINGUISHED_NAME, Constants::Patterns::DN_ESCAPED, Constants::Patterns::DOLLAR, Constants::Patterns::DOT, Constants::Patterns::DQUOTE, Constants::Patterns::DSTRING, Constants::Patterns::EQUALS, Constants::Patterns::ESC, Constants::Patterns::ESCAPED, Constants::Patterns::EXCLAMATION, Constants::Patterns::EXTENSIONS, Constants::Patterns::FILL, Constants::Patterns::FOLD, Constants::Patterns::HEX, Constants::Patterns::HEXPAIR, Constants::Patterns::HEXSTRING, Constants::Patterns::HYPHEN, Constants::Patterns::KEYCHAR, Constants::Patterns::KEYSTRING, Constants::Patterns::KIND, Constants::Patterns::LANGLE, Constants::Patterns::LCURLY, Constants::Patterns::LDAP_ATTRIBUTE_DESCRIPTION, Constants::Patterns::LDAP_ATTRIBUTE_TYPE_DESCRIPTION, Constants::Patterns::LDAP_MATCHING_RULE_DESCRIPTION, Constants::Patterns::LDAP_MATCHING_RULE_USE_DESCRIPTION, Constants::Patterns::LDAP_MISORDERED_DESC_OBJECTCLASS_DESCRIPTION, Constants::Patterns::LDAP_MISORDERED_KIND_OBJECTCLASS_DESCRIPTION, Constants::Patterns::LDAP_MISORDERED_SYNTAX_ATTRIBUTE_TYPE_DESCRIPTION, Constants::Patterns::LDAP_OBJECTCLASS_DESCRIPTION, Constants::Patterns::LDAP_SUBSTRING_FILTER, Constants::Patterns::LDAP_SUBSTRING_FILTER_VALUE, Constants::Patterns::LDAP_SYNTAX_DESCRIPTION, Constants::Patterns::LDAP_TRAILING_KIND_OBJECTCLASS_DESCRIPTION, Constants::Patterns::LDAP_UNESCAPE_SQUOTE_ATTRIBUTE_TYPE_DESCRIPTION, Constants::Patterns::LDIF_ATTRIBUTE_DESCRIPTION, Constants::Patterns::LDIF_ATTRIBUTE_TYPE, Constants::Patterns::LDIF_ATTRTYPE_OPTION, Constants::Patterns::LDIF_ATTRTYPE_OPTIONS, Constants::Patterns::LDIF_ATTRVAL_SPEC, Constants::Patterns::LDIF_ATTR_TYPE_CHARS, Constants::Patterns::LDIF_OPT_CHAR, Constants::Patterns::LDIF_SAFE_CHAR, Constants::Patterns::LDIF_SAFE_INIT_CHAR, Constants::Patterns::LDIF_SAFE_STRING, Constants::Patterns::LDIF_VALUE_SPEC, Constants::Patterns::LDIGIT, Constants::Patterns::LEADCHAR, Constants::Patterns::LEADKEYCHAR, Constants::Patterns::LEN, Constants::Patterns::LPAREN, Constants::Patterns::LUTF1, Constants::Patterns::MALFORMED_DSTRING, Constants::Patterns::MALFORMED_QDSTRING, Constants::Patterns::NOIDLEN, Constants::Patterns::NORMAL, Constants::Patterns::NUL, Constants::Patterns::NUMBER, Constants::Patterns::NUMERICOID, Constants::Patterns::OCTET, Constants::Patterns::OID, Constants::Patterns::OIDLIST, Constants::Patterns::OIDS, Constants::Patterns::PAIR, Constants::Patterns::PLUS, Constants::Patterns::QDESCR, Constants::Patterns::QDESCRLIST, Constants::Patterns::QDESCRS, Constants::Patterns::QDSTRING, Constants::Patterns::QDSTRINGLIST, Constants::Patterns::QDSTRINGS, Constants::Patterns::QQ, Constants::Patterns::QS, Constants::Patterns::QUOTED_DESCR, Constants::Patterns::QUOTED_NUMERICOID, Constants::Patterns::QUTF1, Constants::Patterns::QUTF8, Constants::Patterns::RANGLE, Constants::Patterns::RCURLY, Constants::Patterns::RELATIVE_DISTINGUISHED_NAME, Constants::Patterns::RPAREN, Constants::Patterns::SEMI, Constants::Patterns::SEP, Constants::Patterns::SHARP, Constants::Patterns::SP, Constants::Patterns::SPACE, Constants::Patterns::SPECIAL, Constants::Patterns::SQUOTE, Constants::Patterns::STRING, Constants::Patterns::STRINGCHAR, Constants::Patterns::SUTF1, Constants::Patterns::TILDE, Constants::Patterns::TRAILCHAR, Constants::Patterns::TUTF1, Constants::Patterns::UNESCAPED, Constants::Patterns::URI_REF, Constants::Patterns::USAGE, Constants::Patterns::USCORE, Constants::Patterns::UTF0, Constants::Patterns::UTF1, Constants::Patterns::UTF1SUBSET, Constants::Patterns::UTF2, Constants::Patterns::UTF3, Constants::Patterns::UTF4, Constants::Patterns::UTF8, Constants::Patterns::UTFMB, Constants::Patterns::VALUEENCODING, Constants::Patterns::VERTBAR, Constants::Patterns::WSP, Constants::Patterns::XSTRING

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods included from AttributeDeclarations

predicate_attr

Constructor Details

#initialize(schema, oid, syntax_oid, names = nil, desc = nil, obsolete = false, extensions = nil) ⇒ MatchingRule

Create a new MatchingRule



49
50
51
52
53
54
55
56
57
58
59
60
61
# File 'lib/treequel/schema/matchingrule.rb', line 49

def initialize( schema, oid, syntax_oid, names=nil, desc=nil, obsolete=false, extensions=nil )

  @schema     = schema

  @oid        = oid
  @syntax_oid = syntax_oid
  @names      = names
  @desc       = desc
  @obsolete   = obsolete ? true : false
  @extensions = extensions

  super()
end

Instance Attribute Details

#descObject

The matchingRule’s description



81
82
83
# File 'lib/treequel/schema/matchingrule.rb', line 81

def desc
  @desc
end

#extensionsObject

The matchingRule’s extensions (as a String)



87
88
89
# File 'lib/treequel/schema/matchingrule.rb', line 87

def extensions
  @extensions
end

#namesObject (readonly)

The Array of the matchingRule’s names



78
79
80
# File 'lib/treequel/schema/matchingrule.rb', line 78

def names
  @names
end

#oidObject (readonly)

The matchingRule’s oid



72
73
74
# File 'lib/treequel/schema/matchingrule.rb', line 72

def oid
  @oid
end

#schemaObject (readonly)

The schema the matchingRule belongs to



69
70
71
# File 'lib/treequel/schema/matchingrule.rb', line 69

def schema
  @schema
end

#syntax_oidObject

The oid of the matchingRule’s SYNTAX



75
76
77
# File 'lib/treequel/schema/matchingrule.rb', line 75

def syntax_oid
  @syntax_oid
end

Class Method Details

.parse(schema, description) ⇒ Object

Parse an MatchingRule entry from a matchingRule description from a schema.



28
29
30
31
32
33
34
35
36
37
38
39
40
41
# File 'lib/treequel/schema/matchingrule.rb', line 28

def self::parse( schema, description )
  unless match = ( LDAP_MATCHING_RULE_DESCRIPTION.match(description) )
    raise Treequel::ParseError, "failed to parse matchingRule from %p" % [ description ]
  end

  oid, names, desc, obsolete, syntax_oid, extensions = match.captures
  # Treequel.logger.debug "  parsed matchingRule: %p" % [ match.captures ]

  # Normalize the attributes
  names = Treequel::Schema.parse_names( names )
  desc  = Treequel::Schema.unquote_desc( desc )

  return self.new( schema, oid, syntax_oid, names, desc, obsolete, extensions )
end

Instance Method Details

#inspectObject

Return a human-readable representation of the object suitable for debugging



121
122
123
124
125
126
127
128
129
130
131
# File 'lib/treequel/schema/matchingrule.rb', line 121

def inspect
  return "#<%s:0x%0x %s(%s) %s %sSYNTAX: %p>" % [
    self.class.name,
    self.object_id / 2,
    self.name,
    self.oid,
    self.desc,
    self.obsolete? ? "(OBSOLETE)" : '',
    self.syntax,
  ]
end

#nameObject

Return the first of the matchingRule’s names, if it has any, or nil.



91
92
93
# File 'lib/treequel/schema/matchingrule.rb', line 91

def name
  return self.names.first
end

#syntaxObject

Return the Treequel::Schema::LDAPSyntax object that corresponds to the matchingRule’s SYNTAX attribute.



136
137
138
# File 'lib/treequel/schema/matchingrule.rb', line 136

def syntax
  return self.schema.ldap_syntaxes[ self.syntax_oid ]
end

#to_sObject

Returns the matchingRule as a String, which is the RFC4512-style schema description.



106
107
108
109
110
111
112
113
114
115
116
117
# File 'lib/treequel/schema/matchingrule.rb', line 106

def to_s
  parts = [ self.oid ]

  parts << "NAME %s" % Treequel::Schema.qdescrs( self.names ) unless self.names.empty?

  parts << "DESC '%s'" % [ self.desc ]           if self.desc
  parts << "OBSOLETE"                            if self.obsolete?
  parts << "SYNTAX %s" % [ self.syntax_oid ]
  parts << self.extensions.strip             unless self.extensions.empty?

  return "( %s )" % [ parts.join(' ') ]
end