PSCovid19Stats.psm1

function Get-CovidCountriesStats {

    <#
        .SYNOPSIS
        Command used to extract data (Country Stats) from the NovelCOVID API (github.com/NovelCOVID/API)
     
        .DESCRIPTION
        Command used to extract data (Country Stats) from the NovelCOVID API (github.com/NovelCOVID/API)
        Returns data of all countries that has COVID-19
     
        .INPUTS
        None. You cannot pipe objects to Get-CovidCountryStats
     
        .OUTPUTS
        System.String. Get-CovidCountriesStats returns a string with all of the Covid-19 stats for every
        country affected
     
        .EXAMPLE
        PS C:\GitRepos> Get-CovidCountriesStats | Format-Table -AutoSize
        DeathsPerOneMillion TodayCases CasesPerOneMillion Deaths Critical Active Recovered Country TodayDeaths Cases
        ------------------- ---------- ------------------ ------ -------- ------ --------- ------- ----------- -----
        0.07 0 0.5 1 0 6 0 Zimbabwe 0 7
        0 1 2 0 0 29 0 Zambia 0 29
 
        .LINK
        https://github.com/BanterBoy/PSCovid19Stats/wiki/Get-CovidCountriesStats
     
        .NOTES
        Author: Luke Leigh
        Website: https://blog.lukeleigh.com/
        LinkedIn: https://www.linkedin.com/in/lukeleigh/
        GitHub: https://github.com/BanterBoy/
        GitHubGist: https://gist.github.com/BanterBoy
     
    #>


    BEGIN {

    }

    PROCESS {
        $CountriesHeaders = New-Object "System.Collections.Generic.Dictionary[[String],[String]]"
        $CountriesHeaders.Add("Cookie", "__cfduid=d6907f091c38e985d84bd05e1faf548a61585349147")
        $CountriesResponses = Invoke-RestMethod 'https://corona.lmao.ninja/countries?sort=country' -Method 'GET' -Headers $CountriesHeaders -Body $body

        foreach ($Response in $CountriesResponses) {
            try {
                $properties = @{
                    Country             = [string]$Response.country
                    TodayCases          = [int]$Response.todayCases
                    TodayDeaths         = [int]$Response.todayDeaths
                    Cases               = [int]$Response.cases
                    Active              = [int]$Response.active
                    Critical            = [int]$Response.critical
                    Deaths              = [int]$Response.deaths
                    Recovered           = [int]$Response.recovered
                    CasesPerOneMillion  = [decimal]$Response.casesPerOneMillion
                    DeathsPerOneMillion = [decimal]$Response.deathsPerOneMillion
                }
            }
            catch {
                $properties = @{
                    Country             = [string]$Response.country
                    TodayCases          = [int]$Response.todayCases
                    TodayDeaths         = [int]$Response.todayDeaths
                    Cases               = [int]$Response.cases
                    Active              = [int]$Response.active
                    Critical            = [int]$Response.critical
                    Deaths              = [int]$Response.deaths
                    Recovered           = [int]$Response.recovered
                    CasesPerOneMillion  = [decimal]$Response.casesPerOneMillion
                    DeathsPerOneMillion = [decimal]$Response.deathsPerOneMillion
                }
            }
            finally {
                $obj = New-Object -TypeName PSObject -Property $Properties
                Write-Output $obj
            }
        }
    }

    END {

    }

}

