summaryrefslogtreecommitdiff
path: root/tools/examples/ExampleAuthnVeryOld.java
blob: b2bd8d0a2663c50c8b3add9bfc60d2f8ba463033 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
/* Username/password prompt/save using very old org.tigris.subversion API.

   Compile against non-installed Subversion JavaHL build:

     javac -cp subversion/bindings/javahl/classes -d subversion/bindings/javahl/classes ExampleAuthnVeryOld.java

   Run:

     LD_LIBRARY_PATH=subversion/libsvn_auth_gnome_keyring/.libs java -cp subversion/bindings/javahl/classes -Djava.library.path=subversion/bindings/javahl/native/.libs ExampleAuthnVeryOld <URL> <config-dir>

 */
import org.tigris.subversion.javahl.*;
import java.io.Console;

public class ExampleAuthnVeryOld {

    protected static class MyAuthn {

      public static PromptUserPassword3 getAuthn() {
        return new MyUserPasswordCallback();
      }

      private static class MyUserPasswordCallback
      implements PromptUserPassword3 {

        private String _username = null;

        public String
        getUsername() {
          System.out.println("getUsername");
          return _username;
        }

        private String _password = null;

        public String
        getPassword() {
          System.out.println("getPassword");
          return _password;
        }

        public boolean
        userAllowedSave() {
          System.out.println("userAllowedSave");
          return true;
        }

        public boolean
        askYesNo(String realm, String question, boolean yesIsDefault) {
          System.out.println("askYesNo");
          System.out.print(question + " (y/n): ");
          String s = System.console().readLine();
          return s.equals("y") ? true : s.equals("") ? yesIsDefault : false;
        }

        public boolean
        prompt(String realm, String username, boolean maySave) {
          System.out.println("prompt");
          System.out.println("Realm: " + realm);
          String prompt;
          if (username == null) {
            System.out.print("Username: ");
            _username = System.console().readLine();
            prompt = "Password: ";
          } else {
            _username = username;
            prompt = "Password for " + username + ": ";
          }
          _password = new String(System.console().readPassword(prompt));
          return maySave;
        }

        public boolean
        prompt(String realm, String username) {
          System.out.println("prompt not implemented!");
          return true;
        }

        public String
        askQuestion(String realm,
                    String question,
                    boolean showAnswer,
                    boolean maySave) {
          System.out.println("askQuestion not implemented!");
          return null;
        }

        public String
        askQuestion(String realm, String question, boolean showAnswer) {
          System.out.println("askQuestion not implemented!");
          return null;
        }

        public int
        askTrustSSLServer(String info, boolean allowPermanently) {
          System.out.println("askTrustSSLServer not implemented!");
          return PromptUserPassword3.AcceptTemporary;
        }
      }
    }

  public static void main(String argv[]) {

    if (argv.length != 2) {
      System.err.println("usage: ExampleAuthnVeryOld <URL> <config-dir>");
      return;
    }
    SVNClientInterface client = new SVNClient();
    client.setPrompt(MyAuthn.getAuthn());
    try {
      client.setConfigDirectory(argv[1]);
      client.logMessages(argv[0], Revision.getInstance(0),
                         Revision.getInstance(0), false, false, 0);
    } catch (Exception e) {
      e.printStackTrace();
    }
  }
}