113498266Sopenharmony_ci      * Curl SMTP send source member as attachment
213498266Sopenharmony_ci      *
313498266Sopenharmony_ci     h DFTACTGRP(*NO) ACTGRP(*NEW)
413498266Sopenharmony_ci     h OPTION(*NOSHOWCPY)
513498266Sopenharmony_ci     h BNDDIR('CURL')
613498266Sopenharmony_ci      *
713498266Sopenharmony_ci      **************************************************************************
813498266Sopenharmony_ci      *                                  _   _ ____  _
913498266Sopenharmony_ci      *  Project                     ___| | | |  _ \| |
1013498266Sopenharmony_ci      *                             / __| | | | |_) | |
1113498266Sopenharmony_ci      *                            | (__| |_| |  _ <| |___
1213498266Sopenharmony_ci      *                             \___|\___/|_| \_\_____|
1313498266Sopenharmony_ci      *
1413498266Sopenharmony_ci      * Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
1513498266Sopenharmony_ci      *
1613498266Sopenharmony_ci      * This software is licensed as described in the file COPYING, which
1713498266Sopenharmony_ci      * you should have received as part of this distribution. The terms
1813498266Sopenharmony_ci      * are also available at https://curl.se/docs/copyright.html.
1913498266Sopenharmony_ci      *
2013498266Sopenharmony_ci      * You may opt to use, copy, modify, merge, publish, distribute and/or sell
2113498266Sopenharmony_ci      * copies of the Software, and permit persons to whom the Software is
2213498266Sopenharmony_ci      * furnished to do so, under the terms of the COPYING file.
2313498266Sopenharmony_ci      *
2413498266Sopenharmony_ci      * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF
2513498266Sopenharmony_ci      * ANY KIND, either express or implied.
2613498266Sopenharmony_ci      *
2713498266Sopenharmony_ci      * SPDX-License-Identifier: curl
2813498266Sopenharmony_ci      *
2913498266Sopenharmony_ci      **************************************************************************
3013498266Sopenharmony_ci      *
3113498266Sopenharmony_ci      /include H,CURL.INC
3213498266Sopenharmony_ci      *
3313498266Sopenharmony_ci      * Example to SMTP send source member as attachment via SMTP.
3413498266Sopenharmony_ci      *
3513498266Sopenharmony_ci     fRPGXAMPLESif   e             disk    extmbr(program_name)
3613498266Sopenharmony_ci     f                                     rename(RPGXAMPLES: record)
3713498266Sopenharmony_ci     d                 pi
3813498266Sopenharmony_ci     d url                           60                                         SMTP server URL
3913498266Sopenharmony_ci     d recipient_mail                40                                         Recipient mail addr
4013498266Sopenharmony_ci      *
4113498266Sopenharmony_ci     d program_name    c                   'SMTPSRCMBR'                         Member name to send
4213498266Sopenharmony_ci     d sender_name     c                   'Curl'                               Sender name
4313498266Sopenharmony_ci     d sender_mail     c                   'curl@example.com'                   Sender e-mail
4413498266Sopenharmony_ci     d recipient_name  c                   'WIMC'                               Recipient name
4513498266Sopenharmony_ci     d crlf            c                   X'0D25'
4613498266Sopenharmony_ci      *
4713498266Sopenharmony_ci     d urllen          s             10u 0                                      URL length
4813498266Sopenharmony_ci     d rcptmlen        s             10u 0                                      Recipient mail len
4913498266Sopenharmony_ci      *
5013498266Sopenharmony_ci      **************************************************************************
5113498266Sopenharmony_ci
5213498266Sopenharmony_ci        urllen = trimmed_length(url: %len(url));
5313498266Sopenharmony_ci        rcptmlen = trimmed_length(recipient_mail: %len(recipient_mail));
5413498266Sopenharmony_ci
5513498266Sopenharmony_ci        // Do the curl stuff.
5613498266Sopenharmony_ci
5713498266Sopenharmony_ci        curl_global_init(CURL_GLOBAL_ALL);
5813498266Sopenharmony_ci        main();
5913498266Sopenharmony_ci        curl_global_cleanup();
6013498266Sopenharmony_ci        *inlr = *on;            // Exit
6113498266Sopenharmony_ci      *
6213498266Sopenharmony_ci      **************************************************************************
6313498266Sopenharmony_ci      * Main procedure: do the curl job.
6413498266Sopenharmony_ci      **************************************************************************
6513498266Sopenharmony_ci      *
6613498266Sopenharmony_ci     p main            b
6713498266Sopenharmony_ci     d main            pi
6813498266Sopenharmony_ci      *
6913498266Sopenharmony_ci     d h               s               *                                        Easy handle
7013498266Sopenharmony_ci     d result          s                   like(CURLcode)                       Curl return code
7113498266Sopenharmony_ci     d                                     inz(CURLE_OUT_OF_MEMORY)
7213498266Sopenharmony_ci     d errmsgp         s               *                                        Error string pointer
7313498266Sopenharmony_ci     d response        s             52                                         For error display
7413498266Sopenharmony_ci     d headers         s               *   inz(*NULL)                           Mail headers
7513498266Sopenharmony_ci     d rcpts           s               *   inz(*NULL)                           List of recipients
7613498266Sopenharmony_ci     d mime            s               *                                        Mail MIME structure
7713498266Sopenharmony_ci     d mimepart        s               *                                        Mail part
7813498266Sopenharmony_ci
7913498266Sopenharmony_ci            // Create and fill curl handle.
8013498266Sopenharmony_ci
8113498266Sopenharmony_ci        h = curl_easy_init();
8213498266Sopenharmony_ci        if h <> *NULL;
8313498266Sopenharmony_ci            rcpts = curl_slist_append_ccsid(rcpts:
8413498266Sopenharmony_ci                                        %subst(recipient_mail: 1: rcptmlen): 0);
8513498266Sopenharmony_ci            headers = curl_slist_append_ccsid(headers: 'From: ' + sender_name +
8613498266Sopenharmony_ci                                                       ' <' + sender_mail + '>':
8713498266Sopenharmony_ci                                              0);
8813498266Sopenharmony_ci            headers = curl_slist_append_ccsid(headers: 'To: ' + recipient_name +
8913498266Sopenharmony_ci                           ' <' + %subst(recipient_mail: 1: rcptmlen) + '>': 0);
9013498266Sopenharmony_ci            headers = curl_slist_append_ccsid(headers: 'Subject: An ILE/RPG ' +
9113498266Sopenharmony_ci                                              'source program': 0);
9213498266Sopenharmony_ci            headers = curl_slist_append_ccsid(headers: 'Date: ' + mail_date():
9313498266Sopenharmony_ci                                              0);
9413498266Sopenharmony_ci            curl_easy_setopt_ccsid(h: CURLOPT_URL: %subst(url: 1: urllen): 0);
9513498266Sopenharmony_ci            curl_easy_setopt_ccsid(h: CURLOPT_MAIL_FROM: sender_mail: 0);
9613498266Sopenharmony_ci            curl_easy_setopt(h: CURLOPT_MAIL_RCPT: rcpts);
9713498266Sopenharmony_ci            curl_easy_setopt(h: CURLOPT_HTTPHEADER: headers);
9813498266Sopenharmony_ci            mime = curl_mime_init(h);
9913498266Sopenharmony_ci            mimepart = curl_mime_addpart(mime);
10013498266Sopenharmony_ci            curl_mime_data_ccsid(mimepart: 'Please find the ILE/RPG program ' +
10113498266Sopenharmony_ci                                           program_name + ' source code in ' +
10213498266Sopenharmony_ci                                           'attachment.' + crlf:
10313498266Sopenharmony_ci                                 CURL_ZERO_TERMINATED: 0);
10413498266Sopenharmony_ci            mimepart = curl_mime_addpart(mime);
10513498266Sopenharmony_ci            curl_mime_data_cb(mimepart: -1: %paddr(out_data_cb): *NULL: *NULL:
10613498266Sopenharmony_ci                              *NULL);
10713498266Sopenharmony_ci            curl_mime_filename_ccsid(mimepart: program_name: 0);
10813498266Sopenharmony_ci            curl_mime_encoder_ccsid(mimepart: 'quoted-printable': 0);
10913498266Sopenharmony_ci            curl_easy_setopt(h: CURLOPT_MIMEPOST: mime);
11013498266Sopenharmony_ci
11113498266Sopenharmony_ci            // Perform the request.
11213498266Sopenharmony_ci
11313498266Sopenharmony_ci            setll *start RPGXAMPLES;
11413498266Sopenharmony_ci            result = curl_easy_perform(h);
11513498266Sopenharmony_ci
11613498266Sopenharmony_ci            // Cleanup.
11713498266Sopenharmony_ci
11813498266Sopenharmony_ci            curl_mime_free(mime);
11913498266Sopenharmony_ci            curl_slist_free_all(headers);
12013498266Sopenharmony_ci            curl_slist_free_all(rcpts);
12113498266Sopenharmony_ci            curl_easy_cleanup(h);       // Release handle
12213498266Sopenharmony_ci        endif;
12313498266Sopenharmony_ci
12413498266Sopenharmony_ci        // Check for error and report if some.
12513498266Sopenharmony_ci
12613498266Sopenharmony_ci        if result <> CURLE_OK;
12713498266Sopenharmony_ci            errmsgp = curl_easy_strerror_ccsid(result: 0);
12813498266Sopenharmony_ci            response = %str(errmsgp);
12913498266Sopenharmony_ci            dsply '' '*EXT' response;
13013498266Sopenharmony_ci        else;
13113498266Sopenharmony_ci            response = 'Mail sent';
13213498266Sopenharmony_ci            dsply '' '*EXT' response;
13313498266Sopenharmony_ci        endif;
13413498266Sopenharmony_ci     p main            e
13513498266Sopenharmony_ci      *
13613498266Sopenharmony_ci      **************************************************************************
13713498266Sopenharmony_ci      * Attachment data callback procedure.
13813498266Sopenharmony_ci      **************************************************************************
13913498266Sopenharmony_ci      *
14013498266Sopenharmony_ci     p out_data_cb     b
14113498266Sopenharmony_ci     d out_data_cb     pi            10u 0
14213498266Sopenharmony_ci     d  ptr                            *   value                                Output data pointer
14313498266Sopenharmony_ci     d  size                         10u 0 value                                Data element size
14413498266Sopenharmony_ci     d  nmemb                        10u 0 value                                Data element count
14513498266Sopenharmony_ci     d  userdata                       *   value                                User data pointer
14613498266Sopenharmony_ci      *
14713498266Sopenharmony_ci     d buffer          s        9999999    based(ptr)                           Output buffer
14813498266Sopenharmony_ci     d line            s        9999999    based(lineptr)                       ASCII line pointer
14913498266Sopenharmony_ci     d linelen         s             10u 0
15013498266Sopenharmony_ci     d i               s             10u 0                                      Buffer position
15113498266Sopenharmony_ci      *
15213498266Sopenharmony_ci        size = size * nmemb;                                   // The size in bytes.
15313498266Sopenharmony_ci        i = 0;
15413498266Sopenharmony_ci        dow size - i >= %len(SRCDTA) + %len(crlf) and not %eof(RPGXAMPLES);
15513498266Sopenharmony_ci            read record;
15613498266Sopenharmony_ci            lineptr = curl_from_ccsid(%trimr(SRCDTA) + crlf: 0);
15713498266Sopenharmony_ci            linelen = %scan(X'00': line) - 1;
15813498266Sopenharmony_ci            %subst(buffer: i + 1: linelen) = %str(lineptr);
15913498266Sopenharmony_ci            curl_free(lineptr);
16013498266Sopenharmony_ci            i = i + linelen;
16113498266Sopenharmony_ci        enddo;
16213498266Sopenharmony_ci        return i;
16313498266Sopenharmony_ci     p out_data_cb     e
16413498266Sopenharmony_ci      *
16513498266Sopenharmony_ci      **************************************************************************
16613498266Sopenharmony_ci      * Mail-formatted date procedure.
16713498266Sopenharmony_ci      **************************************************************************
16813498266Sopenharmony_ci      *
16913498266Sopenharmony_ci     p mail_date       b
17013498266Sopenharmony_ci     d mail_date       pi            50    varying
17113498266Sopenharmony_ci      *
17213498266Sopenharmony_ci     d sysval          ds                  qualified                            To retrieve timezone
17313498266Sopenharmony_ci     d  numsysval                    10u 0
17413498266Sopenharmony_ci     d  offset                       10u 0
17513498266Sopenharmony_ci     d                              100
17613498266Sopenharmony_ci      *
17713498266Sopenharmony_ci     d get_sysval      pr                  extpgm('QWCRSVAL')
17813498266Sopenharmony_ci     d  outdata                            likeds(sysval)
17913498266Sopenharmony_ci     d  outsize                      10u 0 const
18013498266Sopenharmony_ci     d  numsysval                    10u 0 const
18113498266Sopenharmony_ci     d  name                         10    const
18213498266Sopenharmony_ci     d  errcode                   10000    options(*varsize)
18313498266Sopenharmony_ci      *
18413498266Sopenharmony_ci     d now             ds                  qualified
18513498266Sopenharmony_ci     d  ts                             z
18613498266Sopenharmony_ci     d  year                          4s 0 overlay(ts: 1)
18713498266Sopenharmony_ci     d  month                         2s 0 overlay(ts: 6)
18813498266Sopenharmony_ci     d  day                           2s 0 overlay(ts: 9)
18913498266Sopenharmony_ci     d  hour                          2s 0 overlay(ts: 12)
19013498266Sopenharmony_ci     d  minute                        2    overlay(ts: 15)
19113498266Sopenharmony_ci     d  second                        2    overlay(ts: 18)
19213498266Sopenharmony_ci      *
19313498266Sopenharmony_ci     d sysvalinfo      ds                  qualified based(sysvalinfoptr)
19413498266Sopenharmony_ci     d  name                         10
19513498266Sopenharmony_ci     d  type                          1
19613498266Sopenharmony_ci     d  status                        1
19713498266Sopenharmony_ci     d  length                       10u 0
19813498266Sopenharmony_ci     d  value                     99999
19913498266Sopenharmony_ci      *
20013498266Sopenharmony_ci     d qusec           ds                  qualified
20113498266Sopenharmony_ci     d                               10u 0 inz(0)
20213498266Sopenharmony_ci      *
20313498266Sopenharmony_ci     d weekday         s             10u 0
20413498266Sopenharmony_ci      *
20513498266Sopenharmony_ci        now.ts = %timestamp(*SYS);
20613498266Sopenharmony_ci        get_sysval(sysval: %len(sysval): 1: 'QUTCOFFSET': qusec);
20713498266Sopenharmony_ci        sysvalinfoptr = %addr(sysval) + sysval.offset;
20813498266Sopenharmony_ci        weekday = %rem(%diff(now.ts: %timestamp('2001-01-01-00.00.00.000000'):
20913498266Sopenharmony_ci                                                *DAYS): 7);
21013498266Sopenharmony_ci        return %subst('MonTueWedThuFriSatSun': 3 * weekday + 1: 3) + ', ' +
21113498266Sopenharmony_ci               %char(now.day) + ' ' +
21213498266Sopenharmony_ci               %subst('JanFebMarAprMayJunJulAugSepOctNovDec':
21313498266Sopenharmony_ci                      3 * now.month - 2: 3) + ' ' +
21413498266Sopenharmony_ci               %char(now.year) + ' ' +
21513498266Sopenharmony_ci               %char(now.hour) + ':' + now.minute + ':' + now.second + ' ' +
21613498266Sopenharmony_ci               %subst(sysvalinfo.value: 1: sysvalinfo.length);
21713498266Sopenharmony_ci     p mail_date       e
21813498266Sopenharmony_ci      *
21913498266Sopenharmony_ci      **************************************************************************
22013498266Sopenharmony_ci      * Get the length of right-trimmed string
22113498266Sopenharmony_ci      **************************************************************************
22213498266Sopenharmony_ci      *
22313498266Sopenharmony_ci     p trimmed_length  b
22413498266Sopenharmony_ci     d trimmed_length  pi            10u 0
22513498266Sopenharmony_ci     d  string                   999999    const options(*varsize)
22613498266Sopenharmony_ci     d  length                       10u 0 value
22713498266Sopenharmony_ci      *
22813498266Sopenharmony_ci     d addrdiff        s             10i 0
22913498266Sopenharmony_ci     d len             s             10u 0
23013498266Sopenharmony_ci      *
23113498266Sopenharmony_ci        len = %scan(X'00': string: 1: length); // Limit to zero-terminated string
23213498266Sopenharmony_ci        if len = 0;
23313498266Sopenharmony_ci            len = length + 1;
23413498266Sopenharmony_ci        endif;
23513498266Sopenharmony_ci        if len <= 1;
23613498266Sopenharmony_ci            return 0;
23713498266Sopenharmony_ci        endif;
23813498266Sopenharmony_ci        return %checkr(' ': string: len - 1);  // Trim right
23913498266Sopenharmony_ci     p trimmed_length  e
240