I am creating a custom read action to get students by :roll_number and :password.
defmodule MyApp.Students.Student do
use Ash.Resource,
domain: MyApp.Students,
data_layer: AshPostgres.DataLayer,
extensions: [
AshJsonApi.Resource
]
json_api do
type "student"
routes do
base("/students")
get(:read, route: ":id")
index :read
get(:get_by_roll, route: "by_roll")
end
end
actions do
read :read do
primary? true
end
read :get_by_roll do
argument :roll_number, :string, allow_nil?: false
argument :password, :string, allow_nil?: false
filter expr(roll_number == ^arg(:roll_number) && password == ^arg(:password))
end
end
postgres do
table "students"
repo MyApp.Repo
end
attributes do
attribute :id, :uuid do
writable? false
primary_key? true
default &Ecto.UUID.generate/0
allow_nil? false
public? true
end
attribute :first_name, :string do
allow_nil? false
public? true
end
attribute :last_name, :string do
allow_nil? false
public? true
end
attribute :class, :string, public?: true
attribute :section, :string, public?: true
attribute :dob, :date, public?: true
attribute :father_name, :string, public?: true
attribute :mother_name, :string, public?: true
attribute :roll_number, :string, public?: true
attribute :password, :string, public?: true
create_timestamp :inserted_at
update_timestamp :updated_at
end
end
API Endpoint call
localhost:4000/api/students/by_roll?roll_number=100&password=sakthibalan@100
Getting Error:
Exception:
** (KeyError) key :id not found in: %Ash.Error.Unknown{
errors: [
%Ash.Error.Unknown.UnknownError{
error: "** (Postgrex.Error) ERROR 42883 (undefined_function) function ash_elixir_and(boolean, boolean) does not exist\n\n query: SELECT s0.\"id\", s0.\"first_name\", s0.\"last_name\", s0.\"class\", s0.\"section\", s0.\"dob\", s0.\"father_name\", s0.\"mother_name\", s0.\"roll_number\", s0.\"password\", s0.\"inserted_at\", s0.\"updated_at\" FROM \"students\" AS s0 WHERE ((ash_elixir_and(s0.\"roll_number\"::text = $1::text, s0.\"password\"::text = $2::text)))\n\n hint: No function matches the given name and argument types. You might need to add explicit type casts.",
field: nil,
splode: Ash.Error,
bread_crumbs: [],
vars: [],
path: [],
stacktrace: #Splode.Stacktrace<>,
class: :unknown
}
]
}
(ash_json_api 1.0.0) lib/ash_json_api/serializer.ex:111: AshJsonApi.Serializer.serialize_one_error/2