C#: Send A Letter with SendLetterAndAddress()

Instructions

  1. Create a new Console Application project and add a web reference.
  2. Copy the entire code below, delete anything written in your application and paste the code there.
  3. Replace the values of the Const lines with your details:
    • Replace MyUsername and MyPassword with your PostalMethods user details.
    • Replace MyDescription with your own text to help you identify this letter in your activity log (optional).
    • Replace MyFileExtension with the extension of the document you are using for this test.
    • Replace MyPathToFile with a path to your test PDF file. Remember, method SendLetterAndAdress will add the recipient's address so it would show through the envelope window. You can use one of our Sample Letter Documents.
    • MyWorkMode determines if your letter will be sent as Production, Development or will use your user's default Work Mode setting. Read more about Production and Development Work Modes.
    • Use the existing postal recipient or replace with another valid postal address. Leave an empty string ("") where no value is needed.
  4. Start your application. It will start, encode your document as Base64 and send a letter to the PostalMethods SendLetterAndAddress Web Service method. If the response is a positive number, you will be able to see your letter in the PostalMethods Control Panel.
    If the response is negative number, check the Web Service Status Codes section.

That's it - you have successfully sent a letter to PostalMethods. Congratulations.

using System;
using System.IO;
 
namespace ConsoleApplication1
{
 
class Module1
{
 
        public static void Main()
        {
            const string MyUsername = "MyUsername";
            const string MyPassword = "MyPassword";
            const string MyDescription = "Sending a letter using C#";
            const string MyFileExtension = "pdf";
            const string MyPathToFile = "C:\\MyFile.pdf";
            const com.postalmethods.api.WorkMode MyWorkMode = com.postalmethods.api.WorkMode.Default;
            const string MyAttention1 = "George Washington";
            const string MyAttention2 = "";
            const string MyCompanyName = "The White House";
            const string MyAddress1 = "1600 Pennsylvania Ave NW";
            const string MyAddress2 = "";
            const string MyCity = "Washington";
            const string MyState = "DC";
            const string MyPostalCode = "20500";
            const string MyCountry = "United States of America";
 
            com.postalmethods.api.PostalWS objPM = new com.postalmethods.api.PostalWS();
            long lngResult = 0;
            //
            // Read your binary document. In this example: C:\MyFile.pdf
            //
            FileStream objFR = default(FileStream);
            objFR = new FileStream(MyPathToFile, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
            byte[] B = new byte[objFR.Length];
            objFR.Read(B, 0, B.Length);
            objFR.Close();
            objFR = null;
            //
            // Invoke the SendLetter method
            //
            lngResult = objPM.SendLetterAndAddress(MyUsername, MyPassword, MyDescription, MyFileExtension, B, MyWorkMode, MyAttention1, MyAttention2, MyCompanyName,
            MyAddress1, MyAddress2, MyCity, MyState, MyPostalCode, MyCountry);
 
            // 
            // Check response status
            //
            if (lngResult > 0)
            {
                //
                // A positive value means the message was successfully queued for processing.
                // The PostalMethods Letter ID is returned.
                //
                Console.WriteLine("LetterID is: " + lngResult);
            }
            else
            {
                //
                // A negative value means an error occurred.
                // See the PostalMethods Status Codes: http://www.postalmethods.com/statuscodes#webservice.
                //
                Console.WriteLine("Error is:" + lngResult);
            }
 
            // In debug mode, the following lines prevent your console application from closing automatically upon termination
            Console.WriteLine("Hit ENTER to terminate application");
            Console.ReadLine();
        }
 
    }
}