- Fix internal function
check_workspace_param()
to use credentials provided in args rather than environment.
- When checking the workspace parameter, use the user-provided credentials, which may differ from those currently in the environment/
.Renviron
.
- Fix bug where some requests failed when the server URL had a terminal
/
. - Allow the user to check credentials provided as arguments in
check_credentials()
rather than as entries in.Renviron
. This allows checking credentials without setting them. Thecheck_credentials()
function still defaults to environment variable values if credentials not arguments not provided as function arguments. - Update tests and test fixtures to Survey Solutions 24.06.1
- Credentials now include the workspace.
set_credentials()
now has aworkspace
argument. All functions that target workspaces now draw from these credentials (#24, #26, h/t @ashwinikalantri). - Interview attributes can now be user-specified. Through the
nodes
argument ofget_interviews()
, users may specify as few or as many nodes of information about interviews as needed. If nothing is specified, the default is to fetch all nodes. If something is specified, it must includeid
and may include other things (#23).
- Credentials used in all functions now expect workspace. Users will need to use
set_credentials()
to add this component to their.Renviron
file.
- Fixed help pages where documentation suggested that logical values be provided as strings rather than as the logical values that the code required (#25, h/t @ashwinikalantri).
- Fixed issue where failure to specify
qnr_version
inget_assignments()
lead to the function returning all assignments for all questionnaires (#27, h/t @ashwinikalantri). - Added checks for arguments throughout--typically logical values, user names, and dates for time intervals--and tests to ensure those checks work correctly.
- Convert
NA_character_
comments to empty strings before forming the request in interview functions. - Added a private function
is_user_name()
to check whether user-provided user names followed Survey Solutions rules about character length and content. - Revised order of arguments and documentation for credentials: server, workspace, user, password.
- Fix
check_credentials()
. Check credentials by getting API user's details rather than fetching workspaces to which the user has access. The former only requires simple API access for the workspace. The latter requires admin API access.
- Fix
set_credentials()
. Better managment of pre-existing.Renviron
files. Previously, the function could delete several or all key-value pairs in.Renviron
while adding/updating Survey Solutions entries. Now, the function preserves all prior key-value entries. Also, tests have been added to check that this function works correctly going forward. A huge thanks to @petbrueck for spotting this and suggesting a fix (#20). - Revise
check_workspace_param()
, a private function used to check that the API user has access to the user-specified workspace, to work better when the API user has access to few or only one workspace. Previously, the function fetched all workspaces to which the user had access. This only worked when the API user had admin rights to access the workspace endpoints. Now, the function checks whether the API user has access to the target workspace by fetching its user details for that workspace.
- Fix
get_interviewers()
. A private function was missing the workspaces argument. (h/t @ashwinikalantri)
- Scope all functions to workspaces. If no workspace is specified, the function will take
"primary"
as the default value. If a workspace is specified, the function will attempt to execute within the designated workspace. The function will only yield a result if the user is authorized to access that workspace. If the function fails, it will both indicate that the target workspace is invalid/inaccessible and will say which workspaces the user credentials can access. To pre-empt function failure, the user can also usecheck_credentials()
and specify the target workspace. - Re-implement several functions with GraphQL API, where the REST endpoint is either deprecated or a less good solution than GraphQL. These include:
get_questionnaires
,get_interviews_for_questionnaire
, andget_interviews
. - Minor fixes