Skip to content

Commit

Permalink
feat: deploy latest main release to production (#406)
Browse files Browse the repository at this point in the history
* fix: remove auto-reload config and default to true (#319)

* fix: remove auto-reload config and default to true

* test: fix ci layout test

* test: fix some playwright tests

* test: fix firefox e2e tests

* test: fix first-hit e2e tests

* chore: code cleanup self review

* deps(dev): bump playwright from 1.45.0 to 1.45.3 (#331)

Bumps [playwright](https://github.com/microsoft/playwright) from 1.45.0 to 1.45.3.
- [Release notes](https://github.com/microsoft/playwright/releases)
- [Commits](microsoft/playwright@v1.45.0...v1.45.3)

---
updated-dependencies:
- dependency-name: playwright
  dependency-type: direct:development
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* feat: build with esbuild, apply source maps (#392)

* feat: use esbuild for building

* feat: remove webpack

* test: fix e2e tests

* chore: remove timeout only required on my network

* chore: remove copyfiles

* chore: suggestions from self code review

* fix: use code-splitting

* fix: firefox doesn't like ESM service workers

* fix: remove type in sw registration

* feat: add git version into index.html

---------

Co-authored-by: Daniel N <[email protected]>

* fix: service worker logs are visible again (#395)

* fix: service worker logs are visible again

* chore: self pr suggestion

* fix: remove fonts from dist folder (#394)

* fix: remove fonts from dist folder

* chore: install http-server for playwright

* fix: use more ipfs-sw prefixes (#396)

* fix: use enable from @libp2p/logger (#398)

* feat: add p2p retrieval option (#391)

* feat: add config toggle for p2p retrieval

* deps: add helia and bump verified fetch

* feat: load p2p helia

* chore: remove console.log

* feat: try to make recursive gateways optional

* fixup! feat: add config toggle for p2p retrieval

* chore: aegir lint --fix

* chore: install missing deps

* feat: use esbuild for building

* feat: remove webpack

* test: fix e2e tests

* chore: remove timeout only required on my network

* chore: remove copyfiles

* chore: suggestions from self code review

* fix: gateways null when loading sw

* fix: use code-splitting

* fix: firefox doesn't like ESM service workers

* fix: remove type in sw registration

* feat: add git version into index.html

* Revert "feat: try to make recursive gateways optional"

This reverts commit eba97a4.

* fix: bug returning an array with 1 el

* ui: improve contrast for disabled toggle

* feat: add granular config options

* test: fix config layout test

* deps: add missing deps

* fix: unused deps

* fix: make toggles smaller

* fix: avoid setting defaults in inputs

* feat: allow a single router for now

* chore: rename to get verified fetch

* feat: reorder config

* feat: add additional title

* fix: break config UI into sections

* chore: output localhost as listening host

* fix: allow multiple routers

see #402

* fix: run validation onblur to allow editing

* fix: log config as string

otherwise it's not viewable in the console

* feat: add ipip-484 filtering to delegated router

* chore: more left padding on input section

Co-authored-by: Daniel Norman <[email protected]>

---------

Co-authored-by: Daniel N <[email protected]>
Co-authored-by: Russell Dempsey <[email protected]>

* chore(main): release 1.4.0 (#334)

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>

* fix: support discovery of /tls/../ws|http  providers (#405)

* fix: support direct retrieval from /tls/sni/../ws
* fix: safelist multiaddrs with /tls
* fix: include /tls/../http in addition to /https
* chore: reference someguy issue

---------

Co-authored-by: Daniel Norman <[email protected]>

* chore(main): release 1.4.1 (#407)

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>

* deps: update helia and libp2p (#408)

Co-authored-by: Daniel N <[email protected]>

---------

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: Russell Dempsey <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Daniel N <[email protected]>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Marcin Rataj <[email protected]>
  • Loading branch information
6 people authored Oct 29, 2024
1 parent 2f4cbfd commit 74f33a3
Show file tree
Hide file tree
Showing 30 changed files with 13,235 additions and 9,442 deletions.
11 changes: 4 additions & 7 deletions .aegir.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,20 +20,17 @@ export default {
'ipfs-css',
'tachyons',

// required by webpack
'webpack-cli',
'webpack-dev-server',
'babel-loader',
'style-loader',
'css-loader'
// playwright dependencies
'http-server'
],
productionIgnorePatterns: [
'webpack.config.js',
'playwright.config.js',
'test-e2e',
'.aegir.js',
'/test',
'dist'
'dist',
'build.js'
]
}
}
24 changes: 24 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,29 @@
# Changelog

## [1.4.1](https://github.com/ipfs/service-worker-gateway/compare/v1.4.0...v1.4.1) (2024-10-25)


### Bug Fixes

* support discovery of /tls/../ws|http providers ([#405](https://github.com/ipfs/service-worker-gateway/issues/405)) ([d848e6c](https://github.com/ipfs/service-worker-gateway/commit/d848e6cbff01d38b851d601a3f65dfdac235086f))

## [1.4.0](https://github.com/ipfs/service-worker-gateway/compare/v1.3.0...v1.4.0) (2024-10-24)


### Features

* add p2p retrieval option ([#391](https://github.com/ipfs/service-worker-gateway/issues/391)) ([0db6d94](https://github.com/ipfs/service-worker-gateway/commit/0db6d94393238853ad5130a6fb17e0a2a821efde))
* build with esbuild, apply source maps ([#392](https://github.com/ipfs/service-worker-gateway/issues/392)) ([2b26bd6](https://github.com/ipfs/service-worker-gateway/commit/2b26bd6354a5f2b9ca51d078ad7c146d69360dac))


### Bug Fixes

* remove auto-reload config and default to true ([#319](https://github.com/ipfs/service-worker-gateway/issues/319)) ([42e6b64](https://github.com/ipfs/service-worker-gateway/commit/42e6b64cf46856eba231b676a4f9c104ff1090f9))
* remove fonts from dist folder ([#394](https://github.com/ipfs/service-worker-gateway/issues/394)) ([86641e5](https://github.com/ipfs/service-worker-gateway/commit/86641e590c8991dad1cc3c1f7b89931b630ccb11))
* service worker logs are visible again ([#395](https://github.com/ipfs/service-worker-gateway/issues/395)) ([98659e2](https://github.com/ipfs/service-worker-gateway/commit/98659e28e98ec5297fd9dc1e6ed2e3d244a51a58))
* use enable from @libp2p/logger ([#398](https://github.com/ipfs/service-worker-gateway/issues/398)) ([cb8c662](https://github.com/ipfs/service-worker-gateway/commit/cb8c662a3d27248c72cb9da2beef5fb56228550e))
* use more ipfs-sw prefixes ([#396](https://github.com/ipfs/service-worker-gateway/issues/396)) ([ade0074](https://github.com/ipfs/service-worker-gateway/commit/ade0074d7f08a61b15f33077c00dc5a1cb273cb7))

## [1.3.0](https://github.com/ipfs/service-worker-gateway/compare/v1.2.0...v1.3.0) (2024-07-04)


Expand Down
215 changes: 215 additions & 0 deletions build.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,215 @@
/* eslint-disable no-console */
import { execSync } from 'node:child_process'
import fs from 'node:fs'
import path from 'node:path'
import esbuild from 'esbuild'

const copyPublicFiles = () => {
const srcDir = path.resolve('public')
const destDir = path.resolve('dist')

// Ensure the destination directory exists
if (!fs.existsSync(destDir)) {
fs.mkdirSync(destDir, { recursive: true })
}

// Read all files in the source directory
const files = fs.readdirSync(srcDir)

// Copy each file to the destination directory
files.forEach(file => {
const srcFile = path.join(srcDir, file)
const destFile = path.join(destDir, file)
fs.copyFileSync(srcFile, destFile)
console.log(`${file} copied to dist folder.`)
})
}

function gitRevision () {
try {
const ref = execSync('git rev-parse --abbrev-ref HEAD').toString().trim()
const sha = execSync('git rev-parse --short HEAD').toString().trim()

try {
// detect production build
execSync('git fetch --force --depth=1 --quiet origin production')
const latestProduction = execSync('git rev-parse remotes/origin/production').toString().trim()
if (latestProduction.startsWith(sha)) {
return `production@${sha}`
}

// detect staging build
execSync('git fetch --force --depth=1 --quiet origin staging')
const latestStaging = execSync('git rev-parse remotes/origin/staging').toString().trim()
if (latestStaging.startsWith(sha)) {
return `staging@${sha}`
}
} catch (_) { /* noop */ }

return `${ref}@${sha}`
} catch (_) {
return `no-git-dirty@${new Date().getTime().toString()}`
}
}

/**
* Inject the dist/index.js and dist/index.css into the dist/index.html file
*
* @param {esbuild.Metafile} metafile
*/
const injectAssets = (metafile) => {
const htmlFilePath = path.resolve('dist/index.html')

// Extract the output file names from the metafile
const outputs = metafile.outputs
const scriptFile = Object.keys(outputs).find(file => file.endsWith('.js') && file.includes('ipfs-sw-index'))
const cssFile = Object.keys(outputs).find(file => file.endsWith('.css') && file.includes('ipfs-sw-index'))

const scriptTag = `<script type="module" src="${path.basename(scriptFile)}"></script>`
const linkTag = `<link rel="stylesheet" href="${path.basename(cssFile)}">`

// Read the index.html file
let htmlContent = fs.readFileSync(htmlFilePath, 'utf8')

// Inject the link tag for CSS before the closing </head> tag
htmlContent = htmlContent.replace('</head>', `${linkTag}</head>`)

// Inject the script tag for JS before the closing </body> tag
htmlContent = htmlContent.replace('</body>', `${scriptTag}</body>`)

// Inject the git revision into the index
htmlContent = htmlContent.replace(/<%= GIT_VERSION %>/g, gitRevision())

// Write the modified HTML back to the index.html file
fs.writeFileSync(htmlFilePath, htmlContent)
console.log(`Injected ${path.basename(scriptFile)} and ${path.basename(cssFile)} into index.html.`)
}

/**
* We need the service worker to have a consistent name
*
* @type {esbuild.Plugin}
*/
const renameSwPlugin = {
name: 'rename-sw-plugin',
setup (build) {
build.onEnd(() => {
const outdir = path.resolve('dist')
const files = fs.readdirSync(outdir)

files.forEach(file => {
if (file.startsWith('ipfs-sw-sw-')) {
// everything after the dot
const extension = file.slice(file.indexOf('.'))
const oldPath = path.join(outdir, file)
const newPath = path.join(outdir, `ipfs-sw-sw${extension}`)
fs.renameSync(oldPath, newPath)
console.log(`Renamed ${file} to ipfs-sw-sw${extension}`)
if (extension === '.js') {
// Replace sourceMappingURL with new path
const contents = fs.readFileSync(newPath, 'utf8')
const newContents = contents.replace(/sourceMappingURL=.*\.js\.map/, 'sourceMappingURL=ipfs-sw-sw.js.map')
fs.writeFileSync(newPath, newContents)
}
}
})
})
}
}

/**
* @type {esbuild.Plugin}
*/
const modifyBuiltFiles = {
name: 'modify-built-files',
setup (build) {
build.onEnd(async (result) => {
copyPublicFiles()
injectAssets(result.metafile)
})
}
}

/**
* @param {string[]} extensions - The extension of the imported files to exclude. Must match the fill ending path in the import(js) or url(css) statement.
* @returns {esbuild.Plugin}
*/
const excludeFilesPlugin = (extensions) => ({
name: 'exclude-files',
setup (build) {
build.onResolve({ filter: /.*/ }, async (args) => {
if (extensions.some(ext => args.path.endsWith(ext))) {
return { path: args.path, namespace: 'exclude', external: true }
}
})
}
})

/**
* @type {esbuild.BuildOptions}
*/
export const buildOptions = {
entryPoints: ['src/index.tsx', 'src/sw.ts'],
bundle: true,
outdir: 'dist',
loader: {
'.js': 'jsx',
'.css': 'css',
'.svg': 'file'
},
minify: true,
sourcemap: true,
metafile: true,
splitting: false,
target: ['es2020'],
format: 'esm',
entryNames: 'ipfs-sw-[name]-[hash]',
assetNames: 'ipfs-sw-[name]-[hash]',
plugins: [renameSwPlugin, modifyBuiltFiles, excludeFilesPlugin(['.eot?#iefix', '.otf', '.woff', '.woff2'])]
}

const ctx = await esbuild.context(buildOptions)

const buildAndWatch = async () => {
try {
await ctx.watch()

process.on('exit', async () => {
await ctx.dispose()
})

console.log('Watching for changes...')
await ctx.rebuild()
console.log('Initial build completed successfully.')
} catch (error) {
console.error('Build failed:', error)
process.exit(1)
}
}

const watchRequested = process.argv.includes('--watch')
const serveRequested = process.argv.includes('--serve')

if (!watchRequested && !serveRequested) {
try {
await ctx.rebuild()
console.log('Build completed successfully.')
} catch (error) {
console.error('Build failed:', error)
process.exit(1)
}
await ctx.dispose()
}

if (watchRequested) {
await buildAndWatch()
}

if (serveRequested) {
const { port } = await ctx.serve({
servedir: 'dist',
port: 8345,
host: 'localhost'
})
console.info(`Listening on http://localhost:${port}`)
}
Loading

0 comments on commit 74f33a3

Please sign in to comment.