JulienCorb

JulienCorb

Protocol Enumerable not implemented for

I am trying to implement my new.html.eex file to create new posts on my website.

new.html.eex:

<h1>Create Post</h1>
<%= form_for @changeset, post_path(@conn, :create, @current_user.id), fn f -> %>
  <%= if @changeset.action do %>
    <div class="alert alert-danger">
      <p>There are some errors</p>
    </div>
  <% end %>
  <div class="form-group">
    <%= text_input f, :title, placeholder: "Title",
                              class: "form-control" %>
    <%= error_tag f, :title %>
  </div>
  <div class="form-group">
    <%= textarea f, :body, placeholder: "Body", class: "form-control" %>
    <%= error_tag f, :body %>
  </div>
  <%= submit "Create post", class: "btn btn-primary" %>
<% end %>

new and create methods in post_controller.ex:

  def new(conn, _params, current_user) do
    changeset =
    current_user
    |> Ecto.build_assoc(:posts)
    |> Post.changeset
    render conn, "new.html", changeset: changeset
  end

  def create(conn, %{"post" => post_params}, current_user) do
    changeset =
    current_user
    |> Ecto.build_assoc(:posts)
    |> Post.changeset(post_params)
    case Repo.insert(changeset) do
      {:ok, _} ->
        conn
        |> put_flash(:info, "Post was created successfully")
        |> redirect(to: post_path(conn, :index, current_user.id))
        {:error, changeset} ->
          render(conn, "new.html", changeset: changeset)
    end
  end

But I can’t access the template. I get the following error:

protocol Enumerable not implemented for 1. This protocol is implemented for: DBConnection.PrepareStream, DBConnection.Stream, Date.Range, Ecto.Adapters.SQL.Stream, File.Stream, Function, GenEvent.Stream, HashDict, HashSet, IO.Stream, List, Map, MapSet, Postgrex.Stream, Range, Stream

Things seems to get wrong in the router, so here is my router.ex:

defmodule GazetteWeb.Router do
  use GazetteWeb, :router

  pipeline :browser do
    plug :accepts, ["html"]
    plug :fetch_session
    plug :fetch_flash
    plug :protect_from_forgery
    plug :put_secure_browser_headers
  end

  pipeline :api do
    plug :accepts, ["json"]
  end

  pipeline :with_session do #if a user is signed in
    plug Guardian.Plug.VerifySession
    plug Guardian.Plug.LoadResource
    plug Gazette.CurrentUser
  end

  pipeline :admin_required do
    plug Gazette.CheckAdmin
  end

  pipeline :login_required do

  end

  scope "/posts", GazetteWeb do
    pipe_through [:browser, :with_session, :admin_required]
    resources "/", PostController, except: [:index, :show]
  end

  scope "/", GazetteWeb do
    pipe_through [:browser, :with_session]

    get "/", PageController, :index

    resources "/users", UserController, only: [:show, :new, :create]
    resources "/sessions", SessionController, only: [:new, :create, :delete]
    resources "/posts", PostController, only: [:index, :show]
  end


  # Other scopes may use custom stacks.
  # scope "/api", GazetteWeb do
  #   pipe_through :api
  # end
end

any Idea ?

Marked As Solved

JulienCorb

JulienCorb

the stacktrace:

 elixir /private/tmp/elixir-20180111-94038-1oxcohh/elixir-1.5.3/lib/elixir/lib/enum.ex:1 Enumerable.impl_for!/1
 elixir /private/tmp/elixir-20180111-94038-1oxcohh/elixir-1.5.3/lib/elixir/lib/enum.ex:116 Enumerable.reduce/3
 elixir lib/enum.ex:1850 Enum.reduce/3
 lib/gazette_web/router.ex:1 GazetteWeb.Router.Helpers.segments/3
 lib/gazette_web/router.ex:1 GazetteWeb.Router.Helpers.post_path/3
 lib/gazette_web/templates/post/new.html.eex:2 GazetteWeb.PostView."new.html"/1
 lib/gazette_web/templates/layout/app.html.eex:26 GazetteWeb.LayoutView."app.html"/1
 phoenix lib/phoenix/view.ex:332 Phoenix.View.render_to_iodata/3
 phoenix lib/phoenix/controller.ex:740 Phoenix.Controller.do_render/4
 lib/gazette_web/controllers/post_controller.ex:1 GazetteWeb.PostController.action/2
 lib/gazette_web/controllers/post_controller.ex:1 GazetteWeb.PostController.phoenix_controller_pipeline/2
 lib/gazette_web/endpoint.ex:1 GazetteWeb.Endpoint.instrument/4
 phoenix lib/phoenix/router.ex:278 Phoenix.Router.__call__/1
 lib/gazette_web/endpoint.ex:1 GazetteWeb.Endpoint.plug_builder_call/2
 lib/plug/debugger.ex:99 GazetteWeb.Endpoint."call (overridable 3)"/2
 lib/gazette_web/endpoint.ex:1 GazetteWeb.Endpoint.call/2
 plug lib/plug/adapters/cowboy/handler.ex:15 Plug.Adapters.Cowboy.Handler.upgrade/4
  • UPDATE: I got it working by removing @current_user from the controller and the template.

