struct UUID
Overview
Adds JSON support to UUID for use in a JSON mapping.
NOTE  require "uuid/json" is required to opt-in to this feature.
require "json"
require "uuid"
require "uuid/json"
class Example
  JSON.mapping id: UUID
end
example = Example.from_json(%({"id": "ba714f86-cac6-42c7-8956-bcf5105e1b81"}))
uuid = UUID.new("87b3042b-9b9a-41b7-8b15-a93d3f17025e")
uuid.to_json # => "87b3042b-9b9a-41b7-8b15-a93d3f17025e"Defined in:
uuid.cruuid/json.cr
Constructors
- 
        .new(bytes : StaticArray(UInt8, 16), variant : UUID::Variant? = nil, version : UUID::Version? = nil)
        
          Generates UUID from bytes, applying version and variant to the UUID if present. 
- 
        .new(slice : Slice(UInt8), variant = nil, version = nil)
        
          Creates UUID from 16-bytes slice. 
- 
        .new(uuid : UUID, variant = nil, version = nil)
        
          Creates another UUIDwhich is a copy of uuid, but allows overriding variant or version.
- 
        .new(value : String, variant = nil, version = nil)
        
          Creates new UUID by decoding valuestring from hyphenated (ie.
- .new(pull : JSON::PullParser)
Class Method Summary
- .empty
- 
        .random(random = Random::Secure, variant = Variant::RFC4122, version = Version::V4)
        
          Generates RFC 4122 v4 UUID. 
Instance Method Summary
- 
        #==(other : UUID)
        
          Returns trueifotherUUID represents the same UUID,falseotherwise.
- #hexstring
- 
        #inspect(io : IO)
        
          Convert to Stringin literal format.
- #to_json(json : JSON::Builder)
- #to_s(io : IO)
- 
        #to_slice
        
          Returns 16-byte slice. 
- 
        #to_unsafe
        
          Returns unsafe pointer to 16-bytes. 
- #urn
- 
        #v1!
        
          Returns trueif UUID looks is a V1, raisesErrorotherwise.
- 
        #v1?
        
          Returns trueif UUID looks is a V1,falseotherwise.
- 
        #v2!
        
          Returns trueif UUID looks is a V2, raisesErrorotherwise.
- 
        #v2?
        
          Returns trueif UUID looks is a V2,falseotherwise.
- 
        #v3!
        
          Returns trueif UUID looks is a V3, raisesErrorotherwise.
- 
        #v3?
        
          Returns trueif UUID looks is a V3,falseotherwise.
- 
        #v4!
        
          Returns trueif UUID looks is a V4, raisesErrorotherwise.
- 
        #v4?
        
          Returns trueif UUID looks is a V4,falseotherwise.
- 
        #v5!
        
          Returns trueif UUID looks is a V5, raisesErrorotherwise.
- 
        #v5?
        
          Returns trueif UUID looks is a V5,falseotherwise.
- 
        #variant
        
          Returns UUID variant. 
- 
        #version
        
          Returns version based on RFC4122 format. 
Instance methods inherited from struct Struct
  
  
    
      ==(other) : Bool
    ==, 
    
  
    
      hash(hasher)
    hash, 
    
  
    
      inspect(io : IO) : Nil
    inspect, 
    
  
    
      pretty_print(pp) : Nil
    pretty_print, 
    
  
    
      to_s(io)
    to_s
    
  
    
    
  
    
  Instance methods inherited from struct Value
  
  
    
      ==(other : JSON::Any)==(other : YAML::Any)
==(other) ==, dup dup
Instance methods inherited from class Object
  
  
    
      !=(other)
    !=, 
    
  
    
      !~(other)
    !~, 
    
  
    
      ==(other)
    ==, 
    
  
    
      ===(other : JSON::Any)===(other : YAML::Any)
===(other) ===, =~(other) =~, class class, dup dup, hash(hasher)
hash hash, inspect(io : IO)
inspect inspect, itself itself, not_nil! not_nil!, pretty_inspect(width = 79, newline = "\n", indent = 0) : String pretty_inspect, pretty_print(pp : PrettyPrint) : Nil pretty_print, tap(&block) tap, to_json(io : IO)
to_json to_json, to_pretty_json(indent : String = " ")
to_pretty_json(io : IO, indent : String = " ") to_pretty_json, to_s
to_s(io : IO) to_s, to_yaml(io : IO)
to_yaml to_yaml, try(&block) try, unsafe_as(type : T.class) forall T unsafe_as
Constructor methods inherited from class Object
  
  
    
      from_json(string_or_io, root : String) : selffrom_json(string_or_io) : self from_json, from_yaml(string_or_io : String | IO) : self from_yaml
Constructor Detail
Generates UUID from bytes, applying version and variant to the UUID if present.
Creates UUID from 16-bytes slice. Raises if slice isn't 16 bytes long. See
#initialize for variant and version.
Creates another UUID which is a copy of uuid, but allows overriding
variant or version.
Creates new UUID by decoding value string from hyphenated (ie. ba714f86-cac6-42c7-8956-bcf5105e1b81),
hexstring (ie. 89370a4ab66440c8add39e06f2bb6af6) or URN (ie. urn:uuid:3f9eaf9e-cdb0-45cc-8ecb-0e5b2bfb0c20)
format.
Class Method Detail
Generates RFC 4122 v4 UUID.
It is strongly recommended to use a cryptographically random source for
random, such as Random::Secure.
Instance Method Detail
Returns true if other UUID represents the same UUID, false otherwise.