mirror of
https://github.com/fazo96/ipfs-boards
synced 2025-01-10 12:24:20 +01:00
limited mode support wip
This commit is contained in:
parent
d53ce31b51
commit
e58349f14f
@ -10,6 +10,7 @@ Needs to be browserified to work in the browser
|
||||
var EventEmitter = require('wolfy87-eventemitter')
|
||||
var asyncjs = require('async')
|
||||
var semver = require('semver')
|
||||
var wreck = require('wreck')
|
||||
|
||||
function asObj (str, done) {
|
||||
if (str.toString) str = str.toString()
|
||||
@ -257,6 +258,31 @@ BoardsAPI.prototype.deleteComment = function (hash, parent, done) {
|
||||
this.delete({ what: 'comment', hash, parent }, done)
|
||||
}
|
||||
|
||||
BoardsAPI.prototype.cat = function (path, done) {
|
||||
if (this.limited) {
|
||||
// Download via gateway
|
||||
if (path.indexOf('/ipfs/') !== 0) path = '/ipfs/' + path
|
||||
wreck.get(path, (err, res, payload) => {
|
||||
console.log('GET:', err, res, payload)
|
||||
if (payload.toString) payload = payload.toString()
|
||||
done(err, payload)
|
||||
})
|
||||
} else {
|
||||
// Download via http api
|
||||
this.ipfs.cat(path, done)
|
||||
}
|
||||
}
|
||||
|
||||
BoardsAPI.prototype.ls = function (path, done) {
|
||||
if (this.limited) {
|
||||
// Download via gateway not yet implemented :(
|
||||
done('this operation is not supported in limited mode')
|
||||
} else {
|
||||
// Download via http api
|
||||
this.ipfs.ls(path, done)
|
||||
}
|
||||
}
|
||||
|
||||
BoardsAPI.prototype.backupCache = function () {
|
||||
if (window && window.localStorage !== undefined) {
|
||||
// Use localStorage to store the IPNS cache
|
||||
@ -700,6 +726,15 @@ BoardsAPI.prototype.getUserCommentList = function (parent, user, done) {
|
||||
return this.ee
|
||||
}
|
||||
|
||||
BoardsAPI.prototype.isRunningFromGateway = function () {
|
||||
if (!window) return false
|
||||
return window.location.pathname.indexOf('/ipfs/') === 0
|
||||
}
|
||||
|
||||
BoardsAPI.prototype.isNode = function () {
|
||||
return process && process.env
|
||||
}
|
||||
|
||||
// API for publishing content and managing to be done later...
|
||||
|
||||
// Initialize API
|
||||
@ -708,9 +743,15 @@ BoardsAPI.prototype.init = function (done) {
|
||||
this.ipfs.id((err, res) => {
|
||||
if (err) {
|
||||
console.log('Error while getting OWN ID:', err)
|
||||
if (this.isRunningFromGateway()) {
|
||||
console.log('Running in limited mode')
|
||||
this.limited = true
|
||||
} else console.log('Limited mode not available')
|
||||
this.ee.emit('error', err)
|
||||
this.ee.emit('init', err)
|
||||
if (done && done.apply) done(err)
|
||||
this.ee.emit('init', err, this.limited)
|
||||
if (done && done.apply) {
|
||||
done(err, this.limited)
|
||||
}
|
||||
} else if (res.ID) {
|
||||
console.log('I am', res.ID)
|
||||
this.id = res.ID
|
||||
|
@ -38,6 +38,7 @@
|
||||
"html-webpack-plugin": "~1.7.0",
|
||||
"https-browserify": "0.0.1",
|
||||
"ipfs-api": "github:ipfs/js-ipfs-api#ba85b3b",
|
||||
"glob-stream": "5.2.0",
|
||||
"json-loader": "~0.5.4",
|
||||
"lodash.sortedindex": "~3.1.1",
|
||||
"markdown-loader": "^0.1.7",
|
||||
|
@ -28,6 +28,7 @@ var CommentPage = require('commentpage.jsx')(boards)
|
||||
var ProfileEditor = require('profile-editor.jsx')(boards)
|
||||
var BoardEditor = require('board-editor.jsx')(boards)
|
||||
var PostEditor = require('post-editor.jsx')(boards)
|
||||
var Status = require('status.jsx')(boards)
|
||||
|
||||
// Define Main Components
|
||||
|
||||
@ -103,6 +104,7 @@ ReactDOM.render(
|
||||
<Route path="board/:boardname" component={Board} />
|
||||
<Route path="users" component={Users} />
|
||||
<Route path="settings" component={Settings} />
|
||||
<Route path="status" component={Status} />
|
||||
<Route path="*" component={NotFound} />
|
||||
</Route>
|
||||
</Router>, document.getElementById('root')
|
||||
|
@ -29,7 +29,7 @@ module.exports = function (boardsAPI) {
|
||||
} else if (this.state.loading) {
|
||||
return <Icon name="refresh" className="fa-2x fa-spin light"/>
|
||||
} else {
|
||||
return <Link className="nounderline" to="/users"><Icon name="ban" className="fa-2x light"/></Link>
|
||||
return <Link className="nounderline" to="/status"><Icon name="ban" className="fa-2x light"/></Link>
|
||||
}
|
||||
},
|
||||
render: function () {
|
||||
|
@ -3,62 +3,69 @@ var Link = require('react-router').Link
|
||||
var Icon = require('icon.jsx')
|
||||
|
||||
module.exports = React.createClass({
|
||||
getInitialState: function () {
|
||||
getInitialState () {
|
||||
return {}
|
||||
},
|
||||
componentWillReceiveProps: function (props) {
|
||||
if (props.api) {
|
||||
this.checkStatus(props.api)
|
||||
}
|
||||
},
|
||||
componentDidMount: function () {
|
||||
this.checkStatus(this.props.api)
|
||||
},
|
||||
checkStatus: function (boards) {
|
||||
if (boards) {
|
||||
if (!this.isMounted()) return
|
||||
if (boards.isInit) {
|
||||
this.setState({ connected: true })
|
||||
} else {
|
||||
if (boards.init_error) {
|
||||
this.setState({ error: boards.init_error })
|
||||
} else {
|
||||
boards.getEventEmitter().on('init', error => {
|
||||
if (!this.isMounted()) return
|
||||
if (error) {
|
||||
this.setState({ error })
|
||||
} else {
|
||||
this.setState({ connected: true })
|
||||
clearTimeout(this.timer)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
} else this.startTimer()
|
||||
},
|
||||
componentWillUnmount: function () {
|
||||
componentWillUnmount () {
|
||||
if (this.timer) clearTimeout(this.timer)
|
||||
},
|
||||
startTimer: function () {
|
||||
componentWillReceiveProps (props) {
|
||||
this.init(props)
|
||||
},
|
||||
componentDidMount () {
|
||||
this.init(this.props)
|
||||
},
|
||||
init (props) {
|
||||
var boards = props.api
|
||||
if (this.timer) clearTimeout(this.timer)
|
||||
if (boards) {
|
||||
boards.getEventEmitter().on('init', (err, limited) => {
|
||||
if (!this.isMounted()) return
|
||||
if (err) {
|
||||
this.setState({ error: true, limited })
|
||||
} else {
|
||||
this.setState({ connected: true })
|
||||
}
|
||||
})
|
||||
if (boards.isInit) {
|
||||
this.setState({ connected: true })
|
||||
} else if (boards.limited) {
|
||||
this.setState({ error: true, limited: true })
|
||||
} else this.startTimer()
|
||||
} else this.startTimer()
|
||||
},
|
||||
startTimer () {
|
||||
console.log('start timer')
|
||||
this.timer = setTimeout(_ => {
|
||||
if (this.isMounted()) {
|
||||
console.log('Connection to go-ipfs has timed out (probably due to CORS)')
|
||||
console.log('Connection to go-ipfs has timed out (probably due to CORS)')
|
||||
if (this.isMounted() && !this.state.connected && !this.state.limited) {
|
||||
this.setState({ long: true })
|
||||
this.checkStatus()
|
||||
this.init(this.props)
|
||||
}
|
||||
}, 5000)
|
||||
},
|
||||
render: function () {
|
||||
getContent () {
|
||||
if (this.state.limited) {
|
||||
return <div>
|
||||
<h1><Icon name="ban"/> You're running in limited mode</h1>
|
||||
<h4 className="light">Sorry, but at the moment an external application is needed to fully take advantage of the app</h4>
|
||||
<p>Only a few features are available in limited mode.</p>
|
||||
<h5>Why am I running in limited mode?</h5>
|
||||
</div>
|
||||
} else {
|
||||
return <div>
|
||||
<h1><Icon name="ban"/> Connection to IPFS not available</h1>
|
||||
<h4 className="light">Sorry, but at the moment an external application is needed to try the Prototype</h4>
|
||||
<p><b>Tip:</b> you can also run in limited mode by loading the app from an IPFS Gateway.</p>
|
||||
</div>
|
||||
}
|
||||
},
|
||||
render () {
|
||||
var opt = require('options.jsx').get()
|
||||
if (this.state.error || this.state.long) {
|
||||
return (
|
||||
<div className="">
|
||||
<h1><Icon name="ban"/> Connection to IPFS not available</h1>
|
||||
<h4 className="light">Sorry, but at the moment an external application is needed to try the Prototype</h4>
|
||||
<hr/>
|
||||
<h5>Error Message</h5>
|
||||
<p>{this.state.error || 'connection to go-ipfs failed'}</p>
|
||||
<hr/>
|
||||
<div>
|
||||
{this.getContent()}
|
||||
<p>You don't have an IPFS node running at <code>{opt.addr}:{opt.port}</code> or it is not reachable.
|
||||
The IPFS Boards prototype requires a full IPFS node. Please start one by following the
|
||||
<a href="https://github.com/ipfs/go-ipfs"><code>go-ipfs</code> documentation.</a></p>
|
||||
|
16
webapp/pages/status.jsx
Normal file
16
webapp/pages/status.jsx
Normal file
@ -0,0 +1,16 @@
|
||||
var React = require('react')
|
||||
var GetIPFS = require('getipfs.jsx')
|
||||
|
||||
module.exports = function (boardsAPI) {
|
||||
return React.createClass({
|
||||
getInitialState () {
|
||||
return { }
|
||||
},
|
||||
componentDidMount () {
|
||||
boardsAPI.use(api => this.setState({ api }))
|
||||
},
|
||||
render () {
|
||||
return <GetIPFS api={this.state.api} />
|
||||
}
|
||||
})
|
||||
}
|
Loading…
Reference in New Issue
Block a user