Skip to content

pull and process data from stocksmart website #95

pull and process data from stocksmart website

pull and process data from stocksmart website #95

Workflow file for this run

name: pull and process data from stocksmart website
on:
push:
branches:
- main
- master
pull_request:
branches:
- main
- master
schedule:
# uses UTC/GMT time (+ 5 hrs)
## put on HOLD until stockSMART have finished the reorganization
- cron: "0 17 * * 3" # Every Wednesday at 1200 hrs = 1700 UTC
#- cron: "0 22 * * 3" # Every Wednesday at 1200 hrs = 1700 UTC
#- cron: "0 */4 * * *" # Every 4th hour on
#- cron: "0 6 * * *" # Every day at 1am EST = 0600 GMT
#- cron: "26 * * * *" # Every hour on hour
#- cron: "0 18 * * 0" # Every Sunday at 1300 hrs = 1800 GMT
jobs:
build:
runs-on: ubuntu-latest
env:
GITHUB_PAT: ${{ secrets.GH_RELEASE }}
R_REMOTES_NO_ERRORS_FROM_WARNINGS: false
steps:
- name: Checkout repo
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: set up pandoc
uses: r-lib/actions/setup-pandoc@v2
- name: Install command line packages
run: |
sudo apt update
sudo apt-get install libcurl4-openssl-dev libgit2-dev
# sudo apt-get install libgdal-dev libcurl4-gnutls-dev libgit2-dev libudunits2-dev libharfbuzz-dev libfribidi-dev
shell: bash
- name: Set up R
uses: r-lib/actions/setup-r@v2
with:
r-version: '4.2.0'
- name: Install packages
run: |
install.packages(c("remotes","dplyr", "httr", "here","readxl", "usethis","gt","rmarkdown","rlang"))
remotes::install_github("NOAA-EDAB/stocksmart")
shell: Rscript {0}
- name: Save current rdas
run: |
load(here::here("data/stockAssessmentSummary.rda"))
load(here::here("data/stockAssessmentData.rda"))
saveRDS(stockAssessmentSummary,here::here("data-raw/tempSummary.rds"))
saveRDS(stockAssessmentData,here::here("data-raw/tempData.rds"))
rm(stockAssessmentData)
rm(stockAssessmentSummary)
shell: Rscript {0}
- name: Pull stocksmart data
run: |
options(timeout = 60 * 60 * 6)
source(here::here("data-raw/query_stocksmart_api.R"))
query_stocksmart_api()
shell: Rscript {0}
- name: Process stocksmart data
run: |
options(timeout = 60 * 60 * 6)
source(here::here("data-raw/process_stocksmart_ts_data.R"))
out <- process_stocksmart_ts_data(exportFile=TRUE,isRunLocal=F)
saveRDS(out$summaryData,here::here("data-raw/newSummary.rds"))
saveRDS(out$tsData,here::here("data-raw/newData.rds"))
# incorporate difference check (below) prior to writing to repo or save as RDS and
# and write to repo later
shell: Rscript {0}
- name: Compare current pull with existing
# creates an rmd to send as email
# adds content to news.md
# increments package version in description
run: |
options(timeout = 60 * 60 * 6)
source(here::here("data-raw/compareData.r"))
source(here::here("data-raw/update_description.R"))
source(here::here("data-raw/update_news.R"))
diffs <- compareData()
version <- update_description(diffs,digit=3)
update_news(version,diffs)
rmarkdown::render(here::here("data-raw/sendAsEmail.Rmd"),
params = diffs)
saveRDS(version,here::here("data-raw/version.rds"))
shell: Rscript {0}
- name: render readme.rmd
run: |
options(timeout = 60 * 60 * 6)
rmarkdown::render(here::here("README.Rmd"))
shell: Rscript {0}
#- name: Find differences
# Create text explaining differences and append to news.md and release notes
#- name: Find differences
# Create text explaining differences and append to news.md and release notes
# Send email indicating if anything has changed
- name: Send email
uses: dawidd6/action-send-mail@v3
with:
server_address: smtp.gmail.com
server_port: 465
username: ${{ secrets.MAIL_USERNAME }}
password: ${{ secrets.MAIL_PASSWORD }}
subject: Github Actions job result
to: [email protected]
from: Stocksmart GitHub
#body: file://${{github.workspace}}/data-raw/datapull.txt
html_body: file://${{github.workspace}}/data-raw/sendAsEmail.html
#attachments: ./data-raw/sendAsEmail.html
- name: commit data files
run: |
git config user.name github-actions
git config user.email [email protected]
git add data/stockAssessmentData.rda
git add data/stockAssessmentSummary.rda
git add data-raw/datapull.txt
git add README.md
git add NEWS.md
git add DESCRIPTION
git commit -m "automated commit from api yml"
git push
- name: create gh-release
run: |
version <- readRDS(here::here("data-raw/version.rds"))
if(!is.null(version)){
usethis::use_github_release(publish = T)
}
shell: Rscript {0}