However, I am wondering if it works right: here is my DB:

iex(2)> Gazette.Repo.all(Gazette.Post)
[debug] QUERY OK source="posts" db=3.2ms decode=5.6ms
SELECT p0."id", p0."body", p0."title", p0."user_id", p0."inserted_at", p0."updated_at" FROM "posts" AS p0 []
[%Gazette.Post{__meta__: #Ecto.Schema.Metadata<:loaded, "posts">,
  body: "Alors voici mon tout premier post. J'espère qu'il en appellera bien d'autres, de bonne qualité et plaisant pour les lecteurs. J'ai hâte que tout cela démarre ! ",
  id: 1, inserted_at: ~N[2018-02-12 17:05:54.966289],
  title: "Mon tout Premier Post !! ",
  updated_at: ~N[2018-02-12 17:05:54.966325],
  user: #Ecto.Association.NotLoaded<association :user is not loaded>,
  user_id: 1},

What is this user: #Ecto.Association.NotLoaded<association :user is not loaded>, ??

Also Liked

idi527

idi527

You would first need to preload it.

For example,

Repo.preload(post, :user)
idi527

idi527

What is this user: #Ecto.Association.NotLoaded, ??

It’s something like a placeholder. It allows for lazy-loading resources.

idi527

idi527

The problem seems to be that post_path(@conn, :create, @current_user.id) accepts 3 arguments, where the last is a list of options. So you should probably change it to post_path(@conn, :create).

With options it would be

post_path(@conn, :create, to: "a", by: "b")
# which is the same as
post_path(@conn, :create, [to: "a", by: "b"])
# which is the same as
post_path(@conn, :create, [{:to, "a"}, {:by, "b"}])
# and results in
"/posts?to=a&by=b"

Where Next?

Popular in Questions Top

gshaw
What is the idiomatic way of matching for not nil in Elixir? E.g., First way: defp halt_if_not_signed_in(conn, signed_in_account) when...
New
electic
Hi, I am new to Elixir. I am trying to use the DateTime component to insert a date into MySQL however the there seems to be no way to fo...
New
minhajuddin
I have seen a lot of code which picks the first element from a list using Enum.at(0) instead of List.first. Is there a reason why people ...
New
earth10
Hi, I’m just starting to build a side-project with Elixir and Phoenix and doing some basic test with Elixir alone. What strikes me is th...
New
ycv005
I have followed this StackOverflow post to install the specific version of Erlang. And When I am running mix ecto.setup then getting fol...
New
jay1
Why is it that the mnesia database isn’t the most preferred database for use in Elixir/Phoenix?
New
belgoros
I’m not a pro in using Regex and can’t figure out why the following behaviour happens, especially if we take into account the difference ...
New
script
If I have a string “1000 cfu/ml” . I want to remove the characters and / and space . So the string is like this "1000" What is the ...
New
nsuchy
Hi. I’ve noticed that Windows Powershell has it’s own IEX command and you cannot access Elixir’s IEX due to the conflict. This isn’t a cr...
New
jononomo
For some reason my phoenix channels are working for me in my local dev environment, but as soon as I deploy via Docker, I get a 403 error...
New

Other popular topics Top

marius95
Hello everyone, I try to use an Javascript Event Handler in my root.html.leex file. Therefore I created a function in the app.js file: ...
New
electic
Hi, I am new to Elixir. I am trying to use the DateTime component to insert a date into MySQL however the there seems to be no way to fo...
New
jerry
Good day to you all. I have been struggling to get a query involving like and ilike to work. Can anyone assist me on this, please? pro...
New
josevalim
Hi everyone, One of the features added to Elixir early on to help integration with Erlang code was the idea of overridable function defi...
New
alice
Hey, Just curious what are the main benefits of Elixir compared to Clojure? When is Elixir more useful than Clojure and vice versa? Th...
New
jason.o
In the code below, if the create action is not set to accept “extra_key” as an input, it errors out with a message shown above. Is there ...
New
dblack
I’ve got an issue with an app and I’ve no idea of how to troubleshoot it. I’m hoping someone here might have seen something similar. I p...
New
boundedvariable
I am going through the kafka architecture. All the features what the kafka is providing are already in Erlang. I would like hear your opi...
New
marick
I had some trouble figuring out how to make many-to-many associations work. Once I got it working, I wrote a blog post. Because I’m a nov...
New
Qqwy
Update: How to use the Blogs &amp; Podcasts section You can post links to your blog posts or podcasts either in one of the Official Blog...
3271 126479 1222
New

We're in Beta

About us Mission Statement