Πως δημιουργούμε XML για σκοπούς SEPA με C#

Στο Απλές λύσεις σε σύνθετα προβλήματαφτιάξαμε ένα απλό πρόγραμμα για να μετατρέψουμε μια λίστα με objects σε xml αρχείο.

Σε αυτό το άρθρο θα δούμε τη λύση για ένα πολύ σύνθετο πρόβλημα.  

Η λύση που παρουσιάζετε είναι σχετικά περίπλοκη, αλλά συνάμα μας επιτρέπει να δούμε και άλλες πτυχές της C# και το πως μπορούμε να την χρησιμοποιήσουμε για πραγματικά προβλήματα…

Στη σύγχρονη εποχή που ζούμε, όλα έχουν γίνει ψηφιακά.  Οι τράπεζες για να γλυτώσουν κόστος διευκολύνουν τους πελάτες, έχουν εναρμονιστεί με τα ευρωπαϊκά πρότυπα που επιτρέπουν την αλληλεπίδραση με τα συστήματα τους.

Σε αυτό το άρθρο θα δούμε πως οι επιχειρήσεις μπορούν να κάνουν μαζικές πληρωμές προς τους προμηθευτές, μέσα από το σύστημα του SEPA.  

Αυτό γλυτώνει χρόνο τόσο στις επιχειρήσεις όσο και στις τράπεζες.  Οι επιχειρήσεις γλυτώνουν το κόστος εκτύπωσης και υπογραφής των επιταγών, οι δε τράπεζες γλυτώνουν το κόστος του υπάλληλου που θα καθίσει να καταχωρίσει την επιταγή .

Στην περίπτωση μας θα μελετήσουμε την δημιουργία ενός class library που ο σκοπός του είναι να δημιουργία το xml με βάση σύνθετων παραμέτρων. 

Η ολοκληρωμένη λύση, συνάδει απόλυτα με τις προϋποθέσεις που θέτει η Τράπεζα Κύπρου στη κατηγορία ψηφιακά κανάλια οι προδιαγραφές βρίσκονται εδώ και ισχύουν σήμερα 15/11/2021

Πιθανό το εργαλείο να δουλεύει και για άλλες τράπεζες αλλά δεν το έχω δοκιμάσει.

Τι είναι το Class Library; 

Με απλά λόγια είναι μια συλλογή με λειτουργίες.  

Στη C# όταν χτιστεί παράγει DLL, το οποίο θα ενσωματώσουμε στη περίπτωση μου σε λογιστικό πρόγραμμα. 

Το πρόβλημα.

Το λογιστήριο μιας επιχείρησης μέσω του λογιστικού προγράμματος του εκδίδει πληρωμές προς τους προμηθευτές.  Πρότινος εκτυπώνονταν οι επιταγές και ο ιδιοκτήτης τις υπέγραφε.

Ένα άτομο καθόταν όλη μέρα και καλούσε τους προμηθευτές να έρθουν να παραλάβουν τις πληρωμές.

Όπως αντιλαμβανόμαστε η διαδικασία είναι χρονοβόρα.  

Λύση…

Ενσωματώνουμε στο λογιστικό μας πρόγραμμα αντί για εκτύπωση επιταγών να περνά τις πληροφορίες στο dll μας και αυτό να επιστρέφει πίσω το xml αρχείο.

Η εγκρίσεις θα γίνονται ηλεκτρονικά (μεσώ διαχείρισης του λογιστικού).

Στη προκειμένη περίπτωση πάμε με αυτή τη μεθοδολογία γιατί μας επιτρέπει το λογιστικό πρόγραμμα μας να το πειράξουμε…

Στη περίπτωση που δεν μπορούσε να γίνει κάτι τέτοιο, τότε θα έπρεπε με κάποιο τρόπο να εξαχθούν τα δεδομένα από το λογιστικό και να γίνει η xml διαδικασία σε εξωτερικό πρόγραμμα.

Δεδομένα που πρέπει να “έχουμε“.

