1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package net.sf.asterisk.fastagi.command;
18
19 /***
20 * Say a given character string with phonetics, returning early if any of the
21 * given DTMF digits are received on the channel.<br>
22 * Returns 0 if playback completes without a digit being pressed, or the ASCII
23 * numerical value of the digit if one was pressed or -1 on error/hangup.
24 *
25 * @author srt
26 * @version $Id: SayPhoneticCommand.java,v 1.3 2005/03/10 21:48:11 srt Exp $
27 */
28 public class SayPhoneticCommand extends AGICommand
29 {
30 /***
31 * Serial version identifier.
32 */
33 private static final long serialVersionUID = 3256721797012404276L;
34
35 /***
36 * The text to say.
37 */
38 private String text;
39
40 /***
41 * When one of these digits is pressed the command returns.
42 */
43 private String escapeDigits;
44
45 /***
46 * Creates a new SayPhonticCommand.
47 *
48 * @param text the text to say.
49 */
50 public SayPhoneticCommand(String text)
51 {
52 this.text = text;
53 this.escapeDigits = null;
54 }
55
56 /***
57 * Creates a new SayPhoneticCommand.
58 *
59 * @param text the text to say.
60 * @param escapeDigits contains the digits that allow the user to interrupt
61 * this command.
62 */
63 public SayPhoneticCommand(String text, String escapeDigits)
64 {
65 this.text = text;
66 this.escapeDigits = escapeDigits;
67 }
68
69 /***
70 * Returns the text to say.
71 *
72 * @return the text to say.
73 */
74 public String getText()
75 {
76 return text;
77 }
78
79 /***
80 * Sets the text to say.
81 *
82 * @param text the text to say.
83 */
84 public void setText(String text)
85 {
86 this.text = text;
87 }
88
89 /***
90 * Returns the digits that allow the user to interrupt this command.
91 *
92 * @return the digits that allow the user to interrupt this command.
93 */
94 public String getEscapeDigits()
95 {
96 return escapeDigits;
97 }
98
99 /***
100 * Sets the digits that allow the user to interrupt this command.
101 *
102 * @param escapeDigits the text that allow the user to interrupt this
103 * command or <code>null</code> for none.
104 */
105 public void setEscapeDigits(String escapeDigits)
106 {
107 this.escapeDigits = escapeDigits;
108 }
109
110 public String buildCommand()
111 {
112 return "SAY PHONETIC " + escapeAndQuote(text) + " "
113 + escapeAndQuote(escapeDigits);
114 }
115 }