/* * Copyright (c) 2008-2014 MongoDB, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.mongodb.gridfs; import com.mongodb.DBCursor; import com.mongodb.DBObject; import com.mongodb.Mongo; import com.mongodb.MongoClient; import com.mongodb.util.Util; import java.io.File; import java.security.DigestInputStream; import java.security.MessageDigest; /** * A simple CLI for GridFS. */ public class CLI { private static String host = "127.0.0.1"; private static String db = "test"; private static Mongo mongo = null; private static GridFS gridFS; /** * Dumps usage info to stdout */ // CHECKSTYLE:OFF private static void printUsage() { System.out.println("Usage : [--bucket bucketname] action"); System.out.println(" where action is one of:"); System.out.println(" list : lists all files in the store"); System.out.println(" put filename : puts the file filename into the store"); System.out.println(" get filename1 filename2 : gets filename1 from store and sends to filename2"); System.out.println(" md5 filename : does an md5 hash on a file in the db (for testing)"); } // CHECKSTYLE:ON private static Mongo getMongo() throws Exception { if (mongo == null) { mongo = new MongoClient(host); } return mongo; } @SuppressWarnings("deprecation") // We know GridFS uses the old API. A new API version will be address later. private static GridFS getGridFS() throws Exception { if (gridFS == null) { gridFS = new GridFS(getMongo().getDB(db)); } return gridFS; } // CHECKSTYLE:OFF public static void main(final String[] args) throws Exception { if (args.length < 1) { printUsage(); return; } for (int i = 0; i < args.length; i++) { String s = args[i]; if (s.equals("--db")) { db = args[i + 1]; i++; continue; } if (s.equals("--host")) { host = args[i + 1]; i++; continue; } if (s.equals("help")) { printUsage(); return; } if (s.equals("list")) { GridFS fs = getGridFS(); System.out.printf("%-60s %-10s%n", "Filename", "Length"); DBCursor fileListCursor = fs.getFileList(); try { while (fileListCursor.hasNext()) { DBObject o = fileListCursor.next(); System.out.printf("%-60s %-10d%n", o.get("filename"), ((Number) o.get("length")).longValue()); } } finally { fileListCursor.close(); } return; } if (s.equals("get")) { GridFS fs = getGridFS(); String fn = args[i + 1]; GridFSDBFile f = fs.findOne(fn); if (f == null) { System.err.println("can't find file: " + fn); return; } f.writeTo(f.getFilename()); return; } if (s.equals("put")) { GridFS fs = getGridFS(); String fn = args[i + 1]; GridFSInputFile f = fs.createFile(new File(fn)); f.save(); f.validate(); return; } if (s.equals("md5")) { GridFS fs = getGridFS(); String fn = args[i + 1]; GridFSDBFile f = fs.findOne(fn); if (f == null) { System.err.println("can't find file: " + fn); return; } MessageDigest md5 = MessageDigest.getInstance("MD5"); md5.reset(); int read = 0; DigestInputStream is = new DigestInputStream(f.getInputStream(), md5); try { while (is.read() >= 0) { read++; int r = is.read(new byte[17]); if (r < 0) { break; } read += r; } } finally { is.close(); } byte[] digest = md5.digest(); System.out.println("length: " + read + " md5: " + Util.toHex(digest)); return; } System.err.println("unknown option: " + s); return; } } // CHECKSTYLE:ON }