class User
- User
- Reference
- Object
Included Modules
- Lustra::Model
Extended Modules
- Lustra::Model::HasHooks::ClassMethods
Defined in:
models/user.crConstant Summary
-
COLUMNS =
{"id" => {type: Int64, primary: true, converter: "Int64", db_column_name: "id", crystal_variable_name: id, presence: false, mass_assign: true}, "telegram_id" => {type: Int64, primary: false, converter: "Int64", db_column_name: "telegram_id", crystal_variable_name: telegram_id, presence: true, mass_assign: true}, "first_name" => {type: String, primary: false, converter: "String", db_column_name: "first_name", crystal_variable_name: first_name, presence: true, mass_assign: true}, "last_name" => {type: String | ::Nil, primary: false, converter: "String", db_column_name: "last_name", crystal_variable_name: last_name, presence: true, mass_assign: true}, "username" => {type: String | ::Nil, primary: false, converter: "String", db_column_name: "username", crystal_variable_name: username, presence: true, mass_assign: true}, "language_code" => {type: String | ::Nil, primary: false, converter: "String", db_column_name: "language_code", crystal_variable_name: language_code, presence: true, mass_assign: true}, "updated_at" => {type: Time, primary: false, converter: "Time", db_column_name: "updated_at", crystal_variable_name: updated_at, presence: true, mass_assign: true}, "created_at" => {type: Time, primary: false, converter: "Time", db_column_name: "created_at", crystal_variable_name: created_at, presence: true, mass_assign: true}} of Nil => Nil -
POLYMORPHISM_SETTINGS =
{} of Nil => Nil
Constructors
-
.build(x : NamedTuple) : self
Build a new empty model and fill the columns using the NamedTuple in argument.
-
.build(x : NamedTuple, &block : self -> Nil) : self
Build a new empty model and fill the columns using the NamedTuple in argument.
-
.create(x : NamedTuple, &block : self -> Nil) : self
Build and new model and save it.
-
.create(**tuple, &block : self -> Nil) : self
Build and new model and save it.
-
.create(x : NamedTuple) : self
Build and new model and save it.
-
.create(**tuple) : self
Build and new model and save it.
-
.create!(x : NamedTuple, &block : self -> Nil) : self
Build and new model and save it.
-
.create!(**tuple, &block : self -> Nil) : self
Build and new model and save it.
-
.create!(x : NamedTuple) : self
Build and new model and save it.
-
.create!(**tuple) : self
Build and new model and save it.
- .new(h : Hash(String, _), cache : Lustra::Model::QueryCache | Nil = nil, persisted = false, fetch_columns = false)
- .new(json : JSON::Any, cache : Lustra::Model::QueryCache | Nil = nil, persisted = false)
- .new(t : NamedTuple, persisted = false)
- .new
Class Method Summary
-
.build(**tuple : **T) forall T
Build a new empty model and fill the columns using the NamedTuple in argument.
-
.build(**tuple)
Build a new empty model and fill the columns using the NamedTuple in argument.
-
.build(**tuple, &)
Build a new empty model and fill the columns using the NamedTuple in argument.
- .columns
-
.connection : String
Define on which connection the model is living.
-
.connection=(connection : String)
Define on which connection the model is living.
-
.create_from_json(string_or_io : String | IO, trusted : Bool = false)
Create a new model from json and save it.
-
.create_from_json!(string_or_io : String | IO, trusted : Bool = false)
Create a new model from json and save it.
-
.find(ids : Array)
Find multiple models by an array of primary keys.
-
.find(x)
Returns a model using primary key equality Returns
nilif not found. -
.find!(ids : Array)
Find multiple models by an array of primary keys.
-
.find!(x)
Returns a model using primary key equality.
-
.find_by(tuple : NamedTuple)
Find a model by column values.
-
.find_by(**tuple)
Find a model by column values.
-
.find_by!(tuple : NamedTuple)
Find a model by column values.
-
.find_by!(**tuple)
Find a model by column values.
-
.from_json(string_or_io : String | IO, trusted : Bool = false)
Create a new empty model and fill the columns from json.
-
.full_table_name
returns the fully qualified and escaped name for this table.
-
.import(array : Enumerable(self), on_conflict : Lustra::SQL::InsertQuery -> | Nil = nil)
Import a bulk of models in one SQL insert query.
- .polymorphic? : Bool
-
.query
Return a new query
SELECT * FROM [my_model_table]. - .read_only=(read_only : Bool)
- .read_only? : Bool
-
.register_counter_cache(association_model : Class, counter_column : String, foreign_key : String)
Register a counter cache for this model using model class
-
.reset_counters(id, *counter_models)
Reset counter cache columns to their correct values.
-
.schema : Lustra::SQL::Symbolic | Nil
Define the current schema used in PostgreSQL.
-
.schema=(schema : Lustra::SQL::Symbolic | Nil)
Define the current schema used in PostgreSQL.
-
.table : Lustra::SQL::Symbolic
Return the table name setup for this model.
-
.table=(table : Lustra::SQL::Symbolic)
Return the table name setup for this model.
Instance Method Summary
-
#add_built_association(association_name : String, model : Lustra::Model)
Add a built association to track for autosave
-
#attributes : Hash(String, Lustra::SQL::Any)
Attributes, used when fetch_columns is true
-
#built_associations : Hash(String, Array(Lustra::Model))
Track built associations for autosave functionality
-
#built_associations=(built_associations : Hash(String, Array(Lustra::Model)))
Track built associations for autosave functionality
- #cache : Lustra::Model::QueryCache | Nil
-
#changed : Array(String)
Returns an array of names of all changed attributes.
-
#changed?
Return
trueif the model is dirty (e.g. -
#changes : Hash(String, Tuple(Lustra::SQL::Any, Lustra::SQL::Any))
Returns a hash of all changed attributes with their [old_value, new_value].
-
#clear_built_associations
Clear all built associations (called after successful save)
-
#clear_change_flags
Reset the
#changed?flag on all columns -
#created_at : Time
Returns the value of
#created_atcolumn or throw an exception if the column is not defined. -
#created_at=(x : Time)
Setter for
#created_atcolumn. -
#created_at_column : Lustra::Model::Column(Time, Lustra::Model::Converter::TimeConverter)
Returns the column object used to manage
#created_atfield -
#first_name : String
Returns the value of
#first_namecolumn or throw an exception if the column is not defined. -
#first_name=(x : String)
Setter for
#first_namecolumn. -
#first_name_column : Lustra::Model::Column(String, Lustra::Model::Converter::StringConverter)
Returns the column object used to manage
#first_namefield -
#has_built_associations? : Bool
Check if there are any pending built associations
-
#id : Int64
Returns the value of
#idcolumn or throw an exception if the column is not defined. -
#id=(x : Int64)
Setter for
#idcolumn. -
#id_column : Lustra::Model::Column(Int64, Lustra::Model::Converter::Int64Converter)
Returns the column object used to manage
#idfield -
#invalidate_caching : self
Force to clean-up the caches for the relations connected to this model.
-
#language_code : String | Nil
Returns the value of
#language_codecolumn or throw an exception if the column is not defined. -
#language_code=(x : String | Nil)
Setter for
#language_codecolumn. -
#language_code_column : Lustra::Model::Column(String | Nil, Lustra::Model::Converter::StringConverter)
Returns the column object used to manage
#language_codefield -
#last_name : String | Nil
Returns the value of
#last_namecolumn or throw an exception if the column is not defined. -
#last_name=(x : String | Nil)
Setter for
#last_namecolumn. -
#last_name_column : Lustra::Model::Column(String | Nil, Lustra::Model::Converter::StringConverter)
Returns the column object used to manage
#last_namefield -
#reset(h : Hash(Symbol, _))
Set the columns from hash
-
#reset(h : Hash(String, _))
Set the model fields from hash
- #reset(t : NamedTuple)
- #reset(from_json : JSON::Any)
-
#reset(**t : **T) forall T
reset flavors
-
#reset_counters(*counter_models)
Reset counter cache columns
-
#set(h : Hash(Symbol, _))
Set the columns from hash
-
#set(h : Hash(String, _))
Set the model fields from hash
- #set(t : NamedTuple)
- #set(from_json : JSON::Any)
-
#set(**t : **T) forall T
Set one or multiple columns to a specific value This two are equivalents:
-
#set_from_json(string_or_io : String | IO, trusted : Bool = false)
Set the fields from json passed as argument Trusted flag set to true will allow mass assignment without protection, FALSE by default
-
#telegram_id : Int64
Returns the value of
#telegram_idcolumn or throw an exception if the column is not defined. -
#telegram_id=(x : Int64)
Setter for
#telegram_idcolumn. -
#telegram_id_column : Lustra::Model::Column(Int64, Lustra::Model::Converter::Int64Converter)
Returns the column object used to manage
#telegram_idfield -
#to_h(full = false) : Hash(String, Lustra::SQL::Any)
Return a hash version of the columns of this model.
- #to_json(emit_nulls : Bool = false)
- #to_json(json, emit_nulls = false)
-
#touch(time : Time = Time.local) : Lustra::Model
Updates timestamp columns without triggering validations or callbacks.
-
#touch(column : Symbol | String, time : Time = Time.local) : Lustra::Model
Updates the specified column and updated_at without triggering validations or callbacks.
-
#touch(columns : Array(Symbol | String), time : Time = Time.local) : Lustra::Model
Updates multiple timestamp columns without triggering validations or callbacks.
-
#touch(*columns, time : Time = Time.local) : Lustra::Model
Updates multiple timestamp columns at once.
-
#update_from_json(string_or_io : String | IO, trusted : Bool = false)
Set the fields from json passed as argument and call
saveon the object Trusted flag set to true will allow mass assignment without protection, FALSE by default -
#update_from_json!(string_or_io : String | IO, trusted : Bool = false)
Set the fields from json passed as argument and call
save!on the object Trusted flag set to true will allow mass assignment without protection, FALSE by default -
#update_h : Hash(String, Lustra::SQL::Any)
Generate the hash for update request (like during save)
-
#updated_at : Time
Returns the value of
#updated_atcolumn or throw an exception if the column is not defined. -
#updated_at=(x : Time)
Setter for
#updated_atcolumn. -
#updated_at_column : Lustra::Model::Column(Time, Lustra::Model::Converter::TimeConverter)
Returns the column object used to manage
#updated_atfield -
#username : String | Nil
Returns the value of
#usernamecolumn or throw an exception if the column is not defined. -
#username=(x : String | Nil)
Setter for
#usernamecolumn. -
#username_column : Lustra::Model::Column(String | Nil, Lustra::Model::Converter::StringConverter)
Returns the column object used to manage
#usernamefield -
#validate_fields_presence
For each column, ensure than when needed the column has present information into it.
Constructor Detail
Build a new empty model and fill the columns using the NamedTuple in argument.
Returns the new model
Build a new empty model and fill the columns using the NamedTuple in argument.
Returns the new model
Build and new model and save it. Returns the model.
The model may not be saved due to validation failure;
check the returned model errors? and persisted? flags.
Build and new model and save it. Returns the model.
The model may not be saved due to validation failure;
check the returned model errors? and persisted? flags.
Build and new model and save it. Returns the model.
The model may not be saved due to validation failure;
check the returned model errors? and persisted? flags.
Build and new model and save it. Returns the model.
The model may not be saved due to validation failure;
check the returned model errors? and persisted? flags.
Build and new model and save it. Returns the model.
Returns the newly inserted model Raises an exception if validation failed during the saving process.
Build and new model and save it. Returns the model.
Returns the newly inserted model Raises an exception if validation failed during the saving process.
Build and new model and save it. Returns the model.
Returns the newly inserted model Raises an exception if validation failed during the saving process.
Build and new model and save it. Returns the model.
Returns the newly inserted model Raises an exception if validation failed during the saving process.
Class Method Detail
Build a new empty model and fill the columns using the NamedTuple in argument.
Returns the new model
Build a new empty model and fill the columns using the NamedTuple in argument.
Returns the new model
Build a new empty model and fill the columns using the NamedTuple in argument.
Returns the new model
Define on which connection the model is living. Useful in case of models living in different databases.
Is set to "default" by default.
See Lustra::SQL#init(URI, *opts) for more information about multi-connections.
Example:
Lustra::SQL.init("postgres://postgres@localhost/database_1")
Lustra::SQL.init("secondary", "postgres://postgres@localhost/database_2")
class ModelA
include Lustra::Model
# Performs all the queries on `database_1`
# self.connection = "default"
column id : Int32, primary: true, presence: false
column title : String
end
class ModelB
include Lustra::Model
# Performs all the queries on `database_2`
self.connection = "secondary"
column id : Int32, primary: true, presence: false
end
Define on which connection the model is living. Useful in case of models living in different databases.
Is set to "default" by default.
See Lustra::SQL#init(URI, *opts) for more information about multi-connections.
Example:
Lustra::SQL.init("postgres://postgres@localhost/database_1")
Lustra::SQL.init("secondary", "postgres://postgres@localhost/database_2")
class ModelA
include Lustra::Model
# Performs all the queries on `database_1`
# self.connection = "default"
column id : Int32, primary: true, presence: false
column title : String
end
class ModelB
include Lustra::Model
# Performs all the queries on `database_2`
self.connection = "secondary"
column id : Int32, primary: true, presence: false
end
Create a new model from json and save it. Returns the model.
The model may not be saved due to validation failure;
check the returned model errors? and persisted? flags.
Trusted flag set to true will allow mass assignment without protection, FALSE by default
Create a new model from json and save it. Returns the model.
Returns the newly inserted model Raises an exception if validation failed during the saving process. Trusted flag set to true will allow mass assignment without protection, FALSE by default
Find multiple models by an array of primary keys. Returns an array of models (may be empty if none found).
users = User.find([1, 2, 3])
users.size # => 0..3 depending on how many were found
Find multiple models by an array of primary keys. Raises error if ANY of the IDs are not found.
users = User.find!([1, 2, 3]) # Raises if any ID is not found
Returns a model using primary key equality. Raises error if the model is not found.
Find a model by column values. Returns nil if not found.
This is an alias for query.find(**tuple) with better naming.
user = User.find_by(email: "[email protected]")
user = User.find_by(first_name: "John", last_name: "Doe")
Find a model by column values. Returns nil if not found.
This is an alias for query.find(**tuple) with better naming.
user = User.find_by(email: "[email protected]")
user = User.find_by(first_name: "John", last_name: "Doe")
Find a model by column values. Raises error if not found.
This is an alias for query.find!(**tuple) with better naming.
user = User.find_by!(email: "[email protected]")
Find a model by column values. Raises error if not found.
This is an alias for query.find!(**tuple) with better naming.
user = User.find_by!(email: "[email protected]")
Create a new empty model and fill the columns from json. Returns the new model
Trusted flag set to true will allow mass assignment without protection, FALSE by default
returns the fully qualified and escaped name for this table. add schema if schema is different from 'public' (default schema)
ex: "schema"."table"
Import a bulk of models in one SQL insert query. Each model must be non-persisted.
on_conflict callback can be optionnaly turned on
to manage constraints of the database.
Note: Old models are not modified. This method return a copy of the models as saved in the database.
Example:
users = [User.new(id: 1), User.new(id: 2), User.new(id: 3)]
users = User.import(users)
Return a new query SELECT * FROM [my_model_table]. Can be refined after that.
Automatically applies default_scope if defined.
Register a counter cache for this model using model class
Reset counter cache columns to their correct values. This is useful when counter caches become out of sync due to direct SQL operations.
Example:
User.reset_counters(user.id, Post)
User.reset_counters(user.id, Post, Comment)
Define the current schema used in PostgreSQL. The value is nil by default, which lead to non-specified
schema during the querying, and usage of "public" by PostgreSQL.
This property can be redefined on initialization. Example:
class MyModel
include Lustra::Model
self.schema = "my_schema"
end
MyModel.query.to_sql # SELECT * FROM "my_schema"."my_models"
Define the current schema used in PostgreSQL. The value is nil by default, which lead to non-specified
schema during the querying, and usage of "public" by PostgreSQL.
This property can be redefined on initialization. Example:
class MyModel
include Lustra::Model
self.schema = "my_schema"
end
MyModel.query.to_sql # SELECT * FROM "my_schema"."my_models"
Return the table name setup for this model. By convention, the class name is by default equals to the pluralized underscored string form of the model name. Example:
MyModel => "my_models"
Person => "people"
Project::Info => "project_infos"
The property can be updated at initialization to a custom table name:
class MyModel
include Lustra::Model
self.table = "another_table_name"
end
MyModel.query.to_sql # SELECT * FROM "another_table_name"
Return the table name setup for this model. By convention, the class name is by default equals to the pluralized underscored string form of the model name. Example:
MyModel => "my_models"
Person => "people"
Project::Info => "project_infos"
The property can be updated at initialization to a custom table name:
class MyModel
include Lustra::Model
self.table = "another_table_name"
end
MyModel.query.to_sql # SELECT * FROM "another_table_name"
Instance Method Detail
Add a built association to track for autosave
Track built associations for autosave functionality
Track built associations for autosave functionality
Returns an array of names of all changed attributes.
user.email = "[email protected]"
user.first_name = "John"
user.changed # => ["email", "first_name"]
Return true if the model is dirty (e.g. one or more fields
have been changed.). Return false otherwise.
Returns a hash of all changed attributes with their [old_value, new_value].
user.email = "[email protected]"
user.first_name = "John"
user.changes # => {"email" => ["[email protected]", "[email protected]"], "first_name" => [nil, "John"]}
Reset the #changed? flag on all columns
The model behave like its not dirty anymore and call to save would apply no changes.
Returns self
Returns the value of #created_at column or throw an exception if the column is not defined.
Returns the column object used to manage #created_at field
See Lustra::Model::Column
Returns the value of #first_name column or throw an exception if the column is not defined.
Returns the column object used to manage #first_name field
See Lustra::Model::Column
Returns the value of #id column or throw an exception if the column is not defined.
Returns the column object used to manage #id field
See Lustra::Model::Column
Force to clean-up the caches for the relations connected to this model.
Returns the value of #language_code column or throw an exception if the column is not defined.
Returns the column object used to manage #language_code field
See Lustra::Model::Column
Returns the value of #last_name column or throw an exception if the column is not defined.
Returns the column object used to manage #last_name field
See Lustra::Model::Column
Reset counter cache columns
Example:
user = User.find(1)
user.reset_counters(Post)
user.reset_counters(Post, Comment)
Set one or multiple columns to a specific value This two are equivalents:
model.set(a: 1)
model.a = 1
Set the fields from json passed as argument Trusted flag set to true will allow mass assignment without protection, FALSE by default
Returns the value of #telegram_id column or throw an exception if the column is not defined.
Returns the column object used to manage #telegram_id field
See Lustra::Model::Column
Return a hash version of the columns of this model.
Updates timestamp columns without triggering validations or callbacks.
user.touch # Updates updated_at
user.touch(2.days.ago) # Updates updated_at to specific time
Updates the specified column and updated_at without triggering validations or callbacks.
user.touch(:last_login_at) # Updates last_login_at and updated_at
user.touch(:last_seen_at, 1.hour.ago)
Updates multiple timestamp columns without triggering validations or callbacks.
user.touch([:last_login_at, :last_seen_at])
user.touch([:last_login_at, :last_seen_at], 3.days.ago)
Updates multiple timestamp columns at once.
user.touch(:last_login_at, :last_seen_at)
user.touch(:last_login_at, :last_seen_at, time: 1.day.ago)
Set the fields from json passed as argument and call save on the object
Trusted flag set to true will allow mass assignment without protection, FALSE by default
Set the fields from json passed as argument and call save! on the object
Trusted flag set to true will allow mass assignment without protection, FALSE by default
Generate the hash for update request (like during save)
Returns the value of #updated_at column or throw an exception if the column is not defined.
Returns the column object used to manage #updated_at field
See Lustra::Model::Column
Returns the value of #username column or throw an exception if the column is not defined.
Returns the column object used to manage #username field
See Lustra::Model::Column
For each column, ensure than when needed the column has present information into it.
This method is called on validation.