All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jgroups.tests.GridFilesystemTest Maven / Gradle / Ivy

package org.jgroups.tests;

import org.jgroups.blocks.GridFile;
import org.jgroups.blocks.GridFilesystem;
import org.jgroups.blocks.ReplCache;
import org.jgroups.util.Util;

import java.io.*;
import java.util.HashMap;
import java.util.Map;

/**
 * @author Bela Ban
 * todo: regexp for file ls, rm, down and up
 * todo: recursive up and down
 */
public class GridFilesystemTest {
    static final Map commands=new HashMap<>();
    static String current_dir="/";
    static final String HOME=System.getProperty("user.home");

    static {
        commands.put("mkdir", new mkdir());
        commands.put("ls",    new ls());
        commands.put("cd",    new cd());
        commands.put("pwd",   new pwd());
        commands.put("rm",    new rm());
        commands.put("up",    new up());
        commands.put("down",  new down());
    }

    public static void main(String[] args) throws Exception {
        String props="udp.xml";
        String cluster_name="imfs-cluster";
        String metadata_cluster_name="metadata-cluster";
        short default_repl_count=1;
        int default_chunk_size=4000;
        GridFilesystem fs;

        for(int i=0; i < args.length; i++) {
            if(args[i].equals("-props")) {
                props=args[++i];
                continue;
            }
            if(args[i].equals("-cluster_name")) {
                cluster_name=args[++i];
                continue;
            }
            if(args[i].equals("-metadata_cluster_name")) {
                metadata_cluster_name=args[++i];
                continue;
            }
            if(args[i].equals("-repl_count")) {
                default_repl_count=Short.parseShort(args[++i]);
                continue;
            }
            if(args[i].equals("-chunk_size")) {
                default_chunk_size=Integer.parseInt(args[++i]);
                continue;
            }

            System.out.println("GridFilesystemTest [-props ] [-cluster_name ] " +
                    "[-metadata_cluster_name ] [-repl_count ] [-chunk_size ]");
            return;
        }

        ReplCache data=new ReplCache<>(props, cluster_name);
        ReplCache metadata=new ReplCache<>(props, metadata_cluster_name);
        data.start();
        metadata.start();

        fs=new GridFilesystem(data, metadata, default_repl_count, default_chunk_size);
        loop(fs);

        data.stop();
        metadata.stop();
    }

    private static void loop(GridFilesystem fs) {
        while(true) {
            try {
                System.out.print("> ");
                String line=Util.readLine(System.in);
                if(!execute(fs, line))
                    break;
            }
            catch(Throwable t) {
                t.printStackTrace();
            }
        }
    }

    private static boolean execute(GridFilesystem fs, String line) {
        String[] comps=parseCommandLine(line);
        if(comps == null || comps.length == 0) {
            help();
            return true;
        }
        if(comps[0].equalsIgnoreCase("quit") || comps[0].equalsIgnoreCase("exit"))
            return false;
        if(comps[0].equalsIgnoreCase("help")) {
            help();
            return true;
        }
        Command cmd=commands.get(comps[0]);
        if(cmd == null) {
            System.err.println(comps[0] + " not known");
            help();
            return true;
        }
        String[] args=null;
        if(comps.length > 1) {
            args=new String[comps.length -1];
            System.arraycopy(comps, 1, args, 0, args.length);
        }
        cmd.execute(fs, args);
        return true;
    }

    private static void help() {
        StringBuilder sb=new StringBuilder("Valid commands:\nhelp\nquit\nexit\n");
        for(Command cmd: commands.values()) {
            String help=cmd.help();
            if(help != null)
                sb.append(help).append("\n");
        }
        System.out.println(sb.toString());
    }

    private static String[] parseCommandLine(String line) {
        if(line == null)
            return null;
        return line.trim().split(" ");
    }


    private static interface Command {
        void execute(GridFilesystem fs, String[] args);
        String help();
    }

    private static class ls implements Command {

        public void execute(GridFilesystem fs, String[] args) {
            String options=parseOptions(args);
            boolean recursive=options.contains("R");
            boolean detailed=options.contains("l");
            String[] files=getNonOptions(args);
            if(files == null || files.length == 0)
                files=new String[]{current_dir};
            for(String str: files) {
                if(!str.startsWith(File.separator))
                    str=current_dir + File.separator + str;
                File file=fs.getFile(str);
                if(!file.exists()) {
                    System.err.println("File " + file + " doesn't exist");
                    continue;
                }
                print(file, detailed, recursive, 0, file.isDirectory());
            }
        }

        public String help() {
            return "ls [-lR] [dirs | files]";
        }
    }

    private static class mkdir implements Command {

