Skip to contents

Set up WildTrax credentials

To obtain an Auth0 token, you must login into WildTrax using Auth0 (Google authorization is currently not supported). You also need to store your WildTrax user name and password as environment variables.

# Note that you need to use 'WT_USERNAME' and 'WT_PASSWORD'
Sys.setenv(WT_USERNAME = 'guest', WT_PASSWORD = 'Apple123')

Authenticate

Next, you use the wt_auth() function to authenticate.

# Authenticate
wt_auth()
#> Authentication into WildTrax successful.

The Auth0 token you obtained will last for 12 hours. After that time, you will need to re-authenticate.

Making API calls

Once authenticated, you can now use various functions that call upon the WildTrax API. For instance, you can use wt_get_download_summary() to see basic metadata about projects that you can download data for.

# Download the project summary you have access to
my_projects <- wt_get_download_summary(sensor_id = 'ARU')

head(my_projects)
#>   organization_id organization                                 project
#> 1               5         ABMI    ABMI Adopt-a-Camera ARU Surveys 2017
#> 2               5         ABMI          ABMI Amphibian Monitoring 2020
#> 3               5         ABMI Before-After Dose Response Project 2021
#> 4               5         ABMI Before-After Dose Response Project 2022
#> 5               5         ABMI                               Big Grids
#> 6               5         ABMI                         BirdNET Example
#>   project_id sensor tasks                      status
#> 1         42    ARU   309 Published - Map+Report Only
#> 2        382    ARU  1528 Published - Map+Report Only
#> 3        686    ARU  1873 Published - Map+Report Only
#> 4       1174    ARU  1014 Published - Map+Report Only
#> 5        381    ARU  2226 Published - Map+Report Only
#> 6       2349    ARU     1 Published - Map+Report Only

Using the project_id number in the download summary you can then use wt_download_report() to access the species data. You can also find the project_id number in the url of a WildTrax project, e.g. https://www.wildtrax.ca/home/aru-tasks.html?projectId=605&sensorId=ARU.

# Download the project report
my_report <- wt_download_report(project_id = 620, sensor_id = 'ARU', reports = "main", weather_cols = F) %>%
  tibble::as_tibble()
head(my_report)
#> # A tibble: 6 × 31
#>   organization project_id location  location_id location_buffer_m longitude
#>   <chr>             <dbl> <chr>           <dbl> <lgl>                 <dbl>
#> 1 BU                  620 CHPP-WP-1       94515 NA                    -110.
#> 2 BU                  620 CHPP-WP-1       94515 NA                    -110.
#> 3 BU                  620 CHPP-WP-1       94515 NA                    -110.
#> 4 BU                  620 CHPP-WP-1       94515 NA                    -110.
#> 5 BU                  620 CHPP-WP-1       94515 NA                    -110.
#> 6 BU                  620 CHPP-WP-1       94515 NA                    -110.
#> # ℹ 25 more variables: latitude <dbl>, equipment_make <lgl>,
#> #   equipment_model <lgl>, recording_id <dbl>, recording_date_time <dttm>,
#> #   task_id <dbl>, aru_task_status <chr>, task_duration <dbl>,
#> #   task_method <chr>, species_code <chr>, species_common_name <chr>,
#> #   species_scientific_name <chr>, individual_order <dbl>, tag_id <dbl>,
#> #   individual_count <chr>, vocalization <chr>, detection_time <dbl>,
#> #   tag_duration <dbl>, rms_peak_dbfs <dbl>, tag_is_verified <lgl>, …

An easy way to download multiple projects at once is to use wt_get_download_summary() and then filter by a substring in order to get the project ids to download the data.

# Download all of the published Ecosystem Health ARU data to a single object
wt_get_download_summary(sensor_id = "ARU") %>%
  tibble::as_tibble() %>%
  dplyr::filter(grepl('^Ecosystem Health',project)) %>%
  dplyr::mutate(data = purrr::map(.x = project_id, .f = ~wt_download_report(project_id = .x, sensor_id = "ARU", weather_cols = F, reports = "main")))

