MyNixOS website logo
Description

Interact with the 'Octopus Energy' API.

A simple wrapper for the 'Octopus Energy' API <https://developer.octopus.energy/docs/api/>. It handles authentication, by storing a provided API key and meter details. Implemented endpoints include 'products' for viewing tariff details and 'consumption' for viewing meter consumption data.

octopusR

CRANstatus R-CMD-check Codecov testcoverage

octopusR is an R package that provides access to the Octopus Energy API. With octopusR, you can easily retrieve data from the Octopus Energy API and use it in your R projects, or Shiny dashboards.

Installation

octopusR can be installed from CRAN.

install.packages("octopusR")

If you would like the development version, it can be installed from GitHub, using the devtools package:

# Install devtools if needed
if (!require("devtools")) install.packages("devtools")
devtools::install_github("moohan/octopusR")

Usage

To use most functions in octopusR, you will need an API key from Octopus Energy, you can find this on the developer dashboard. Once you have your API key, you can use set_api_key() to interactively input and store the API key for the session:

library(octopusR)

# Set your API key
set_api_key()

Once you have authenticated with the API, you may also want to set your electric and/or gas meter details.

# Set details for your electricity meter
set_meter_details(meter_type = "electricity")

# Set details for your gas meter
set_meter_details(meter_type = "gas")

You can use the other functions in the package to interact with the API. For example, you can use the get_consumption() function to retrieve data about your energy usage:

# Get data about your energy usage
energy_usage <- get_consumption(meter_type = "elec")
#> ℹ Returning 100 rows only as a date range wasn't provided.
#> ✔ Specify a date range with `period_to` and `period_from`.

# View the data
head(energy_usage)
#> # A tibble: 6 × 3
#>   consumption interval_start       interval_end        
#>         <dbl> <chr>                <chr>               
#> 1       0.096 2023-01-15T23:30:00Z 2023-01-16T00:00:00Z
#> 2       0.097 2023-01-15T23:00:00Z 2023-01-15T23:30:00Z
#> 3       0.097 2023-01-15T22:30:00Z 2023-01-15T23:00:00Z
#> 4       0.097 2023-01-15T22:00:00Z 2023-01-15T22:30:00Z
#> 5       0.098 2023-01-15T21:30:00Z 2023-01-15T22:00:00Z
#> 6       0.098 2023-01-15T21:00:00Z 2023-01-15T21:30:00Z

For more information and examples, see the package documentation and the Octopus Energy API documentation.

Contributing

If you have suggestions for improving octopusR, or if you have found a bug, please open an issue. Contributions in the form of pull requests are also welcome. See the guide to contributing for more details.

Code of Conduct

Please note that the octopusR project is released with a Contributor Code of Conduct. By contributing to this project, you agree to abide by its terms.

License

octopusR is licensed under the MIT License. See LICENSE for more information.

Metadata

Version

1.0.1

License

Unknown

Platforms (77)

    Darwin
    FreeBSD
    Genode
    GHCJS
    Linux
    MMIXware
    NetBSD
    none
    OpenBSD
    Redox
    Solaris
    WASI
    Windows
Show all
  • aarch64-darwin
  • aarch64-freebsd
  • aarch64-genode
  • aarch64-linux
  • aarch64-netbsd
  • aarch64-none
  • aarch64-windows
  • aarch64_be-none
  • arm-none
  • armv5tel-linux
  • armv6l-linux
  • armv6l-netbsd
  • armv6l-none
  • armv7a-darwin
  • armv7a-linux
  • armv7a-netbsd
  • armv7l-linux
  • armv7l-netbsd
  • avr-none
  • i686-cygwin
  • i686-darwin
  • i686-freebsd
  • i686-genode
  • i686-linux
  • i686-netbsd
  • i686-none
  • i686-openbsd
  • i686-windows
  • javascript-ghcjs
  • loongarch64-linux
  • m68k-linux
  • m68k-netbsd
  • m68k-none
  • microblaze-linux
  • microblaze-none
  • microblazeel-linux
  • microblazeel-none
  • mips-linux
  • mips-none
  • mips64-linux
  • mips64-none
  • mips64el-linux
  • mipsel-linux
  • mipsel-netbsd
  • mmix-mmixware
  • msp430-none
  • or1k-none
  • powerpc-netbsd
  • powerpc-none
  • powerpc64-linux
  • powerpc64le-linux
  • powerpcle-none
  • riscv32-linux
  • riscv32-netbsd
  • riscv32-none
  • riscv64-linux
  • riscv64-netbsd
  • riscv64-none
  • rx-none
  • s390-linux
  • s390-none
  • s390x-linux
  • s390x-none
  • vc4-none
  • wasm32-wasi
  • wasm64-wasi
  • x86_64-cygwin
  • x86_64-darwin
  • x86_64-freebsd
  • x86_64-genode
  • x86_64-linux
  • x86_64-netbsd
  • x86_64-none
  • x86_64-openbsd
  • x86_64-redox
  • x86_64-solaris
  • x86_64-windows