mirror of
https://github.com/sasjs/core.git
synced 2025-12-12 06:54:35 +00:00
Compare commits
3 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
df832a184f | ||
|
|
15084be09d | ||
|
|
92ff1a53dc |
3
.github/FUNDING.yml
vendored
3
.github/FUNDING.yml
vendored
@@ -1,3 +0,0 @@
|
|||||||
# These are supported funding model platforms
|
|
||||||
|
|
||||||
custom: https://getalby.com/p/sasjs
|
|
||||||
@@ -1,6 +0,0 @@
|
|||||||
FROM gitpod/workspace-full
|
|
||||||
|
|
||||||
RUN sudo apt-get update \
|
|
||||||
&& sudo apt-get install -y doxygen \
|
|
||||||
&& sudo apt-get install -y graphviz \
|
|
||||||
&& sudo rm -rf /var/lib/apt/lists/*
|
|
||||||
27
.gitpod.yml
27
.gitpod.yml
@@ -1,27 +0,0 @@
|
|||||||
tasks:
|
|
||||||
- init: npm install -g npm
|
|
||||||
- command: npm i
|
|
||||||
- command: npm i -g @sasjs/cli
|
|
||||||
|
|
||||||
image:
|
|
||||||
file: .gitpod.dockerfile
|
|
||||||
vscode:
|
|
||||||
extensions:
|
|
||||||
- sasjs.sasjs-for-vscode
|
|
||||||
|
|
||||||
github:
|
|
||||||
prebuilds:
|
|
||||||
# enable for the master/default branch (defaults to true)
|
|
||||||
master: true
|
|
||||||
# enable for all branches in this repo (defaults to false)
|
|
||||||
branches: false
|
|
||||||
# enable for pull requests coming from this repo (defaults to true)
|
|
||||||
pullRequests: true
|
|
||||||
# enable for pull requests coming from forks (defaults to false)
|
|
||||||
pullRequestsFromForks: true
|
|
||||||
# add a "Review in Gitpod" button as a comment to pull requests (defaults to true)
|
|
||||||
addComment: true
|
|
||||||
# add a "Review in Gitpod" button to pull requests (defaults to false)
|
|
||||||
addBadge: false
|
|
||||||
# add a label once the prebuild is ready to pull requests (defaults to false)
|
|
||||||
addLabel: prebuilt-in-gitpod
|
|
||||||
11
README.md
11
README.md
@@ -213,13 +213,12 @@ When contributing to this library, it is therefore important to ensure that all
|
|||||||
|
|
||||||
We are currently on major release v4. Breaking changes should be marked with the [deprecated](https://www.doxygen.nl/manual/commands.html#cmddeprecated) doxygen tag. The following changes are planned when the next major/breaking release (v5) becomes necessary:
|
We are currently on major release v4. Breaking changes should be marked with the [deprecated](https://www.doxygen.nl/manual/commands.html#cmddeprecated) doxygen tag. The following changes are planned when the next major/breaking release (v5) becomes necessary:
|
||||||
|
|
||||||
* mcf_xxx macros to have `insert_cmplib` option deprecated (the option is now checked automatically with value inserted only if needed)
|
* mf_getuniquelibref.sas to have the deprecated maxtried parameter removed (no longer needed)
|
||||||
* mcf_xxx macros to have `wrap=` option defaulted to YES for convenience. Set this option explicitly to avoid issues.
|
|
||||||
* mf_getuniquelibref.sas to have the deprecated maxtries parameter removed (no longer needed)
|
|
||||||
* mp_abort.sas will have the redundant type= parameter removed.
|
|
||||||
* mp_coretable.sas will be replaced by the standalone macros in the `ddl` folder (which are already available)
|
|
||||||
* mp_getddl.sas to be renamed to mp_ds2ddl.sas (consistent with other ds2xxx macros). A wrapper macro is already in place, and you are able to use this immediately. The default for SHOWLOG will also be YES instead of NO.
|
|
||||||
* mp_testservice.sas to be renamed as mp_execute.sas (as it doesn't actually test anything)
|
* mp_testservice.sas to be renamed as mp_execute.sas (as it doesn't actually test anything)
|
||||||
|
* `insert_cmplib` option of mcf_xxx macros will be deprecated (the option is now checked automatically with value inserted only if needed)
|
||||||
|
* mcf_xxx macros to have `wrap=` option defaulted to YES for convenience. Set this option explicitly to avoid issues.
|
||||||
|
* mp_getddl.sas to be renamed to mp_ds2ddl.sas (consistent with other ds2xxx macros). A wrapper macro is already in place, and you are able to use this immediately. The default for SHOWLOG will also be YES instead of NO.
|
||||||
|
* mp_coretable.sas will be replaced by the standalone macros in the `ddl` folder (which are already available)
|
||||||
|
|
||||||
## Star Gazing
|
## Star Gazing
|
||||||
|
|
||||||
|
|||||||
340
all.sas
340
all.sas
@@ -4002,6 +4002,10 @@ run;
|
|||||||
ignorelist=,
|
ignorelist=,
|
||||||
outds=work.test_results
|
outds=work.test_results
|
||||||
)/*/STORE SOURCE*/;
|
)/*/STORE SOURCE*/;
|
||||||
|
%local ds test_result test_comments del add mod ilist;
|
||||||
|
%let ilist=%upcase(&sasjs_prefix._FUNCTIONS SYS_PROCHTTP_STATUS_CODE
|
||||||
|
SYS_PROCHTTP_STATUS_CODE SYS_PROCHTTP_STATUS_PHRASE &ignorelist);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* this sets up the global vars, it will also enter STRICT mode. If this
|
* this sets up the global vars, it will also enter STRICT mode. If this
|
||||||
* behaviour is not desired, simply initiate the following global macro
|
* behaviour is not desired, simply initiate the following global macro
|
||||||
@@ -4009,10 +4013,6 @@ run;
|
|||||||
*/
|
*/
|
||||||
%mp_init()
|
%mp_init()
|
||||||
|
|
||||||
%local ds test_result test_comments del add mod ilist;
|
|
||||||
%let ilist=%upcase(&sasjs_prefix._FUNCTIONS SYS_PROCHTTP_STATUS_CODE
|
|
||||||
SYS_PROCHTTP_STATUS_CODE SYS_PROCHTTP_STATUS_PHRASE &ignorelist);
|
|
||||||
|
|
||||||
/* get current variables */
|
/* get current variables */
|
||||||
%if &action=SNAPSHOT %then %do;
|
%if &action=SNAPSHOT %then %do;
|
||||||
proc sql;
|
proc sql;
|
||||||
@@ -13859,7 +13859,6 @@ run;
|
|||||||
@li mf_islibds.sas
|
@li mf_islibds.sas
|
||||||
@li mf_wordsinstr1butnotstr2.sas
|
@li mf_wordsinstr1butnotstr2.sas
|
||||||
@li mp_abort.sas
|
@li mp_abort.sas
|
||||||
@li mp_ds2squeeze.sas
|
|
||||||
|
|
||||||
<h4> Related Macros </h4>
|
<h4> Related Macros </h4>
|
||||||
@li mddl_dc_difftable.sas
|
@li mddl_dc_difftable.sas
|
||||||
@@ -24356,7 +24355,6 @@ run;
|
|||||||
@li mp_base64copy.sas
|
@li mp_base64copy.sas
|
||||||
@li mp_replace.sas
|
@li mp_replace.sas
|
||||||
@li mv_createfolder.sas
|
@li mv_createfolder.sas
|
||||||
@li mv_getviyafileextparms.sas
|
|
||||||
|
|
||||||
<h4> Related Macros</h4>
|
<h4> Related Macros</h4>
|
||||||
@li mv_createfile.sas
|
@li mv_createfile.sas
|
||||||
@@ -24441,7 +24439,7 @@ run;
|
|||||||
|
|
||||||
options noquotelenmax;
|
options noquotelenmax;
|
||||||
%local base_uri; /* location of rest apis */
|
%local base_uri; /* location of rest apis */
|
||||||
%let base_uri=%trim(%mf_getplatform(VIYARESTAPI));
|
%let base_uri=%mf_getplatform(VIYARESTAPI);
|
||||||
|
|
||||||
/* create folder if it does not already exist */
|
/* create folder if it does not already exist */
|
||||||
%local folderds self_uri;
|
%local folderds self_uri;
|
||||||
@@ -24460,7 +24458,7 @@ run;
|
|||||||
/* abort or delete if file already exists */
|
/* abort or delete if file already exists */
|
||||||
%let force=%upcase(&force);
|
%let force=%upcase(&force);
|
||||||
%local fileuri ;
|
%local fileuri ;
|
||||||
%let fileuri=%trim(%mfv_getpathuri(&path/&name));
|
%let fileuri=%mfv_getpathuri(&path/&name);
|
||||||
%mp_abort(iftrue=(%mf_isblank(&fileuri)=0 and &force ne YES)
|
%mp_abort(iftrue=(%mf_isblank(&fileuri)=0 and &force ne YES)
|
||||||
,mac=MV_CREATEFILE
|
,mac=MV_CREATEFILE
|
||||||
,msg=%str(File &path/&name already exists and force=&force)
|
,msg=%str(File &path/&name already exists and force=&force)
|
||||||
@@ -24487,13 +24485,7 @@ run;
|
|||||||
|
|
||||||
%local url mimetype ext;
|
%local url mimetype ext;
|
||||||
%let url=&base_uri/files/files?parentFolderUri=&self_uri;
|
%let url=&base_uri/files/files?parentFolderUri=&self_uri;
|
||||||
%let ext=%upcase(%trim(%scan(&name,-1,.)));
|
%let ext=%upcase(%scan(&name,-1,.));
|
||||||
|
|
||||||
/* Get Viya file-extension details into some macro variables */
|
|
||||||
%mv_getViyaFileExtParms(&ext
|
|
||||||
,propertiesVar=viyaProperties
|
|
||||||
,typeDefNameVar=viyaTypeDefName
|
|
||||||
,mdebug=&mdebug);
|
|
||||||
|
|
||||||
/* fetch job info */
|
/* fetch job info */
|
||||||
%local fname1;
|
%local fname1;
|
||||||
@@ -24506,24 +24498,13 @@ proc http method='POST' out=&fname1 &oauth_bearer in=&fref
|
|||||||
%else %do;
|
%else %do;
|
||||||
ct="&ctype"
|
ct="&ctype"
|
||||||
%end;
|
%end;
|
||||||
|
%if "&ext"="HTML" or "&ext"="CSS" or "&ext"="JS" or "&ext"="PNG"
|
||||||
/* typeDefName */
|
or "&ext"="SVG" %then %do;
|
||||||
%if not %mf_isBlank(&viyaTypeDefName) %then %do;
|
url="&url%str(&)typeDefName=file";
|
||||||
url="&url%str(&)typeDefName=&viyaTypeDefName";
|
|
||||||
%end;
|
|
||||||
%else %do;
|
|
||||||
%if "&ext"="HTM" or "&ext"="HTML" or "&ext"="XHTML" %then %do;
|
|
||||||
url="&url%str(&)typeDefName=file_html";
|
|
||||||
%end;
|
|
||||||
%else %do;
|
|
||||||
%if "&ext"="CSS" or "&ext"="JS" or "&ext"="PNG" or "&ext"="SVG" %then %do;
|
|
||||||
url="&url%str(&)typeDefName=file_%lowcase(&ext)";
|
|
||||||
%end;
|
%end;
|
||||||
%else %do;
|
%else %do;
|
||||||
url="&url";
|
url="&url";
|
||||||
%end;
|
%end;
|
||||||
%end;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
headers "Accept"="application/json"
|
headers "Accept"="application/json"
|
||||||
%if &grant_type=authorization_code %then %do;
|
%if &grant_type=authorization_code %then %do;
|
||||||
@@ -24544,7 +24525,6 @@ run;
|
|||||||
,mac=MV_CREATEFILE
|
,mac=MV_CREATEFILE
|
||||||
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
||||||
)
|
)
|
||||||
|
|
||||||
%local libref2;
|
%local libref2;
|
||||||
%let libref2=%mf_getuniquelibref();
|
%let libref2=%mf_getuniquelibref();
|
||||||
libname &libref2 JSON fileref=&fname1;
|
libname &libref2 JSON fileref=&fname1;
|
||||||
@@ -24552,60 +24532,12 @@ libname &libref2 JSON fileref=&fname1;
|
|||||||
data &outds;
|
data &outds;
|
||||||
set &libref2..links end=last;
|
set &libref2..links end=last;
|
||||||
if rel='createChild' then do;
|
if rel='createChild' then do;
|
||||||
|
call symputx('href',quote(cats("&base_uri",href)),'l');
|
||||||
&dbg put (_all_)(=);
|
&dbg put (_all_)(=);
|
||||||
end;
|
end;
|
||||||
run;
|
run;
|
||||||
|
|
||||||
/* URI of the created file */
|
%put &sysmacroname: %trim(&base_uri)%mfv_getpathuri(&path/&name);
|
||||||
%let fileuri=%trim(%mfv_getpathuri(&path/&name));
|
|
||||||
|
|
||||||
/* If properties were found then patch the file to include them */
|
|
||||||
%if not %mf_isBlank(%superq(viyaProperties)) %then %do;
|
|
||||||
/* Wrap the properties object in a root object also containing the file name */
|
|
||||||
%local viyapatch;
|
|
||||||
%let viyapatch = %sysfunc(pathname(work))/%mf_getuniquename(prefix=patch_json_);
|
|
||||||
data _null_;
|
|
||||||
length line $32767;
|
|
||||||
file "&viyapatch" lrecl=32767;
|
|
||||||
put '{ "name": "' "&name" '",';
|
|
||||||
line = cat('"properties": ',symget("viyaProperties"));
|
|
||||||
put line;
|
|
||||||
put '}';
|
|
||||||
stop;
|
|
||||||
run;
|
|
||||||
|
|
||||||
%if &mdebug=1 %then %do;
|
|
||||||
data _null_;
|
|
||||||
if (_n_ eq 1) then put 'DEBUG: ** PATCH JSON **';
|
|
||||||
infile "&viyapatch" end=last;
|
|
||||||
input;
|
|
||||||
put _infile_;
|
|
||||||
run;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
/* And apply the properties to the newly created file, using the PATCH method */
|
|
||||||
%let fref=%mf_getuniquefileref();
|
|
||||||
filename &fref "&viyapatch";
|
|
||||||
%let url=&base_uri&fileuri;
|
|
||||||
|
|
||||||
proc http method='PATCH' oauth_bearer=sas_services in=&fref
|
|
||||||
url="&url";
|
|
||||||
headers "Accept"="application/json"
|
|
||||||
"Content-Type"="application/json"
|
|
||||||
"If-Match"="*";
|
|
||||||
%if &mdebug=1 %then %do;
|
|
||||||
debug level=2;
|
|
||||||
%end;
|
|
||||||
run;
|
|
||||||
%if &mdebug=1 %then %put &sysmacroname PATCH &=url
|
|
||||||
&=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
|
||||||
%mp_abort(iftrue=(&SYS_PROCHTTP_STATUS_CODE ne 200)
|
|
||||||
,mac=MV_CREATEFILE
|
|
||||||
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
|
||||||
)
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%put &sysmacroname: &base_uri&fileuri;
|
|
||||||
%put /SASJobExecution?_file=&path/&name;%put;
|
%put /SASJobExecution?_file=&path/&name;%put;
|
||||||
|
|
||||||
%if &mdebug=0 %then %do;
|
%if &mdebug=0 %then %do;
|
||||||
@@ -28179,254 +28111,6 @@ filename &fname1 clear;
|
|||||||
libname &libref1 clear;
|
libname &libref1 clear;
|
||||||
|
|
||||||
%mend mv_getusers;/**
|
%mend mv_getusers;/**
|
||||||
@file mv_getviyafileextparms.sas
|
|
||||||
@brief Reads the VIYA file-extension type definition and returns selected
|
|
||||||
values in SAS macro variables
|
|
||||||
|
|
||||||
@details Content is derived from the following endpoint:
|
|
||||||
"https://${serverUrl}/types/types?limit=999999"
|
|
||||||
|
|
||||||
@param [in] ext File extension to retrieve property info for.
|
|
||||||
@param [out] propertiesVar= SAS macro variable name that will contain
|
|
||||||
the 'properties' object json, if found, else blank.
|
|
||||||
@param [out] typeDefNameVar= SAS macro variable name that will contain
|
|
||||||
the 'typeDefName' property value, if found, else blank.
|
|
||||||
@param [out] mediaTypeVar= SAS macro variable name that will contain
|
|
||||||
the 'mediaType' property value, if found, else blank.
|
|
||||||
@param [out] viyaFileExtRespLibDs (work.mv_getViyaFileExtParmsResponse)
|
|
||||||
Library.name of the dataset to receive the local working copy of the initial
|
|
||||||
response that requests all file extension details. Created once per session
|
|
||||||
to avoid multiple api calls.
|
|
||||||
@param [in] mdebug= (0) Set to 1 to enable DEBUG messages
|
|
||||||
|
|
||||||
<h4> SAS Macros </h4>
|
|
||||||
@li mf_existds.sas
|
|
||||||
@li mf_getplatform.sas
|
|
||||||
@li mf_getuniquefileref.sas
|
|
||||||
@li mf_getuniquename.sas
|
|
||||||
@li mf_getvalue.sas
|
|
||||||
@li mf_getvarlist.sas
|
|
||||||
@li mf_getvartype.sas
|
|
||||||
@li mf_isblank.sas
|
|
||||||
@li mf_nobs.sas
|
|
||||||
@li mp_abort.sas
|
|
||||||
|
|
||||||
**/
|
|
||||||
|
|
||||||
%macro mv_getViyaFileExtParms(
|
|
||||||
ext,
|
|
||||||
typeDefNameVar=,
|
|
||||||
propertiesVar=,
|
|
||||||
mediaTypeVar=,
|
|
||||||
viyaFileExtRespLibDs=work.mv_getViyaFileExtParmsResponse,
|
|
||||||
mdebug=0
|
|
||||||
);
|
|
||||||
%local base_uri; /* location of rest apis */
|
|
||||||
%local url; /* File extension info end-point */
|
|
||||||
|
|
||||||
%mp_abort(
|
|
||||||
iftrue=(%mf_isBlank(&ext))
|
|
||||||
,msg=%str(No file extension provided.)
|
|
||||||
,mac=MV_GETVIYAFILEEXTPARMS
|
|
||||||
);
|
|
||||||
|
|
||||||
%mp_abort(
|
|
||||||
iftrue=(%mf_isBlank(&typeDefNameVar) and
|
|
||||||
%mf_isBlank(&propertiesVar) and
|
|
||||||
%mf_isBlank(&mediaTypeVar))
|
|
||||||
,msg=%str(MV_GETVIYAFILEEXTPARMS - No parameter was requested.)
|
|
||||||
,mac=MV_GETVIYAFILEEXTPARMS
|
|
||||||
);
|
|
||||||
|
|
||||||
%mp_abort(
|
|
||||||
iftrue=(%mf_isBlank(&viyaFileExtRespLibDs))
|
|
||||||
,msg=%str(No <libname.>dataset name provided to cache inital response.)
|
|
||||||
,mac=MV_GETVIYAFILEEXTPARMS
|
|
||||||
);
|
|
||||||
|
|
||||||
/* Declare requested parameters as global macro vars and initialize blank */
|
|
||||||
%if not %mf_isBlank(&typeDefNameVar) %then %do;
|
|
||||||
%global &typeDefNameVar;
|
|
||||||
%let &typeDefNameVar = %str();
|
|
||||||
%end;
|
|
||||||
%if not %mf_isBlank(&propertiesVar) %then %do;
|
|
||||||
%global &propertiesVar;
|
|
||||||
%let &propertiesVar = %str();
|
|
||||||
%end;
|
|
||||||
%if not %mf_isBlank(&mediaTypeVar) %then %do;
|
|
||||||
%global &mediaTypeVar;
|
|
||||||
%let &mediaTypeVar = %str();
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%let base_uri=%mf_getplatform(VIYARESTAPI);
|
|
||||||
%if &mdebug=1 %then %do;
|
|
||||||
%put DEBUG: &=base_uri;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%let ext=%lowcase(&ext);
|
|
||||||
|
|
||||||
/* Create a local copy of the Viya response containing all file type info, if
|
|
||||||
it does not already exist. */
|
|
||||||
%if not %mf_existds(&viyaFileExtRespLibDs) %then %do;
|
|
||||||
/* Create a temp file and fill with JSON that declares */
|
|
||||||
/* VIYA file-type details for the given file extension */
|
|
||||||
%local viyatypedefs;
|
|
||||||
%let viyatypedefs=%mf_getuniquefileref();
|
|
||||||
filename &viyatypedefs temp;
|
|
||||||
|
|
||||||
%let url = &base_uri/types/types?limit=999999;
|
|
||||||
|
|
||||||
proc http oauth_bearer=sas_services out=&viyatypedefs
|
|
||||||
url="&url";
|
|
||||||
run;
|
|
||||||
|
|
||||||
%if &mdebug=1 %then %put DEBUG: &sysmacroname &=url
|
|
||||||
&=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
|
||||||
|
|
||||||
%if (&SYS_PROCHTTP_STATUS_CODE ne 200) %then %do;
|
|
||||||
/* To avoid a breaking change, exit early if the request failed.
|
|
||||||
The calling process will proceed with empty requested macro variables. */
|
|
||||||
%put INFO: &sysmacroname File extension details were not retrieved.;
|
|
||||||
filename &viyatypedefs clear;
|
|
||||||
%return;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%if &mdebug=1 %then %do;
|
|
||||||
/* Dump the response to the log */
|
|
||||||
data _null_;
|
|
||||||
length line $120;
|
|
||||||
null=byte(0);
|
|
||||||
infile &viyatypedefs dlm=null lrecl=120 recfm=n;
|
|
||||||
input line $120.;
|
|
||||||
if _n_ = 1 then put "DEBUG:";
|
|
||||||
put line;
|
|
||||||
run;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
/* Convert the content of that JSON into SAS datasets */
|
|
||||||
/* First prepare a new WORK-based folder to receive the datasets */
|
|
||||||
%local jsonworkfolder jsonlib opt_dlcreatedir;
|
|
||||||
%let jsonworkfolder=%sysfunc(pathname(work))/%mf_getuniquename(prefix=json_);
|
|
||||||
%let jsonlib=%mf_getuniquelibref(prefix=json);
|
|
||||||
/* And point a libname at it */
|
|
||||||
%let opt_dlcreatedir = %sysfunc(getoption(dlcreatedir));
|
|
||||||
options dlcreatedir; libname &jsonlib "&jsonworkfolder"; options &opt_dlcreatedir;
|
|
||||||
|
|
||||||
/* Read the json output once and copy datasets to its work folder */
|
|
||||||
%local libref1;
|
|
||||||
%let libref1=%mf_getuniquelibref();
|
|
||||||
libname &libref1 JSON fileref=&viyatypedefs automap=create;
|
|
||||||
proc copy in=&libref1 out=&jsonlib; run;
|
|
||||||
|
|
||||||
libname &libref1 clear;
|
|
||||||
|
|
||||||
/* Now give all rows belonging to the same items array a grouping value */
|
|
||||||
data &viyaFileExtRespLibDs;
|
|
||||||
length _viyaItemIdx 8;
|
|
||||||
set &jsonlib..alldata;
|
|
||||||
retain _viyaItemIdx 0;
|
|
||||||
/* Increment the row group index when a new 'items' group is observed */
|
|
||||||
if P=1 and P1='items' then _viyaItemIdx + 1;
|
|
||||||
run;
|
|
||||||
|
|
||||||
%if &mdebug=0 %then %do;
|
|
||||||
/* Tidy up, unless debug=1 */
|
|
||||||
proc datasets library=&jsonlib nolist kill; quit;
|
|
||||||
libname &jsonlib clear;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
filename &viyatypedefs clear;
|
|
||||||
|
|
||||||
%end; /* If initial filetype query response didn't exist */
|
|
||||||
|
|
||||||
/* Find the row-group for the current file extension */
|
|
||||||
%local itemRowGroup;
|
|
||||||
%let itemRowGroup =
|
|
||||||
%mf_getValue(
|
|
||||||
&viyaFileExtRespLibDs
|
|
||||||
,_viyaItemIdx
|
|
||||||
,filter=%quote(p1='items' and p2='extensions' and value="&ext")
|
|
||||||
);
|
|
||||||
|
|
||||||
%if &mdebug %then %put DEBUG: &=itemRowGroup;
|
|
||||||
|
|
||||||
%if %mf_isBlank(&itemRowGroup) %then %do;
|
|
||||||
/* extension was not found */
|
|
||||||
%if(&mdebug=1) %then %put DEBUG: No type details found for extension "&ext".;
|
|
||||||
%return;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
/* Filter the cached response data down to the required file extension */
|
|
||||||
%local dsItems;
|
|
||||||
%let dsItems = %mf_getuniquename(prefix=dsItems_);
|
|
||||||
data work.&dsItems;
|
|
||||||
set &viyaFileExtRespLibDs;
|
|
||||||
where _viyaItemIdx = &itemRowGroup;
|
|
||||||
run;
|
|
||||||
|
|
||||||
/* Populate typeDefName, if requested */
|
|
||||||
%if (not %mf_isBlank(&typeDefNameVar)) %then %do;
|
|
||||||
%let &typeDefNameVar = %mf_getvalue(&dsItems,value,filter=%quote(p1="items" and p2="name"));
|
|
||||||
%if &mdebug=1 %then %put DEBUG: &=typeDefNameVar &typeDefNameVar=&&&typeDefNameVar;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
/* Populate mediaType, if requested */
|
|
||||||
%if (not %mf_isBlank(&mediaTypeVar)) %then %do;
|
|
||||||
%let &mediaTypeVar = %mf_getvalue(&dsItems,value,filter=%quote(p1="items" and p2="mediaType"));
|
|
||||||
%if &mdebug=1 %then %put DEBUG: &=mediaTypeVar &mediaTypeVar=&&&mediaTypeVar;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
/* Populate properties macro variable, if requested */
|
|
||||||
%if not %mf_isBlank(&propertiesVar) %then %do;
|
|
||||||
|
|
||||||
/* Filter dsItems down to the properties */
|
|
||||||
%local dsProperties;
|
|
||||||
%let dsProperties = %mf_getuniquename(prefix=dsProperties_);
|
|
||||||
data work.&dsProperties ( rename=(p3 = propertyName) );
|
|
||||||
set work.&dsItems;
|
|
||||||
where p2="properties" and v=1;
|
|
||||||
run;
|
|
||||||
|
|
||||||
/* Check for 1+ properties */
|
|
||||||
%if ( %mf_nobs(&dsProperties) = 0 ) %then %do;
|
|
||||||
%let &propertiesVar = %str();
|
|
||||||
%if &mdebug=1 %then %put DEBUG: &SYSMACRONAME - No Viya properties found for file suffix %str(%')&ext%str(%');
|
|
||||||
%end;
|
|
||||||
%else %do;
|
|
||||||
/* Properties potentially span multiple rows in the input table */
|
|
||||||
data _null_;
|
|
||||||
length
|
|
||||||
line $32767
|
|
||||||
properties $32767
|
|
||||||
;
|
|
||||||
retain properties;
|
|
||||||
set &dsProperties end=last;
|
|
||||||
if _n_ = 1 then properties = '{';
|
|
||||||
|
|
||||||
line = cats(quote(trim(propertyName)),':');
|
|
||||||
/* Only strings and bools appear in properties */
|
|
||||||
if value not in ("true","false") then value = quote(trim(value));
|
|
||||||
line = catx(' ',line,value);
|
|
||||||
/* Add a comma separator to all except the last line */
|
|
||||||
if not last then line = cats(line,',');
|
|
||||||
|
|
||||||
/* Add this line to the output value */
|
|
||||||
properties = catx(' ',properties,line);
|
|
||||||
|
|
||||||
if last then do;
|
|
||||||
/* Close off the properties object and output to the macro variable */
|
|
||||||
properties=catx(' ',properties,'}');
|
|
||||||
call symputx("&propertiesVar",properties);
|
|
||||||
end;
|
|
||||||
run;
|
|
||||||
|
|
||||||
%if &mdebug=1 %then %put DEBUG: &=propertiesVar &propertiesVar=&&&propertiesVar;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%mend mv_getViyaFileExtParms;
|
|
||||||
/**
|
|
||||||
@file
|
@file
|
||||||
@brief Executes a SAS Viya Job
|
@brief Executes a SAS Viya Job
|
||||||
@details Triggers a SAS Viya Job, with optional URL parameters, using
|
@details Triggers a SAS Viya Job, with optional URL parameters, using
|
||||||
|
|||||||
@@ -73,6 +73,10 @@
|
|||||||
ignorelist=,
|
ignorelist=,
|
||||||
outds=work.test_results
|
outds=work.test_results
|
||||||
)/*/STORE SOURCE*/;
|
)/*/STORE SOURCE*/;
|
||||||
|
%local ds test_result test_comments del add mod ilist;
|
||||||
|
%let ilist=%upcase(&sasjs_prefix._FUNCTIONS SYS_PROCHTTP_STATUS_CODE
|
||||||
|
SYS_PROCHTTP_STATUS_CODE SYS_PROCHTTP_STATUS_PHRASE &ignorelist);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* this sets up the global vars, it will also enter STRICT mode. If this
|
* this sets up the global vars, it will also enter STRICT mode. If this
|
||||||
* behaviour is not desired, simply initiate the following global macro
|
* behaviour is not desired, simply initiate the following global macro
|
||||||
@@ -80,10 +84,6 @@
|
|||||||
*/
|
*/
|
||||||
%mp_init()
|
%mp_init()
|
||||||
|
|
||||||
%local ds test_result test_comments del add mod ilist;
|
|
||||||
%let ilist=%upcase(&sasjs_prefix._FUNCTIONS SYS_PROCHTTP_STATUS_CODE
|
|
||||||
SYS_PROCHTTP_STATUS_CODE SYS_PROCHTTP_STATUS_PHRASE &ignorelist);
|
|
||||||
|
|
||||||
/* get current variables */
|
/* get current variables */
|
||||||
%if &action=SNAPSHOT %then %do;
|
%if &action=SNAPSHOT %then %do;
|
||||||
proc sql;
|
proc sql;
|
||||||
|
|||||||
@@ -36,7 +36,6 @@
|
|||||||
@li mf_islibds.sas
|
@li mf_islibds.sas
|
||||||
@li mf_wordsinstr1butnotstr2.sas
|
@li mf_wordsinstr1butnotstr2.sas
|
||||||
@li mp_abort.sas
|
@li mp_abort.sas
|
||||||
@li mp_ds2squeeze.sas
|
|
||||||
|
|
||||||
<h4> Related Macros </h4>
|
<h4> Related Macros </h4>
|
||||||
@li mddl_dc_difftable.sas
|
@li mddl_dc_difftable.sas
|
||||||
|
|||||||
@@ -5,10 +5,7 @@
|
|||||||
"ddl",
|
"ddl",
|
||||||
"fcmp",
|
"fcmp",
|
||||||
"lua",
|
"lua",
|
||||||
"meta",
|
|
||||||
"metax",
|
|
||||||
"server",
|
"server",
|
||||||
"viya",
|
|
||||||
"xplatform",
|
"xplatform",
|
||||||
"tests/base",
|
"tests/base",
|
||||||
"tests/ddlonly",
|
"tests/ddlonly",
|
||||||
@@ -45,6 +42,7 @@
|
|||||||
"deployScripts": []
|
"deployScripts": []
|
||||||
},
|
},
|
||||||
"macroFolders": [
|
"macroFolders": [
|
||||||
|
"viya",
|
||||||
"tests/viyaonly"
|
"tests/viyaonly"
|
||||||
],
|
],
|
||||||
"contextName": "SAS Job Execution compute context"
|
"contextName": "SAS Job Execution compute context"
|
||||||
@@ -58,6 +56,8 @@
|
|||||||
},
|
},
|
||||||
"appLoc": "/Shared Data/temp/macrocore",
|
"appLoc": "/Shared Data/temp/macrocore",
|
||||||
"macroFolders": [
|
"macroFolders": [
|
||||||
|
"meta",
|
||||||
|
"metax",
|
||||||
"tests/sas9only"
|
"tests/sas9only"
|
||||||
],
|
],
|
||||||
"programFolders": [],
|
"programFolders": [],
|
||||||
@@ -82,6 +82,7 @@
|
|||||||
"deployScripts": []
|
"deployScripts": []
|
||||||
},
|
},
|
||||||
"macroFolders": [
|
"macroFolders": [
|
||||||
|
"server",
|
||||||
"tests/serveronly"
|
"tests/serveronly"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -1,96 +0,0 @@
|
|||||||
/**
|
|
||||||
@file
|
|
||||||
@brief Testing mv_getviyafileextparms macro
|
|
||||||
|
|
||||||
<h4> SAS Macros </h4>
|
|
||||||
@li mf_isblank.sas
|
|
||||||
@li mp_assert.sas
|
|
||||||
@li mp_assertscope.sas
|
|
||||||
@li mv_getviyafileextparms.sas
|
|
||||||
|
|
||||||
**/
|
|
||||||
|
|
||||||
options mprint;
|
|
||||||
|
|
||||||
%let mvarIgnoreList =
|
|
||||||
MC0_JADP1LEN MC0_JADP2LEN MC0_JADP3LEN MC0_JADPNUM MC0_JADVLEN
|
|
||||||
SASJSPROCESSMODE SASJS_STPSRV_HEADER_LOC;
|
|
||||||
|
|
||||||
%put TEST 1 - Test with common extension, requesting only typeDefName parameter;
|
|
||||||
%mp_assertscope(SNAPSHOT)
|
|
||||||
%mv_getviyafileextparms(ext=txt, typeDefNameVar=viyaTypeDefName)
|
|
||||||
%mp_assertscope(COMPARE
|
|
||||||
,ignorelist=&mvarIgnoreList viyaTypeDefName
|
|
||||||
)
|
|
||||||
|
|
||||||
%mp_assert(
|
|
||||||
iftrue=(not %mf_isBlank(&viyaTypeDefName)),
|
|
||||||
desc=Check the requested macro variable viyaTypeDefName is not blank.
|
|
||||||
)
|
|
||||||
|
|
||||||
%put TEST 2 - Test with common extension, requesting only properties parameter;
|
|
||||||
%mp_assertscope(SNAPSHOT)
|
|
||||||
%mv_getviyafileextparms(ext=html, propertiesVar=viyaProperties)
|
|
||||||
%mp_assertscope(COMPARE
|
|
||||||
,ignorelist=&mvarIgnoreList viyaProperties
|
|
||||||
)
|
|
||||||
|
|
||||||
%mp_assert(
|
|
||||||
iftrue=(not %mf_isBlank(%superq(viyaProperties))),
|
|
||||||
desc=Check the requested macro variable viyaProperties is not blank.
|
|
||||||
)
|
|
||||||
|
|
||||||
%put TEST 3 - Test with common extension, requesting only mediaType parameter;
|
|
||||||
%mp_assertscope(SNAPSHOT)
|
|
||||||
%mv_getviyafileextparms(ext=mp3, mediaTypeVar=viyaMediaType)
|
|
||||||
%mp_assertscope(COMPARE
|
|
||||||
,ignorelist=&mvarIgnoreList viyaMediaType
|
|
||||||
)
|
|
||||||
|
|
||||||
%mp_assert(
|
|
||||||
iftrue=(not %mf_isBlank(&viyaMediaType)),
|
|
||||||
desc=Check the requested macro variable viyaMediaType is not blank.
|
|
||||||
)
|
|
||||||
|
|
||||||
%put TEST 4 - Test with common extension, requesting all parameters;
|
|
||||||
%mp_assertscope(SNAPSHOT)
|
|
||||||
%mv_getviyafileextparms(
|
|
||||||
ext=css,
|
|
||||||
typeDefNameVar=cssViyaTypeDefName,
|
|
||||||
propertiesVar=cssViyaProperties,
|
|
||||||
mediaTypeVar=cssViyaMediaType
|
|
||||||
)
|
|
||||||
%mp_assertscope(COMPARE
|
|
||||||
,ignorelist=
|
|
||||||
&mvarIgnoreList cssViyaTypeDefName cssViyaProperties cssViyaMediaType
|
|
||||||
)
|
|
||||||
|
|
||||||
%mp_assert(
|
|
||||||
iftrue=(not ( %mf_isBlank(&cssViyaTypeDefName) or
|
|
||||||
%mf_isBlank(%superq(cssViyaProperties)) or
|
|
||||||
%mf_isBlank(&cssViyaMediaType) ) ),
|
|
||||||
desc=Check a full set of requested macro variables are not blank.
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
%put TEST 5 - Test with invalid extension - requested parameters will be blank;
|
|
||||||
%mp_assertscope(SNAPSHOT)
|
|
||||||
%mv_getviyafileextparms(
|
|
||||||
ext=xxxINVALIDxxx,
|
|
||||||
typeDefNameVar=invalidTypeDefName,
|
|
||||||
propertiesVar=invalidProperties,
|
|
||||||
mediaTypeVar=invalidMediaType
|
|
||||||
)
|
|
||||||
%mp_assertscope(COMPARE
|
|
||||||
,ignorelist=
|
|
||||||
&mvarIgnoreList invalidTypeDefName invalidProperties invalidMediaType
|
|
||||||
)
|
|
||||||
|
|
||||||
%mp_assert(
|
|
||||||
iftrue=(
|
|
||||||
%mf_isBlank(&invalidTypeDefName) and
|
|
||||||
%mf_isBlank(%superq(invalidProperties)) and
|
|
||||||
%mf_isBlank(&invalidMediaType)
|
|
||||||
),
|
|
||||||
desc=Check the requested macro variables are all blank.
|
|
||||||
)
|
|
||||||
@@ -69,7 +69,6 @@
|
|||||||
@li mp_base64copy.sas
|
@li mp_base64copy.sas
|
||||||
@li mp_replace.sas
|
@li mp_replace.sas
|
||||||
@li mv_createfolder.sas
|
@li mv_createfolder.sas
|
||||||
@li mv_getviyafileextparms.sas
|
|
||||||
|
|
||||||
<h4> Related Macros</h4>
|
<h4> Related Macros</h4>
|
||||||
@li mv_createfile.sas
|
@li mv_createfile.sas
|
||||||
@@ -154,7 +153,7 @@
|
|||||||
|
|
||||||
options noquotelenmax;
|
options noquotelenmax;
|
||||||
%local base_uri; /* location of rest apis */
|
%local base_uri; /* location of rest apis */
|
||||||
%let base_uri=%trim(%mf_getplatform(VIYARESTAPI));
|
%let base_uri=%mf_getplatform(VIYARESTAPI);
|
||||||
|
|
||||||
/* create folder if it does not already exist */
|
/* create folder if it does not already exist */
|
||||||
%local folderds self_uri;
|
%local folderds self_uri;
|
||||||
@@ -173,7 +172,7 @@ run;
|
|||||||
/* abort or delete if file already exists */
|
/* abort or delete if file already exists */
|
||||||
%let force=%upcase(&force);
|
%let force=%upcase(&force);
|
||||||
%local fileuri ;
|
%local fileuri ;
|
||||||
%let fileuri=%trim(%mfv_getpathuri(&path/&name));
|
%let fileuri=%mfv_getpathuri(&path/&name);
|
||||||
%mp_abort(iftrue=(%mf_isblank(&fileuri)=0 and &force ne YES)
|
%mp_abort(iftrue=(%mf_isblank(&fileuri)=0 and &force ne YES)
|
||||||
,mac=MV_CREATEFILE
|
,mac=MV_CREATEFILE
|
||||||
,msg=%str(File &path/&name already exists and force=&force)
|
,msg=%str(File &path/&name already exists and force=&force)
|
||||||
@@ -200,13 +199,7 @@ run;
|
|||||||
|
|
||||||
%local url mimetype ext;
|
%local url mimetype ext;
|
||||||
%let url=&base_uri/files/files?parentFolderUri=&self_uri;
|
%let url=&base_uri/files/files?parentFolderUri=&self_uri;
|
||||||
%let ext=%upcase(%trim(%scan(&name,-1,.)));
|
%let ext=%upcase(%scan(&name,-1,.));
|
||||||
|
|
||||||
/* Get Viya file-extension details into some macro variables */
|
|
||||||
%mv_getViyaFileExtParms(&ext
|
|
||||||
,propertiesVar=viyaProperties
|
|
||||||
,typeDefNameVar=viyaTypeDefName
|
|
||||||
,mdebug=&mdebug);
|
|
||||||
|
|
||||||
/* fetch job info */
|
/* fetch job info */
|
||||||
%local fname1;
|
%local fname1;
|
||||||
@@ -219,24 +212,13 @@ proc http method='POST' out=&fname1 &oauth_bearer in=&fref
|
|||||||
%else %do;
|
%else %do;
|
||||||
ct="&ctype"
|
ct="&ctype"
|
||||||
%end;
|
%end;
|
||||||
|
%if "&ext"="HTML" or "&ext"="CSS" or "&ext"="JS" or "&ext"="PNG"
|
||||||
/* typeDefName */
|
or "&ext"="SVG" %then %do;
|
||||||
%if not %mf_isBlank(&viyaTypeDefName) %then %do;
|
url="&url%str(&)typeDefName=file";
|
||||||
url="&url%str(&)typeDefName=&viyaTypeDefName";
|
|
||||||
%end;
|
|
||||||
%else %do;
|
|
||||||
%if "&ext"="HTM" or "&ext"="HTML" or "&ext"="XHTML" %then %do;
|
|
||||||
url="&url%str(&)typeDefName=file_html";
|
|
||||||
%end;
|
|
||||||
%else %do;
|
|
||||||
%if "&ext"="CSS" or "&ext"="JS" or "&ext"="PNG" or "&ext"="SVG" %then %do;
|
|
||||||
url="&url%str(&)typeDefName=file_%lowcase(&ext)";
|
|
||||||
%end;
|
%end;
|
||||||
%else %do;
|
%else %do;
|
||||||
url="&url";
|
url="&url";
|
||||||
%end;
|
%end;
|
||||||
%end;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
headers "Accept"="application/json"
|
headers "Accept"="application/json"
|
||||||
%if &grant_type=authorization_code %then %do;
|
%if &grant_type=authorization_code %then %do;
|
||||||
@@ -257,7 +239,6 @@ run;
|
|||||||
,mac=MV_CREATEFILE
|
,mac=MV_CREATEFILE
|
||||||
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
||||||
)
|
)
|
||||||
|
|
||||||
%local libref2;
|
%local libref2;
|
||||||
%let libref2=%mf_getuniquelibref();
|
%let libref2=%mf_getuniquelibref();
|
||||||
libname &libref2 JSON fileref=&fname1;
|
libname &libref2 JSON fileref=&fname1;
|
||||||
@@ -265,60 +246,12 @@ libname &libref2 JSON fileref=&fname1;
|
|||||||
data &outds;
|
data &outds;
|
||||||
set &libref2..links end=last;
|
set &libref2..links end=last;
|
||||||
if rel='createChild' then do;
|
if rel='createChild' then do;
|
||||||
|
call symputx('href',quote(cats("&base_uri",href)),'l');
|
||||||
&dbg put (_all_)(=);
|
&dbg put (_all_)(=);
|
||||||
end;
|
end;
|
||||||
run;
|
run;
|
||||||
|
|
||||||
/* URI of the created file */
|
%put &sysmacroname: %trim(&base_uri)%mfv_getpathuri(&path/&name);
|
||||||
%let fileuri=%trim(%mfv_getpathuri(&path/&name));
|
|
||||||
|
|
||||||
/* If properties were found then patch the file to include them */
|
|
||||||
%if not %mf_isBlank(%superq(viyaProperties)) %then %do;
|
|
||||||
/* Wrap the properties object in a root object also containing the file name */
|
|
||||||
%local viyapatch;
|
|
||||||
%let viyapatch = %sysfunc(pathname(work))/%mf_getuniquename(prefix=patch_json_);
|
|
||||||
data _null_;
|
|
||||||
length line $32767;
|
|
||||||
file "&viyapatch" lrecl=32767;
|
|
||||||
put '{ "name": "' "&name" '",';
|
|
||||||
line = cat('"properties": ',symget("viyaProperties"));
|
|
||||||
put line;
|
|
||||||
put '}';
|
|
||||||
stop;
|
|
||||||
run;
|
|
||||||
|
|
||||||
%if &mdebug=1 %then %do;
|
|
||||||
data _null_;
|
|
||||||
if (_n_ eq 1) then put 'DEBUG: ** PATCH JSON **';
|
|
||||||
infile "&viyapatch" end=last;
|
|
||||||
input;
|
|
||||||
put _infile_;
|
|
||||||
run;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
/* And apply the properties to the newly created file, using the PATCH method */
|
|
||||||
%let fref=%mf_getuniquefileref();
|
|
||||||
filename &fref "&viyapatch";
|
|
||||||
%let url=&base_uri&fileuri;
|
|
||||||
|
|
||||||
proc http method='PATCH' oauth_bearer=sas_services in=&fref
|
|
||||||
url="&url";
|
|
||||||
headers "Accept"="application/json"
|
|
||||||
"Content-Type"="application/json"
|
|
||||||
"If-Match"="*";
|
|
||||||
%if &mdebug=1 %then %do;
|
|
||||||
debug level=2;
|
|
||||||
%end;
|
|
||||||
run;
|
|
||||||
%if &mdebug=1 %then %put &sysmacroname PATCH &=url
|
|
||||||
&=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
|
||||||
%mp_abort(iftrue=(&SYS_PROCHTTP_STATUS_CODE ne 200)
|
|
||||||
,mac=MV_CREATEFILE
|
|
||||||
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
|
||||||
)
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%put &sysmacroname: &base_uri&fileuri;
|
|
||||||
%put /SASJobExecution?_file=&path/&name;%put;
|
%put /SASJobExecution?_file=&path/&name;%put;
|
||||||
|
|
||||||
%if &mdebug=0 %then %do;
|
%if &mdebug=0 %then %do;
|
||||||
|
|||||||
@@ -1,248 +0,0 @@
|
|||||||
/**
|
|
||||||
@file mv_getviyafileextparms.sas
|
|
||||||
@brief Reads the VIYA file-extension type definition and returns selected
|
|
||||||
values in SAS macro variables
|
|
||||||
|
|
||||||
@details Content is derived from the following endpoint:
|
|
||||||
"https://${serverUrl}/types/types?limit=999999"
|
|
||||||
|
|
||||||
@param [in] ext File extension to retrieve property info for.
|
|
||||||
@param [out] propertiesVar= SAS macro variable name that will contain
|
|
||||||
the 'properties' object json, if found, else blank.
|
|
||||||
@param [out] typeDefNameVar= SAS macro variable name that will contain
|
|
||||||
the 'typeDefName' property value, if found, else blank.
|
|
||||||
@param [out] mediaTypeVar= SAS macro variable name that will contain
|
|
||||||
the 'mediaType' property value, if found, else blank.
|
|
||||||
@param [out] viyaFileExtRespLibDs (work.mv_getViyaFileExtParmsResponse)
|
|
||||||
Library.name of the dataset to receive the local working copy of the initial
|
|
||||||
response that requests all file extension details. Created once per session
|
|
||||||
to avoid multiple api calls.
|
|
||||||
@param [in] mdebug= (0) Set to 1 to enable DEBUG messages
|
|
||||||
|
|
||||||
<h4> SAS Macros </h4>
|
|
||||||
@li mf_existds.sas
|
|
||||||
@li mf_getplatform.sas
|
|
||||||
@li mf_getuniquefileref.sas
|
|
||||||
@li mf_getuniquename.sas
|
|
||||||
@li mf_getvalue.sas
|
|
||||||
@li mf_getvarlist.sas
|
|
||||||
@li mf_getvartype.sas
|
|
||||||
@li mf_isblank.sas
|
|
||||||
@li mf_nobs.sas
|
|
||||||
@li mp_abort.sas
|
|
||||||
|
|
||||||
**/
|
|
||||||
|
|
||||||
%macro mv_getViyaFileExtParms(
|
|
||||||
ext,
|
|
||||||
typeDefNameVar=,
|
|
||||||
propertiesVar=,
|
|
||||||
mediaTypeVar=,
|
|
||||||
viyaFileExtRespLibDs=work.mv_getViyaFileExtParmsResponse,
|
|
||||||
mdebug=0
|
|
||||||
);
|
|
||||||
%local base_uri; /* location of rest apis */
|
|
||||||
%local url; /* File extension info end-point */
|
|
||||||
|
|
||||||
%mp_abort(
|
|
||||||
iftrue=(%mf_isBlank(&ext))
|
|
||||||
,msg=%str(No file extension provided.)
|
|
||||||
,mac=MV_GETVIYAFILEEXTPARMS
|
|
||||||
);
|
|
||||||
|
|
||||||
%mp_abort(
|
|
||||||
iftrue=(%mf_isBlank(&typeDefNameVar) and
|
|
||||||
%mf_isBlank(&propertiesVar) and
|
|
||||||
%mf_isBlank(&mediaTypeVar))
|
|
||||||
,msg=%str(MV_GETVIYAFILEEXTPARMS - No parameter was requested.)
|
|
||||||
,mac=MV_GETVIYAFILEEXTPARMS
|
|
||||||
);
|
|
||||||
|
|
||||||
%mp_abort(
|
|
||||||
iftrue=(%mf_isBlank(&viyaFileExtRespLibDs))
|
|
||||||
,msg=%str(No <libname.>dataset name provided to cache inital response.)
|
|
||||||
,mac=MV_GETVIYAFILEEXTPARMS
|
|
||||||
);
|
|
||||||
|
|
||||||
/* Declare requested parameters as global macro vars and initialize blank */
|
|
||||||
%if not %mf_isBlank(&typeDefNameVar) %then %do;
|
|
||||||
%global &typeDefNameVar;
|
|
||||||
%let &typeDefNameVar = %str();
|
|
||||||
%end;
|
|
||||||
%if not %mf_isBlank(&propertiesVar) %then %do;
|
|
||||||
%global &propertiesVar;
|
|
||||||
%let &propertiesVar = %str();
|
|
||||||
%end;
|
|
||||||
%if not %mf_isBlank(&mediaTypeVar) %then %do;
|
|
||||||
%global &mediaTypeVar;
|
|
||||||
%let &mediaTypeVar = %str();
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%let base_uri=%mf_getplatform(VIYARESTAPI);
|
|
||||||
%if &mdebug=1 %then %do;
|
|
||||||
%put DEBUG: &=base_uri;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%let ext=%lowcase(&ext);
|
|
||||||
|
|
||||||
/* Create a local copy of the Viya response containing all file type info, if
|
|
||||||
it does not already exist. */
|
|
||||||
%if not %mf_existds(&viyaFileExtRespLibDs) %then %do;
|
|
||||||
/* Create a temp file and fill with JSON that declares */
|
|
||||||
/* VIYA file-type details for the given file extension */
|
|
||||||
%local viyatypedefs;
|
|
||||||
%let viyatypedefs=%mf_getuniquefileref();
|
|
||||||
filename &viyatypedefs temp;
|
|
||||||
|
|
||||||
%let url = &base_uri/types/types?limit=999999;
|
|
||||||
|
|
||||||
proc http oauth_bearer=sas_services out=&viyatypedefs
|
|
||||||
url="&url";
|
|
||||||
run;
|
|
||||||
|
|
||||||
%if &mdebug=1 %then %put DEBUG: &sysmacroname &=url
|
|
||||||
&=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
|
||||||
|
|
||||||
%if (&SYS_PROCHTTP_STATUS_CODE ne 200) %then %do;
|
|
||||||
/* To avoid a breaking change, exit early if the request failed.
|
|
||||||
The calling process will proceed with empty requested macro variables. */
|
|
||||||
%put INFO: &sysmacroname File extension details were not retrieved.;
|
|
||||||
filename &viyatypedefs clear;
|
|
||||||
%return;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%if &mdebug=1 %then %do;
|
|
||||||
/* Dump the response to the log */
|
|
||||||
data _null_;
|
|
||||||
length line $120;
|
|
||||||
null=byte(0);
|
|
||||||
infile &viyatypedefs dlm=null lrecl=120 recfm=n;
|
|
||||||
input line $120.;
|
|
||||||
if _n_ = 1 then put "DEBUG:";
|
|
||||||
put line;
|
|
||||||
run;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
/* Convert the content of that JSON into SAS datasets */
|
|
||||||
/* First prepare a new WORK-based folder to receive the datasets */
|
|
||||||
%local jsonworkfolder jsonlib opt_dlcreatedir;
|
|
||||||
%let jsonworkfolder=%sysfunc(pathname(work))/%mf_getuniquename(prefix=json_);
|
|
||||||
%let jsonlib=%mf_getuniquelibref(prefix=json);
|
|
||||||
/* And point a libname at it */
|
|
||||||
%let opt_dlcreatedir = %sysfunc(getoption(dlcreatedir));
|
|
||||||
options dlcreatedir; libname &jsonlib "&jsonworkfolder"; options &opt_dlcreatedir;
|
|
||||||
|
|
||||||
/* Read the json output once and copy datasets to its work folder */
|
|
||||||
%local libref1;
|
|
||||||
%let libref1=%mf_getuniquelibref();
|
|
||||||
libname &libref1 JSON fileref=&viyatypedefs automap=create;
|
|
||||||
proc copy in=&libref1 out=&jsonlib; run;
|
|
||||||
|
|
||||||
libname &libref1 clear;
|
|
||||||
|
|
||||||
/* Now give all rows belonging to the same items array a grouping value */
|
|
||||||
data &viyaFileExtRespLibDs;
|
|
||||||
length _viyaItemIdx 8;
|
|
||||||
set &jsonlib..alldata;
|
|
||||||
retain _viyaItemIdx 0;
|
|
||||||
/* Increment the row group index when a new 'items' group is observed */
|
|
||||||
if P=1 and P1='items' then _viyaItemIdx + 1;
|
|
||||||
run;
|
|
||||||
|
|
||||||
%if &mdebug=0 %then %do;
|
|
||||||
/* Tidy up, unless debug=1 */
|
|
||||||
proc datasets library=&jsonlib nolist kill; quit;
|
|
||||||
libname &jsonlib clear;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
filename &viyatypedefs clear;
|
|
||||||
|
|
||||||
%end; /* If initial filetype query response didn't exist */
|
|
||||||
|
|
||||||
/* Find the row-group for the current file extension */
|
|
||||||
%local itemRowGroup;
|
|
||||||
%let itemRowGroup =
|
|
||||||
%mf_getValue(
|
|
||||||
&viyaFileExtRespLibDs
|
|
||||||
,_viyaItemIdx
|
|
||||||
,filter=%quote(p1='items' and p2='extensions' and value="&ext")
|
|
||||||
);
|
|
||||||
|
|
||||||
%if &mdebug %then %put DEBUG: &=itemRowGroup;
|
|
||||||
|
|
||||||
%if %mf_isBlank(&itemRowGroup) %then %do;
|
|
||||||
/* extension was not found */
|
|
||||||
%if(&mdebug=1) %then %put DEBUG: No type details found for extension "&ext".;
|
|
||||||
%return;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
/* Filter the cached response data down to the required file extension */
|
|
||||||
%local dsItems;
|
|
||||||
%let dsItems = %mf_getuniquename(prefix=dsItems_);
|
|
||||||
data work.&dsItems;
|
|
||||||
set &viyaFileExtRespLibDs;
|
|
||||||
where _viyaItemIdx = &itemRowGroup;
|
|
||||||
run;
|
|
||||||
|
|
||||||
/* Populate typeDefName, if requested */
|
|
||||||
%if (not %mf_isBlank(&typeDefNameVar)) %then %do;
|
|
||||||
%let &typeDefNameVar = %mf_getvalue(&dsItems,value,filter=%quote(p1="items" and p2="name"));
|
|
||||||
%if &mdebug=1 %then %put DEBUG: &=typeDefNameVar &typeDefNameVar=&&&typeDefNameVar;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
/* Populate mediaType, if requested */
|
|
||||||
%if (not %mf_isBlank(&mediaTypeVar)) %then %do;
|
|
||||||
%let &mediaTypeVar = %mf_getvalue(&dsItems,value,filter=%quote(p1="items" and p2="mediaType"));
|
|
||||||
%if &mdebug=1 %then %put DEBUG: &=mediaTypeVar &mediaTypeVar=&&&mediaTypeVar;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
/* Populate properties macro variable, if requested */
|
|
||||||
%if not %mf_isBlank(&propertiesVar) %then %do;
|
|
||||||
|
|
||||||
/* Filter dsItems down to the properties */
|
|
||||||
%local dsProperties;
|
|
||||||
%let dsProperties = %mf_getuniquename(prefix=dsProperties_);
|
|
||||||
data work.&dsProperties ( rename=(p3 = propertyName) );
|
|
||||||
set work.&dsItems;
|
|
||||||
where p2="properties" and v=1;
|
|
||||||
run;
|
|
||||||
|
|
||||||
/* Check for 1+ properties */
|
|
||||||
%if ( %mf_nobs(&dsProperties) = 0 ) %then %do;
|
|
||||||
%let &propertiesVar = %str();
|
|
||||||
%if &mdebug=1 %then %put DEBUG: &SYSMACRONAME - No Viya properties found for file suffix %str(%')&ext%str(%');
|
|
||||||
%end;
|
|
||||||
%else %do;
|
|
||||||
/* Properties potentially span multiple rows in the input table */
|
|
||||||
data _null_;
|
|
||||||
length
|
|
||||||
line $32767
|
|
||||||
properties $32767
|
|
||||||
;
|
|
||||||
retain properties;
|
|
||||||
set &dsProperties end=last;
|
|
||||||
if _n_ = 1 then properties = '{';
|
|
||||||
|
|
||||||
line = cats(quote(trim(propertyName)),':');
|
|
||||||
/* Only strings and bools appear in properties */
|
|
||||||
if value not in ("true","false") then value = quote(trim(value));
|
|
||||||
line = catx(' ',line,value);
|
|
||||||
/* Add a comma separator to all except the last line */
|
|
||||||
if not last then line = cats(line,',');
|
|
||||||
|
|
||||||
/* Add this line to the output value */
|
|
||||||
properties = catx(' ',properties,line);
|
|
||||||
|
|
||||||
if last then do;
|
|
||||||
/* Close off the properties object and output to the macro variable */
|
|
||||||
properties=catx(' ',properties,'}');
|
|
||||||
call symputx("&propertiesVar",properties);
|
|
||||||
end;
|
|
||||||
run;
|
|
||||||
|
|
||||||
%if &mdebug=1 %then %put DEBUG: &=propertiesVar &propertiesVar=&&&propertiesVar;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%mend mv_getViyaFileExtParms;
|
|
||||||
Reference in New Issue
Block a user