Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore(*): Use new createContentDigest helper #8992

Merged
merged 70 commits into from
Apr 23, 2019
Merged
Show file tree
Hide file tree
Changes from 19 commits
Commits
Show all changes
70 commits
Select commit Hold shift + click to select a range
353b60d
add createContentDigest helper for gatsby-transformer-remark
samscha Oct 10, 2018
9c0e187
add createContentDigest helper for gatsby-source-filesystem
samscha Oct 10, 2018
d3b3931
Added createContentDigest in test
samscha Oct 10, 2018
4c13027
Added missing createContentDigest param
samscha Oct 10, 2018
3bfd43a
update createContentDigest helper tests for gatsby-transformer-remark
samscha Oct 15, 2018
46e277a
update createContentDigest helper tests for gatsby-source-filesystem
samscha Oct 15, 2018
d8e9689
update createContentDigest helper tests for gatsby-transformer-csv
samscha Oct 15, 2018
096f1c8
add createContentDigest helper for internal-plugins/internal-data-bridge
samscha Oct 15, 2018
9d28bec
add createContentDigest helper for gatsby-source-hacker-news
samscha Oct 15, 2018
f379bb6
add createContentDigest helper for gatsby-transformer-excel
samscha Oct 15, 2018
2320a48
add createContentDigest helper for gatsby-source-mongodb
samscha Oct 17, 2018
0a1e9c2
add createContentDigest helper for gatsby-source-lever
samscha Oct 17, 2018
a5e2cd4
add createContentDigest helper for internal-plugins/query-runner
samscha Oct 17, 2018
917b140
Updated gatsby dep
samscha Oct 17, 2018
e936637
add createContentDigest helper for gatsby-source-contentful
samscha Oct 17, 2018
524ca7b
add createContentDigest helper for gatsby-transformer-hjson
samscha Oct 17, 2018
9db133e
add createContentDigest helper for gatsby-transformer-sqip
samscha Oct 17, 2018
90e40f7
add createContentDigest helper for gatsby-source-npm-package-search
samscha Oct 17, 2018
66674f1
add createContentDigest helper for gatsby-transformer-toml
samscha Oct 17, 2018
002c8c3
update createContentDigest helper for gatsby-source-mongodb
samscha Oct 18, 2018
4b79ae9
update createContentDigest helper for gatsby-source-lever
samscha Oct 18, 2018
aa9c1ff
update createContentDigest helper for internal-plugins/query-runner
samscha Oct 18, 2018
4a9c152
update createContentDigest helper for gatsby-source-npm-package-search
samscha Oct 18, 2018
58ecb37
update createContentDigest helper for gatsby-source-contentful*
samscha Oct 18, 2018
cdb0a8a
update createContentDigest helper for gatsby-transformer-sqip*
samscha Oct 18, 2018
c0f681c
update createContentDigest helper for gatsby-transformer-sqip
samscha Oct 18, 2018
a493701
Merge branch 'master' into topics/createContentDigest-plugins
m-allanson Dec 14, 2018
ab255b1
Merge remote-tracking branch 'origin/master' into topics/createConten…
pieh Dec 31, 2018
26fa18a
use caret version selector
pieh Dec 31, 2018
10d995a
no need to import it - it's passed to `sourceNodes`
pieh Dec 31, 2018
2af8461
merge master into createContestDigest-plugins
samscha Mar 2, 2019
595e5ce
merge again
samscha Mar 2, 2019
93ee035
update to pass tests
samscha Mar 2, 2019
625e16f
Merge branch 'master' of https://github.com/samscha/gatsby into topic…
samscha Mar 7, 2019
6fd3850
update hash to use createContentDigest
samscha Mar 7, 2019
ce82633
Merge branch 'master' of https://github.com/samscha/gatsby into topic…
samscha Mar 8, 2019
4360e58
move createContentDigest to import
samscha Mar 8, 2019
f5a5583
move createContentDigest to import for gatsby-source-contentful
samscha Mar 8, 2019
942a174
remove createContentDigest import in gatsby-source-filesystem test
samscha Mar 8, 2019
58a5ef1
rereplace createContentDigest with crypto in gatsby-source-filesystem
samscha Mar 8, 2019
42f7d4e
revert createContentDigest to crypto for create-file-node in gatsby-s…
samscha Mar 8, 2019
2320c79
revert createContentDigest for gatsby-plugin-sharp
samscha Mar 8, 2019
9153109
update crypto misspell
samscha Mar 8, 2019
2e7b305
revert gatsby-remark-contentful and gatsby-source-contentful
samscha Mar 8, 2019
bd9e193
fix old code
samscha Mar 8, 2019
e7e2625
fix old code v2
samscha Mar 8, 2019
0752777
update gatsby pkg
samscha Mar 8, 2019
c3d6853
revert gatsby-transformer-remark
samscha Mar 8, 2019
d54c261
add export for gatsby utils
samscha Mar 8, 2019
e90f381
update gatsby-source-filesystem
samscha Mar 9, 2019
1fe7b89
revert gatsby-source-graphql
samscha Mar 9, 2019
84558cd
revert gatsby-source-graphql
samscha Mar 9, 2019
335c0c6
revert gatsby-source-hacker-news
samscha Mar 9, 2019
9f709e0
revert gatsby-source-lever
samscha Mar 9, 2019
c2b4c1a
revert gatsby-source-medium
samscha Mar 9, 2019
5537c77
revert gatsby-source-mongodb
samscha Mar 9, 2019
da57567
revert gatsby-source-mongodb mapping
samscha Mar 9, 2019
74222a5
revert gatsby-source-npm-package-search
samscha Mar 9, 2019
41b2deb
revert gatsby-source-wikipedia
samscha Mar 9, 2019
c105a3f
revert gatsby-source-wordpress
samscha Mar 9, 2019
90b54c5
revert gatsby-transformer-csv
samscha Mar 9, 2019
cf92d0e
revert gatsby-transformer-documentationjs
samscha Mar 9, 2019
18c86b1
revert gatsby-transformer-excel
samscha Mar 9, 2019
da90859
revert gatsby-transformer-hjson
samscha Mar 9, 2019
e005647
revert other packages
samscha Mar 9, 2019
2e5846c
revert some pkgs
samscha Mar 10, 2019
66136a0
add gatsby
samscha Mar 10, 2019
5a313e4
Merge branch 'master' of https://github.com/samscha/gatsby into topic…
samscha Mar 10, 2019
5e908e6
Merge remote-tracking branch 'upstream/master' into pr/8992
wardpeet Apr 23, 2019
fd1217d
move gatsby to peerdeps
wardpeet Apr 23, 2019
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion packages/gatsby-source-contentful/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@
],
"license": "MIT",
"peerDependencies": {
"gatsby": ">2.0.0-alpha"
"gatsby": ">2.0.15"
},
"repository": "https://github.com/gatsbyjs/gatsby/tree/master/packages/gatsby-source-contentful",
"scripts": {
Expand Down
8 changes: 3 additions & 5 deletions packages/gatsby-source-contentful/src/cache-image.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
const crypto = require(`crypto`)
const { resolve, parse } = require(`path`)

const axios = require(`axios`)
const { pathExists, createWriteStream } = require(`fs-extra`)

const createContentDigest = require(`../../gatsby/src/utils/create-content-digest`)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we should pass this from caller and not import directly here

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we should only import it directly for tests

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

thank you for the comment! getting from the caller makes a lot more sense! I fixed all but two of these instances in previous commits.

I'm going to work on removing the import from gatsby-source-contentful and gatsby-transformer-sqip (both use the cache-image code mentioned above)


module.exports = async function cacheImage(store, image, options) {
const program = store.getState().program
const CACHE_DIR = resolve(`${program.directory}/.cache/contentful/assets/`)
Expand Down Expand Up @@ -37,10 +38,7 @@ module.exports = async function cacheImage(store, image, options) {
params.push(`bg=${background}`)
}

const optionsHash = crypto
.createHash(`md5`)
.update(JSON.stringify([url, ...params]))
.digest(`hex`)
const optionsHash = createContentDigest([url, ...params])

const { name, ext } = parse(fileName)
const absolutePath = resolve(CACHE_DIR, `${name}-${optionsHash}${ext}`)
Expand Down
9 changes: 3 additions & 6 deletions packages/gatsby-source-contentful/src/normalize.js
Original file line number Diff line number Diff line change
@@ -1,13 +1,10 @@
const _ = require(`lodash`)
const crypto = require(`crypto`)
const stringify = require(`json-stringify-safe`)
const deepMap = require(`deep-map`)

const digest = str =>
crypto
.createHash(`md5`)
.update(str)
.digest(`hex`)
const createContentDigest = require(`../../gatsby/src/utils/create-content-digest`)

const digest = str => createContentDigest(str)
const typePrefix = `Contentful`
const makeTypeName = type => _.upperFirst(_.camelCase(`${typePrefix} ${type}`))

Expand Down
2 changes: 1 addition & 1 deletion packages/gatsby-source-filesystem/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@
],
"license": "MIT",
"peerDependencies": {
"gatsby": ">2.0.0-alpha"
"gatsby": ">2.0.15"
},
"repository": "https://github.com/gatsbyjs/gatsby/tree/master/packages/gatsby-source-filesystem",
"scripts": {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
const path = require(`path`)

const { createFileNode } = require(`../create-file-node`)
const createContentDigest = require(`../../../gatsby/src/utils/create-content-digest`)

// FIXME: This test needs to not use snapshots because of file differences
// and locations across users and CI systems
Expand All @@ -11,6 +12,7 @@ describe(`create-file-node`, () => {
return createFileNode(
path.resolve(`${__dirname}/fixtures/file.json`),
createNodeId,
createContentDigest,
{}
)
})
Expand Down
12 changes: 5 additions & 7 deletions packages/gatsby-source-filesystem/src/create-file-node.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,11 @@ const mime = require(`mime`)
const prettyBytes = require(`pretty-bytes`)

const md5File = require(`bluebird`).promisify(require(`md5-file`))
const crypto = require(`crypto`)

exports.createFileNode = async (
pathToFile,
createNodeId,
createContentDigest,
pluginOptions = {}
) => {
const slashed = slash(pathToFile)
Expand All @@ -27,12 +27,10 @@ exports.createFileNode = async (
const stats = await fs.stat(slashedFile.absolutePath)
let internal
if (stats.isDirectory()) {
const contentDigest = crypto
.createHash(`md5`)
.update(
JSON.stringify({ stats: stats, absolutePath: slashedFile.absolutePath })
)
.digest(`hex`)
const contentDigest = createContentDigest({
stats: stats,
absolutePath: slashedFile.absolutePath,
})
internal = {
contentDigest,
type: `Directory`,
Expand Down
25 changes: 8 additions & 17 deletions packages/gatsby-source-filesystem/src/create-remote-file-node.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
const fs = require(`fs-extra`)
const got = require(`got`)
const crypto = require(`crypto`)
const path = require(`path`)
const { isWebUri } = require(`valid-url`)
const Queue = require(`better-queue`)
Expand Down Expand Up @@ -46,20 +45,6 @@ const cacheId = url => `create-remote-file-node-${url}`
* utils *
*********/

/**
* createHash
* --
*
* Create an md5 hash of the given str
* @param {Stringq} str
* @return {String}
*/
const createHash = str =>
crypto
.createHash(`md5`)
.update(str)
.digest(`hex`)

const CACHE_DIR = `.cache`
const FS_PLUGIN_DIR = `gatsby-source-filesystem`

Expand Down Expand Up @@ -172,6 +157,7 @@ async function processRemoteNode({
store,
cache,
createNode,
createContentDigest,
auth = {},
createNodeId,
}) {
Expand All @@ -195,7 +181,7 @@ async function processRemoteNode({
}

// Create the temp and permanent file names for the url.
const digest = createHash(url)
const digest = createContentDigest(url)
const ext = getRemoteFileExtension(url)

const tmpFilename = createFilePath(programDir, `tmp-${digest}`, ext)
Expand All @@ -221,7 +207,12 @@ async function processRemoteNode({
}

// Create the file node.
const fileNode = await createFileNode(filename, createNodeId, {})
const fileNode = await createFileNode(
filename,
createNodeId,
createContentDigest,
{}
)
fileNode.internal.description = `File "${url}"`
// Override the default plugin as gatsby-source-filesystem needs to
// be the owner of File nodes or there'll be conflicts if any other
Expand Down
11 changes: 10 additions & 1 deletion packages/gatsby-source-filesystem/src/gatsby-node.js
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,15 @@ const createFSMachine = () =>
})

exports.sourceNodes = (
{ actions, getNode, createNodeId, hasNodeChanged, reporter, emitter },
{
actions,
getNode,
createNodeId,
createContentDigest,
hasNodeChanged,
reporter,
emitter,
},
pluginOptions
) => {
const { createNode, deleteNode } = actions
Expand Down Expand Up @@ -103,6 +111,7 @@ See docs here - https://www.gatsbyjs.org/packages/gatsby-source-filesystem/
const fileNodePromise = createFileNode(
path,
createNodeId,
createContentDigest,
pluginOptions
).then(fileNode => {
createNode(fileNode)
Expand Down
2 changes: 1 addition & 1 deletion packages/gatsby-source-hacker-news/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@
],
"license": "MIT",
"peerDependencies": {
"gatsby": ">2.0.0-alpha"
"gatsby": ">2.0.15"
},
"repository": "https://github.com/gatsbyjs/gatsby/tree/master/packages/gatsby-source-hacker-news",
"scripts": {
Expand Down
12 changes: 3 additions & 9 deletions packages/gatsby-source-hacker-news/src/gatsby-node.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
const axios = require(`axios`)
const crypto = require(`crypto`)
const url = require(`url`)
const _ = require(`lodash`)

Expand All @@ -12,6 +11,7 @@ exports.sourceNodes = async ({
actions,
getNode,
createNodeId,
createContentDigest,
hasNodeChanged,
}) => {
const { createNode } = actions
Expand Down Expand Up @@ -117,10 +117,7 @@ fragment commentsFragment on HackerNewsItem {
storyNode.by = storyNode.by.id

// Get content digest of node.
const contentDigest = crypto
.createHash(`md5`)
.update(JSON.stringify(storyNode))
.digest(`hex`)
const contentDigest = createContentDigest(storyNode)

storyNode.internal.contentDigest = contentDigest
createNode(storyNode)
Expand All @@ -147,10 +144,7 @@ fragment commentsFragment on HackerNewsItem {
const nodeStr = JSON.stringify(commentNode)

// Get content digest of comment node.
const contentDigest = crypto
.createHash(`md5`)
.update(nodeStr)
.digest(`hex`)
const contentDigest = createContentDigest(nodeStr)

commentNode.internal.contentDigest = contentDigest
commentNode.internal.content = nodeStr
Expand Down
2 changes: 1 addition & 1 deletion packages/gatsby-source-lever/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@
],
"license": "MIT",
"peerDependencies": {
"gatsby": ">2.0.0-alpha"
"gatsby": ">2.0.15"
},
"repository": "https://github.com/gatsbyjs/gatsby/tree/master/packages/gatsby-source-lever",
"scripts": {
Expand Down
9 changes: 3 additions & 6 deletions packages/gatsby-source-lever/src/normalize.js
Original file line number Diff line number Diff line change
@@ -1,21 +1,18 @@
const crypto = require(`crypto`)
const deepMapKeys = require(`deep-map-keys`)
const stringify = require(`json-stringify-safe`)

const conflictFieldPrefix = `lever_`
// restrictedNodeFields from here https://www.gatsbyjs.org/docs/node-interface/
const restrictedNodeFields = [`id`, `children`, `parent`, `fields`, `internal`]

const createContentDigest = require(`../../gatsby/src/utils/create-content-digest`)

/**
* Encrypts a String using md5 hash of hexadecimal digest.
*
* @param {any} str
*/
const digest = str =>
crypto
.createHash(`md5`)
.update(str)
.digest(`hex`)
const digest = str => createContentDigest(str)

/**
* Create the Graph QL Node
Expand Down
2 changes: 1 addition & 1 deletion packages/gatsby-source-mongodb/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@
"license": "MIT",
"main": "index.js",
"peerDependencies": {
"gatsby": ">2.0.0-alpha"
"gatsby": ">2.0.15"
},
"repository": "https://github.com/gatsbyjs/gatsby/tree/master/packages/gatsby-source-mongodb",
"scripts": {
Expand Down
11 changes: 5 additions & 6 deletions packages/gatsby-source-mongodb/src/gatsby-node.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
const MongoClient = require(`mongodb`).MongoClient
const crypto = require(`crypto`)
const prepareMappingChildNode = require(`./mapping`)
const _ = require(`lodash`)
const queryString = require(`query-string`)

const createContentDigest = require(`../../gatsby/src/utils/create-content-digest`)

exports.sourceNodes = (
{ actions, getNode, createNodeId, hasNodeChanged },
pluginOptions
Expand Down Expand Up @@ -85,10 +86,7 @@ function createNodes(
internal: {
type: `mongodb${caps(dbName)}${caps(collectionName)}`,
content: JSON.stringify(item),
contentDigest: crypto
.createHash(`md5`)
.update(JSON.stringify(item))
.digest(`hex`),
contentDigest: createContentDigest(item),
},
}
const childrenNodes = []
Expand All @@ -109,7 +107,8 @@ function createNodes(
mediaItemFieldKey,
node[mediaItemFieldKey],
mapObj[mediaItemFieldKey],
createNode
createNode,
createContentDigest
)

node[`${mediaItemFieldKey}___NODE`] = mappingChildNode.id
Expand Down
17 changes: 10 additions & 7 deletions packages/gatsby-source-mongodb/src/mapping.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,13 @@
const _ = require(`lodash`),
crypto = require(`crypto`)
const _ = require(`lodash`)

module.exports = function(node, key, text, mediaType, createNode) {
module.exports = function(
node,
key,
text,
mediaType,
createNode,
createContentDigest
) {
const str = _.isString(text) ? text : ` `
const id = `${node.id}${key}MappingNode`
const mappingNode = {
Expand All @@ -13,10 +19,7 @@ module.exports = function(node, key, text, mediaType, createNode) {
type: _.camelCase(`${node.internal.type} ${key} MappingNode`),
mediaType: mediaType,
content: str,
contentDigest: crypto
.createHash(`md5`)
.update(JSON.stringify(str))
.digest(`hex`),
contentDigest: createContentDigest(str),
},
}

Expand Down
2 changes: 1 addition & 1 deletion packages/gatsby-source-npm-package-search/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@
"license": "MIT",
"main": "index.js",
"peerDependencies": {
"gatsby": ">2.0.0-alpha"
"gatsby": ">2.0.15"
},
"scripts": {
"build": "babel src --out-dir . --ignore **/__tests__",
Expand Down
9 changes: 2 additions & 7 deletions packages/gatsby-source-npm-package-search/src/gatsby-node.js
Original file line number Diff line number Diff line change
@@ -1,15 +1,10 @@
const algoliasearch = require(`algoliasearch`)
const crypto = require(`crypto`)

const createContentDigest = require(`../../gatsby/src/utils/create-content-digest`)

const client = algoliasearch(`OFCNCOG2CU`, `6fbcaeafced8913bf0e4d39f0b541957`)
var index = client.initIndex(`npm-search`)

const createContentDigest = obj =>
crypto
.createHash(`md5`)
.update(JSON.stringify(obj))
.digest(`hex`)

function browse({ index, ...params }) {
let hits = []
const browser = index.browseAll(params)
Expand Down
Loading