43 lines
1.5 KiB
JavaScript
43 lines
1.5 KiB
JavaScript
import VERSION from 'data/version.js'
|
|
import ProductDownloader from '@hashicorp/react-product-downloader'
|
|
import Head from 'next/head'
|
|
import HashiHead from '@hashicorp/react-head'
|
|
|
|
export default function DownloadsPage({ downloadData }) {
|
|
return (
|
|
<div id="p-downloads" className="g-container">
|
|
<HashiHead is={Head} title="Downloads | Packer by HashiCorp" />
|
|
<ProductDownloader
|
|
product="Packer"
|
|
version={VERSION}
|
|
downloads={downloadData}
|
|
/>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export async function getStaticProps() {
|
|
return fetch(`https://releases.hashicorp.com/packer/${VERSION}/index.json`)
|
|
.then((r) => r.json())
|
|
.then((r) => {
|
|
// TODO: restructure product-downloader to run this logic internally
|
|
return r.builds.reduce((acc, build) => {
|
|
if (!acc[build.os]) acc[build.os] = {}
|
|
acc[build.os][build.arch] = build.url
|
|
return acc
|
|
}, {})
|
|
})
|
|
.then((r) => ({ props: { downloadData: r } }))
|
|
.catch(() => {
|
|
throw new Error(
|
|
`--------------------------------------------------------
|
|
Unable to resolve version ${VERSION} on releases.hashicorp.com from link
|
|
<https://releases.hashicorp.com/packer/${VERSION}/index.json>. Usually this
|
|
means that the specified version has not yet been released. The downloads page
|
|
version can only be updated after the new version has been released, to ensure
|
|
that it works for all users.
|
|
----------------------------------------------------------`
|
|
)
|
|
})
|
|
}
|