mirror of
https://github.com/status-im/liquid-funding.git
synced 2025-01-25 18:59:48 +00:00
update gateway persist
This commit is contained in:
parent
14f2d5e27a
commit
480f201c1c
@ -73,6 +73,7 @@
|
|||||||
"babel-plugin-named-asset-import": "^0.3.1",
|
"babel-plugin-named-asset-import": "^0.3.1",
|
||||||
"babel-preset-react-app": "^7.0.2",
|
"babel-preset-react-app": "^7.0.2",
|
||||||
"bfj": "6.1.1",
|
"bfj": "6.1.1",
|
||||||
|
"buffer": "^5.2.1",
|
||||||
"case-sensitive-paths-webpack-plugin": "2.2.0",
|
"case-sensitive-paths-webpack-plugin": "2.2.0",
|
||||||
"chai": "^4.1.0",
|
"chai": "^4.1.0",
|
||||||
"chart.js": "^2.7.3",
|
"chart.js": "^2.7.3",
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
/*global Buffer*/
|
|
||||||
import React, { createRef, useState, useContext } from 'react'
|
import React, { createRef, useState, useContext } from 'react'
|
||||||
import { Formik } from 'formik'
|
import { Formik } from 'formik'
|
||||||
import classnames from 'classnames'
|
import classnames from 'classnames'
|
||||||
@ -12,7 +11,7 @@ import Button from '@material-ui/core/Button'
|
|||||||
import InputAdornment from '@material-ui/core/InputAdornment'
|
import InputAdornment from '@material-ui/core/InputAdornment'
|
||||||
import CloudUpload from '@material-ui/icons/CloudUpload'
|
import CloudUpload from '@material-ui/icons/CloudUpload'
|
||||||
import { withStyles } from '@material-ui/core/styles'
|
import { withStyles } from '@material-ui/core/styles'
|
||||||
import { formatForIpfs, uploadToIpfsGateway, formatMedia, isWeb } from '../../utils/ipfs'
|
import { uploadFilesToIpfs, formatMedia, isWeb } from '../../utils/ipfs'
|
||||||
import { FundingContext } from '../../context'
|
import { FundingContext } from '../../context'
|
||||||
import {ZERO_ADDRESS} from '../../utils/address'
|
import {ZERO_ADDRESS} from '../../utils/address'
|
||||||
import CurrencySelect from '../base/CurrencySelect'
|
import CurrencySelect from '../base/CurrencySelect'
|
||||||
@ -154,14 +153,7 @@ const SubmissionSection = ({ classes, history }) => {
|
|||||||
onSubmit={async (values, { resetForm }) => {
|
onSubmit={async (values, { resetForm }) => {
|
||||||
const { title, commitTime } = values
|
const { title, commitTime } = values
|
||||||
const manifest = createJSON(values)
|
const manifest = createJSON(values)
|
||||||
let fileLists = []
|
const contentHash = await uploadFilesToIpfs(uploads, manifest, true)
|
||||||
Object.keys(uploads).forEach(k => {
|
|
||||||
fileLists = [...fileLists, formatForIpfs(uploads[k][0])]
|
|
||||||
})
|
|
||||||
fileLists.push({
|
|
||||||
path: '/root/manifest.json', content: Buffer.from(manifest)
|
|
||||||
})
|
|
||||||
const contentHash = await uploadToIpfsGateway(fileLists)
|
|
||||||
const args = [title, contentHash, account, 0, hoursToSeconds(commitTime), ZERO_ADDRESS]
|
const args = [title, contentHash, account, 0, hoursToSeconds(commitTime), ZERO_ADDRESS]
|
||||||
addProject(...args)
|
addProject(...args)
|
||||||
.estimateGas({ from: account })
|
.estimateGas({ from: account })
|
||||||
@ -178,7 +170,7 @@ const SubmissionSection = ({ classes, history }) => {
|
|||||||
})
|
})
|
||||||
.catch(e => openSnackBar('error', e))
|
.catch(e => openSnackBar('error', e))
|
||||||
})
|
})
|
||||||
console.log({manifest, values, uploads, fileLists, contentHash})
|
console.log({manifest, values, uploads, contentHash})
|
||||||
|
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import IPFS from 'ipfs'
|
import IPFS from 'ipfs'
|
||||||
import ipfsClient from 'ipfs-http-client'
|
import ipfsClient from 'ipfs-http-client'
|
||||||
import fileReaderPullStream from 'pull-file-reader'
|
import fileReaderPullStream from 'pull-file-reader'
|
||||||
|
import { Buffer } from 'buffer'
|
||||||
import { Matcher } from '@areknawo/rex'
|
import { Matcher } from '@areknawo/rex'
|
||||||
import { getImageType } from './images'
|
import { getImageType } from './images'
|
||||||
|
|
||||||
@ -42,6 +43,16 @@ export const formatForIpfs = file => {
|
|||||||
content
|
content
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export const formatForIpfsGateway = file => {
|
||||||
|
const { name, type: _type } = file
|
||||||
|
const content = file
|
||||||
|
return {
|
||||||
|
path: `/root/${name}`,
|
||||||
|
content
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
export const saveToIpfs = (files, cb, imgCb) => {
|
export const saveToIpfs = (files, cb, imgCb) => {
|
||||||
let ipfsId
|
let ipfsId
|
||||||
ipfs.add(files, { progress: (prog) => console.log(`received: ${prog}`) })
|
ipfs.add(files, { progress: (prog) => console.log(`received: ${prog}`) })
|
||||||
@ -55,15 +66,27 @@ export const saveToIpfs = (files, cb, imgCb) => {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export const uploadFilesToIpfs = async (files, manifest, gateway = false) => {
|
||||||
|
let fileLists = []
|
||||||
|
const formatFn = gateway ? formatForIpfsGateway : formatForIpfs
|
||||||
|
const uploadFn = gateway ? uploadToIpfsGateway : uploadToIpfs
|
||||||
|
Object.keys(files).forEach(k => {
|
||||||
|
fileLists = [...fileLists, formatFn(files[k][0])]
|
||||||
|
})
|
||||||
|
fileLists.push({
|
||||||
|
path: '/root/manifest.json', content: Buffer.from(manifest)
|
||||||
|
})
|
||||||
|
const res = await uploadFn(fileLists)
|
||||||
|
return res
|
||||||
|
}
|
||||||
|
|
||||||
export const uploadToIpfs = async files => {
|
export const uploadToIpfs = async files => {
|
||||||
const res = await ipfs.add(files, { progress: (prog) => console.log(`received: ${prog}`) })
|
const res = await ipfs.add(files, { progress: (prog) => console.log(`received: ${prog}`) })
|
||||||
return `ipfs/${res[0].hash}`
|
return `ipfs/${res[0].hash}`
|
||||||
}
|
}
|
||||||
|
|
||||||
export const uploadToIpfsGateway = async files => {
|
export const uploadToIpfsGateway = async files => {
|
||||||
const res = await ipfs.add(files, { progress: (prog) => console.log(`received: ${prog}`) })
|
const res = await ipfsHttp.add(files, { progress: (prog) => console.log(`received: ${prog}`) })
|
||||||
const gatewayUpload = await ipfsHttp.add(files)
|
|
||||||
console.log({gatewayUpload})
|
|
||||||
return `ipfs/${res[0].hash}`
|
return `ipfs/${res[0].hash}`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user