        public void execute(GridFilesystem fs, String[] args) {
            String options=parseOptions(args);
            boolean recursive=options.contains("p");
            String[] dir_names=getNonOptions(args);
            if(dir_names == null || dir_names.length < 1) {
                System.err.println(help());
                return;
            }
            for(String dir: dir_names) {
                if(!dir.startsWith(File.separator))
                    dir=current_dir + File.separator + dir;
                File file=fs.getFile(dir);
                boolean result;
                if(recursive)
                    result=file.mkdirs();
                else
                    result=file.mkdir();
                if(!result)
                    System.err.println("failed creating " + dir);
            }
        }

        public String help() {
            return "mkdir [-p] dirs";
        }
    }


    private static class rm implements Command {

        public void execute(GridFilesystem fs, String[] args) {
            String options=parseOptions(args);
            boolean recursive=options.contains("r");
            String[] dir_names=getNonOptions(args);
            if(dir_names == null || dir_names.length < 1) {
                System.err.println(help());
                return;
            }
            for(String dir: dir_names) {
                if(!dir.startsWith(File.separator))
                    dir=current_dir.equals(File.separator)? current_dir + dir : current_dir + File.separator + dir;
                File file=fs.getFile(dir);
                if(!file.exists()) {
                    System.err.println(file.getName() + " doesn't exist");
                    return;
                }
                if(file.isFile()) {
                    if(!file.delete())
                        System.err.println("cannot remove " + file.getName());
                    return;
                }

                if(!recursive) {
                    if(!file.delete())
                        System.err.println("cannot remove " + file.getName() + ": is a directory");
                }
                else {
                    if(!delete(file)) { // recursive delete
                        System.err.println("recursive removal of " + file.getName() + " failed");
                    }
                }
            }
        }

        public String help() {
            return "rm [-fr] ";
        }
    }


    private static class cd implements Command {

        public void execute(GridFilesystem fs, String[] args) {
            String[] tmp=getNonOptions(args);
            String target_dir="~";
            if(tmp != null && tmp.length == 1)
                target_dir=tmp[0];

            if(target_dir.equals(".."))
                target_dir=new File(current_dir).getParent();
            if(target_dir.contains("~") && HOME != null)
                target_dir=target_dir.replace("~", HOME);
            if(!target_dir.trim().startsWith(File.separator)) {
                target_dir=current_dir.equals(File.separator)?
                        current_dir + target_dir :
                        current_dir + File.separator + target_dir;
            }
            File dir=fs.getFile(target_dir);
            if(!dir.exists()) {
                System.err.println("Directory " + target_dir + " doesn't exist");
            }
            else
                current_dir=target_dir;
        }

        public String help() {
            return "cd [dir]";
        }
    }

    private static class pwd implements Command {

        public void execute(GridFilesystem fs, String[] args) {
            System.out.println(current_dir);
        }

        public String help() {
            return "pwd";
        }
    }


    private static class up implements Command {

        public void execute(GridFilesystem fs, String[] args) {
            String   options=parseOptions(args);
            String[] real_args=getNonOptions(args);
            boolean  overwrite=options.contains("f");

            if(real_args.length == 0) {
                System.err.println(help());
                return;
            }

            String local_path=real_args[0], grid_path=real_args.length > 1? real_args[1] : null;
            if(HOME != null && local_path.contains("~"))
                local_path=local_path.replace("~", HOME);
            String target_path=grid_path != null? grid_path : local_path;
            if(target_path.contains("~"))
                target_path=target_path.replace("~", HOME);
            if(target_path.equals("."))
                target_path=current_dir;

            File target=fs.getFile(target_path);
            if(!overwrite && target.exists() && target.isFile()) {
                System.err.println("grid file " + target_path + " already exists; use -f to force overwrite");
                return;
            }
            
            if(target.exists() && target.isDirectory()) {
                String[] comps=Util.components(local_path, File.separator);
                String filename=comps[comps.length - 1];
                target_path=target_path + (target_path.equals(File.separator)? filename : File.separator + filename);
            }

            FileInputStream in=null;
            OutputStream out=null;
            try {
                in=new FileInputStream(local_path);
                File out_file=fs.getFile(target_path);
                if(out_file.exists() && out_file.isDirectory()) {
                    System.err.println("target " + target_path + " is a directory");
                    return;
                }
                if(out_file.exists() && out_file.isFile() && overwrite) {
                    if(out_file instanceof GridFile)
                        ((GridFile)out_file).delete(true);
                    else
                        out_file.delete();
                }

                out=fs.getOutput((GridFile)out_file);
                byte[] buf=new byte[50000];
                int len, total=0;
                while((len=in.read(buf, 0, buf.length)) != -1) {
                    out.write(buf, 0, len);
                    total+=len;
                }
                System.out.println("uploaded " + local_path + " to " + target_path + " (" + total + " bytes)");
            }
            catch(FileNotFoundException e) {
                System.err.println("local file " + local_path + " not found");
            }
            catch(IOException e) {
                System.err.println("cannot create " + target_path);
            }
            finally {
                Util.close(in);
                Util.close(out);
            }
        }

