class: center, middle, inverse, title-slide .title[ # Getting started with R-universe ] .subtitle[ ## rOpenSci community call, May 2021 ] .author[ ### Jeroen Ooms ] .date[ ### 2021/05/25 ] --- class: fullpage # R-universe is for everyone ! data:image/s3,"s3://crabby-images/65d82/65d82baa9909d231fea4045cd3cc278c823d88f8" alt="website2" ??? Teams, organizations, developers or just personal projects --- class: inverse, center, middle # What is R-universe? --- # What is R-universe? R-universe is new platform by rOpenSci for _publishing_ and _discovering_ R packages, Rmd articles, and other R based content. ## `https://<user>.r-universe.dev` Every user or organization has a personal domain for publishing their content. On this domain you can find: -- - __CRAN-like repo__ with any R packages + win/mac binaries - Live rendered __Rmd articles__ - Programmable __API access__ - Interactive __dashboard__ for browsing and monitoring activity - Everything is __fully automated__ - Metrics and other meta functionality (planned later 2021) -- The R-universe platform connects these different universes with each other, though global feeds, cross referencing maintainers, etc. A bit like GitHub! But for R :-) --- class: inverse, center, middle # Example! --- class: fullpage # Example: the ggseg universe data:image/s3,"s3://crabby-images/05a92/05a927580b1b8e560d2deda3e3515239f04d8f72" alt="ggseg-builds" --- class: fullpage # Example: the ggseg universe data:image/s3,"s3://crabby-images/588e4/588e43b4ddeb261051d9589e27202f480cf940e1" alt="ggseg-builds2" --- class: fullpage # Example: the ggseg universe data:image/s3,"s3://crabby-images/16c0e/16c0ef7340cadef70a87e300acacc691e36e5c62" alt="ggseg-builds2" --- class: inverse, center, middle # Browsing R packages in a universe --- class: fullpage # Example: the ggseg universe (packages) data:image/s3,"s3://crabby-images/81808/818081b54958e29ed550e535cb9a5cccf8c0d9e1" alt="ggseg-builds3" --- class: fullpage # Example: the ggseg universe (packages) data:image/s3,"s3://crabby-images/05cd1/05cd15d09da9fdce2b80afa5cf9a597a17627a0f" alt="ggseg-builds4" --- # Example: the ggseg universe (packages) ### Users install simply using `install.packages`. ```r # Enable this universe options(repos = c( ggseg = 'https://ggseg.r-universe.dev', CRAN = 'https://cloud.r-project.org')) # Install some packages install.packages('ggseg3d') ``` -- ## No `remotes` / `devtools`/ `rtools` required !! --- class: fullpage # Example: the ggseg universe (packages) data:image/s3,"s3://crabby-images/34160/34160ced4217bc3c23ea9e3315d1a3d2b942b98f" alt="ggseg-packages0" --- class: fullpage # Example: the ggseg universe (packages) data:image/s3,"s3://crabby-images/22773/227737ada7590cd17601f8f71b1e0c6f7f74488c" alt="ggseg-packages" --- class: fullpage # Example: the ggseg universe (packages) data:image/s3,"s3://crabby-images/6b32a/6b32aab92dcb1c30e91e5d991f54278fbba104e9" alt="ggseg-packages2" --- class: fullpage # Example: the ggseg universe (packages) data:image/s3,"s3://crabby-images/e16db/e16db9ea5817b1ca2f042c56c124057200c9ae43" alt="ggseg-packages1" --- class: inverse, center, middle # Browsing articles in a universe --- class: fullpage # Example: the ggseg universe (articles) data:image/s3,"s3://crabby-images/80e1d/80e1dffce6be8f66d2d7e15d5709581146e0f3f2" alt="ggseg-articles0" --- class: fullpage # Example: the ggseg universe (articles) data:image/s3,"s3://crabby-images/539b8/539b8c72c09b8949b976ec650b70ce2f893ec28c" alt="ggseg-articles1" --- class: fullpage # Example: the ggseg universe (articles) data:image/s3,"s3://crabby-images/6c0f5/6c0f524ba3089ac902a93e568685369d6afbad47" alt="ggseg-article" --- class: fullpage # Example: the ggseg universe (articles) data:image/s3,"s3://crabby-images/eb69b/eb69ba4899a190abebf60244b7a8ae332f38a504" alt="ggseg-article1" --- class: inverse, center, middle # API access to all the data ! --- class: fullpage # Example: the ggseg universe (APIs) data:image/s3,"s3://crabby-images/c9e15/c9e15d21ff45185937fefaaf1b74aa5a14c92c57" alt="ggseg-api0" --- class: fullpage # Example: the ggseg universe (APIs) data:image/s3,"s3://crabby-images/df2b1/df2b1c4cf0047f7ceb99155bb6a644840eb9e995" alt="ggseg-api0" --- class: fullpage # Example: the ggseg universe (APIs) data:image/s3,"s3://crabby-images/c385a/c385aa74adcc98534e7dae61cbcb1c7275d0572d" alt="ggseg-json" --- # Example: the ggseg universe (APIs) Use `jsonlite` to read data in R: ```r library(jsonlite) ggseg <- fromJSON('https://ggseg.r-universe.dev/api/packages/ggseg') ``` Aggregate data uses ndjson so you need `jsonlite::stream_in()`: ```r library(jsonlite) # All package description data descriptions <- stream_in(url('https://ggseg.r-universe.dev/stats/descriptions')) # All articles vignettes <- stream_in(url('https://ggseg.r-universe.dev/stats/vignettes')) ``` --- class: inverse, center, middle # For who is R universe intended? --- # For who is R universe intended? ## Anyone can start a universe ! Example use cases - Both for personal and organizations. - Packages do NOT need to be on CRAN. In your universe you make the rules! - Experimental projects - Research compendia packages - Homework assignments - Dev versions of CRAN packages Package git repos do not need to be in the same GitHub user/org as the universe. You can even add packages from Gitlab or another Git server. You only need the GitHub username for the universe itself. --- class: inverse, center, middle # Example use-cases for R-universe --- class: fullpage # Personal package portfolio data:image/s3,"s3://crabby-images/927bd/927bdb936e659923705b1d81728c0449254d90bf" alt="mohammed" --- class: fullpage # Research software publishing data:image/s3,"s3://crabby-images/e0d2d/e0d2df36adf21c2f6d1869b13cf3b0fdd6724dca" alt="mrc" --- class: fullpage # Curated suite of packages data:image/s3,"s3://crabby-images/a0f7a/a0f7a4e94021c5135520fa989e3dba725191084a" alt="ropensci" --- class: fullpage # Dev versions for CRAN packages data:image/s3,"s3://crabby-images/32479/32479b58a05ef187bd68c13e3ca00c30fd6087c6" alt="rlib" --- class: fullpage # Domain specific suite of packages data:image/s3,"s3://crabby-images/867b8/867b8934b4d3e638b00a10f545e1f12157214cab" alt="rspatial" --- class: fullpage # And many more ! data:image/s3,"s3://crabby-images/5d396/5d396ddb293d248db27011470f4ee858593ab130" alt="listuniverses" --- # Other types of universes R-universe is specifically intended to allow publishing non-software R packages. For example you can think about: - Packages containing only a vignette which serves to create a live, reproducible paper - Research compendium packages with supporting data or code used in a scientific publication - A package where you publish interesting R tutorials by including them as vignettes - A package containing an interesting dataset Any R-based content can fit in a package! --- class: inverse, center, middle # Global feeds connect the universes --- class: fullpage # Global feed: builds data:image/s3,"s3://crabby-images/9685d/9685d7dfa70e86584acca0100baac4dcef07c0e7" alt="globalbuilds" --- class: fullpage # Global feed: articles data:image/s3,"s3://crabby-images/c8b80/c8b801ccd5c2d6e010a98e78ddb632f681ea6c73" alt="globalarticles" --- class: fullpage # Global feed: maintainers data:image/s3,"s3://crabby-images/7614b/7614bf4999c7109af37c485693f4fb1e3e58016c" alt="globalmaintainers" --- class: fullpage # Global feed: maintainers data:image/s3,"s3://crabby-images/0abfc/0abfc8fdbf8a4e80b6b56ebdd60e4b9ab3886c38" alt="maintainerinfo" --- class: inverse, center, middle # How to setup your own universe --- class: fullpage # Setup your own universe data:image/s3,"s3://crabby-images/77451/774512bdfecdc53b06b36d4ceff507c19e49db48" alt="help" --- # Step 1: create your registry Create a repository called `{user}.universe.dev` on your GitHub account where `{user}` equals your GitHub username. Add a file called `packages.json` listing the names and git URLs of the R packages you want to include: ```json [ { "package": "goodpress", "url": "https://github.com/maelle/goodpress" }, { "package": "cransays", "url": "https://github.com/lockedata/cransays" }, { "package": "rodev", "url": "https://github.com/ropenscilabs/rodev", "branch" : "master" } ] ``` Example: https://github.com/maelle/maelle.r-universe.dev. Start by adding no more than a few packages, you can add more later. The `branch` field is optional. --- class: fullpage # Step 1: create your registry data:image/s3,"s3://crabby-images/f7a32/f7a32c28f9c3b3e1d17c5f87e80886fa85f4eb46" alt="maelle" --- class: fullpage # Step 2: install the GitHub app data:image/s3,"s3://crabby-images/32a06/32a06de6f29d0b8d3472275cf49484820e3b0e95" alt="setup" --- class: fullpage # Step 2: install the GitHub app data:image/s3,"s3://crabby-images/bbef5/bbef51392027113374004acfb2984c9b835caf25" alt="installapp" --- class: fullpage # Your universe monorepo data:image/s3,"s3://crabby-images/0127a/0127aaa89ccb9d7ef975071c96b0f58e5cff9933" alt="monorepo" --- class: fullpage # Your universe monorepo data:image/s3,"s3://crabby-images/4dbe6/4dbe6f185ccbbb94289a2a937a0f51d79be18506" alt="actions" --- class: fullpage # Now just wait... data:image/s3,"s3://crabby-images/44217/44217fa83288b671a2a656198e94b19cf989698a" alt="maelledash" --- class: fullpage # Show commit status (if permitted) data:image/s3,"s3://crabby-images/b1332/b1332686551684928a23328e6ae6e5d44ebff85c" alt="commitstatus" --- # Conclusion What is R-universe and why is it useful? - R-universe is an open platform that provides users and organizations with a personal space for publishing R content - The system automatically tracks your git repos, builds and distributes binary versions of your packages for Mac and Windows. - Users can easily install packages from your personal CRAN-like repository, without complex configuration of compile tools and dependencies - The dashboard showcases a collection of R packages and vignette content, even when spread across multiple GitHub organizations - R-universe can be used as a simple zero-configuration CI/CD system, running the standard checks on the most important platforms. - R-universe is very easy to set up! We have dealt with lots of challenges related to dependencies, platforms, etc., for you. You can have a universe with just a few clicks. - R-universe combines the best features of hosting your packages on GitHub and CRAN, without being exclusive to either. - Anyone, from novice R user to veteran package developer, can setup their own universe.