Project

usesguid

0.0
No commit activity in last 3 years
No release in over 3 years
A much faster version of the usesguid plugin for Rails ported to a gem (uses database for GUID generation)
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
 Dependencies

Development

~> 1.3
>= 0
 Project Readme

Changes in this Fork¶ ↑

  • Converted to Gem ported by C. Jason Harrelson (midas)

DETAILS¶ ↑

This plugin for ActiveRecord makes the “ID” field into a URL-safe GUID It is a mashup by Andy Singleton <andy@assembla.com> that includes

  • the UUID class from Bob Aman.

  • the plugin skeleton from Demetrius Nunes

  • the 22 character URL-safe format from Andy Singleton

You can get standard 36 char UUID formats instead TODO: Auto-detect a character ID field and use a GUID in this case (DRY principle)

It has been extended by Brian Morearty with:

  • the addition of a mysql_create function (configurable with a guid_generator accessor) for much better performance

  • id assignment is now done before_create instead of after_initialize, to more closely mimic the default Rails behavior of assigning an id upon save.

This library is free software; you can redistribute it and/or modify it under the terms of the MIT license.

USAGE¶ ↑

define ID as char(22) call “usesguid” in ActiveRecord class declaration, like:

class Mymodel < ActiveRecord::Base
  usesguid			
end

If your ID field is not called “ID”, call “usesguid :column =>‘IdColumnName’”

In order to use a GUID in another field that is not your primary key, id call usesguid like:

class Mymodel < ActiveRecord::Base
  usesguid, :as => :field
end

If you would like to validate your GUID a validation macro is provided:

class Mymodel < ActiveRecord::Base
  usesguid, :as => :field

  validate_guid
end

validate_guid is the same as:

validates_presence_of( ActiveRecord::Base.guid_column )
validates_uniqueness_of( ActiveRecord::Base.guid_column )
validates_length_of( ActiveRecord::Base.guid_column, :maximum => (ActiveRecord::Base.guid_compression == 's22' ? 22 : 36), :allow_blank => true )

If you use MySQL or SQL Server as your database, you can make guid generation much faster by using the database to generate GUIDs.

You can accomplish this by specifying the GUID generator in an initializer file. There are also options for guid_compression and guid_column.

ActiveRecord::Base.guid_generator   = :mysql # mysql or sqlserver
ActiveRecord::Base.guid_compression = :s     # :s for string or :s22 for compressed string
ActiveRecord::Base.guid_column      = 'guid' # the name of your GUID column