2016-04-10 5 views
3

現在、私はファイルをアップロードするたびに、サーバーの展開を行っていますが、S330の代わりにGridStoreファイルアダプタを格納しています。私のアプリJSは次のようになります:Parse S3FileAdapter

// Example express application adding the parse-server module to expose Parse 
// compatible API routes. 

var express = require('express'); 
var ParseServer = require('parse-server').ParseServer; 
var path = require('path'); 

var S3Adapter = require('parse-server').S3Adapter; 

var databaseUri = process.env.DATABASE_URI || process.env.MONGOLAB_URI; 

if (!databaseUri) { 
    console.log('DATABASE_URI not specified, falling back to localhost.'); 
} 

var api = new ParseServer({ 
    databaseURI: databaseUri || 'mongodb://localhost:27017/dev', 
    cloud: process.env.CLOUD_CODE_MAIN || __dirname + '/cloud/main.js', 
    appId: process.env.APP_ID || 'somAppId', 
    masterKey: process.env.MASTER_KEY || '', //Add your master key here. Keep it secret! 
    serverURL: process.env.SERVER_URL || 'http://localhost:1337/parse', // Don't forget to change to https if needed 
    liveQuery: { 
    classNames: ["Posts", "Comments"] // List of classes to support for query subscriptions 
    }, 
    filesAdapter: new S3Adapter(
    "S31", 
    "S32", 
    "bucket-name", 
    {directAccess: true} 
) 
}); 
// Client-keys like the javascript key or the .NET key are not necessary with parse-server 
// If you wish you require them, you can set them as options in the initialization above: 
// javascriptKey, restAPIKey, dotNetKey, clientKey 

var app = express(); 

// Serve static assets from the /public folder 
app.use('/public', express.static(path.join(__dirname, '/public'))); 

// Serve the Parse API on the /parse URL prefix 
var mountPath = process.env.PARSE_MOUNT || '/parse'; 
app.use(mountPath, api); 

// Parse Server plays nicely with the rest of your web routes 
app.get('/', function(req, res) { 
    res.status(200).send('Make sure to star the parse-server repo on GitHub!'); 
}); 

// There will be a test page available on the /test path of your server url 
// Remove this before launching your app 
app.get('/test', function(req, res) { 
    res.sendFile(path.join(__dirname, '/public/test.html')); 
}); 

var port = process.env.PORT || 1337; 
var httpServer = require('http').createServer(app); 
httpServer.listen(port, function() { 
    console.log('parse-server-example running on port ' + port + '.'); 
}); 

// This will enable the Live Query real-time server 
ParseServer.createLiveQueryServer(httpServer); 

私は配備した後もエラーは発生しません。すべてが正常に動作しているようです。しかし、ファイルをアップロードすると、S3ストレージの代わりにmonglab DBに移動します。これを設定するには他に何かする必要がありますか?私はこれを設定するための基準としてドキュメントを使用しています:

https://github.com/ParsePlatform/parse-server/wiki/Configuring-File-Adapters

私はまた、解析サーバレポにそれがS3FileAdapter持っていないことに気づいた: https://github.com/ParsePlatform/parse-server/tree/master/src/Adapters/Files

をすべてのヘルプは非常になります感謝!

おかげで、

デビッド

+0

こんにちはDavid、私は同じ正確な問題を抱えています。あなたは解決策を見つけましたか? –

答えて

1

MLAB DBはファイルを格納しません。これは、ファイルのリンクのみを格納します。まずS3にファイルをアップロードする必要があります。成功した場合は、サーバーを解析するとファイル名が返され、その名前がdbに書き込まれます。 curlコマンドを使ってファイルの書き込みをチェックします。それがうまくいくならば、あなたの設定は大丈夫です。 parse-server/lib/Adapters/AdapterLoader.jsに通じてしまったときに

curl -X POST \ 
    -H "X-Parse-Application-Id: YOUR-APP-ID" \ 
    -H "X-Parse-REST-API-Key: YOUR-KEY" \ 
    -H "Content-Type: text/plain" \ 
    -d 'Hello, it is me!' \ 
    http://your-parse-server/parse/files/filename.txt 
0

が、私はこのスクリプトを使用していますし、それはまったく同じ問題に直面して

filesAdapter: new S3Adapter(
    "ACCESS_KEY", 
    "SECRET_KEY", 
    "BUCKET_NAME", 
    "REGION" 
) 
0

細かい作業ですが、私は、設定オプションや機能を持つfilesAdapter許可カスタムモジュールを発見しました。だから私は私のためにうまく動作する以下のソリューションを試してみました。

var S3Adapter = require('parse-server').S3Adapter; 
var api = new ParseServer({ 
... 
filesAdapter:() => { 
    return new S3Adapter("ACCESS_KEY", "SECRET_KEY", "BUCKET_NAME") 
} 
... 
});