* Curl header API: extract headers post transfer * h DFTACTGRP(*NO) ACTGRP(*NEW) h OPTION(*NOSHOWCPY) h BNDDIR('CURL') * ************************************************************************** * _ _ ____ _ * Project ___| | | | _ \| | * / __| | | | |_) | | * | (__| |_| | _ <| |___ * \___|\___/|_| \_\_____| * * Copyright (C) Daniel Stenberg, , et al. * * This software is licensed as described in the file COPYING, which * you should have received as part of this distribution. The terms * are also available at https://curl.se/docs/copyright.html. * * You may opt to use, copy, modify, merge, publish, distribute and/or sell * copies of the Software, and permit persons to whom the Software is * furnished to do so, under the terms of the COPYING file. * * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF * ANY KIND, either express or implied. * * SPDX-License-Identifier: curl * ************************************************************************** * /include H,CURL.INC * * Extract headers post transfer with the header API. * d pi d url 120 * d urllen s 10u 0 URL length * ************************************************************************** urllen = trimmed_length(url: %len(url)); // Do the curl stuff. curl_global_init(CURL_GLOBAL_ALL); main(); curl_global_cleanup(); *inlr = *on; // Exit * ************************************************************************** * Main procedure: do the curl job. ************************************************************************** * p main b d main pi * d h s * Easy handle d result s like(CURLcode) Curl return code d inz(CURLE_OUT_OF_MEMORY) d header ds likeds(curl_header) based(hp) d strp1 s * Work string pointer d strp2 s * Work string pointer d inout s 52 For error display // Create and fill curl handle. h = curl_easy_init(); if h <> *NULL; curl_easy_setopt_ccsid(h: CURLOPT_URL: %subst(url: 1: urllen): 0); curl_easy_setopt(h: CURLOPT_FOLLOWLOCATION: 1); curl_easy_setopt(h: CURLOPT_WRITEFUNCTION: %paddr(in_data_cb)); // Ignore input data // Perform the request. result = curl_easy_perform(h); endif; // Check for error and report if some. if result <> CURLE_OK; inout = %str(curl_easy_strerror_ccsid(result: 0)); dsply '' '*EXT' inout; else; if curl_easy_header_ccsid(h: 'Content-Type': 0: CURLH_HEADER: -1: hp: 0) = CURLHE_OK; strp2 = curl_to_ccsid(header.value: 0); inout = 'Content-Type: ' + %str(strp2); dsply inout; curl_free(strp2); endif; dsply ' All server headers:'; hp = *NULL; dow *on; hp = curl_easy_nextheader(h: CURLH_HEADER: -1: hp); if hp = *NULL; leave; endif; strp1 = curl_to_ccsid(header.name: 0); strp2 = curl_to_ccsid(header.value: 0); inout = %str(strp1) + ': ' + %str(strp2) + ' (' + %char(header.amount) + ')'; curl_free(strp2); curl_free(strp1); dsply inout; enddo; inout = 'Done'; dsply '' '*EXT' inout; curl_easy_cleanup(h); // Release handle endif; p main e * ************************************************************************** * Dummy data input callback procedure. ************************************************************************** * p in_data_cb b d in_data_cb pi 10u 0 d ptr * value Input data pointer d size 10u 0 value Data element size d nmemb 10u 0 value Data element count d userdata * value User data pointer * return size * nmemb; p in_data_cb e * ************************************************************************** * Get the length of right-trimmed string ************************************************************************** * p trimmed_length b d trimmed_length pi 10u 0 d string 999999 const options(*varsize) d length 10u 0 value * d len s 10u 0 * len = %scan(X'00': string: 1: length); // Limit to zero-terminated string if len = 0; len = length + 1; endif; if len <= 1; return 0; endif; return %checkr(' ': string: len - 1); // Trim right p trimmed_length e