Skip to content
Snippets Groups Projects
Select Git revision
  • f16a389df88a388a20533b55531b6ce6c9d0b34f
  • master default protected
  • devel
  • hruska-feature-clients-api
  • malostik-#5066-deduplicate-idea-ids
  • warden-postgresql-port
  • hruska-feature-#6799-filter-keys
  • hruska-feature-5066-duplicateIdeaID
  • warden-client-3.0-beta3
  • warden-server-3.0-beta3
  • warden-client-2.2-final
  • warden-server-2.2-final
  • warden-client-3.0-beta2
  • warden-server-3.0-beta2
  • warden-client-2.2
  • warden-server-2.2-patch3
  • warden-client-3.0-beta1
  • warden-server-3.0-beta1
  • warden-server-2.2-patch1
  • warden-client-3.0-beta0
  • warden-server-3.0-beta0
  • warden-server-2.2
  • warden-server-2.1-patch1
  • warden-client-2.1
  • warden-server-2.1
  • warden-server-2.1-beta6
  • warden-server-2.1-beta5
  • warden-server-2.1-beta4
28 results

warden_server.py

Blame
  • index.ts 1.47 KiB
    /**
     * Copyright (c) 2018 mol* contributors, licensed under MIT, See LICENSE file for more info.
     *
     * @author Alexander Rose <alexander.rose@weirdbyte.de>
     */
    
    import CIF from 'mol-io/reader/cif'
    import { Run, Progress } from 'mol-task'
    import { Model } from 'mol-model/structure'
    
    export function log(progress: Progress) {
        const p = progress.root.progress
        console.log(`${p.message} ${(p.current/p.max*100).toFixed(2)}%`)
    }
    
    export async function parseCif(data: string|Uint8Array) {
        const comp = CIF.parse(data)
        const parsed = await Run(comp, log, 100);
        if (parsed.isError) throw parsed;
        return parsed
    }
    
    export async function getModelFromPdbId(pdbid: string) {
        const data = await fetch(`https://files.rcsb.org/download/${pdbid}.cif`)
        const parsed = await parseCif(await data.text())
        return Model.create({ kind: 'mmCIF', data: CIF.schema.mmCIF(parsed.result.blocks[0]) })
    }
    
    const readFileAsText = (file: File) => {
        const fileReader = new FileReader()
        return new Promise<string>((resolve, reject) => {
            fileReader.onerror = () => {
                fileReader.abort()
                reject(new DOMException('Error parsing input file.'))
            }
            fileReader.onload = () => resolve(fileReader.result)
            fileReader.readAsText(file)
        })
    }
    
    export async function getModelFromFile(file: File) {
        const parsed = await parseCif(await readFileAsText(file))
        return Model.create({ kind: 'mmCIF', data: CIF.schema.mmCIF(parsed.result.blocks[0]) })
    }