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

chokchit
** (DBConnection.ConnectionError) connection not available and request was dropped from queue after 2733ms. You can configure how long re...
New
vertexbuffer
Hello, can anybody help here..? I have a list of players and I what to delete an element, but every for loop the list is reverting to ori...
New
siddhant3030
Hi, I have to write a raw query for one of my project. But till now I have used ecto queries and don’t have much experience writing raw ...
New
ovidiubadita
Hey all, I discovered Elixir and I love it. I always wanted to learn a functional programming and I intended to go for Haskell, but afte...
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
jay1
Why is it that the mnesia database isn’t the most preferred database for use in Elixir/Phoenix?
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
vonH
When I run the Plug and I recompile I wind up having to use Ctrl C to quit iex and start again. Witht the help of rlwrap I can use the cu...
New
bsollish-terakeet
Credo is smart enough to check for (something like) this: assert length(the_list) == 0 with this response: Checking if an enum is empt...
New
chensan
I have a User schema with a :from_id field set to type :string: defmodule TweetBot.Repo.Migrations.CreateUsers do use Ecto.Migration ...
New

Other popular topics Top

albydarned
Hello all! I am typing this post from my new MacBook Pro with the M1 chip. I’m loving it so far, and will probably use it as my daily dr...
New
lessless
I believe there are people here who are dealing with CSV files import on the daily basis, and since Excel is a really popular tool there ...
New
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
shahryarjb
Hello, I have map which I want to convert it to string like this: the map: %{last_name: "tavakkoli", name: "shahryar"} the string I ne...
New
JorisKok
I have a server on AWS, and was running a load test using artillery. When looking at the Phoenix dashboard I see the Ports going to 100% ...
New
AngeloChecked
What learn first? Rust or Elixir Hi Elixir community! I’m here because i want learn a new language. I’m a junior developer and mainly i ...
New
gausby
I asked this very same question on twitter and got some interesting feedback, but I thought it would be a good question to ask here as we...
1207 39297 209
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
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
vonH
In asking this question I am more interested about the expressiveness of the language itself and less concerned about the availability of...
New

We're in Beta

About us Mission Statement