| retrieveJSON {magmaR} | R Documentation | 
Download data from magma as a json, and convert to a list
Description
Analogous to the '/retrieve' function of magma, with format = "json"
Usage
retrieveJSON(
  target,
  projectName,
  modelName,
  recordNames = "all",
  attributeNames = "all",
  filter = "",
  page = NULL,
  pageSize = 10,
  showDisconnected = FALSE,
  hideTemplate = FALSE,
  ...
)
Arguments
| target | A list, which can be created using  | 
| projectName | Single string. The name of the project you would like to interact with. For options, see  | 
| modelName | Single string. The name of the subset data structure within the project, which are referred to as 'model's in magma, to interact with.
For options, see  | 
| recordNames | Single string or string vector indicating which particular sample/tube/etc. records to target.
Options are "all" or any combination of individual record names. To retrieve individual options, see  | 
| attributeNames | Single string or string vector indicating which features of the data to target.
Options are "all" or any combination of individual attribute names. To retrieve individual options, see  | 
| filter | String. Potential filter(s) of the data. Example: "<targetAttributeName>~GYN" to filter to records where <targetAttributeName> contains "GYN". Refer to https://mountetna.github.io/magma.html#retrieve for more details about options and format. | 
| page | Integer. For retrieving just a portion of the data, sets which slice to get. | 
| pageSize | Integer. For retrieving just a portion of the data, sets slice/page size, which is equivalent to the a number of rows. | 
| showDisconnected | Boolean. Set to true to access "disconnected" records, which are records that are missing an (upstream) parent linkage, and so do not connect up with the project's top-level project record. Generally, disconnected records are ones that were deemed low quality in some way, thus were purposefully disconnected from the rest of the dataset. But sometimes a record might just be disconnected because an upload went awry. | 
| hideTemplate | Logical. Allows to leave out the project template from the return. Often this does not matter much, but the template can be bulky. | 
| ... | Additional parameters passed along to the internal '.retrieve()', '.query()', or '.update()' functions, for troubleshooting or advanced-user purposes only: 
 | 
Details
This function makes a call to magma/retrieve with format = "json".
Then, it converts the json output into a list which is more compatible with R.
Value
A list
See Also
retrieve for similar functionality, but where the call to magma/retrieve will be made with format = "tsv" and the output is a dataframe.
retrieveMatrix for matrix data-targeted utilization of this current retreiveJSON function, followed by automated restructuring of the return into a matrix format.
https://mountetna.github.io/magma.html#retrieve for documentation of the underlying magma/retrieve function.
Examples
if (interactive()) {
    # First, we use magmaRset to create an object which will tell other magmaR
    #  functions our authentication token (as well as some other optional bits).
    # When run in this way, it will ask you to give your token.
    magma <- magmaRset()
    
    # Now we can retrieve data as json (->list) with...
    json_out <- retrieveJSON(
        target = magma,
        projectName = "example",
        modelName = "rna_seq",
        recordNames = "all",
        attributeNames = "all",
        filter = "")
    # The return will be a nested list with data in a 'documents' element and
    #  some extra information about each attribute in a 'template' element.
    str(json_out, max.level = 4)
    # Often, the 'template' part is bulky but not needed, so its retrieval may
    #  be turned off by giving hideTemplaate = TRUE'
    json_out <- retrieveJSON(
        target = magma,
        projectName = "example",
        modelName = "rna_seq",
        recordNames = "all",
        attributeNames = "all",
        filter = "",
        hideTemplate = TRUE)
    str(json_out, max.level = 4)
}