Η διαδικασία του SEPA με βάση το πρότυπο ISO 20022 (βλέπουμε τον οδηγό της τράπεζας) ορίζει ότι σαν βασικά στοιχεία: 

  • Ημερομηνία εκτέλεσης
  • Αριθμός πληρωμών
  • Σύνολο πληρωμής
  • Όνομα του αποστολέα 
  • Το IBAN και το SWIFT του αποστολέα
  • Λίστα με πληρωμές:
    • Κωδικό προμηθευτή (προαιρετικό, αλλά μπορούμε να το χρησιμοποιήσουμε)
    • Όνομα προμηθευτή
    • Χώρα προμηθευτή (προαιρετικό, σε μορφή CY, GR κτλ.)
    •  Διεύθυνση αλληλογραφίας (μέχρι 3 γραμμές)
    • IBAN 
    • SWIFT
    • Ποσό πληρωμής

Όλα πεδία και τι πληροφορίες χρειάζονται, περιέχονται στο Schema μόνο για σκληροπυρηνικούς 😁🐱‍👤

Εκτέλεση: 👷‍♂️

Καταρχάς πρέπει να κατεβάσουμε το Schema, θα το αποθηκεύσουμε πχ στα Downloads.

θα χρησιμοποιήσουμε τα εργαλεία του Visual Studio ώστε να μετατρέψουμε το XSD αρχείο σε Κλάσεις (Classes) της C#.

Θα μπορούσαμε να γράψουμε μόνοι μας την Class;

Η απάντηση είναι ναι αλλά για τέτοιες περίπλοκες περιπτώσεις που ο πάροχος μας δίνει το schema συνιστάτε να μετατρέπουμε το schema σε κλάση.  Εξάλλου η περιπλοκότητα που υπάρχει σε αυτές τις περιπτώσεις μπορεί να οδηγήσει σε λάθη και χρειάζεστε απίστευτος χρόνος για να δημιουργηθούν και να δοκιμαστούν

Η τοποθεσία του εργαλείου XSD.exe στη περίπτωση μου είναι στο 

c:\Program Files (x86)\Microsoft SDKs\Windows\v10.0A\bin\NETFX 4.8 Tools\

Βήμα πρώτο είναι να ανοίξουμε ένα command line και να σιγουρευτούμε ότι το αρχείο που κατεβάσαμε είναι στο ίδιο φάκελο.

Η εντολή που πρέπει να δώσουμε είναι η εξής

c:\Program Files (x86)\Microsoft SDKs\Windows\v10.0A\bin\NETFX 4.8 Tools\xsd.exe pain.001.001.03.xsd /c

 Θα μας δημιουργήσει ένα αρχείο που ονομάζεται pain_001_001_03.cs

Το εργαλείο μετάτρεψε το schema σε συγγενής κλάσεις, δηλαδή που συσχετίζονται μεταξύ τους.

Κρατάμε αυτό το αρχείο και προχωράμε με την δημιουργία της Class Library

Πιο κάτω θα πάμε επιγραμματικά να δούμε τη διαδικασία, για λεπτομέρειες, μπορείτε να δείτε τη συνέχεια στο βίντεο από το κανάλι μου στο YouTube

🎫Στη κλάση που δημιουργήθηκε αφού της αλλάξουμε όνομα σε SepaPaymentManager θα προσθέσουμε την constructor διαδικασία για τα δεδομένα που χρειαζόμαστε, όπως τα δηλώσαμε προηγουμένους

✨Οι πληρωμές όπως είπαμε είναι ξεχωριστός πίνακας με αντικείμενα και θα ορίσουμε και την κλάση που θα έχει μέσα μια constructor διαδικασία με τις πληροφορίες.

🏛 Στη συνέχεια θα δημιουργήσουμε ένα καινούργιο class αρχείο, όπου θα προσθέσουμε με αντιγραφή και επικόλληση τον κώδικα που μετατρέψαμε προηγουμένους, δηλαδή το Schema, κατόπιν θα αντικαταστήσουμε το public class σε όλο το αρχείο με sealed public class και φυσικά θα διαγράψουμε το namespace από το αρχείο μας ώστε να μπορούμε να ορίσουμε τα variables με το τύπο από διάφορες κλάσεις.  

