1
0
mirror of https://github.com/oceanprotocol/commons.git synced 2023-03-15 18:03:00 +01:00

Merge pull request #41 from oceanprotocol/feature/oep-8-files

update file metadata structure
This commit is contained in:
Matthias Kretschmann 2019-04-01 12:39:13 +02:00 committed by GitHub
commit 7b8a49c6e9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 57 additions and 17 deletions

View File

@ -8,14 +8,10 @@ const AssetModel = {
name: null, name: null,
description: null, description: null,
dateCreated: null, dateCreated: null,
size: null,
author: null, author: null,
type: '', type: '',
license: null, license: null,
copyrightHolder: null, copyrightHolder: null,
encoding: null,
compression: null,
contentType: null,
workExample: null, workExample: null,
files: [], files: [],
categories: [], categories: [],

View File

@ -1,6 +1,5 @@
import React, { Component } from 'react' import React, { Component } from 'react'
import { Logger } from '@oceanprotocol/squid' import { Logger } from '@oceanprotocol/squid'
import queryString from 'query-string'
import Route from '../../components/templates/Route' import Route from '../../components/templates/Route'
import Spinner from '../../components/atoms/Spinner' import Spinner from '../../components/atoms/Spinner'
import { User } from '../../context/User' import { User } from '../../context/User'
@ -37,8 +36,14 @@ export default class Details extends Component<DetailsProps, DetailsState> {
accessService.serviceDefinitionId, accessService.serviceDefinitionId,
account[0] account[0]
) )
const folder = "" const folder = ''
const path = await this.context.ocean.assets.consume(agreementId, ddo.id, accessService.serviceDefinitionId, account[0], folder) const path = await this.context.ocean.assets.consume(
agreementId,
ddo.id,
accessService.serviceDefinitionId,
account[0],
folder
)
Logger.log('path', path) Logger.log('path', path)
} catch (e) { } catch (e) {
Logger.log('error', e) Logger.log('error', e)

View File

@ -8,10 +8,15 @@ const Item = ({ item, removeItem }: { item: any; removeItem: any }) => (
<div className={styles.details}> <div className={styles.details}>
<span>url: {item.found ? 'confirmed' : 'unconfirmed'}</span> <span>url: {item.found ? 'confirmed' : 'unconfirmed'}</span>
<span> <span>
size: {item.found && item.contentLength
{item.found && item.size ? filesize(item.size) : 'unknown'} ? filesize(item.contentLength)
: 'unknown size'}
</span>
<span>
{item.found && item.contentType
? item.contentType
: 'unknown type'}
</span> </span>
<span>type: {item.found && item.type ? item.type : 'unknown'}</span>
</div> </div>
<button <button
type="button" type="button"

View File

@ -8,8 +8,19 @@ import styles from './index.module.scss'
import { serviceHost, servicePort, serviceScheme } from '../../../config' import { serviceHost, servicePort, serviceScheme } from '../../../config'
interface File {
url: string
checksum?: string
checksumType?: string
contentLength?: string
contentType?: string
resourceId?: string
encoding?: string
compression?: string
}
interface FilesProps { interface FilesProps {
files: any[] files: File[]
placeholder: string placeholder: string
help?: string help?: string
name: string name: string
@ -20,6 +31,32 @@ interface FilesStates {
isFormShown: boolean isFormShown: boolean
} }
const getFileCompression = async (contentType: string) => {
// TODO: add all the possible archive & compression MIME types
if (
contentType === 'application/zip' ||
contentType === 'application/gzip' ||
contentType === 'application/x-lzma' ||
contentType === 'application/x-xz' ||
contentType === 'application/x-tar' ||
contentType === 'application/x-gtar' ||
contentType === 'application/x-bzip2' ||
contentType === 'application/x-7z-compressed' ||
contentType === 'application/x-rar-compressed' ||
contentType === 'application/x-apple-diskimage'
) {
const contentTypeSplit = contentType.split('/')
if (contentTypeSplit[1].includes('x-')) {
return contentTypeSplit[1].replace('x-', '')
}
return contentTypeSplit[1]
} else {
return 'none'
}
}
export default class Files extends PureComponent<FilesProps, FilesStates> { export default class Files extends PureComponent<FilesProps, FilesStates> {
public state: FilesStates = { public state: FilesStates = {
isFormShown: false isFormShown: false
@ -46,8 +83,9 @@ export default class Files extends PureComponent<FilesProps, FilesStates> {
} }
) )
res = await response.json() res = await response.json()
file.size = res.result.contentLength file.contentLength = res.result.contentLength
file.type = res.result.contentType file.contentType = res.result.contentType
file.compression = await getFileCompression(file.contentType)
file.found = res.result.found file.found = res.result.found
} catch (error) { } catch (error) {
// error // error

View File

@ -258,10 +258,6 @@ class Publish extends Component<{}, PublishState> {
price: this.state.price, price: this.state.price,
type: this.state.type, type: this.state.type,
categories: [this.state.categories], categories: [this.state.categories],
size: '',
encoding: '',
compression: undefined,
contentType: '',
workExample: undefined, workExample: undefined,
inLanguage: undefined, inLanguage: undefined,
tags: '' tags: ''