Downloading the WildTrax species table with wt_get_species() also grants you access to other valuable columns or provides a complete list of the species currently supported by WildTrax.

# Download the WildTrax species table
spp_table <- wt_get_species()
spp_table |> arrange(species_code)
#> # A tibble: 5,109 × 6
#>    species_id species_code species_common_name       species_class species_order
#>         <dbl> <chr>        <chr>                     <chr>         <chr>        
#>  1       2780 10           Wolves, Coyotes and Alli… MAMMALIA      Carnivora    
#>  2       2705 100          Barren-ground Caribou     MAMMALIA      Artiodactyla 
#>  3       2738 105          Porcupine Caribou         MAMMALIA      Artiodactyla 
#>  4       2735 106          Peary Caribou             MAMMALIA      Artiodactyla 
#>  5       2750 107          Varying Lemming           MAMMALIA      Rodentia     
#>  6       2618 108          Bird                      AVES          NA           
#>  7       2616 109          Bear                      MAMMALIA      Carnivora    
#>  8       2694 110          Train                     NONE          NA           
#>  9       2728 114          Kermode Bear              MAMMALIA      Carnivora    
#> 10       2819 129          Opossum                   MAMMALIA      Didelphimorp…
#> # ℹ 5,099 more rows
#> # ℹ 1 more variable: species_scientific_name <chr>

WildTrax also pre-formats ARU to point count (PC) data depending on the type of analysis you wish to perform. See the Boreal Avian Modelling project website and GitHub repositories to find out more on integration of avian point count and ARU data.

# As ARU format
my_report
#> # A tibble: 388 × 31
#>    organization project_id location  location_id location_buffer_m longitude
#>    <chr>             <dbl> <chr>           <dbl> <lgl>                 <dbl>
#>  1 BU                  620 CHPP-WP-1       94515 NA                    -110.
#>  2 BU                  620 CHPP-WP-1       94515 NA                    -110.
#>  3 BU                  620 CHPP-WP-1       94515 NA                    -110.
#>  4 BU                  620 CHPP-WP-1       94515 NA                    -110.
#>  5 BU                  620 CHPP-WP-1       94515 NA                    -110.
#>  6 BU                  620 CHPP-WP-1       94515 NA                    -110.
#>  7 BU                  620 CHPP-WP-1       94515 NA                    -110.
#>  8 BU                  620 CHPP-WP-1       94515 NA                    -110.
#>  9 BU                  620 CHPP-WP-1       94515 NA                    -110.
#> 10 BU                  620 CHPP-WP-1       94515 NA                    -110.
#> # ℹ 378 more rows
#> # ℹ 25 more variables: latitude <dbl>, equipment_make <lgl>,
#> #   equipment_model <lgl>, recording_id <dbl>, recording_date_time <dttm>,
#> #   task_id <dbl>, aru_task_status <chr>, task_duration <dbl>,
#> #   task_method <chr>, species_code <chr>, species_common_name <chr>,
#> #   species_scientific_name <chr>, individual_order <dbl>, tag_id <dbl>,
#> #   individual_count <chr>, vocalization <chr>, detection_time <dbl>, …
# As point count format
head(aru_as_pc)
#> # A tibble: 6 × 23
#>   organization project         project_id location location_id location_buffer_m
#>   <chr>        <chr>                <dbl> <chr>          <dbl> <lgl>            
#> 1 BU           Community - Cy…        620 CHPP-WP…       94517 NA               
#> 2 BU           Community - Cy…        620 CHPP-WP…       94518 NA               
#> 3 BU           Community - Cy…        620 CHPP-WP…       89972 NA               
#> 4 BU           Community - Cy…        620 CHPP-WP…       89972 NA               
#> 5 BU           Community - Cy…        620 CHPP-WP…       89972 NA               
#> 6 BU           Community - Cy…        620 CHPP-WP…       89972 NA               
#> # ℹ 17 more variables: latitude <dbl>, longitude <dbl>, survey_id <chr>,
#> #   survey_date <dttm>, survey_url <chr>, observer <chr>,
#> #   survey_distance_method <chr>, survey_duration_method <chr>,
#> #   detection_distance <chr>, detection_time <chr>, species_code <chr>,
#> #   species_common_name <chr>, species_scientific_name <chr>,
#> #   individual_count <chr>, detection_heard <lgl>, detection_seen <lgl>,
#> #   detection_comments <chr>