Το sealed class θα αποτρέψει την εμφάνιση κατά το declaration από εφαρμογές που θα χρησιμοποιούν το library μας, αλλά εσωτερικά θα μας επιτρέπει να το διαχειριστούμε.  Άρα θα είναι μόνο για εσωτερική χρήση.

🧾Στην class SepaPaymentManager θα δηλώσουμε και μία μέθοδο που επιστρέφει string για να μπορεί το πρόγραμμα να επιστρέφει των XML κώδικα πίσω στο πρόγραμμα.  Θα ονομάσουμε την μέθοδο μας ως GetXml.

Η GetXml θα δημιουργεί το header της πληρωμής με τα βασικά στοιχεία που θέλει η Τράπεζα και τις πληρωμές. 

Ως τελικός χρήστης για να δημιουργήσουμε ένα SEPA xml αρχείο πρέπει απλά να περάσουμε τις πιο κάτω πληροφορίες και το class μας επιστρέφει σε μορφή string το xml.

Κατεβάστε τη λύση εδώ

Αφήστε ένα Σχόλιο

Η ηλ. διεύθυνση σας δεν δημοσιεύεται. Τα υποχρεωτικά πεδία σημειώνονται με *

We use cookies to personalise content and ads, to provide social media features and to analyse our traffic. We also share information about your use of our site with our social media, advertising and analytics partners. View more
Cookies settings
Accept
Decline
Privacy & Cookie policy
Privacy & Cookies policy
Cookie name Active

Who we are

Our website address is: http://stavrosbyte.eu.

Comments

When visitors leave comments on the site we collect the data shown in the comments form, and also the visitor’s IP address and browser user agent string to help spam detection. An anonymized string created from your email address (also called a hash) may be provided to the Gravatar service to see if you are using it. The Gravatar service privacy policy is available here: https://automattic.com/privacy/. After approval of your comment, your profile picture is visible to the public in the context of your comment.

Media

If you upload images to the website, you should avoid uploading images with embedded location data (EXIF GPS) included. Visitors to the website can download and extract any location data from images on the website.

Cookies

If you leave a comment on our site you may opt-in to saving your name, email address and website in cookies. These are for your convenience so that you do not have to fill in your details again when you leave another comment. These cookies will last for one year. If you visit our login page, we will set a temporary cookie to determine if your browser accepts cookies. This cookie contains no personal data and is discarded when you close your browser. When you log in, we will also set up several cookies to save your login information and your screen display choices. Login cookies last for two days, and screen options cookies last for a year. If you select "Remember Me", your login will persist for two weeks. If you log out of your account, the login cookies will be removed. If you edit or publish an article, an additional cookie will be saved in your browser. This cookie includes no personal data and simply indicates the post ID of the article you just edited. It expires after 1 day.

Embedded content from other websites

Articles on this site may include embedded content (e.g. videos, images, articles, etc.). Embedded content from other websites behaves in the exact same way as if the visitor has visited the other website. These websites may collect data about you, use cookies, embed additional third-party tracking, and monitor your interaction with that embedded content, including tracking your interaction with the embedded content if you have an account and are logged in to that website.

Who we share your data with

If you request a password reset, your IP address will be included in the reset email.

How long we retain your data

If you leave a comment, the comment and its metadata are retained indefinitely. This is so we can recognize and approve any follow-up comments automatically instead of holding them in a moderation queue. For users that register on our website (if any), we also store the personal information they provide in their user profile. All users can see, edit, or delete their personal information at any time (except they cannot change their username). Website administrators can also see and edit that information.

What rights you have over your data

If you have an account on this site, or have left comments, you can request to receive an exported file of the personal data we hold about you, including any data you have provided to us. You can also request that we erase any personal data we hold about you. This does not include any data we are obliged to keep for administrative, legal, or security purposes.

Where your data is sent

Visitor comments may be checked through an automated spam detection service.
Save settings
Cookies settings