mirror of
https://github.com/owncast/owncast.git
synced 2024-10-10 19:16:02 +00:00
![dependabot[bot]](/assets/img/avatar_default.png)
* Commit updated Javascript packages * Bump preact from 10.5.4 to 10.5.5 in /build/javascript (#265) * Trying a new github workflow to install javascript packages * Bump tailwindcss from 1.9.2 to 1.9.4 in /build/javascript (#266) Bumps [tailwindcss](https://github.com/tailwindlabs/tailwindcss) from 1.9.2 to 1.9.4. - [Release notes](https://github.com/tailwindlabs/tailwindcss/releases) - [Changelog](https://github.com/tailwindlabs/tailwindcss/blob/master/CHANGELOG.md) - [Commits](https://github.com/tailwindlabs/tailwindcss/compare/v1.9.2...v1.9.4) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * Commit updated Javascript packages * Bump preact from 10.5.4 to 10.5.5 in /build/javascript Bumps [preact](https://github.com/preactjs/preact) from 10.5.4 to 10.5.5. - [Release notes](https://github.com/preactjs/preact/releases) - [Commits](https://github.com/preactjs/preact/compare/10.5.4...10.5.5) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: Gabe Kangas <gabek@real-ity.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Owncast <owncast@owncast.online> * Bump @justinribeiro/lite-youtube in /build/javascript Bumps [@justinribeiro/lite-youtube](https://github.com/justinribeiro/lite-youtube) from 0.9.0 to 0.9.1. - [Release notes](https://github.com/justinribeiro/lite-youtube/releases) - [Commits](https://github.com/justinribeiro/lite-youtube/commits) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: Owncast <owncast@owncast.online> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Gabe Kangas <gabek@real-ity.com>
64 lines
1.6 KiB
JavaScript
64 lines
1.6 KiB
JavaScript
'use strict'
|
|
|
|
const fs = require('graceful-fs')
|
|
const path = require('path')
|
|
const invalidWin32Path = require('./win32').invalidWin32Path
|
|
|
|
const o777 = parseInt('0777', 8)
|
|
|
|
function mkdirs (p, opts, callback, made) {
|
|
if (typeof opts === 'function') {
|
|
callback = opts
|
|
opts = {}
|
|
} else if (!opts || typeof opts !== 'object') {
|
|
opts = { mode: opts }
|
|
}
|
|
|
|
if (process.platform === 'win32' && invalidWin32Path(p)) {
|
|
const errInval = new Error(p + ' contains invalid WIN32 path characters.')
|
|
errInval.code = 'EINVAL'
|
|
return callback(errInval)
|
|
}
|
|
|
|
let mode = opts.mode
|
|
const xfs = opts.fs || fs
|
|
|
|
if (mode === undefined) {
|
|
mode = o777 & (~process.umask())
|
|
}
|
|
if (!made) made = null
|
|
|
|
callback = callback || function () {}
|
|
p = path.resolve(p)
|
|
|
|
xfs.mkdir(p, mode, er => {
|
|
if (!er) {
|
|
made = made || p
|
|
return callback(null, made)
|
|
}
|
|
switch (er.code) {
|
|
case 'ENOENT':
|
|
if (path.dirname(p) === p) return callback(er)
|
|
mkdirs(path.dirname(p), opts, (er, made) => {
|
|
if (er) callback(er, made)
|
|
else mkdirs(p, opts, callback, made)
|
|
})
|
|
break
|
|
|
|
// In the case of any other error, just see if there's a dir
|
|
// there already. If so, then hooray! If not, then something
|
|
// is borked.
|
|
default:
|
|
xfs.stat(p, (er2, stat) => {
|
|
// if the stat fails, then that's super weird.
|
|
// let the original error be the failure reason.
|
|
if (er2 || !stat.isDirectory()) callback(er, made)
|
|
else callback(null, made)
|
|
})
|
|
break
|
|
}
|
|
})
|
|
}
|
|
|
|
module.exports = mkdirs
|