function Get-CovidCountryStats {

    <#
        .SYNOPSIS
        Command used to extract data (Country Stats) from the NovelCOVID API (github.com/NovelCOVID/API)
     
        .DESCRIPTION
        Command used to extract data (Country Stats) from the NovelCOVID API (github.com/NovelCOVID/API)
        Returns data of a specific country.
     
        .PARAMETER Country
        This is a mandatory field which you can enter manually or using tab to cycle through the options.
        This field uses the standard [ISO Country Codes](https://en.wikipedia.org/wiki/List_of_ISO_3166_country_codes)
     
        .INPUTS
        None. You cannot pipe objects to Get-CovidCountryStats
     
        .OUTPUTS
        System.String. Get-CovidCountriesStats returns a string with all of the Covid-19 stats for the
        specified country.
     
        .EXAMPLE
        PS C:\GitRepos> Get-CovidCountryStats -Country UK
         
        DeathsPerOneMillion : 18
        TodayCases : 2433
        CasesPerOneMillion : 288
        Deaths : 1228
        Critical : 163
        Active : 18159
        Recovered : 135
        Country : UK
        TodayDeaths : 209
        Cases : 19522
 
        .LINK
        https://github.com/BanterBoy/PSCovid19Stats/wiki/Get-CovidCountryStats
     
        .NOTES
        Author: Luke Leigh
        Website: https://blog.lukeleigh.com/
        LinkedIn: https://www.linkedin.com/in/lukeleigh/
        GitHub: https://github.com/BanterBoy/
        GitHubGist: https://gist.github.com/BanterBoy
     
    #>

    

    [CmdletBinding(DefaultParameterSetName = 'ParameterSet1',
        SupportsShouldProcess = $false,
        PositionalBinding = $false,
        HelpUri = 'https://github.com/BanterBoy/PSCovid19Stats/wiki/Get-CovidCountryStats',
        ConfirmImpact = 'Medium')]
    param(
        [Parameter(Mandatory = $true,
            ValueFromPipeline = $true,
            ValueFromPipelineByPropertyName = $true,
            ParameterSetName = 'ParameterSet1')]
        [ValidateNotNull()]
        [ValidateNotNullOrEmpty()]
        [OutputType([String])]
        [ArgumentCompleter( {
                $Content = Invoke-RestMethod -Uri 'https://datahub.io/core/country-list/r/data.json'
                $ISOCodes = $Content | Sort-Object -Property Code
                foreach ($Code in $ISOCodes) {
                    $Code.Code
                }
            }) ]
        [string]
        $Country
    )

    BEGIN {
    }
    
    PROCESS {
        $CountryHeaders = New-Object "System.Collections.Generic.Dictionary[[String],[String]]"
        $CountryHeaders.Add("Cookie", "__cfduid=d6907f091c38e985d84bd05e1faf548a61585349147")
        $CountryResponse = Invoke-RestMethod "https://corona.lmao.ninja/countries/$Country" -Method 'GET' -Headers $CountryHeaders -Body $body
        
        foreach ($Response in $CountryResponse) {
            try {
                $properties = @{
                    Country             = [string]$Response.country
                    TodayCases          = [int]$Response.todayCases
                    TodayDeaths         = [int]$Response.todayDeaths
                    Cases               = [int]$Response.cases
                    Active              = [int]$Response.active
                    Critical            = [int]$Response.critical
                    Deaths              = [int]$Response.deaths
                    Recovered           = [int]$Response.recovered
                    CasesPerOneMillion  = [decimal]$Response.casesPerOneMillion
                    DeathsPerOneMillion = [decimal]$Response.deathsPerOneMillion
                }
            }
            catch {
                $properties = @{
                    Country             = [string]$Response.country
                    TodayCases          = [int]$Response.todayCases
                    TodayDeaths         = [int]$Response.todayDeaths
                    Cases               = [int]$Response.cases
                    Active              = [int]$Response.active
                    Critical            = [int]$Response.critical
                    Deaths              = [int]$Response.deaths
                    Recovered           = [int]$Response.recovered
                    CasesPerOneMillion  = [decimal]$Response.casesPerOneMillion
                    DeathsPerOneMillion = [decimal]$Response.deathsPerOneMillion
                }
            }
            finally {
                $obj = New-Object -TypeName PSObject -Property $Properties
                Write-Output $obj
            }
        }
    }

    END {

    }

}

function Get-CovidHistoricalData {

    <#
        .SYNOPSIS
        Command used to extract historical data from the NovelCOVID API (github.com/NovelCOVID/API)
 
        .DESCRIPTION
        Command used to extract historical data from the NovelCOVID API (github.com/NovelCOVID/API)
 
        .INPUTS
        None. You cannot pipe objects to Get-CovidHistoricalData
 
        .OUTPUTS
        System.String. Get-CovidHistoricalData returns a string with all of the Covid-19 stats for every
        country affected
 
        .EXAMPLE
        PS C:\GitRepos> Get-CovidHistoricalData
 
        .LINK
        https://github.com/BanterBoy/PSCovid19Stats/wiki/Get-CovidHistoricalData
 
        .NOTES
        Author: Luke Leigh
        Website: https://blog.lukeleigh.com
        LinkedIn: https://www.linkedin.com/in/lukeleigh
        GitHub: https://github.com/BanterBoy
        GitHubGist: https://gist.github.com/BanterBoy
    #>


    BEGIN {
    
    }

    PROCESS {
        $HistoricalDataHeaders = New-Object "System.Collections.Generic.Dictionary[[String],[String]]"
        $HistoricalDataHeaders.Add("Cookie", "__cfduid=d6907f091c38e985d84bd05e1faf548a61585349147")
        $HistoricalData = Invoke-RestMethod 'https://corona.lmao.ninja/v2/historical' -Method 'GET' -Headers $HistoricalDataHeaders -Body $body

        foreach ($Data in $HistoricalData) {
            try {
                $properties = @{
                    country  = $Data.country
                    province = $Data.province
                    Cases    = $HistoricalData[0].timeline.cases
                    Deaths   = $HistoricalData[0].timeline.deaths
                }
            }
            catch {
                $properties = @{
                    country  = $Data.country
                    province = $Data.province
                    Cases    = $HistoricalData[0].timeline.cases
                    Deaths   = $HistoricalData[0].timeline.deaths
                }
            }
            finally {
                $obj = New-Object -TypeName PSObject -Property $Properties
                Write-Output $obj
            }
        }
    }

    END {

    }

}

function Get-CovidjhucsseData {

    <#
 
        .SYNOPSIS
        Command used to extract John HOpkins CSSE Data from the NovelCOVID API (github.com/NovelCOVID/API)
 
        .DESCRIPTION
        Command used to extract John HOpkins CSSE Data from the NovelCOVID API (github.com/NovelCOVID/API)
        Return data from the John Hopkins CSSE Data Repository (Provinces and such).
 
        .INPUTS
        None. You cannot pipe objects to Get-CovidjhucsseData
 
        .OUTPUTS
        System.String. Get-CovidjhucsseData returns a string with all of the Covid-19 stats for every
        country affected
 
        .EXAMPLE
        PS C:\GitRepos> Get-CovidjhucsseData
 
        .LINK
        https://github.com/BanterBoy/PSCovid19Stats/wiki/Get-CovidjhucsseData
 
        .NOTES
        Author: Luke Leigh
        Website: https://blog.lukeleigh.com
        LinkedIn: https://www.linkedin.com/in/lukeleigh
        GitHub: https://github.com/BanterBoy
        GitHubGist: https://gist.github.com/BanterBoy
 
#>



    BEGIN {
    
    }

    PROCESS {
        $jhucsseDataHeaders = New-Object "System.Collections.Generic.Dictionary[[String],[String]]"
        $jhucsseDataHeaders.Add("Cookie", "__cfduid=d6907f091c38e985d84bd05e1faf548a61585349147")
        $jhucsseData = Invoke-RestMethod 'https://corona.lmao.ninja/jhucsse' -Method 'GET' -Headers $jhucsseDataHeaders -Body $body

        foreach ($jhucsse in $jhucsseData) {
            try {
                $properties = @{
                    City      = [string]$jhucsse.city
                    Province  = [string]$jhucsse.province
                    Country   = [string]$jhucsse.country
                    UpdatedAt = [datetime]$jhucsse.updatedAt
                    Longitude = $jhucsse.coordinates.longitude
                    Latitude  = $jhucsse.coordinates.latitude
                    Confirmed = $jhucsse.stats.confirmed
                    Recovered = $jhucsse.stats.recovered
                    Deaths    = $jhucsse.stats.deaths
                }
            }
            catch {
                $properties = @{
                    City      = [string]$jhucsse.city
                    Province  = [string]$jhucsse.province
                    Country   = [string]$jhucsse.country
                    UpdatedAt = [datetime]$jhucsse.updatedAt
                    Longitude = $jhucsse.coordinates.longitude
                    Latitude  = $jhucsse.coordinates.latitude
                    Confirmed = $jhucsse.stats.confirmed
                    Recovered = $jhucsse.stats.recovered
                    Deaths    = $jhucsse.stats.deaths
                }
            }
            finally {
                $obj = New-Object -TypeName PSObject -Property $Properties
                Write-Output $obj
            }
        }
    }

    END {

    }

}

function Get-CovidStateStats {

    <#
 
        .SYNOPSIS
        Command used to extract Data for all US States from the NovelCOVID API (github.com/NovelCOVID/API)
 
        .DESCRIPTION
        Command used to extract John HOpkins CSSE Data from the NovelCOVID API (github.com/NovelCOVID/API)
        Return data from the John Hopkins CSSE Data Repository (Provinces and such).
 
        .INPUTS
        None. You cannot pipe objects to Get-CovidStateStats
 
        .OUTPUTS
        System.String. Get-CovidStateStats returns a string with all of the Covid-19 stats for all US States
 
        .EXAMPLE
        PS C:\GitRepos> Get-CovidStateStats
 
        .LINK
        https://github.com/BanterBoy/PSCovid19Stats/wiki/Get-CovidStateStats
 
        .NOTES
        Author: Luke Leigh
        Website: https://blog.lukeleigh.com
        LinkedIn: https://www.linkedin.com/in/lukeleigh
        GitHub: https://github.com/BanterBoy
        GitHubGist: https://gist.github.com/BanterBoy
 
    #>



    BEGIN {
        
    }
    
    PROCESS {
        $StateHeaders = New-Object "System.Collections.Generic.Dictionary[[String],[String]]"
        $StateHeaders.Add("Cookie", "__cfduid=d6907f091c38e985d84bd05e1faf548a61585349147")
        $StateResponses = Invoke-RestMethod 'https://corona.lmao.ninja/states' -Method 'GET' -Headers $StateHeaders -Body $body
        
        foreach ($Response in $StateResponses) {
            try {
                $properties = @{
                    State       = [string]$Response.state
                    TodayCases  = [int]$Response.todayCases
                    TodayDeaths = [int]$Response.todayDeaths
                    Cases       = [int]$Response.cases
                    Active      = [int]$Response.active
                    Deaths      = [int]$Response.deaths
                }
            }
            catch {
                $properties = @{
                    State       = [string]$Response.state
                    TodayCases  = [int]$Response.todayCases
                    TodayDeaths = [int]$Response.todayDeaths
                    Cases       = [int]$Response.cases
                    Active      = [int]$Response.active
                    Deaths      = [int]$Response.deaths
                }
            }
            finally {
                $obj = New-Object -TypeName PSObject -Property $Properties
                Write-Output $obj
            }
        }
    }

    END {

    }

}

function Get-CovidWorldStats {

    <#
 
        .SYNOPSIS
        Command used to extract Data for all Returns all total cases, recovery, and deaths from the NovelCOVID API (github.com/NovelCOVID/API)
 
        .DESCRIPTION
        Command used to extract John HOpkins CSSE Data from the NovelCOVID API (github.com/NovelCOVID/API)
        Returns all total cases, recovery, and deaths.
 
        .INPUTS
        None. You cannot pipe objects to Get-CovidWorldStats
 
        .OUTPUTS
        System.String. Get-CovidWorldStats returns a string of all total cases, recovery, and deaths.
 
        .EXAMPLE
        PS C:\GitRepos> Get-CovidWorldStats
        Active : 536625
        Recovered : 151312
        Deaths : 33966
        Cases : 721903
        Updated : 30/03/2020 02:08:07
 
        .LINK
        https://github.com/BanterBoy/PSCovid19Stats/wiki/Get-CovidWorldStats
 
        .NOTES
        Author: Luke Leigh
        Website: https://blog.lukeleigh.com
        LinkedIn: https://www.linkedin.com/in/lukeleigh
        GitHub: https://github.com/BanterBoy
        GitHubGist: https://gist.github.com/BanterBoy
 
    #>



    BEGIN {
    
    }

    PROCESS {
        $AllHeaders = New-Object "System.Collections.Generic.Dictionary[[String],[String]]"
        $AllHeaders.Add("Cookie", "__cfduid=d6907f091c38e985d84bd05e1faf548a61585349147")
        $AllResponses = Invoke-RestMethod 'https://corona.lmao.ninja/all' -Method 'GET' -Headers $AllHeaders -Body $body
        $EpochStart = Get-Date "01/01/1970 00:00:00"

        foreach ($Response in $AllResponses) {
            try {
                $properties = @{
                    Cases     = $Response.cases
                    Deaths    = $Response.Deaths
                    Recovered = $Response.Recovered
                    Updated   = $EpochStart.AddMilliseconds($Response.Updated)
                    Active    = $Response.Active
                }
            }
            catch {
                $properties = @{
                    Cases     = $Response.cases
                    Deaths    = $Response.Deaths
                    Recovered = $Response.Recovered
                    Updated   = $EpochStart.AddMilliseconds($Response.Updated)
                    Active    = $Response.Active
                }
            }
            finally {
                $obj = New-Object -TypeName PSObject -Property $Properties
                Write-Output $obj
            }
        }
    }

    END {

    }

}

function Show-CountryCodes {
    <#
        .SYNOPSIS
        Command used to display a list of Country Codes
     
        .DESCRIPTION
        This Command can be used to display a list of standard Country Codes from the standard [ISO Country Codes](https://en.wikipedia.org/wiki/List_of_ISO_3166_country_codes)
     
        .INPUTS
        None. You cannot pipe objects to Show-CountryCodes
     
        .OUTPUTS
        System.String. Show-CountryCodes returns a string with all of the ISO Country Codes.
     
        .EXAMPLE
        PS C:\GitRepos> Show-CountryCodes
        Code Name
        ---- ----
        AF Afghanistan
        AX Åland Islands
        AL Albania
        DZ Algeria
        AS American Samoa
        AD Andorra
        AO Angola
        AI Anguilla
        AQ Antarctica
        ...............
 
        .LINK
        https://github.com/BanterBoy/PSCovid19Stats/wiki/Show-CountryCodes
     
        .NOTES
        Author: Luke Leigh
        Website: https://blog.lukeleigh.com/
        LinkedIn: https://www.linkedin.com/in/lukeleigh/
        GitHub: https://github.com/BanterBoy/
        GitHubGist: https://gist.github.com/BanterBoy
     
    #>

    Invoke-RestMethod -Uri 'https://datahub.io/core/country-list/r/data.json'
}