Merge pull request #4459 from tchak/graphql-post-message
[GraphQL] Add dossierEnvoyerMessage mutation
This commit is contained in:
commit
111e7509c1
7 changed files with 181 additions and 2 deletions
27
app/graphql/mutations/dossier_envoyer_message.rb
Normal file
27
app/graphql/mutations/dossier_envoyer_message.rb
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
module Mutations
|
||||||
|
class DossierEnvoyerMessage < Mutations::BaseMutation
|
||||||
|
description "Envoyer un message à l'usager du dossier."
|
||||||
|
|
||||||
|
argument :dossier_id, ID, required: true, loads: Types::DossierType
|
||||||
|
argument :instructeur_id, ID, required: true, loads: Types::ProfileType
|
||||||
|
argument :body, String, required: true
|
||||||
|
argument :attachment, ID, required: false
|
||||||
|
|
||||||
|
field :message, Types::MessageType, null: true
|
||||||
|
field :errors, [Types::ValidationErrorType], null: true
|
||||||
|
|
||||||
|
def resolve(dossier:, instructeur:, body:, attachment: nil)
|
||||||
|
message = CommentaireService.build(instructeur, dossier, body: body, piece_jointe: attachment)
|
||||||
|
|
||||||
|
if message.save
|
||||||
|
{ message: message }
|
||||||
|
else
|
||||||
|
{ errors: message.errors.full_messages }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def authorized?(dossier:, instructeur:, body:)
|
||||||
|
instructeur.is_a?(Instructeur) && instructeur.dossiers.exists?(id: dossier.id)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -352,6 +352,33 @@ type DossierEdge {
|
||||||
node: Dossier
|
node: Dossier
|
||||||
}
|
}
|
||||||
|
|
||||||
|
"""
|
||||||
|
Autogenerated input type of DossierEnvoyerMessage
|
||||||
|
"""
|
||||||
|
input DossierEnvoyerMessageInput {
|
||||||
|
attachment: ID
|
||||||
|
body: String!
|
||||||
|
|
||||||
|
"""
|
||||||
|
A unique identifier for the client performing the mutation.
|
||||||
|
"""
|
||||||
|
clientMutationId: String
|
||||||
|
dossierId: ID!
|
||||||
|
instructeurId: ID!
|
||||||
|
}
|
||||||
|
|
||||||
|
"""
|
||||||
|
Autogenerated return type of DossierEnvoyerMessage
|
||||||
|
"""
|
||||||
|
type DossierEnvoyerMessagePayload {
|
||||||
|
"""
|
||||||
|
A unique identifier for the client performing the mutation.
|
||||||
|
"""
|
||||||
|
clientMutationId: String
|
||||||
|
errors: [ValidationError!]
|
||||||
|
message: Message
|
||||||
|
}
|
||||||
|
|
||||||
type DossierLinkChamp implements Champ {
|
type DossierLinkChamp implements Champ {
|
||||||
dossier: Dossier
|
dossier: Dossier
|
||||||
id: ID!
|
id: ID!
|
||||||
|
@ -495,6 +522,11 @@ type Mutation {
|
||||||
File information required to prepare a direct upload
|
File information required to prepare a direct upload
|
||||||
"""
|
"""
|
||||||
createDirectUpload(input: CreateDirectUploadInput!): CreateDirectUploadPayload
|
createDirectUpload(input: CreateDirectUploadInput!): CreateDirectUploadPayload
|
||||||
|
|
||||||
|
"""
|
||||||
|
Envoyer un message à l'usager du dossier.
|
||||||
|
"""
|
||||||
|
dossierEnvoyerMessage(input: DossierEnvoyerMessageInput!): DossierEnvoyerMessagePayload
|
||||||
}
|
}
|
||||||
|
|
||||||
enum Order {
|
enum Order {
|
||||||
|
@ -806,4 +838,14 @@ enum TypeDeChamp {
|
||||||
"""
|
"""
|
||||||
A valid URL, transported as a string
|
A valid URL, transported as a string
|
||||||
"""
|
"""
|
||||||
scalar URL
|
scalar URL
|
||||||
|
|
||||||
|
"""
|
||||||
|
Éreur de validation
|
||||||
|
"""
|
||||||
|
type ValidationError {
|
||||||
|
"""
|
||||||
|
A description of the error
|
||||||
|
"""
|
||||||
|
message: String!
|
||||||
|
}
|
|
@ -1,5 +1,7 @@
|
||||||
module Types
|
module Types
|
||||||
class MutationType < Types::BaseObject
|
class MutationType < Types::BaseObject
|
||||||
field :create_direct_upload, mutation: Mutations::CreateDirectUpload
|
field :create_direct_upload, mutation: Mutations::CreateDirectUpload
|
||||||
|
|
||||||
|
field :dossier_envoyer_message, mutation: Mutations::DossierEnvoyerMessage
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
11
app/graphql/types/validation_error_type.rb
Normal file
11
app/graphql/types/validation_error_type.rb
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
module Types
|
||||||
|
class ValidationErrorType < Types::BaseObject
|
||||||
|
description "Éreur de validation"
|
||||||
|
|
||||||
|
field :message, String, "A description of the error", null: false
|
||||||
|
|
||||||
|
def message
|
||||||
|
object
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -10,7 +10,7 @@ class Commentaire < ApplicationRecord
|
||||||
|
|
||||||
has_one_attached :piece_jointe
|
has_one_attached :piece_jointe
|
||||||
|
|
||||||
validates :body, presence: { message: "Votre message ne peut être vide" }
|
validates :body, presence: { message: "ne peut être vide" }
|
||||||
|
|
||||||
default_scope { order(created_at: :asc) }
|
default_scope { order(created_at: :asc) }
|
||||||
scope :updated_since?, -> (date) { where('commentaires.updated_at > ?', date) }
|
scope :updated_since?, -> (date) { where('commentaires.updated_at > ?', date) }
|
||||||
|
|
|
@ -2,4 +2,5 @@ fr:
|
||||||
activerecord:
|
activerecord:
|
||||||
attributes:
|
attributes:
|
||||||
commentaire:
|
commentaire:
|
||||||
|
body: 'Votre message'
|
||||||
file: fichier
|
file: fichier
|
||||||
|
|
|
@ -216,6 +216,81 @@ describe API::V2::GraphqlController do
|
||||||
end
|
end
|
||||||
|
|
||||||
context "mutations" do
|
context "mutations" do
|
||||||
|
describe 'dossierEnvoyerMessage' do
|
||||||
|
context 'success' do
|
||||||
|
let(:query) do
|
||||||
|
"mutation {
|
||||||
|
dossierEnvoyerMessage(input: {
|
||||||
|
dossierId: \"#{dossier.to_typed_id}\",
|
||||||
|
instructeurId: \"#{instructeur.to_typed_id}\",
|
||||||
|
body: \"Bonjour\"
|
||||||
|
}) {
|
||||||
|
message {
|
||||||
|
body
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}"
|
||||||
|
end
|
||||||
|
|
||||||
|
it "should post a message" do
|
||||||
|
expect(gql_errors).to eq(nil)
|
||||||
|
|
||||||
|
expect(gql_data).to eq(dossierEnvoyerMessage: {
|
||||||
|
message: {
|
||||||
|
body: "Bonjour"
|
||||||
|
}
|
||||||
|
})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'schema error' do
|
||||||
|
let(:query) do
|
||||||
|
"mutation {
|
||||||
|
dossierEnvoyerMessage(input: {
|
||||||
|
dossierId: \"#{dossier.to_typed_id}\",
|
||||||
|
instructeurId: \"#{instructeur.to_typed_id}\"
|
||||||
|
}) {
|
||||||
|
message {
|
||||||
|
body
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}"
|
||||||
|
end
|
||||||
|
|
||||||
|
it "should fail" do
|
||||||
|
expect(gql_data).to eq(nil)
|
||||||
|
expect(gql_errors).not_to eq(nil)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'validation error' do
|
||||||
|
let(:query) do
|
||||||
|
"mutation {
|
||||||
|
dossierEnvoyerMessage(input: {
|
||||||
|
dossierId: \"#{dossier.to_typed_id}\",
|
||||||
|
instructeurId: \"#{instructeur.to_typed_id}\",
|
||||||
|
body: \"\"
|
||||||
|
}) {
|
||||||
|
message {
|
||||||
|
body
|
||||||
|
}
|
||||||
|
errors {
|
||||||
|
message
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}"
|
||||||
|
end
|
||||||
|
|
||||||
|
it "should fail" do
|
||||||
|
expect(gql_errors).to eq(nil)
|
||||||
|
expect(gql_data).to eq(dossierEnvoyerMessage: {
|
||||||
|
errors: [{ message: "Votre message ne peut être vide" }],
|
||||||
|
message: nil
|
||||||
|
})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
context 'createDirectUpload' do
|
context 'createDirectUpload' do
|
||||||
let(:query) do
|
let(:query) do
|
||||||
"mutation {
|
"mutation {
|
||||||
|
@ -263,5 +338,26 @@ describe API::V2::GraphqlController do
|
||||||
expect(gql_errors).not_to eq(nil)
|
expect(gql_errors).not_to eq(nil)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context "mutation" do
|
||||||
|
let(:query) do
|
||||||
|
"mutation {
|
||||||
|
dossierEnvoyerMessage(input: {
|
||||||
|
dossierId: \"#{dossier.to_typed_id}\",
|
||||||
|
instructeurId: \"#{instructeur.to_typed_id}\",
|
||||||
|
body: \"Bonjour\"
|
||||||
|
}) {
|
||||||
|
message {
|
||||||
|
body
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}"
|
||||||
|
end
|
||||||
|
|
||||||
|
it "should return error" do
|
||||||
|
expect(gql_data[:dossierEnvoyerMessage]).to eq(nil)
|
||||||
|
expect(gql_errors).not_to eq(nil)
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue