Ecto.Rut
Ecto Model shortcuts to make your life easier! :tada:
Tired of calling YourApp.Repo in your Ecto app for all CRUD operations? Sick of code repetitions?
Want to create, find, update and delete model objects the old ruby-way? Fret no more, Ecto.Rut is here!
Installation
Add :ecto_rut as a dependency in your mix.exs file:
defp deps do
[
{:ecto_rut, "~> 1.0.0-alpha"}
]
endand run:
$ mix deps.getPhoenix Projects
If you have an app built in Phoenix Framework, just add use Ecto.Rut in the models method
in web/web.ex:
# web/web.ex
def model do
quote do
use Ecto.Schema
use Ecto.Rut
# Other stuff...
end
end
That's it! Ecto.Rut will automatically be loaded in all of your models. You can now relax!
Other Ecto Projects
If you're not using Phoenix or you don't want to use Ecto.Rut with all of your models (why wouldn't
you!?), you'll have to manually add use Ecto.Rut:
defmodule YourApp.Post do
use Ecto.Schema
use Ecto.Rut
# Schema, Changeset and other stuff...
endBasic Usage
You can call normal Ecto.Repo methods directly on the Models:
Post.all
# instead of YourApp.Repo.all(Post)
Post.get(2)
# instead of YourApp.Repo.get(Post, 2)
# Other available methods:
Post.insert(%Post{title: "awesome_post"})
Post.delete(bad_post)Todo
Write Tests
Write Documentation
Cover all main
Ecto.RepomethodsIntroduce new wrapper methods that accept direct arguments
# Examples Post.create title: "Another Post", category: "Ramblings" Post.delete_by_id(3)
Contributing
- Fork the Project
-
Create your feature branch (
git checkout -b my-new-feature) -
Commit your changes (
git commit -am 'Add some feature') -
Push to the branch (
git push origin my-new-feature) - Create a new Pull Request
License
This package is available as open source under the terms of the MIT License.