        public String help() {
            return "up [-f]  []";
        }
    }


    private static class down implements Command {

        public void execute(GridFilesystem fs, String[] args) {
            String   options=parseOptions(args);
            String[] real_args=getNonOptions(args);
            boolean  overwrite=options.contains("f");

            if(real_args.length == 0) {
                System.err.println(help());
                return;
            }

            String grid_path=real_args[0], local_path=real_args.length > 1? real_args[1] : null;
            if(HOME != null && grid_path.contains("~"))
                grid_path=grid_path.replace("~", HOME);
            String target_path=local_path != null? local_path : grid_path;
            if(target_path.contains("~"))
                target_path=target_path.replace("~", HOME);
            if(target_path.equals("."))
                target_path=System.getProperty("user.dir");

            File target=new File(target_path);
            if(!overwrite && target.exists() && target.isFile()) {
                System.err.println("grid file " + target_path + " already exists; use -f to force overwrite");
                return;
            }

            if(target.exists() && target.isDirectory()) {
                String[] comps=Util.components(grid_path, File.separator);
                String filename=comps[comps.length - 1];
                target_path=target_path + (target_path.endsWith(File.separator)? filename : File.separator + filename);
            }

            InputStream in=null;
            FileOutputStream out=null;
            try {
                in=fs.getInput(grid_path);
                File out_file=new File(target_path);
                if(out_file.exists() && out_file.isDirectory()) {
                    System.err.println("target " + target_path + " is a directory");
                    return;
                }
                out=new FileOutputStream(out_file);
                byte[] buf=new byte[50000];
                int len, total=0;
                while((len=in.read(buf, 0, buf.length)) != -1) {
                    out.write(buf, 0, len);
                    total+=len;
                }
                System.out.println("downloaded " + local_path + " to " + target_path + " (" + total + " bytes)");
            }
            catch(FileNotFoundException e) {
                System.err.println("local file " + local_path + " not found");
            }
            catch(IOException e) {
                System.err.println("cannot create " + target_path);
            }
            finally {
                Util.close(in);
                Util.close(out);
            }
        }

        public String help() {
            return "down [-f]  []";
        }
    }


    private static String parseOptions(String[] args) {
        StringBuilder sb=new StringBuilder();
        if(args == null)
            return "";
        for(String str: args) {
            if(str.startsWith("-"))
                sb.append(str.substring(1));
        }
        return sb.toString();
    }

    private static String[] getNonOptions(String[] args) {
        if(args == null)
            return null;
        int cnt=0;
        for(String str: args)
            if(!str.startsWith("-"))
                cnt++;
        String[] retval=new String[cnt];
        cnt=0;
        for(String str: args)
            if(!str.startsWith("-"))
                retval[cnt++]=str;
        return retval;
    }

    private static boolean delete(File dir) {
        boolean retval=true;
        if(dir == null)
            return false;
        File[] files=dir.listFiles();
        if(files != null) {
            for(File file: files) {
                if(!delete(file))
                    retval=false;
            }
        }
        boolean rc=dir instanceof GridFile? ((GridFile)dir).delete(true) : dir.delete();
        if(!rc)
            retval=false;
        return retval;
    }

    private static void print(File file, boolean details, boolean recursive, int indent, boolean exclude_self) {
        if(file.isDirectory()) {
            if(!exclude_self)
                System.out.print(print(file, details, indent));
            File[] children=file.listFiles();
            for(File child: children) {
                if(!recursive)
                    System.out.print(print(child, details, indent));
                else {
                    print(child, details, recursive, indent +4, false);
                }
            }
            if(children.length > 0)
                System.out.println("");
        }
        else {
            String tmp=print(file, details, indent);
            System.out.print(tmp);
        }
    }

    private static String print(File file, boolean details, int indent) {
        StringBuilder sb=new StringBuilder();
        if(file.isDirectory()) {
            if(details)
                sb.append(indent(indent));
            sb.append(file.getName()).append("/");
        }
        else {
            if(details)
                sb.append(indent(indent));
            sb.append(file.getName());
            if(details) {
                sb.append(" " + Util.printBytes(file.length()));
                if(file instanceof GridFile)
                    sb.append(", chunk_sise=" + ((GridFile)file).getChunkSize());
            }

        }
        sb.append(details? '\n' : ' ');
        return sb.toString();
    }

    private static String indent(int num) {
        StringBuilder sb=new StringBuilder();
        for(int i=0; i < num; i++)
            sb.append(' ');
        return sb.toString();
    }


}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy