mirror of
https://github.com/sasjs/core.git
synced 2026-01-09 10:20:06 +00:00
Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
aef9a6325b |
3
.github/FUNDING.yml
vendored
Normal file
3
.github/FUNDING.yml
vendored
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
# These are supported funding model platforms
|
||||||
|
|
||||||
|
custom: https://getalby.com/p/sasjs
|
||||||
6
.gitpod.dockerfile
Normal file
6
.gitpod.dockerfile
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
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
Normal file
27
.gitpod.yml
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
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
|
||||||
34
README.md
34
README.md
@@ -1,12 +1,19 @@
|
|||||||
# Macro Core
|
# Macro Core
|
||||||
|
[![npm package][npm-image]][npm-url]
|
||||||
[](http://npmjs.org/package/@sasjs/core)
|
[![Github Workflow][githubworkflow-image]][githubworkflow-url]
|
||||||
[](https://github.com/sasjs/core/blob/main/.github/workflows/main.yml)
|
|
||||||

|

|
||||||

|

|
||||||
[](https://github.com/sasjs/core/issues?q=is%3Aissue+is%3Aclosed)
|
[](https://github.com/sasjs/core/issues?q=is%3Aissue+is%3Aclosed)
|
||||||
[](https://github.com/sasjs/core/issues)
|
[](https://github.com/sasjs/core/issues)
|
||||||

|

|
||||||
|
[](https://gitpod.io/#https://github.com/sasjs/core)
|
||||||
|
|
||||||
|
|
||||||
|
[npm-image]:https://img.shields.io/npm/v/@sasjs/core.svg
|
||||||
|
[npm-url]:http://npmjs.org/package/@sasjs/core
|
||||||
|
[githubworkflow-image]:https://github.com/sasjs/core/actions/workflows/main.yml/badge.svg
|
||||||
|
[githubworkflow-url]:https://github.com/sasjs/core/blob/main/.github/workflows/main.yml
|
||||||
|
[dependency-url]:https://github.com/sasjs/core/blob/main/package.json
|
||||||
|
|
||||||
|
|
||||||
Much quality. Many standards. The **Macro Core** library exists to save time and development effort! Herein ye shall find a veritable host of MIT-licenced, production quality SAS macros. These are a mix of tools, utilities, functions and code generators that are useful in the context of [Application Development](https://sasapps.io) on the SAS platform (eg https://datacontroller.io). [Contributions](https://github.com/sasjs/core/blob/main/.github/CONTRIBUTING.md) are welcome.
|
Much quality. Many standards. The **Macro Core** library exists to save time and development effort! Herein ye shall find a veritable host of MIT-licenced, production quality SAS macros. These are a mix of tools, utilities, functions and code generators that are useful in the context of [Application Development](https://sasapps.io) on the SAS platform (eg https://datacontroller.io). [Contributions](https://github.com/sasjs/core/blob/main/.github/CONTRIBUTING.md) are welcome.
|
||||||
@@ -140,17 +147,16 @@ filename mc url "https://raw.githubusercontent.com/sasjs/core/main/all.sas";
|
|||||||
- macro names must be lowercase
|
- macro names must be lowercase
|
||||||
- one macro per file
|
- one macro per file
|
||||||
- prefixes:
|
- prefixes:
|
||||||
- _mcf__: macro compiled functions (proc fcmp)
|
- _mcf_ for macro compiled functions (proc fcmp)
|
||||||
- _mddl__: macros containing DDL (Data Definition Language)
|
- _mddl_ for macros containing DDL (Data Definition Language)
|
||||||
- _mf__: macro functions (can be used in open code).
|
- _mf_ for macro functions (can be used in open code).
|
||||||
- _mfv__: macro functions that work only in Viya
|
- _ml_ for macros that are used to compile LUA modules
|
||||||
- _ml__: macros that are used to compile LUA modules
|
- _mm_ for metadata macros (interface with the metadata server).
|
||||||
- _mm__: metadata macros (interface with the metadata server).
|
- _mmx_ for macros that use metadata and are XCMD enabled (working on both windows and unix)
|
||||||
- _mmx__: macros that use metadata and are XCMD enabled (working on both windows and unix)
|
- _mp_ for macro procedures (which generate sas code)
|
||||||
- _mp__: macro procedures (which generate sas code)
|
- _ms_ for macro procedures that will only work with [@sasjs/server](https://github.com/sasjs/server)
|
||||||
- _ms__: macro procedures that will only work with [@sasjs/server](https://github.com/sasjs/server)
|
- _mv_ for macro procedures that will only work in Viya
|
||||||
- _mv__: macro procedures that will only work in Viya
|
- _mx_ for macros that work on Viya, SAS 9 EBI and SASjs Server
|
||||||
- _mx__: macros that work on Viya, SAS 9 EBI and SASjs Server
|
|
||||||
- follow verb-noun convention
|
- follow verb-noun convention
|
||||||
- unix style line endings (lf)
|
- unix style line endings (lf)
|
||||||
- individual lines should be no more than 80 characters long
|
- individual lines should be no more than 80 characters long
|
||||||
|
|||||||
218
all.sas
218
all.sas
@@ -1121,7 +1121,7 @@ or %index(&pgm,/tests/testteardown)
|
|||||||
@author Allan Bowe
|
@author Allan Bowe
|
||||||
**/
|
**/
|
||||||
|
|
||||||
%macro mf_getuniquelibref(prefix=mc,maxtries=1000);
|
%macro mf_getuniquelibref(prefix=mclib,maxtries=1000);
|
||||||
%local x;
|
%local x;
|
||||||
|
|
||||||
%if ( %length(&prefix) gt 7 ) %then %do;
|
%if ( %length(&prefix) gt 7 ) %then %do;
|
||||||
@@ -11828,8 +11828,7 @@ insert into &outds select distinct * from &append_ds;
|
|||||||
LUA, you can also use this macro: mp_gsubfile.sas
|
LUA, you can also use this macro: mp_gsubfile.sas
|
||||||
|
|
||||||
@param [in] infile The QUOTED path to the file on which to perform the
|
@param [in] infile The QUOTED path to the file on which to perform the
|
||||||
substitution. Note that you can extract the pathname from a fileref using
|
substitution
|
||||||
the pathname function, eg: `"%sysfunc(pathname(fref))"`;
|
|
||||||
@param [in] findvar= Macro variable NAME containing the string to search for
|
@param [in] findvar= Macro variable NAME containing the string to search for
|
||||||
@param [in] replacevar= Macro variable NAME containing the replacement string
|
@param [in] replacevar= Macro variable NAME containing the replacement string
|
||||||
@param [out] outfile= (0) Optional QUOTED path to the adjusted output file (to
|
@param [out] outfile= (0) Optional QUOTED path to the adjusted output file (to
|
||||||
@@ -11943,7 +11942,7 @@ data _null_;
|
|||||||
run;
|
run;
|
||||||
|
|
||||||
/* END */
|
/* END */
|
||||||
/* %put &sysmacroname took %sysevalf(%sysfunc(datetime())-&dttm) secs to run; */
|
%put &sysmacroname took %sysevalf(%sysfunc(datetime())-&dttm) seconds to run;
|
||||||
|
|
||||||
%mend mp_replace;
|
%mend mp_replace;
|
||||||
/**
|
/**
|
||||||
@@ -24098,25 +24097,18 @@ run;
|
|||||||
msg=Cannot enter mfv_existfolder.sas with syscc=&syscc
|
msg=Cannot enter mfv_existfolder.sas with syscc=&syscc
|
||||||
)
|
)
|
||||||
|
|
||||||
%local fref rc var;
|
%local fref rc;
|
||||||
%let fref=%mf_getuniquefileref();
|
%let fref=%mf_getuniquefileref();
|
||||||
|
|
||||||
%if %sysfunc(filename(fref,,filesrvc,folderPath="&path"))=0 %then %do;
|
%if %sysfunc(filename(fref,,filesrvc,folderPath="&path"))=0 %then %do;
|
||||||
1
|
1
|
||||||
%let var=_FILESRVC_&fref._URI;
|
|
||||||
%let rc=%sysfunc(filename(fref));
|
%let rc=%sysfunc(filename(fref));
|
||||||
%symdel &var;
|
|
||||||
%end;
|
%end;
|
||||||
%else %do;
|
%else %do;
|
||||||
0
|
0
|
||||||
%let syscc=0;
|
%let syscc=0;
|
||||||
%end;
|
%end;
|
||||||
|
|
||||||
%mf_abort(
|
|
||||||
iftrue=(&syscc ne 0),
|
|
||||||
msg=Cannot leave mfv_existfolder.sas with syscc=&syscc
|
|
||||||
)
|
|
||||||
|
|
||||||
%mend mfv_existfolder;/**
|
%mend mfv_existfolder;/**
|
||||||
@file mfv_existsashdat.sas
|
@file mfv_existsashdat.sas
|
||||||
@brief Checks whether a CAS sashdat dataset exists in persistent storage.
|
@brief Checks whether a CAS sashdat dataset exists in persistent storage.
|
||||||
@@ -24178,58 +24170,6 @@ run;
|
|||||||
|
|
||||||
%mend mfv_existsashdat;
|
%mend mfv_existsashdat;
|
||||||
/**
|
/**
|
||||||
@file
|
|
||||||
@brief Returns the path of a folder from the URI
|
|
||||||
@details Makes use of the SYSMSG() ER8OR response, which resolves the uri,
|
|
||||||
seemingly without entering an er8or state.
|
|
||||||
|
|
||||||
Usage:
|
|
||||||
|
|
||||||
%mv_createfolder(path=/public/demo)
|
|
||||||
%let uri=%mfv_getpathuri(/public/demo);
|
|
||||||
%put %mfv_getfolderpath(&uri);
|
|
||||||
|
|
||||||
Notice above the new path has an uppercase P - the correct path.
|
|
||||||
|
|
||||||
@param [in] uri The uri of the folder -eg /folders/folders/xxxx)
|
|
||||||
|
|
||||||
<h4> SAS Macros </h4>
|
|
||||||
@li mf_getuniquefileref.sas
|
|
||||||
|
|
||||||
<h4> Related Macros </h4>
|
|
||||||
@li mfv_getpathuri.sas
|
|
||||||
|
|
||||||
@version 4
|
|
||||||
@author [Allan Bowe](https://www.linkedin.com/in/allanbowe/)
|
|
||||||
**/
|
|
||||||
%macro mfv_getfolderpath(uri
|
|
||||||
)/*/STORE SOURCE*/;
|
|
||||||
|
|
||||||
%local fref rc path msg var /* var used to avoid delete timing issue */;
|
|
||||||
%let fref=%mf_getuniquefileref();
|
|
||||||
%if %quote(%substr(%str(&uri),1,17)) ne %quote(/folders/folders/)
|
|
||||||
%then %do;
|
|
||||||
%put &sysmacroname: Invalid URI: &uri;
|
|
||||||
%end;
|
|
||||||
%else %if %sysfunc(filename(fref,,filesrvc,folderuri="&uri" ))=0
|
|
||||||
%then %do;
|
|
||||||
%let var=_FILESRVC_&fref._URI;
|
|
||||||
%local fid ;
|
|
||||||
%let fid= %sysfunc(fopen(&fref,I));
|
|
||||||
%let msg=%quote(%sysfunc(sysmsg()));
|
|
||||||
|
|
||||||
%unquote(%scan(&msg,2,%str(,.)))
|
|
||||||
|
|
||||||
%let rc=%sysfunc(fclose(&fid));
|
|
||||||
%let rc=%sysfunc(filename(fref));
|
|
||||||
%symdel &var;
|
|
||||||
%end;
|
|
||||||
%else %do;
|
|
||||||
%put &sysmacroname: Not Found: &uri;
|
|
||||||
%let syscc=0;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%mend mfv_getfolderpath ;/**
|
|
||||||
@file
|
@file
|
||||||
@brief Returns the uri of a file or folder
|
@brief Returns the uri of a file or folder
|
||||||
@details The automatic variable `_FILESRVC_[fref]_URI` is used after assigning
|
@details The automatic variable `_FILESRVC_[fref]_URI` is used after assigning
|
||||||
@@ -24280,10 +24220,6 @@ run;
|
|||||||
%let syscc=0;
|
%let syscc=0;
|
||||||
%end;
|
%end;
|
||||||
|
|
||||||
%mf_abort(
|
|
||||||
iftrue=(&syscc ne 0),
|
|
||||||
msg=Cannot leave &sysmacroname with syscc=&syscc
|
|
||||||
)
|
|
||||||
%mend mfv_getpathuri;/**
|
%mend mfv_getpathuri;/**
|
||||||
@file
|
@file
|
||||||
@brief Creates a file in SAS Drive using the API method
|
@brief Creates a file in SAS Drive using the API method
|
||||||
@@ -24303,20 +24239,6 @@ run;
|
|||||||
run;
|
run;
|
||||||
%mv_createfile(path=/Public/temp,name=newfile.txt,inref=myfile)
|
%mv_createfile(path=/Public/temp,name=newfile.txt,inref=myfile)
|
||||||
|
|
||||||
The macro also supports find & replace (used by the SASjs Streaming App
|
|
||||||
build program). This allows one string to be replaced by another at the
|
|
||||||
point at which the file is created. This is done by passing in the NAMES of
|
|
||||||
the macro variables containing the values to be swapped, eg:
|
|
||||||
|
|
||||||
filename fref temp;
|
|
||||||
data _null_;
|
|
||||||
file fref;
|
|
||||||
put 'whenever life gets you down, Mrs Brown..';
|
|
||||||
run;
|
|
||||||
%let f=Mrs Brown;
|
|
||||||
%let r=just remember that you're standing on a planet that's evolving;
|
|
||||||
%mv_createfile(path=/Public,name=life.md,inref=fref,fin,swap=f r)
|
|
||||||
|
|
||||||
|
|
||||||
@param [in] path= The parent (SAS Drive) folder in which to create the file
|
@param [in] path= The parent (SAS Drive) folder in which to create the file
|
||||||
@param [in] name= The name of the file to be created
|
@param [in] name= The name of the file to be created
|
||||||
@@ -24338,8 +24260,6 @@ run;
|
|||||||
@li sas_services
|
@li sas_services
|
||||||
@param [in] force= (YES) Will overwrite (delete / recreate) files by default.
|
@param [in] force= (YES) Will overwrite (delete / recreate) files by default.
|
||||||
Set to NO to abort if a file already exists in that location.
|
Set to NO to abort if a file already exists in that location.
|
||||||
@param pin] swap= (0) Provide two macro variable NAMES that contain the values
|
|
||||||
to be swapped, eg swap=find replace (see also the example above)
|
|
||||||
@param [out] outds= (_null_) Output dataset with the uri of the new file
|
@param [out] outds= (_null_) Output dataset with the uri of the new file
|
||||||
|
|
||||||
@param [in] mdebug= (0) Set to 1 to enable DEBUG messages
|
@param [in] mdebug= (0) Set to 1 to enable DEBUG messages
|
||||||
@@ -24353,7 +24273,6 @@ run;
|
|||||||
@li mfv_getpathuri.sas
|
@li mfv_getpathuri.sas
|
||||||
@li mp_abort.sas
|
@li mp_abort.sas
|
||||||
@li mp_base64copy.sas
|
@li mp_base64copy.sas
|
||||||
@li mp_replace.sas
|
|
||||||
@li mv_createfolder.sas
|
@li mv_createfolder.sas
|
||||||
|
|
||||||
<h4> Related Macros</h4>
|
<h4> Related Macros</h4>
|
||||||
@@ -24372,7 +24291,6 @@ run;
|
|||||||
,mdebug=0
|
,mdebug=0
|
||||||
,outds=_null_
|
,outds=_null_
|
||||||
,force=YES
|
,force=YES
|
||||||
,swap=0
|
|
||||||
);
|
);
|
||||||
%local dbg;
|
%local dbg;
|
||||||
%if &mdebug=1 %then %do;
|
%if &mdebug=1 %then %do;
|
||||||
@@ -24381,11 +24299,6 @@ run;
|
|||||||
%end;
|
%end;
|
||||||
%else %let dbg=*;
|
%else %let dbg=*;
|
||||||
|
|
||||||
%mp_abort(
|
|
||||||
iftrue=(&syscc ne 0),
|
|
||||||
msg=Cannot enter &sysmacroname with syscc=&syscc
|
|
||||||
)
|
|
||||||
|
|
||||||
%local oauth_bearer;
|
%local oauth_bearer;
|
||||||
%if &grant_type=detect %then %do;
|
%if &grant_type=detect %then %do;
|
||||||
%if %symexist(&access_token_var) %then %let grant_type=authorization_code;
|
%if %symexist(&access_token_var) %then %let grant_type=authorization_code;
|
||||||
@@ -24422,12 +24335,6 @@ run;
|
|||||||
%end;
|
%end;
|
||||||
%else %put %str(ERR)OR: invalid value for intype: &intype;
|
%else %put %str(ERR)OR: invalid value for intype: &intype;
|
||||||
|
|
||||||
%if "&swap" ne "0" %then %do;
|
|
||||||
%mp_replace("%sysfunc(pathname(&fref))"
|
|
||||||
,findvar=%scan(&swap,1,%str( ))
|
|
||||||
,replacevar=%scan(&swap,2,%str( ))
|
|
||||||
)
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%if &mdebug=1 %then %do;
|
%if &mdebug=1 %then %do;
|
||||||
data _null_;
|
data _null_;
|
||||||
@@ -24463,11 +24370,6 @@ run;
|
|||||||
,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)
|
||||||
)
|
)
|
||||||
%mp_abort(
|
|
||||||
iftrue=(&syscc ne 0),
|
|
||||||
mac=MV_CREATEFILE182
|
|
||||||
msg=syscc=&syscc after mfv_getpathuri
|
|
||||||
)
|
|
||||||
|
|
||||||
%if %mf_isblank(&fileuri)=0 and &force=YES %then %do;
|
%if %mf_isblank(&fileuri)=0 and &force=YES %then %do;
|
||||||
proc http method="DELETE" url="&base_uri&fileuri" &oauth_bearer;
|
proc http method="DELETE" url="&base_uri&fileuri" &oauth_bearer;
|
||||||
@@ -24477,29 +24379,26 @@ run;
|
|||||||
%end;
|
%end;
|
||||||
"Accept"="*/*";
|
"Accept"="*/*";
|
||||||
run;
|
run;
|
||||||
%put &sysmacroname DELETE &base_uri&fileuri;
|
%put &sysmacroname DELETE &base_uri&fileuri
|
||||||
%if &SYS_PROCHTTP_STATUS_CODE ne 204 %then %do;
|
&=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
||||||
%put &=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
|
||||||
%end;
|
|
||||||
%end;
|
%end;
|
||||||
|
|
||||||
%local url mimetype ext;
|
%local url mimetype;
|
||||||
%let url=&base_uri/files/files?parentFolderUri=&self_uri;
|
%let url=&base_uri/files/files?parentFolderUri=&self_uri;
|
||||||
%let ext=%upcase(%scan(&name,-1,.));
|
|
||||||
|
|
||||||
/* fetch job info */
|
/* fetch job info */
|
||||||
%local fname1;
|
%local fname1;
|
||||||
%let fname1=%mf_getuniquefileref();
|
%let fname1=%mf_getuniquefileref();
|
||||||
proc http method='POST' out=&fname1 &oauth_bearer in=&fref
|
proc http method='POST' out=&fname1 &oauth_bearer in=&fref
|
||||||
%if "&ctype" = "0" %then %do;
|
%if "&ctype" = "0" %then %do;
|
||||||
%let mimetype=%mf_mimetype(&ext);
|
%let mimetype=%mf_mimetype(%scan(&name,-1,.));
|
||||||
ct="&mimetype"
|
ct="&mimetype"
|
||||||
%end;
|
%end;
|
||||||
%else %do;
|
%else %do;
|
||||||
ct="&ctype"
|
ct="&ctype"
|
||||||
%end;
|
%end;
|
||||||
%if "&ext"="HTML" or "&ext"="CSS" or "&ext"="JS" or "&ext"="PNG"
|
%if "&mimetype"="text/html" or "&mimetype"="text/css"
|
||||||
or "&ext"="SVG" %then %do;
|
or "&mimetype"="text/javascript" %then %do;
|
||||||
url="&url%str(&)typeDefName=file";
|
url="&url%str(&)typeDefName=file";
|
||||||
%end;
|
%end;
|
||||||
%else %do;
|
%else %do;
|
||||||
@@ -24510,16 +24409,9 @@ proc http method='POST' out=&fname1 &oauth_bearer in=&fref
|
|||||||
%if &grant_type=authorization_code %then %do;
|
%if &grant_type=authorization_code %then %do;
|
||||||
"Authorization"="Bearer &&&access_token_var"
|
"Authorization"="Bearer &&&access_token_var"
|
||||||
%end;
|
%end;
|
||||||
"Content-Disposition"=
|
"Content-Disposition"= "&contentdisp filename=""&name""; name=""&name"";";
|
||||||
%if "&ext"="SVG" or "&ext"="HTML" %then %do;
|
|
||||||
"filename=""&name"";"
|
|
||||||
%end;
|
|
||||||
%else %do;
|
|
||||||
"&contentdisp filename=""&name""; name=""&name"";"
|
|
||||||
%end;
|
|
||||||
;
|
|
||||||
run;
|
run;
|
||||||
%if &mdebug=1 %then %put &sysmacroname POST &=url
|
%put &sysmacroname POST &=url
|
||||||
&=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
&=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
||||||
%mp_abort(iftrue=(&SYS_PROCHTTP_STATUS_CODE ne 201)
|
%mp_abort(iftrue=(&SYS_PROCHTTP_STATUS_CODE ne 201)
|
||||||
,mac=MV_CREATEFILE
|
,mac=MV_CREATEFILE
|
||||||
@@ -24528,7 +24420,7 @@ run;
|
|||||||
%local libref2;
|
%local libref2;
|
||||||
%let libref2=%mf_getuniquelibref();
|
%let libref2=%mf_getuniquelibref();
|
||||||
libname &libref2 JSON fileref=&fname1;
|
libname &libref2 JSON fileref=&fname1;
|
||||||
/* Grab the follow on link */
|
%put Grabbing the follow on link ;
|
||||||
data &outds;
|
data &outds;
|
||||||
set &libref2..links end=last;
|
set &libref2..links end=last;
|
||||||
if rel='createChild' then do;
|
if rel='createChild' then do;
|
||||||
@@ -24537,20 +24429,10 @@ data &outds;
|
|||||||
end;
|
end;
|
||||||
run;
|
run;
|
||||||
|
|
||||||
%put &sysmacroname: %trim(&base_uri)%mfv_getpathuri(&path/&name);
|
%put &sysmacroname: File &name successfully created:;%put;
|
||||||
%put /SASJobExecution?_file=&path/&name;%put;
|
%put &base_uri%mfv_getpathuri(&path/&name);%put;
|
||||||
|
%put &base_uri/SASJobExecution?_file=&path/&name;%put;
|
||||||
%if &mdebug=0 %then %do;
|
%put &sysmacroname:;
|
||||||
/* clear refs */
|
|
||||||
filename &fname1 clear;
|
|
||||||
filename &fref clear;
|
|
||||||
libname &libref2 clear;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%mp_abort(
|
|
||||||
iftrue=(&syscc ne 0),
|
|
||||||
msg=Cannot leave &sysmacroname with syscc=&syscc
|
|
||||||
)
|
|
||||||
|
|
||||||
%mend mv_createfile;/**
|
%mend mv_createfile;/**
|
||||||
@file mv_createfolder.sas
|
@file mv_createfolder.sas
|
||||||
@@ -24600,13 +24482,8 @@ run;
|
|||||||
%end;
|
%end;
|
||||||
%else %let dbg=*;
|
%else %let dbg=*;
|
||||||
|
|
||||||
%mp_abort(
|
|
||||||
iftrue=(&syscc ne 0),
|
|
||||||
msg=Cannot enter &sysmacroname with syscc=&syscc
|
|
||||||
)
|
|
||||||
|
|
||||||
%if %mfv_existfolder(&path)=1 %then %do;
|
%if %mfv_existfolder(&path)=1 %then %do;
|
||||||
%&dbg.put &sysmacroname: &path already exists;
|
%put &sysmacroname: &path already exists;
|
||||||
data &outds;
|
data &outds;
|
||||||
self_uri="%mfv_getpathuri(&path)";
|
self_uri="%mfv_getpathuri(&path)";
|
||||||
output;
|
output;
|
||||||
@@ -24614,7 +24491,6 @@ run;
|
|||||||
run;
|
run;
|
||||||
%return;
|
%return;
|
||||||
%end;
|
%end;
|
||||||
%mp_abort(iftrue=(&syscc ne 0),msg=syscc=&syscc when folder checking)
|
|
||||||
|
|
||||||
%local oauth_bearer;
|
%local oauth_bearer;
|
||||||
%if &grant_type=detect %then %do;
|
%if &grant_type=detect %then %do;
|
||||||
@@ -24668,17 +24544,6 @@ options noquotelenmax;
|
|||||||
headers "Authorization"="Bearer &&&access_token_var";
|
headers "Authorization"="Bearer &&&access_token_var";
|
||||||
%end;
|
%end;
|
||||||
run;
|
run;
|
||||||
%if &SYS_PROCHTTP_STATUS_CODE=401 %then %do;
|
|
||||||
/* relates to: https://github.com/sasjs/core/issues/400 */
|
|
||||||
%put 401 thrown in &sysmacroname;
|
|
||||||
%put sleeping: %sysfunc(sleep(12,1)) secs - will try again;
|
|
||||||
proc http method='GET' out=&fname1 &oauth_bearer
|
|
||||||
url="&base_uri/folders/folders/@item?path=&newpath";
|
|
||||||
%if &grant_type=authorization_code %then %do;
|
|
||||||
headers "Authorization"="Bearer &&&access_token_var";
|
|
||||||
%end;
|
|
||||||
run;
|
|
||||||
%end;
|
|
||||||
%local libref1;
|
%local libref1;
|
||||||
%let libref1=%mf_getuniquelibref();
|
%let libref1=%mf_getuniquelibref();
|
||||||
libname &libref1 JSON fileref=&fname1;
|
libname &libref1 JSON fileref=&fname1;
|
||||||
@@ -24686,7 +24551,7 @@ options noquotelenmax;
|
|||||||
iftrue=(
|
iftrue=(
|
||||||
&SYS_PROCHTTP_STATUS_CODE ne 200 and &SYS_PROCHTTP_STATUS_CODE ne 404
|
&SYS_PROCHTTP_STATUS_CODE ne 200 and &SYS_PROCHTTP_STATUS_CODE ne 404
|
||||||
)
|
)
|
||||||
,mac=mv_createfolder124
|
,mac=&sysmacroname
|
||||||
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
||||||
)
|
)
|
||||||
%if &mdebug=1 %then %do;
|
%if &mdebug=1 %then %do;
|
||||||
@@ -24735,9 +24600,8 @@ options noquotelenmax;
|
|||||||
'Content-Type'='application/vnd.sas.content.folder+json'
|
'Content-Type'='application/vnd.sas.content.folder+json'
|
||||||
'Accept'='application/vnd.sas.content.folder+json';
|
'Accept'='application/vnd.sas.content.folder+json';
|
||||||
run;
|
run;
|
||||||
%if &SYS_PROCHTTP_STATUS_CODE ne 201 %then %do;
|
%put &=SYS_PROCHTTP_STATUS_CODE;
|
||||||
%put &=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
%put &=SYS_PROCHTTP_STATUS_PHRASE;
|
||||||
%end;
|
|
||||||
%mp_abort(iftrue=(&SYS_PROCHTTP_STATUS_CODE ne 201)
|
%mp_abort(iftrue=(&SYS_PROCHTTP_STATUS_CODE ne 201)
|
||||||
,mac=&sysmacroname
|
,mac=&sysmacroname
|
||||||
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
||||||
@@ -24765,10 +24629,6 @@ options noquotelenmax;
|
|||||||
filename &fname1 clear;
|
filename &fname1 clear;
|
||||||
libname &libref1 clear;
|
libname &libref1 clear;
|
||||||
%end;
|
%end;
|
||||||
%mp_abort(
|
|
||||||
iftrue=(&syscc ne 0),
|
|
||||||
msg=Cannot leave &sysmacroname with syscc=&syscc
|
|
||||||
)
|
|
||||||
%mend mv_createfolder;/**
|
%mend mv_createfolder;/**
|
||||||
@file
|
@file
|
||||||
@brief Creates a Viya Job
|
@brief Creates a Viya Job
|
||||||
@@ -25248,7 +25108,7 @@ options noquotelenmax;
|
|||||||
%let path=%substr(&path,1,%length(&path)-1);
|
%let path=%substr(&path,1,%length(&path)-1);
|
||||||
|
|
||||||
/* ensure folder exists */
|
/* ensure folder exists */
|
||||||
%&dbg.put &sysmacroname: Path &path being checked / created;
|
%put &sysmacroname: Path &path being checked / created;
|
||||||
%mv_createfolder(path=&path)
|
%mv_createfolder(path=&path)
|
||||||
|
|
||||||
%local base_uri; /* location of rest apis */
|
%local base_uri; /* location of rest apis */
|
||||||
@@ -26081,8 +25941,13 @@ run;
|
|||||||
libname &libref1 clear;
|
libname &libref1 clear;
|
||||||
%end;
|
%end;
|
||||||
|
|
||||||
%put &sysmacroname: Job &name created! Check it out:;
|
%put &sysmacroname: Job &name successfully created in &path;
|
||||||
%put &url/SASJobExecution?_PROGRAM=&path/&name;
|
%put &sysmacroname:;
|
||||||
|
%put &sysmacroname: Check it out here:;
|
||||||
|
%put &sysmacroname:;%put;
|
||||||
|
%put &url/SASJobExecution?_PROGRAM=&path/&name;%put;
|
||||||
|
%put &sysmacroname:;
|
||||||
|
%put &sysmacroname:;
|
||||||
|
|
||||||
%mend mv_createwebservice;
|
%mend mv_createwebservice;
|
||||||
/**
|
/**
|
||||||
@@ -26198,15 +26063,13 @@ proc http method='GET' out=&fname1a &oauth_bearer
|
|||||||
headers "Authorization"="Bearer &&&access_token_var";
|
headers "Authorization"="Bearer &&&access_token_var";
|
||||||
%end;
|
%end;
|
||||||
run;
|
run;
|
||||||
%if &SYS_PROCHTTP_STATUS_CODE ne 200 %then %do;
|
%put &=SYS_PROCHTTP_STATUS_CODE;
|
||||||
%put &=sysmacroname &=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
|
||||||
%end;
|
|
||||||
%local libref1a;
|
%local libref1a;
|
||||||
%let libref1a=%mf_getuniquelibref();
|
%let libref1a=%mf_getuniquelibref();
|
||||||
libname &libref1a JSON fileref=&fname1a;
|
libname &libref1a JSON fileref=&fname1a;
|
||||||
%local uri found;
|
%local uri found;
|
||||||
%let found=0;
|
%let found=0;
|
||||||
/* %put Getting object uri from &libref1a..items; */
|
%put Getting object uri from &libref1a..items;
|
||||||
data _null_;
|
data _null_;
|
||||||
length contenttype name $1000;
|
length contenttype name $1000;
|
||||||
set &libref1a..items;
|
set &libref1a..items;
|
||||||
@@ -26311,7 +26174,8 @@ libname &libref1a clear;
|
|||||||
options noquotelenmax;
|
options noquotelenmax;
|
||||||
%local base_uri; /* location of rest apis */
|
%local base_uri; /* location of rest apis */
|
||||||
%let base_uri=%mf_getplatform(VIYARESTAPI);
|
%let base_uri=%mf_getplatform(VIYARESTAPI);
|
||||||
/* fetch the members of the folder to get the uri */
|
|
||||||
|
%put &sysmacroname: fetching details for &path ;
|
||||||
%local fname1;
|
%local fname1;
|
||||||
%let fname1=%mf_getuniquefileref();
|
%let fname1=%mf_getuniquefileref();
|
||||||
proc http method='GET' out=&fname1 &oauth_bearer
|
proc http method='GET' out=&fname1 &oauth_bearer
|
||||||
@@ -26331,7 +26195,7 @@ run;
|
|||||||
)
|
)
|
||||||
%end;
|
%end;
|
||||||
|
|
||||||
/* grab the follow on link */
|
%put &sysmacroname: grab the follow on link ;
|
||||||
%local libref1;
|
%local libref1;
|
||||||
%let libref1=%mf_getuniquelibref();
|
%let libref1=%mf_getuniquelibref();
|
||||||
libname &libref1 JSON fileref=&fname1;
|
libname &libref1 JSON fileref=&fname1;
|
||||||
@@ -26349,15 +26213,13 @@ proc http method='GET' out=&fname1a &oauth_bearer
|
|||||||
headers "Authorization"="Bearer &&&access_token_var";
|
headers "Authorization"="Bearer &&&access_token_var";
|
||||||
%end;
|
%end;
|
||||||
run;
|
run;
|
||||||
%if &SYS_PROCHTTP_STATUS_CODE ne 200 %then %do;
|
%put &=SYS_PROCHTTP_STATUS_CODE;
|
||||||
%put &=sysmacroname &=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
|
||||||
%end;
|
|
||||||
%local libref1a;
|
%local libref1a;
|
||||||
%let libref1a=%mf_getuniquelibref();
|
%let libref1a=%mf_getuniquelibref();
|
||||||
libname &libref1a JSON fileref=&fname1a;
|
libname &libref1a JSON fileref=&fname1a;
|
||||||
%local uri found;
|
%local uri found;
|
||||||
%let found=0;
|
%let found=0;
|
||||||
/* %put Getting object uri from &libref1a..items; */
|
%put Getting object uri from &libref1a..items;
|
||||||
data _null_;
|
data _null_;
|
||||||
length contenttype name $1000;
|
length contenttype name $1000;
|
||||||
set &libref1a..items;
|
set &libref1a..items;
|
||||||
@@ -26383,7 +26245,7 @@ run;
|
|||||||
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
||||||
)
|
)
|
||||||
%end;
|
%end;
|
||||||
%else %put &sysmacroname: &path/&name deleted;
|
%else %put &sysmacroname: &path/&name successfully deleted;
|
||||||
|
|
||||||
/* clear refs */
|
/* clear refs */
|
||||||
filename &fname1 clear;
|
filename &fname1 clear;
|
||||||
@@ -27334,7 +27196,7 @@ data _null_;
|
|||||||
uri=symget('uri');
|
uri=symget('uri');
|
||||||
if length(uri)<12 then do;
|
if length(uri)<12 then do;
|
||||||
call symputx('errflg',1);
|
call symputx('errflg',1);
|
||||||
call symputx('errmsg',"URI is too short - "!!uri,'l');
|
call symputx('errmsg',"URI is invalid (too short) - '&uri'",'l');
|
||||||
end;
|
end;
|
||||||
if scan(uri,-1)='state' or scan(uri,1) ne 'jobExecution' then do;
|
if scan(uri,-1)='state' or scan(uri,1) ne 'jobExecution' then do;
|
||||||
call symputx('errflg',1);
|
call symputx('errflg',1);
|
||||||
@@ -27399,7 +27261,7 @@ data _null_;
|
|||||||
uri=symget('loglocation');
|
uri=symget('loglocation');
|
||||||
if length(uri)<12 then do;
|
if length(uri)<12 then do;
|
||||||
call symputx('errflg',1);
|
call symputx('errflg',1);
|
||||||
call symputx('errmsg',"URI is too short - "!!uri,'l');
|
call symputx('errmsg',"URI is invalid (too short) - '&uri'",'l');
|
||||||
end;
|
end;
|
||||||
else if (scan(uri,1,'/') ne 'compute' or scan(uri,2,'/') ne 'sessions')
|
else if (scan(uri,1,'/') ne 'compute' or scan(uri,2,'/') ne 'sessions')
|
||||||
and (scan(uri,1,'/') ne 'files' or scan(uri,2,'/') ne 'files')
|
and (scan(uri,1,'/') ne 'files' or scan(uri,2,'/') ne 'files')
|
||||||
@@ -28487,8 +28349,6 @@ run;
|
|||||||
%if %mf_existvarList(&inds,FLOW_ID)=0 %then %do;
|
%if %mf_existvarList(&inds,FLOW_ID)=0 %then %do;
|
||||||
retain FLOW_ID 0;
|
retain FLOW_ID 0;
|
||||||
%end;
|
%end;
|
||||||
/* https://github.com/sasjs/adapter/pull/845#issuecomment-2956589644 */
|
|
||||||
retain _omitSessionResults "false";
|
|
||||||
set &inds;
|
set &inds;
|
||||||
&dbg. putlog (_all_)(=);
|
&dbg. putlog (_all_)(=);
|
||||||
run;
|
run;
|
||||||
|
|||||||
@@ -26,7 +26,7 @@
|
|||||||
@author Allan Bowe
|
@author Allan Bowe
|
||||||
**/
|
**/
|
||||||
|
|
||||||
%macro mf_getuniquelibref(prefix=mc,maxtries=1000);
|
%macro mf_getuniquelibref(prefix=mclib,maxtries=1000);
|
||||||
%local x;
|
%local x;
|
||||||
|
|
||||||
%if ( %length(&prefix) gt 7 ) %then %do;
|
%if ( %length(&prefix) gt 7 ) %then %do;
|
||||||
|
|||||||
@@ -33,8 +33,7 @@
|
|||||||
LUA, you can also use this macro: mp_gsubfile.sas
|
LUA, you can also use this macro: mp_gsubfile.sas
|
||||||
|
|
||||||
@param [in] infile The QUOTED path to the file on which to perform the
|
@param [in] infile The QUOTED path to the file on which to perform the
|
||||||
substitution. Note that you can extract the pathname from a fileref using
|
substitution
|
||||||
the pathname function, eg: `"%sysfunc(pathname(fref))"`;
|
|
||||||
@param [in] findvar= Macro variable NAME containing the string to search for
|
@param [in] findvar= Macro variable NAME containing the string to search for
|
||||||
@param [in] replacevar= Macro variable NAME containing the replacement string
|
@param [in] replacevar= Macro variable NAME containing the replacement string
|
||||||
@param [out] outfile= (0) Optional QUOTED path to the adjusted output file (to
|
@param [out] outfile= (0) Optional QUOTED path to the adjusted output file (to
|
||||||
@@ -148,6 +147,6 @@ data _null_;
|
|||||||
run;
|
run;
|
||||||
|
|
||||||
/* END */
|
/* END */
|
||||||
/* %put &sysmacroname took %sysevalf(%sysfunc(datetime())-&dttm) secs to run; */
|
%put &sysmacroname took %sysevalf(%sysfunc(datetime())-&dttm) seconds to run;
|
||||||
|
|
||||||
%mend mp_replace;
|
%mend mp_replace;
|
||||||
|
|||||||
@@ -1,31 +0,0 @@
|
|||||||
/**
|
|
||||||
@file
|
|
||||||
@brief Testing mfv_getfolderpath macro function
|
|
||||||
|
|
||||||
<h4> SAS Macros </h4>
|
|
||||||
@li mf_uid.sas
|
|
||||||
@li mfv_getfolderpath.sas
|
|
||||||
@li mfv_getpathuri.sas
|
|
||||||
@li mp_assert.sas
|
|
||||||
@li mv_createfolder.sas
|
|
||||||
|
|
||||||
**/
|
|
||||||
|
|
||||||
options mprint sgen;
|
|
||||||
|
|
||||||
%let folder=%mf_uid();
|
|
||||||
/* create a folder */
|
|
||||||
%mv_createfolder(path=&mcTestAppLoc/&folder)
|
|
||||||
%mp_assert(
|
|
||||||
iftrue=(&syscc=0),
|
|
||||||
desc=no errs on folder creation
|
|
||||||
)
|
|
||||||
|
|
||||||
%let uri=%mfv_getpathuri(&mcTestAppLoc/&folder);
|
|
||||||
%put %mfv_getfolderpath(&uri);
|
|
||||||
|
|
||||||
%mp_assert(
|
|
||||||
iftrue=("%mfv_getfolderpath(&uri)"="&mcTestAppLoc/&folder"),
|
|
||||||
desc=Check if correct folder was returned
|
|
||||||
)
|
|
||||||
|
|
||||||
@@ -14,7 +14,7 @@ options mprint sgen;
|
|||||||
|
|
||||||
%let file=%mf_uid();
|
%let file=%mf_uid();
|
||||||
|
|
||||||
/* create a file */
|
/* create a folder */
|
||||||
filename somefile temp;
|
filename somefile temp;
|
||||||
data _null_;
|
data _null_;
|
||||||
file somefile;
|
file somefile;
|
||||||
|
|||||||
@@ -23,7 +23,7 @@ data _null_;
|
|||||||
put 'hello testings';
|
put 'hello testings';
|
||||||
run;
|
run;
|
||||||
%mp_assertscope(SNAPSHOT)
|
%mp_assertscope(SNAPSHOT)
|
||||||
%mv_createfile(path=&mcTestAppLoc, name=&file..txt,inref=somefile,mdebug=1)
|
%mv_createfile(path=&mcTestAppLoc/temp, name=&file..txt,inref=somefile,mdebug=1)
|
||||||
%mp_assertscope(COMPARE
|
%mp_assertscope(COMPARE
|
||||||
,ignorelist=MCLIB0_JADP1LEN MCLIB0_JADP2LEN MCLIB0_JADPNUM
|
,ignorelist=MCLIB0_JADP1LEN MCLIB0_JADP2LEN MCLIB0_JADPNUM
|
||||||
MCLIB0_JADVLEN MCLIB2_JADP1LEN
|
MCLIB0_JADVLEN MCLIB2_JADP1LEN
|
||||||
@@ -32,7 +32,7 @@ run;
|
|||||||
)
|
)
|
||||||
|
|
||||||
%mp_assert(
|
%mp_assert(
|
||||||
iftrue=(%mfv_existfile(&mcTestAppLoc/&file..txt)=1),
|
iftrue=(%mfv_existfile(&mcTestAppLoc/temp/&file..txt)=1),
|
||||||
desc=Check if created file exists
|
desc=Check if created file exists
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -42,10 +42,10 @@ data _null_;
|
|||||||
file f2;
|
file f2;
|
||||||
put '<html><body><p>Hello world</p></body></html>';
|
put '<html><body><p>Hello world</p></body></html>';
|
||||||
run;
|
run;
|
||||||
%mv_createfile(path=&mcTestAppLoc, name=test.html,inref=f2,mdebug=1)
|
%mv_createfile(path=&mcTestAppLoc/temp, name=test.html,inref=f2,mdebug=1)
|
||||||
|
|
||||||
%mp_assert(
|
%mp_assert(
|
||||||
iftrue=(%mfv_existfile(&mcTestAppLoc/test.html)=1),
|
iftrue=(%mfv_existfile(&mcTestAppLoc/temp/test.html)=1),
|
||||||
desc=Check if created file exists
|
desc=Check if created file exists
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -55,10 +55,10 @@ x=1;
|
|||||||
run;
|
run;
|
||||||
filename ds "%sysfunc(pathname(work))/temp.sas7bdat";
|
filename ds "%sysfunc(pathname(work))/temp.sas7bdat";
|
||||||
|
|
||||||
%mv_createfile(path=&mcTestAppLoc, name=&file..sas7bdat,inref=ds,mdebug=1)
|
%mv_createfile(path=&mcTestAppLoc/temp, name=&file..sas7bdat,inref=ds,mdebug=1)
|
||||||
|
|
||||||
%mp_assert(
|
%mp_assert(
|
||||||
iftrue=(%mfv_existfile(&mcTestAppLoc/&file..sas7bdat)=1),
|
iftrue=(%mfv_existfile(&mcTestAppLoc/temp/&file..sas7bdat)=1),
|
||||||
desc=Check if created dataset exists
|
desc=Check if created dataset exists
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -68,44 +68,19 @@ data _null_;
|
|||||||
file f4;
|
file f4;
|
||||||
put '%put hello FromSASStudioBailey; ';
|
put '%put hello FromSASStudioBailey; ';
|
||||||
run;
|
run;
|
||||||
%mv_createfile(path=&mcTestAppLoc, name=test4.sas,inref=f4,mdebug=1)
|
%mv_createfile(path=&mcTestAppLoc/temp, name=test4.sas,inref=f4,mdebug=1)
|
||||||
|
|
||||||
%mp_assert(
|
%mp_assert(
|
||||||
iftrue=(%mfv_existfile(&mcTestAppLoc/test4.sas)=1),
|
iftrue=(%mfv_existfile(&mcTestAppLoc/temp/test4.sas)=1),
|
||||||
desc=Check if created sas program exists
|
desc=Check if created sas program exists
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
%put TEST 5 - reading from files service and writing back;
|
%put TEST 5 - reading from files service and writing back;
|
||||||
filename sendfrom filesrvc folderpath="&mcTestAppLoc" filename='test4.sas';
|
filename sendfrom filesrvc folderpath="&mcTestAppLoc/temp" filename='test4.sas';
|
||||||
|
|
||||||
OPTIONS MERROR SYMBOLGEN MLOGIC MPRINT;
|
OPTIONS MERROR SYMBOLGEN MLOGIC MPRINT;
|
||||||
|
|
||||||
%mv_createfile(path=&mcTestAppLoc,name=test5.sas,inref=sendfrom,mdebug=1) ;
|
%mv_createfile(path=&mcTestAppLoc/temp,name=test5.sas,inref=sendfrom,mdebug=1) ;
|
||||||
|
|
||||||
%put TEST 6 - try the find and replace;
|
|
||||||
filename f6 temp;
|
|
||||||
data _null_;
|
|
||||||
file f6;
|
|
||||||
put '//Hello world!';
|
|
||||||
put 'let var=/some/path/name;';
|
|
||||||
run;
|
|
||||||
%let in=/some/path/name;
|
|
||||||
%let out=/final/destination;
|
|
||||||
%mv_createfile(path=&mcTestAppLoc, name=test6.js,inref=f6,mdebug=1,swap=in out)
|
|
||||||
|
|
||||||
filename getback filesrvc folderpath="&mcTestAppLoc" filename='test6.js';
|
|
||||||
|
|
||||||
%let test6=0;
|
|
||||||
data _null_;
|
|
||||||
infile getback;
|
|
||||||
input;
|
|
||||||
if _infile_="let var=&out;" then call symputx('test6',1);
|
|
||||||
putlog _infile_;
|
|
||||||
run;
|
|
||||||
|
|
||||||
%mp_assert(
|
|
||||||
iftrue=(&test6=1),
|
|
||||||
desc=Check if find & replace worked
|
|
||||||
)
|
|
||||||
@@ -33,23 +33,16 @@
|
|||||||
msg=Cannot enter mfv_existfolder.sas with syscc=&syscc
|
msg=Cannot enter mfv_existfolder.sas with syscc=&syscc
|
||||||
)
|
)
|
||||||
|
|
||||||
%local fref rc var;
|
%local fref rc;
|
||||||
%let fref=%mf_getuniquefileref();
|
%let fref=%mf_getuniquefileref();
|
||||||
|
|
||||||
%if %sysfunc(filename(fref,,filesrvc,folderPath="&path"))=0 %then %do;
|
%if %sysfunc(filename(fref,,filesrvc,folderPath="&path"))=0 %then %do;
|
||||||
1
|
1
|
||||||
%let var=_FILESRVC_&fref._URI;
|
|
||||||
%let rc=%sysfunc(filename(fref));
|
%let rc=%sysfunc(filename(fref));
|
||||||
%symdel &var;
|
|
||||||
%end;
|
%end;
|
||||||
%else %do;
|
%else %do;
|
||||||
0
|
0
|
||||||
%let syscc=0;
|
%let syscc=0;
|
||||||
%end;
|
%end;
|
||||||
|
|
||||||
%mf_abort(
|
|
||||||
iftrue=(&syscc ne 0),
|
|
||||||
msg=Cannot leave mfv_existfolder.sas with syscc=&syscc
|
|
||||||
)
|
|
||||||
|
|
||||||
%mend mfv_existfolder;
|
%mend mfv_existfolder;
|
||||||
@@ -1,53 +0,0 @@
|
|||||||
/**
|
|
||||||
@file
|
|
||||||
@brief Returns the path of a folder from the URI
|
|
||||||
@details Makes use of the SYSMSG() ER8OR response, which resolves the uri,
|
|
||||||
seemingly without entering an er8or state.
|
|
||||||
|
|
||||||
Usage:
|
|
||||||
|
|
||||||
%mv_createfolder(path=/public/demo)
|
|
||||||
%let uri=%mfv_getpathuri(/public/demo);
|
|
||||||
%put %mfv_getfolderpath(&uri);
|
|
||||||
|
|
||||||
Notice above the new path has an uppercase P - the correct path.
|
|
||||||
|
|
||||||
@param [in] uri The uri of the folder -eg /folders/folders/xxxx)
|
|
||||||
|
|
||||||
<h4> SAS Macros </h4>
|
|
||||||
@li mf_getuniquefileref.sas
|
|
||||||
|
|
||||||
<h4> Related Macros </h4>
|
|
||||||
@li mfv_getpathuri.sas
|
|
||||||
|
|
||||||
@version 4
|
|
||||||
@author [Allan Bowe](https://www.linkedin.com/in/allanbowe/)
|
|
||||||
**/
|
|
||||||
%macro mfv_getfolderpath(uri
|
|
||||||
)/*/STORE SOURCE*/;
|
|
||||||
|
|
||||||
%local fref rc path msg var /* var used to avoid delete timing issue */;
|
|
||||||
%let fref=%mf_getuniquefileref();
|
|
||||||
%if %quote(%substr(%str(&uri),1,17)) ne %quote(/folders/folders/)
|
|
||||||
%then %do;
|
|
||||||
%put &sysmacroname: Invalid URI: &uri;
|
|
||||||
%end;
|
|
||||||
%else %if %sysfunc(filename(fref,,filesrvc,folderuri="&uri" ))=0
|
|
||||||
%then %do;
|
|
||||||
%let var=_FILESRVC_&fref._URI;
|
|
||||||
%local fid ;
|
|
||||||
%let fid= %sysfunc(fopen(&fref,I));
|
|
||||||
%let msg=%quote(%sysfunc(sysmsg()));
|
|
||||||
|
|
||||||
%unquote(%scan(&msg,2,%str(,.)))
|
|
||||||
|
|
||||||
%let rc=%sysfunc(fclose(&fid));
|
|
||||||
%let rc=%sysfunc(filename(fref));
|
|
||||||
%symdel &var;
|
|
||||||
%end;
|
|
||||||
%else %do;
|
|
||||||
%put &sysmacroname: Not Found: &uri;
|
|
||||||
%let syscc=0;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%mend mfv_getfolderpath ;
|
|
||||||
@@ -49,8 +49,4 @@
|
|||||||
%let syscc=0;
|
%let syscc=0;
|
||||||
%end;
|
%end;
|
||||||
|
|
||||||
%mf_abort(
|
|
||||||
iftrue=(&syscc ne 0),
|
|
||||||
msg=Cannot leave &sysmacroname with syscc=&syscc
|
|
||||||
)
|
|
||||||
%mend mfv_getpathuri;
|
%mend mfv_getpathuri;
|
||||||
@@ -17,20 +17,6 @@
|
|||||||
run;
|
run;
|
||||||
%mv_createfile(path=/Public/temp,name=newfile.txt,inref=myfile)
|
%mv_createfile(path=/Public/temp,name=newfile.txt,inref=myfile)
|
||||||
|
|
||||||
The macro also supports find & replace (used by the SASjs Streaming App
|
|
||||||
build program). This allows one string to be replaced by another at the
|
|
||||||
point at which the file is created. This is done by passing in the NAMES of
|
|
||||||
the macro variables containing the values to be swapped, eg:
|
|
||||||
|
|
||||||
filename fref temp;
|
|
||||||
data _null_;
|
|
||||||
file fref;
|
|
||||||
put 'whenever life gets you down, Mrs Brown..';
|
|
||||||
run;
|
|
||||||
%let f=Mrs Brown;
|
|
||||||
%let r=just remember that you're standing on a planet that's evolving;
|
|
||||||
%mv_createfile(path=/Public,name=life.md,inref=fref,fin,swap=f r)
|
|
||||||
|
|
||||||
|
|
||||||
@param [in] path= The parent (SAS Drive) folder in which to create the file
|
@param [in] path= The parent (SAS Drive) folder in which to create the file
|
||||||
@param [in] name= The name of the file to be created
|
@param [in] name= The name of the file to be created
|
||||||
@@ -52,8 +38,6 @@
|
|||||||
@li sas_services
|
@li sas_services
|
||||||
@param [in] force= (YES) Will overwrite (delete / recreate) files by default.
|
@param [in] force= (YES) Will overwrite (delete / recreate) files by default.
|
||||||
Set to NO to abort if a file already exists in that location.
|
Set to NO to abort if a file already exists in that location.
|
||||||
@param pin] swap= (0) Provide two macro variable NAMES that contain the values
|
|
||||||
to be swapped, eg swap=find replace (see also the example above)
|
|
||||||
@param [out] outds= (_null_) Output dataset with the uri of the new file
|
@param [out] outds= (_null_) Output dataset with the uri of the new file
|
||||||
|
|
||||||
@param [in] mdebug= (0) Set to 1 to enable DEBUG messages
|
@param [in] mdebug= (0) Set to 1 to enable DEBUG messages
|
||||||
@@ -67,7 +51,6 @@
|
|||||||
@li mfv_getpathuri.sas
|
@li mfv_getpathuri.sas
|
||||||
@li mp_abort.sas
|
@li mp_abort.sas
|
||||||
@li mp_base64copy.sas
|
@li mp_base64copy.sas
|
||||||
@li mp_replace.sas
|
|
||||||
@li mv_createfolder.sas
|
@li mv_createfolder.sas
|
||||||
|
|
||||||
<h4> Related Macros</h4>
|
<h4> Related Macros</h4>
|
||||||
@@ -86,7 +69,6 @@
|
|||||||
,mdebug=0
|
,mdebug=0
|
||||||
,outds=_null_
|
,outds=_null_
|
||||||
,force=YES
|
,force=YES
|
||||||
,swap=0
|
|
||||||
);
|
);
|
||||||
%local dbg;
|
%local dbg;
|
||||||
%if &mdebug=1 %then %do;
|
%if &mdebug=1 %then %do;
|
||||||
@@ -95,11 +77,6 @@
|
|||||||
%end;
|
%end;
|
||||||
%else %let dbg=*;
|
%else %let dbg=*;
|
||||||
|
|
||||||
%mp_abort(
|
|
||||||
iftrue=(&syscc ne 0),
|
|
||||||
msg=Cannot enter &sysmacroname with syscc=&syscc
|
|
||||||
)
|
|
||||||
|
|
||||||
%local oauth_bearer;
|
%local oauth_bearer;
|
||||||
%if &grant_type=detect %then %do;
|
%if &grant_type=detect %then %do;
|
||||||
%if %symexist(&access_token_var) %then %let grant_type=authorization_code;
|
%if %symexist(&access_token_var) %then %let grant_type=authorization_code;
|
||||||
@@ -136,12 +113,6 @@
|
|||||||
%end;
|
%end;
|
||||||
%else %put %str(ERR)OR: invalid value for intype: &intype;
|
%else %put %str(ERR)OR: invalid value for intype: &intype;
|
||||||
|
|
||||||
%if "&swap" ne "0" %then %do;
|
|
||||||
%mp_replace("%sysfunc(pathname(&fref))"
|
|
||||||
,findvar=%scan(&swap,1,%str( ))
|
|
||||||
,replacevar=%scan(&swap,2,%str( ))
|
|
||||||
)
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%if &mdebug=1 %then %do;
|
%if &mdebug=1 %then %do;
|
||||||
data _null_;
|
data _null_;
|
||||||
@@ -177,11 +148,6 @@ run;
|
|||||||
,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)
|
||||||
)
|
)
|
||||||
%mp_abort(
|
|
||||||
iftrue=(&syscc ne 0),
|
|
||||||
mac=MV_CREATEFILE182
|
|
||||||
msg=syscc=&syscc after mfv_getpathuri
|
|
||||||
)
|
|
||||||
|
|
||||||
%if %mf_isblank(&fileuri)=0 and &force=YES %then %do;
|
%if %mf_isblank(&fileuri)=0 and &force=YES %then %do;
|
||||||
proc http method="DELETE" url="&base_uri&fileuri" &oauth_bearer;
|
proc http method="DELETE" url="&base_uri&fileuri" &oauth_bearer;
|
||||||
@@ -191,29 +157,26 @@ run;
|
|||||||
%end;
|
%end;
|
||||||
"Accept"="*/*";
|
"Accept"="*/*";
|
||||||
run;
|
run;
|
||||||
%put &sysmacroname DELETE &base_uri&fileuri;
|
%put &sysmacroname DELETE &base_uri&fileuri
|
||||||
%if &SYS_PROCHTTP_STATUS_CODE ne 204 %then %do;
|
&=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
||||||
%put &=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
|
||||||
%end;
|
|
||||||
%end;
|
%end;
|
||||||
|
|
||||||
%local url mimetype ext;
|
%local url mimetype;
|
||||||
%let url=&base_uri/files/files?parentFolderUri=&self_uri;
|
%let url=&base_uri/files/files?parentFolderUri=&self_uri;
|
||||||
%let ext=%upcase(%scan(&name,-1,.));
|
|
||||||
|
|
||||||
/* fetch job info */
|
/* fetch job info */
|
||||||
%local fname1;
|
%local fname1;
|
||||||
%let fname1=%mf_getuniquefileref();
|
%let fname1=%mf_getuniquefileref();
|
||||||
proc http method='POST' out=&fname1 &oauth_bearer in=&fref
|
proc http method='POST' out=&fname1 &oauth_bearer in=&fref
|
||||||
%if "&ctype" = "0" %then %do;
|
%if "&ctype" = "0" %then %do;
|
||||||
%let mimetype=%mf_mimetype(&ext);
|
%let mimetype=%mf_mimetype(%scan(&name,-1,.));
|
||||||
ct="&mimetype"
|
ct="&mimetype"
|
||||||
%end;
|
%end;
|
||||||
%else %do;
|
%else %do;
|
||||||
ct="&ctype"
|
ct="&ctype"
|
||||||
%end;
|
%end;
|
||||||
%if "&ext"="HTML" or "&ext"="CSS" or "&ext"="JS" or "&ext"="PNG"
|
%if "&mimetype"="text/html" or "&mimetype"="text/css"
|
||||||
or "&ext"="SVG" %then %do;
|
or "&mimetype"="text/javascript" %then %do;
|
||||||
url="&url%str(&)typeDefName=file";
|
url="&url%str(&)typeDefName=file";
|
||||||
%end;
|
%end;
|
||||||
%else %do;
|
%else %do;
|
||||||
@@ -224,16 +187,9 @@ proc http method='POST' out=&fname1 &oauth_bearer in=&fref
|
|||||||
%if &grant_type=authorization_code %then %do;
|
%if &grant_type=authorization_code %then %do;
|
||||||
"Authorization"="Bearer &&&access_token_var"
|
"Authorization"="Bearer &&&access_token_var"
|
||||||
%end;
|
%end;
|
||||||
"Content-Disposition"=
|
"Content-Disposition"= "&contentdisp filename=""&name""; name=""&name"";";
|
||||||
%if "&ext"="SVG" or "&ext"="HTML" %then %do;
|
|
||||||
"filename=""&name"";"
|
|
||||||
%end;
|
|
||||||
%else %do;
|
|
||||||
"&contentdisp filename=""&name""; name=""&name"";"
|
|
||||||
%end;
|
|
||||||
;
|
|
||||||
run;
|
run;
|
||||||
%if &mdebug=1 %then %put &sysmacroname POST &=url
|
%put &sysmacroname POST &=url
|
||||||
&=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
&=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
||||||
%mp_abort(iftrue=(&SYS_PROCHTTP_STATUS_CODE ne 201)
|
%mp_abort(iftrue=(&SYS_PROCHTTP_STATUS_CODE ne 201)
|
||||||
,mac=MV_CREATEFILE
|
,mac=MV_CREATEFILE
|
||||||
@@ -242,7 +198,7 @@ run;
|
|||||||
%local libref2;
|
%local libref2;
|
||||||
%let libref2=%mf_getuniquelibref();
|
%let libref2=%mf_getuniquelibref();
|
||||||
libname &libref2 JSON fileref=&fname1;
|
libname &libref2 JSON fileref=&fname1;
|
||||||
/* Grab the follow on link */
|
%put Grabbing the follow on link ;
|
||||||
data &outds;
|
data &outds;
|
||||||
set &libref2..links end=last;
|
set &libref2..links end=last;
|
||||||
if rel='createChild' then do;
|
if rel='createChild' then do;
|
||||||
@@ -251,19 +207,9 @@ data &outds;
|
|||||||
end;
|
end;
|
||||||
run;
|
run;
|
||||||
|
|
||||||
%put &sysmacroname: %trim(&base_uri)%mfv_getpathuri(&path/&name);
|
%put &sysmacroname: File &name successfully created:;%put;
|
||||||
%put /SASJobExecution?_file=&path/&name;%put;
|
%put &base_uri%mfv_getpathuri(&path/&name);%put;
|
||||||
|
%put &base_uri/SASJobExecution?_file=&path/&name;%put;
|
||||||
%if &mdebug=0 %then %do;
|
%put &sysmacroname:;
|
||||||
/* clear refs */
|
|
||||||
filename &fname1 clear;
|
|
||||||
filename &fref clear;
|
|
||||||
libname &libref2 clear;
|
|
||||||
%end;
|
|
||||||
|
|
||||||
%mp_abort(
|
|
||||||
iftrue=(&syscc ne 0),
|
|
||||||
msg=Cannot leave &sysmacroname with syscc=&syscc
|
|
||||||
)
|
|
||||||
|
|
||||||
%mend mv_createfile;
|
%mend mv_createfile;
|
||||||
@@ -46,13 +46,8 @@
|
|||||||
%end;
|
%end;
|
||||||
%else %let dbg=*;
|
%else %let dbg=*;
|
||||||
|
|
||||||
%mp_abort(
|
|
||||||
iftrue=(&syscc ne 0),
|
|
||||||
msg=Cannot enter &sysmacroname with syscc=&syscc
|
|
||||||
)
|
|
||||||
|
|
||||||
%if %mfv_existfolder(&path)=1 %then %do;
|
%if %mfv_existfolder(&path)=1 %then %do;
|
||||||
%&dbg.put &sysmacroname: &path already exists;
|
%put &sysmacroname: &path already exists;
|
||||||
data &outds;
|
data &outds;
|
||||||
self_uri="%mfv_getpathuri(&path)";
|
self_uri="%mfv_getpathuri(&path)";
|
||||||
output;
|
output;
|
||||||
@@ -60,7 +55,6 @@
|
|||||||
run;
|
run;
|
||||||
%return;
|
%return;
|
||||||
%end;
|
%end;
|
||||||
%mp_abort(iftrue=(&syscc ne 0),msg=syscc=&syscc when folder checking)
|
|
||||||
|
|
||||||
%local oauth_bearer;
|
%local oauth_bearer;
|
||||||
%if &grant_type=detect %then %do;
|
%if &grant_type=detect %then %do;
|
||||||
@@ -114,17 +108,6 @@ options noquotelenmax;
|
|||||||
headers "Authorization"="Bearer &&&access_token_var";
|
headers "Authorization"="Bearer &&&access_token_var";
|
||||||
%end;
|
%end;
|
||||||
run;
|
run;
|
||||||
%if &SYS_PROCHTTP_STATUS_CODE=401 %then %do;
|
|
||||||
/* relates to: https://github.com/sasjs/core/issues/400 */
|
|
||||||
%put 401 thrown in &sysmacroname;
|
|
||||||
%put sleeping: %sysfunc(sleep(12,1)) secs - will try again;
|
|
||||||
proc http method='GET' out=&fname1 &oauth_bearer
|
|
||||||
url="&base_uri/folders/folders/@item?path=&newpath";
|
|
||||||
%if &grant_type=authorization_code %then %do;
|
|
||||||
headers "Authorization"="Bearer &&&access_token_var";
|
|
||||||
%end;
|
|
||||||
run;
|
|
||||||
%end;
|
|
||||||
%local libref1;
|
%local libref1;
|
||||||
%let libref1=%mf_getuniquelibref();
|
%let libref1=%mf_getuniquelibref();
|
||||||
libname &libref1 JSON fileref=&fname1;
|
libname &libref1 JSON fileref=&fname1;
|
||||||
@@ -132,7 +115,7 @@ options noquotelenmax;
|
|||||||
iftrue=(
|
iftrue=(
|
||||||
&SYS_PROCHTTP_STATUS_CODE ne 200 and &SYS_PROCHTTP_STATUS_CODE ne 404
|
&SYS_PROCHTTP_STATUS_CODE ne 200 and &SYS_PROCHTTP_STATUS_CODE ne 404
|
||||||
)
|
)
|
||||||
,mac=mv_createfolder124
|
,mac=&sysmacroname
|
||||||
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
||||||
)
|
)
|
||||||
%if &mdebug=1 %then %do;
|
%if &mdebug=1 %then %do;
|
||||||
@@ -181,9 +164,8 @@ options noquotelenmax;
|
|||||||
'Content-Type'='application/vnd.sas.content.folder+json'
|
'Content-Type'='application/vnd.sas.content.folder+json'
|
||||||
'Accept'='application/vnd.sas.content.folder+json';
|
'Accept'='application/vnd.sas.content.folder+json';
|
||||||
run;
|
run;
|
||||||
%if &SYS_PROCHTTP_STATUS_CODE ne 201 %then %do;
|
%put &=SYS_PROCHTTP_STATUS_CODE;
|
||||||
%put &=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
%put &=SYS_PROCHTTP_STATUS_PHRASE;
|
||||||
%end;
|
|
||||||
%mp_abort(iftrue=(&SYS_PROCHTTP_STATUS_CODE ne 201)
|
%mp_abort(iftrue=(&SYS_PROCHTTP_STATUS_CODE ne 201)
|
||||||
,mac=&sysmacroname
|
,mac=&sysmacroname
|
||||||
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
||||||
@@ -211,8 +193,4 @@ options noquotelenmax;
|
|||||||
filename &fname1 clear;
|
filename &fname1 clear;
|
||||||
libname &libref1 clear;
|
libname &libref1 clear;
|
||||||
%end;
|
%end;
|
||||||
%mp_abort(
|
|
||||||
iftrue=(&syscc ne 0),
|
|
||||||
msg=Cannot leave &sysmacroname with syscc=&syscc
|
|
||||||
)
|
|
||||||
%mend mv_createfolder;
|
%mend mv_createfolder;
|
||||||
@@ -122,7 +122,7 @@ options noquotelenmax;
|
|||||||
%let path=%substr(&path,1,%length(&path)-1);
|
%let path=%substr(&path,1,%length(&path)-1);
|
||||||
|
|
||||||
/* ensure folder exists */
|
/* ensure folder exists */
|
||||||
%&dbg.put &sysmacroname: Path &path being checked / created;
|
%put &sysmacroname: Path &path being checked / created;
|
||||||
%mv_createfolder(path=&path)
|
%mv_createfolder(path=&path)
|
||||||
|
|
||||||
%local base_uri; /* location of rest apis */
|
%local base_uri; /* location of rest apis */
|
||||||
@@ -955,7 +955,12 @@ run;
|
|||||||
libname &libref1 clear;
|
libname &libref1 clear;
|
||||||
%end;
|
%end;
|
||||||
|
|
||||||
%put &sysmacroname: Job &name created! Check it out:;
|
%put &sysmacroname: Job &name successfully created in &path;
|
||||||
%put &url/SASJobExecution?_PROGRAM=&path/&name;
|
%put &sysmacroname:;
|
||||||
|
%put &sysmacroname: Check it out here:;
|
||||||
|
%put &sysmacroname:;%put;
|
||||||
|
%put &url/SASJobExecution?_PROGRAM=&path/&name;%put;
|
||||||
|
%put &sysmacroname:;
|
||||||
|
%put &sysmacroname:;
|
||||||
|
|
||||||
%mend mv_createwebservice;
|
%mend mv_createwebservice;
|
||||||
|
|||||||
@@ -111,15 +111,13 @@ proc http method='GET' out=&fname1a &oauth_bearer
|
|||||||
headers "Authorization"="Bearer &&&access_token_var";
|
headers "Authorization"="Bearer &&&access_token_var";
|
||||||
%end;
|
%end;
|
||||||
run;
|
run;
|
||||||
%if &SYS_PROCHTTP_STATUS_CODE ne 200 %then %do;
|
%put &=SYS_PROCHTTP_STATUS_CODE;
|
||||||
%put &=sysmacroname &=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
|
||||||
%end;
|
|
||||||
%local libref1a;
|
%local libref1a;
|
||||||
%let libref1a=%mf_getuniquelibref();
|
%let libref1a=%mf_getuniquelibref();
|
||||||
libname &libref1a JSON fileref=&fname1a;
|
libname &libref1a JSON fileref=&fname1a;
|
||||||
%local uri found;
|
%local uri found;
|
||||||
%let found=0;
|
%let found=0;
|
||||||
/* %put Getting object uri from &libref1a..items; */
|
%put Getting object uri from &libref1a..items;
|
||||||
data _null_;
|
data _null_;
|
||||||
length contenttype name $1000;
|
length contenttype name $1000;
|
||||||
set &libref1a..items;
|
set &libref1a..items;
|
||||||
|
|||||||
@@ -69,7 +69,8 @@
|
|||||||
options noquotelenmax;
|
options noquotelenmax;
|
||||||
%local base_uri; /* location of rest apis */
|
%local base_uri; /* location of rest apis */
|
||||||
%let base_uri=%mf_getplatform(VIYARESTAPI);
|
%let base_uri=%mf_getplatform(VIYARESTAPI);
|
||||||
/* fetch the members of the folder to get the uri */
|
|
||||||
|
%put &sysmacroname: fetching details for &path ;
|
||||||
%local fname1;
|
%local fname1;
|
||||||
%let fname1=%mf_getuniquefileref();
|
%let fname1=%mf_getuniquefileref();
|
||||||
proc http method='GET' out=&fname1 &oauth_bearer
|
proc http method='GET' out=&fname1 &oauth_bearer
|
||||||
@@ -89,7 +90,7 @@ run;
|
|||||||
)
|
)
|
||||||
%end;
|
%end;
|
||||||
|
|
||||||
/* grab the follow on link */
|
%put &sysmacroname: grab the follow on link ;
|
||||||
%local libref1;
|
%local libref1;
|
||||||
%let libref1=%mf_getuniquelibref();
|
%let libref1=%mf_getuniquelibref();
|
||||||
libname &libref1 JSON fileref=&fname1;
|
libname &libref1 JSON fileref=&fname1;
|
||||||
@@ -107,15 +108,13 @@ proc http method='GET' out=&fname1a &oauth_bearer
|
|||||||
headers "Authorization"="Bearer &&&access_token_var";
|
headers "Authorization"="Bearer &&&access_token_var";
|
||||||
%end;
|
%end;
|
||||||
run;
|
run;
|
||||||
%if &SYS_PROCHTTP_STATUS_CODE ne 200 %then %do;
|
%put &=SYS_PROCHTTP_STATUS_CODE;
|
||||||
%put &=sysmacroname &=SYS_PROCHTTP_STATUS_CODE &=SYS_PROCHTTP_STATUS_PHRASE;
|
|
||||||
%end;
|
|
||||||
%local libref1a;
|
%local libref1a;
|
||||||
%let libref1a=%mf_getuniquelibref();
|
%let libref1a=%mf_getuniquelibref();
|
||||||
libname &libref1a JSON fileref=&fname1a;
|
libname &libref1a JSON fileref=&fname1a;
|
||||||
%local uri found;
|
%local uri found;
|
||||||
%let found=0;
|
%let found=0;
|
||||||
/* %put Getting object uri from &libref1a..items; */
|
%put Getting object uri from &libref1a..items;
|
||||||
data _null_;
|
data _null_;
|
||||||
length contenttype name $1000;
|
length contenttype name $1000;
|
||||||
set &libref1a..items;
|
set &libref1a..items;
|
||||||
@@ -141,7 +140,7 @@ run;
|
|||||||
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
,msg=%str(&SYS_PROCHTTP_STATUS_CODE &SYS_PROCHTTP_STATUS_PHRASE)
|
||||||
)
|
)
|
||||||
%end;
|
%end;
|
||||||
%else %put &sysmacroname: &path/&name deleted;
|
%else %put &sysmacroname: &path/&name successfully deleted;
|
||||||
|
|
||||||
/* clear refs */
|
/* clear refs */
|
||||||
filename &fname1 clear;
|
filename &fname1 clear;
|
||||||
|
|||||||
@@ -126,7 +126,7 @@ data _null_;
|
|||||||
uri=symget('uri');
|
uri=symget('uri');
|
||||||
if length(uri)<12 then do;
|
if length(uri)<12 then do;
|
||||||
call symputx('errflg',1);
|
call symputx('errflg',1);
|
||||||
call symputx('errmsg',"URI is too short - "!!uri,'l');
|
call symputx('errmsg',"URI is invalid (too short) - '&uri'",'l');
|
||||||
end;
|
end;
|
||||||
if scan(uri,-1)='state' or scan(uri,1) ne 'jobExecution' then do;
|
if scan(uri,-1)='state' or scan(uri,1) ne 'jobExecution' then do;
|
||||||
call symputx('errflg',1);
|
call symputx('errflg',1);
|
||||||
@@ -191,7 +191,7 @@ data _null_;
|
|||||||
uri=symget('loglocation');
|
uri=symget('loglocation');
|
||||||
if length(uri)<12 then do;
|
if length(uri)<12 then do;
|
||||||
call symputx('errflg',1);
|
call symputx('errflg',1);
|
||||||
call symputx('errmsg',"URI is too short - "!!uri,'l');
|
call symputx('errmsg',"URI is invalid (too short) - '&uri'",'l');
|
||||||
end;
|
end;
|
||||||
else if (scan(uri,1,'/') ne 'compute' or scan(uri,2,'/') ne 'sessions')
|
else if (scan(uri,1,'/') ne 'compute' or scan(uri,2,'/') ne 'sessions')
|
||||||
and (scan(uri,1,'/') ne 'files' or scan(uri,2,'/') ne 'files')
|
and (scan(uri,1,'/') ne 'files' or scan(uri,2,'/') ne 'files')
|
||||||
|
|||||||
@@ -188,8 +188,6 @@
|
|||||||
%if %mf_existvarList(&inds,FLOW_ID)=0 %then %do;
|
%if %mf_existvarList(&inds,FLOW_ID)=0 %then %do;
|
||||||
retain FLOW_ID 0;
|
retain FLOW_ID 0;
|
||||||
%end;
|
%end;
|
||||||
/* https://github.com/sasjs/adapter/pull/845#issuecomment-2956589644 */
|
|
||||||
retain _omitSessionResults "false";
|
|
||||||
set &inds;
|
set &inds;
|
||||||
&dbg. putlog (_all_)(=);
|
&dbg. putlog (_all_)(=);
|
||||||
run;
|
run;
|
||||||
|
|||||||
Reference in New Issue
Block a user