PAYDUNYA Client Ruby
https://paydunya.com/developers/ruby
Ajouter cette ligne au fichier Gemfile de votre application:
gem 'paydunya'
Et exécuter ensuite la commande:
$ bundle
Ou installer le directement en tapant:
$ gem install paydunya
Si vous utilisez Ruby on Rails vous pouvez créer un fichier au niveau de RAILS_ROOT/config/initializers
et y insérer les paramètres suivants:
Paydunya::Setup.master_key = "VOTRE_CLE_PRINCIPALE"
Paydunya::Setup.public_key = "VOTRE_CLE_PUBLIQUE"
Paydunya::Setup.private_key = "VOTRE_CLE_PRIVEE"
Paydunya::Setup.mode = "test|live"
Paydunya::Setup.token = "VOTRE_TOKEN"
Configurer ensuite les informations de votre service/activité/entreprise comme illustré ci-dessous. La plupart des paramètres sont optionels mais il serait tout de meme intéressant de configurer le nom de l'entreprise et le slogan.
Paydunya::Checkout::Store.name = "NOM_DE_VOTRE_ENTREPRISE"
Paydunya::Checkout::Store.tagline = "SLOGAN_DE_VOTRE_ENTREPRISE"
Paydunya::Checkout::Store.postal_address = "ADRESSE_DE_VOTRE_ENTREPRISE"
Paydunya::Checkout::Store.phone_number = "NUMERO_DE_TELEPHONE_DE_VOTRE_ENTREPRISE"
Paydunya::Checkout::Store.website_url = "URL_DU_SITE_WEB_DE_VOTRE_ENTREPRISE"
Paydunya::Checkout::Store.logo_url = "URL_DU_LOGO_DE_VOTRE_ENTREPRISE"
Vous pouvez optionnellement définir une URL à laquelle seront redirigés vos clients après une annulation de commande.
# Configuration globale de l'URL de redirection après annulation de paiement.
Paydunya::Checkout::Store.cancel_url = "URL_DE_REDIRECTION_APRES_ANNULATION"
PAYDUNYA redirigera automatiquement le client à cette adresse URL après un paiement fructueux. Cette configuration est facultative et il fortement recommandé de ne pas s'en servir, à moins que vous voulez personnaliser l'expérience de paiement de vos clients. Si cette URL de redirection n'est pas définie, PAYDUNYA redirigera le client vers une page affichant son reçu électronique.
# Configuration globale de l'URL de redirection après confirmation de paiement.
Paydunya::Checkout::Store.return_url = "URL_DE_REDIRECTION_APRES_SUCCES"
co = Paydunya::Checkout::Invoice.new
co = Paydunya::Onsite::Invoice.new
Les paramètres attendus sont nom du produit, la quantité, le prix unitaire,
le prix total et une description optionelle. addItem(nom_du_produit, quantité, prix_unitaire, prix_total, description_optionelle)
co.add_item("Clavier DELL", 2, 3000, 6000)
co.add_item("Ordinateur Lenovo L440", 1, 400000, 400000, "Réduction de 10%")
co.add_item("Casque Logitech", 1, 8000, 8000)
PAYDUNYA s'attend à ce que vous préciser un montant total de facture. Ce sera ce montant qui sera facturé à votre client. Nous considérons que vous auriez déjà fait tous les calculs au niveau de votre serveur avant de fixer ce montant.
NOTE: PAYDUNYA n'effectuera pas de calculs au niveau de ses serveurs. Le montant total de la facture fixé à partir de votre serveur sera celui que PAYDUNYA utilisera pour facturer votre client.
co.total_amount = 6500
Vous pouvez de manière optionelle définir une description générale de facture qui sera utilisée dans les cas où la facture n'a pas besoin d'une liste des éléments ou dans les cas où vous avez besoin d'inclure des informations supplémentaires à votre facture
co.description = "Description Optionnelle"
Vous pouvez représenter l'ajout d'informations de taxes au niveau de la page de paiement. Ces informations seront ensuite affichées sur la facture, le reçu électronique, le reçu imprimé et les téléchargements PDF.
co.add_tax('TVA (18%)', 5000);
co.add_tax('Autre taxe', 700);
Si vous avez besoin d'ajouter des données supplémentaires à vos informations de requête de paiement à des fins d'utilisation ultérieure, nous vous offrons la possibilité de sauvegarder des données personnalisées sur nos serveurs et de les récupérer une fois le paiement réussi.
NOTE: Les données personnalisées ne sont affichées nulle part sur la page de paiement, les factures/reçus, les téléchargements et impressions.
co.add_custom_data("Prénom", "Badara")
co.add_custom_data("Nom", "Alioune")
co.add_custom_data("CartId", 97628)
co.add_custom_data("Coupon","NOEL")
Après avoir rajouté des articles à votre facture et configurer le montant total de la facture, vous pouvez rediriger votre client vers la page de paiement en appelant la méthode create depuis votre objet facture ($co). Veuillez s'il vous plaît noter que la méthode "$co->create()" retourne un booléen (true ou false) selon le fait que la facture ait été créée avec succès ou non. Cela vous permet de mettre une instruction if - else et gérer le résultat comme bon vous semble.
if co.create
redirect_to co.invoice_url
else
@message = co.response_text
end
La première étape consiste à récupérer l'adresse email ou le numéro de téléphone du client PAYDUNYA.
Passer le ensuite en paramètre la méthode create
d'une instance de la classe Paydunya::Onsite::Invoice
.
PAYDUNYA vous renverra un token PSR. Le client PAYDUNYA recevra également un code de confirmation par e-mail et SMS (uniquement pour les transactions réelles).
if co.create("EMAIL_OU_NUMERO_DU_CLIENT_PAYDUNYA")
@opr_token = co.token
else
@message = co.response_text
end
La seconde étape nécessite que vous récupérer le code de confirmation envoyé au client, y ajouter votre token PSR pour ensuite facturer réellement le client. En cas de succès de paiement, vous devriez être en mesure d'accéder à l'URL du reçu électronique et d'autres informations listées au niveau de la documentation officielle.
if co.charge("TOKEN_PSR", "CODE_DE_CONFIRMATION_DU_CLIENT")
@receipt = co.receipt_url
@customer_name = co.customer['name']
else
@message = co.response_text
end
Cette option s'avère très intéressante si vous souhaitez créer votre propre solution de paiement par dessus celle de PAYDUNYA ou si vous devez reverser un certain pourcentage à chaque vente. L'argent est reçu sur les comptes destinataires et le service n'est pas facturé.
Vous pouvez transférer des fonds vers d'autres comptes clients PAYDUNYA à partir de votre compte via l'API de Transfert Automatique (TFA). Pour des raisons de sécurité, vous devez explicitement activer l'option de Transfert Automatique (TFA) dans la configuration de votre intégration. Vous pouvez toujours activer ou désactiver le Transfert Automatique (TFA) en mettant à jour la configuration de votre intégration.
direct_pay = Paydunya::DirectPay.new
if (direct_pay.credit_account("EMAIL_OU_NUMERO_MOBILE_DU_CLIENT_PAYDUNYA", MONTANT_A_TRANSFERER))
puts direct_pay.description
puts direct_pay.response_text
puts direct_pay.transaction_id
else
puts direct_pay.description
puts direct_pay.response_text
end
https://github.com/paydunya/paydunya-rails-demo-store
- Faire un Fork de ce dépôt
- Créer une nouvelle branche (
git checkout -b new-feature
) - Faire un commit de vos modifications (
git commit -am "Ajout d'une nouvelle fonctionnalité"
) - Faire un Push au niveau de la branche (
git push origin new-feature
) - Créer un Pull Request