2017-11-23 10:22:54 +02:00
|
|
|
#!/usr/bin/env node
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Script to generate SRI hashes for use in our docs.
|
|
|
|
* Remember to use the same vendor files as the CDN ones,
|
|
|
|
* otherwise the hashes won't match!
|
|
|
|
*
|
2023-01-02 00:30:53 +00:00
|
|
|
* Copyright 2017-2023 The Bootstrap Authors
|
2020-06-16 21:41:47 +03:00
|
|
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
|
2017-11-23 10:22:54 +02:00
|
|
|
*/
|
|
|
|
|
2018-11-28 13:03:28 +02:00
|
|
|
'use strict'
|
|
|
|
|
2022-09-20 08:09:14 +03:00
|
|
|
const crypto = require('node:crypto')
|
|
|
|
const fs = require('node:fs')
|
|
|
|
const path = require('node:path')
|
2017-11-23 10:22:54 +02:00
|
|
|
const sh = require('shelljs')
|
|
|
|
|
|
|
|
sh.config.fatal = true
|
|
|
|
|
2019-01-08 18:33:28 +02:00
|
|
|
const configFile = path.join(__dirname, '../config.yml')
|
2017-11-23 10:22:54 +02:00
|
|
|
|
|
|
|
// Array of objects which holds the files to generate SRI hashes for.
|
|
|
|
// `file` is the path from the root folder
|
2019-01-08 18:33:28 +02:00
|
|
|
// `configPropertyName` is the config.yml variable's name of the file
|
2017-11-23 10:22:54 +02:00
|
|
|
const files = [
|
|
|
|
{
|
|
|
|
file: 'dist/css/bootstrap.min.css',
|
|
|
|
configPropertyName: 'css_hash'
|
|
|
|
},
|
2020-06-08 18:19:14 +03:00
|
|
|
{
|
|
|
|
file: 'dist/css/bootstrap.rtl.min.css',
|
|
|
|
configPropertyName: 'css_rtl_hash'
|
|
|
|
},
|
2017-11-23 10:22:54 +02:00
|
|
|
{
|
|
|
|
file: 'dist/js/bootstrap.min.js',
|
|
|
|
configPropertyName: 'js_hash'
|
|
|
|
},
|
|
|
|
{
|
2018-09-28 18:09:49 +03:00
|
|
|
file: 'dist/js/bootstrap.bundle.min.js',
|
|
|
|
configPropertyName: 'js_bundle_hash'
|
2018-09-28 17:45:05 +03:00
|
|
|
},
|
|
|
|
{
|
2020-06-19 11:17:01 +03:00
|
|
|
file: 'node_modules/@popperjs/core/dist/umd/popper.min.js',
|
2018-09-28 17:45:05 +03:00
|
|
|
configPropertyName: 'popper_hash'
|
2017-11-23 10:22:54 +02:00
|
|
|
}
|
|
|
|
]
|
|
|
|
|
2023-04-09 20:13:08 +03:00
|
|
|
for (const { file, configPropertyName } of files) {
|
|
|
|
fs.readFile(file, 'utf8', (error, data) => {
|
2021-10-29 10:38:35 +03:00
|
|
|
if (error) {
|
|
|
|
throw error
|
2017-11-23 10:22:54 +02:00
|
|
|
}
|
|
|
|
|
2018-10-13 16:40:38 +03:00
|
|
|
const algo = 'sha384'
|
|
|
|
const hash = crypto.createHash(algo).update(data, 'utf8').digest('base64')
|
|
|
|
const integrity = `${algo}-${hash}`
|
2017-11-23 10:22:54 +02:00
|
|
|
|
2023-04-09 20:13:08 +03:00
|
|
|
console.log(`${configPropertyName}: ${integrity}`)
|
2017-11-23 10:22:54 +02:00
|
|
|
|
2023-04-09 20:13:08 +03:00
|
|
|
sh.sed('-i', new RegExp(`^(\\s+${configPropertyName}:\\s+["'])\\S*(["'])`), `$1${integrity}$2`, configFile)
|
2017-11-23 10:22:54 +02:00
|
|
|
})
|
2021-07-30 09:28:51 +03:00
|
|
|
}
|