Data Discover

Explore species and data within WildTrax’s Data Discover by employing the wt_dd_summary() function. Access a portion of data, even without user privileges. Utilize wt_auth() to uncover data pertinent to your account or those publicly available on WildTrax.

discover <- wt_dd_summary(sensor = "ARU", species = "White-throated Sparrow", boundary = NULL)
head(discover)
#> [[1]]
#> # A tibble: 11 × 5
#>    projectId project_name       count species_common_name species_scientific_n…¹
#>        <int> <chr>              <dbl> <chr>               <chr>                 
#>  1       686 "ABMI-Before-Afte…   152 White-throated Spa… ZONOTRICHIA ALBICOLLIS
#>  2        41 "BU-Boreal Wetlan…   297 White-throated Spa… ZONOTRICHIA ALBICOLLIS
#>  3        32 "BU-Big Grid Pilo…    90 White-throated Spa… ZONOTRICHIA ALBICOLLIS
#>  4        31 "BU-Big Grids"       794 White-throated Spa… ZONOTRICHIA ALBICOLLIS
#>  5       334 "BU-General-Commu…    57 White-throated Spa… ZONOTRICHIA ALBICOLLIS
#>  6        99 "BU-Old Growth Fo…   222 White-throated Spa… ZONOTRICHIA ALBICOLLIS
#>  7        84 "BU-Community tag…    50 White-throated Spa… ZONOTRICHIA ALBICOLLIS
#>  8        19 "ABMI-Ecosystem H…    63 White-throated Spa… ZONOTRICHIA ALBICOLLIS
#>  9        34 "ABMI-Ecosystem H…    80 White-throated Spa… ZONOTRICHIA ALBICOLLIS
#> 10         1 "ABMI-Ecosystem H…    51 White-throated Spa… ZONOTRICHIA ALBICOLLIS
#> 11        NA ""                   158 White-throated Spa… ZONOTRICHIA ALBICOLLIS
#> # ℹ abbreviated name: ¹​species_scientific_name
#> 
#> [[2]]
#> # A tibble: 1,812 × 4
#>    species_common_name    count longitude latitude
#>    <chr>                  <int>     <dbl>    <dbl>
#>  1 White-throated Sparrow     1     -113.     53.8
#>  2 White-throated Sparrow     1     -113.     54.8
#>  3 White-throated Sparrow     1     -113.     54.2
#>  4 White-throated Sparrow     4     -113.     54.7
#>  5 White-throated Sparrow     4     -113.     54.7
#>  6 White-throated Sparrow     1     -113.     54.8
#>  7 White-throated Sparrow     4     -113.     55.0
#>  8 White-throated Sparrow     1     -113.     55.1
#>  9 White-throated Sparrow     1     -113.     55.1
#> 10 White-throated Sparrow     1     -113.     55.1
#> # ℹ 1,802 more rows

Use custom bounding areas:

# Define a polygon
my_aoi <- list(c(-113.96067733931979, 56.238173020067734),
            c(-117.06284589142298, 54.87576824970637),
            c(-112.88035197161919, 54.90431032422126),
            c(-113.96067733931979, 56.238173020067734))

discover <- wt_dd_summary(sensor = "ARU", species = "White-throated Sparrow", boundary = my_aoi)

head(discover)
library(sf)
# Alberta bounding box
abbox <- read_sf("...shp") |> # Shapefile of Alberta
  filter(Province == "Alberta") |>
  st_transform(crs = 4326) |> 
  st_bbox()

discover <- wt_dd_summary(sensor = "ARU", species = "White-throated Sparrow", boundary = abbox)

head(discover)