001/**
002 * Licensed to the Apache Software Foundation (ASF) under one
003 * or more contributor license agreements.  See the NOTICE file
004 * distributed with this work for additional information
005 * regarding copyright ownership.  The ASF licenses this file
006 * to you under the Apache License, Version 2.0 (the
007 * "License"); you may not use this file except in compliance
008 * with the License.  You may obtain a copy of the License at
009 *
010 *      http://www.apache.org/licenses/LICENSE-2.0
011 *
012 * Unless required by applicable law or agreed to in writing, software
013 * distributed under the License is distributed on an "AS IS" BASIS,
014 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
015 * See the License for the specific language governing permissions and
016 * limitations under the License.
017 */
018
019package org.apache.oozie;
020
021import org.apache.oozie.util.XLog;
022
023public enum ErrorCode {
024    E0000(XLog.STD, "System property ''oozie.home.dir'' not defined"),
025    E0001(XLog.OPS, "Could not create runtime directory, {0}"),
026    E0002(XLog.STD, "System is in safe mode"),
027    E0003(XLog.OPS, "Oozie home directory must be an absolute path [{0}]"),
028    E0004(XLog.OPS, "Oozie home directory does not exist [{0}]"),
029
030    E0010(XLog.OPS, "Could not initialize log service, {0}"),
031    E0011(XLog.OPS, "Log4j file must be a file name [{0}]"),
032    E0012(XLog.OPS, "Log4j file must be a ''.properties'' file [{0}]"),
033    E0013(XLog.OPS, "Log4j file [{0}] not found in configuration dir [{1}] neither in classpath"),
034
035    E0020(XLog.OPS, "Environment variable {0} not defined"),
036    E0022(XLog.OPS, "Configuration file must be a file name [{0}]"),
037    E0023(XLog.OPS, "Default configuration file [{0}] not found in classpath"),
038    E0024(XLog.OPS, "Oozie configuration directory does not exist [{0}]"),
039    E0025(XLog.OPS, "Configuration service internal error, it should never happen, {0}"),
040    E0026(XLog.OPS, "Missing required configuration property [{0}]"),
041
042    E0100(XLog.OPS, "Could not initialize service [{0}], {1}"),
043    E0101(XLog.OPS, "Service [{0}] does not implement declared interface [{1}]"),
044    E0102(XLog.OPS, "Could not instantiate service class [{0}], {1}"),
045    E0103(XLog.OPS, "Could not load service classes, {0}"),
046    E0104(XLog.OPS, "Could not fully initialize service [{0}], {1}"),
047    E0110(XLog.OPS, "Could not parse or validate EL definition [{0}], {1}"),
048    E0111(XLog.OPS, "class#method not found [{0}#{1}]"),
049    E0112(XLog.OPS, "class#method does not have PUBLIC or STATIC modifier [{0}#{1}]"),
050    E0113(XLog.OPS, "class not found [{0}]"),
051    E0114(XLog.OPS, "class#constant does not have PUBLIC or STATIC modifier [{0}#{1}]"),
052    E0115(XLog.OPS, "class#constant not found"),
053    E0116(XLog.OPS, "class#constant does not have PUBLIC or STATIC modifier [{0}#{1}]"),
054    E0120(XLog.OPS, "UUID, invalid generator type [{0}]"),
055    E0130(XLog.OPS, "Could not parse workflow schemas file/s, {0}"),
056    E0131(XLog.OPS, "Could not read workflow schemas file/s, {0}"),
057    E0140(XLog.OPS, "Could not access database, {0}"),
058    E0141(XLog.OPS, "Could not create DataSource connection pool, {0}"),
059    E0160(XLog.OPS, "Could not read admin users file [{0}], {1}"),
060
061    E0300(XLog.STD, "Invalid content-type [{0}]"),
062    E0301(XLog.STD, "Invalid resource [{0}]"),
063    E0302(XLog.STD, "Invalid parameter [{0}]"),
064    E0303(XLog.STD, "Invalid parameter value, [{0}] = [{1}]"),
065    E0304(XLog.STD, "Invalid parameter type, parameter [{0}] expected type [{1}]"),
066    E0305(XLog.STD, "Missing parameter [{0}]"),
067    E0306(XLog.STD, "Invalid parameter"),
068    E0307(XLog.STD, "Runtime error [{0}]"),
069    E0308(XLog.STD, "Could not parse date range parameter [{0}]"),
070
071
072    E0401(XLog.STD, "Missing configuration property [{0}]"),
073    E0402(XLog.STD, "Invalid callback ID [{0}]"),
074    E0403(XLog.STD, "Invalid callback data, {0}"),
075    E0404(XLog.STD, "Only one of the properties are allowed [{0}]"),
076    E0405(XLog.STD, "Submission request does not have any application or lib path"),
077
078    E0420(XLog.STD, "Invalid jobs filter [{0}], {1}"),
079    E0421(XLog.STD, "Invalid job filter [{0}], {1}"),
080
081    E0500(XLog.OPS, "Not authorized, {0}"),
082    E0501(XLog.OPS, "Could not perform authorization operation, {0}"),
083    E0502(XLog.OPS, "User [{0}] does not belong to group [{1}]"),
084    E0503(XLog.OPS, "User [{0}] does not have admin privileges"),
085    E0504(XLog.OPS, "App directory [{0}] does not exist"),
086    E0505(XLog.OPS, "App definition [{0}] does not exist"),
087    E0506(XLog.OPS, "App definition [{0}] is not a file"),
088    E0507(XLog.OPS, "Could not access to [{0}], {1}"),
089    E0508(XLog.OPS, "User [{0}] not authorized for WF job [{1}]"),
090    E0509(XLog.OPS, "User [{0}] not authorized for Coord job [{1}]"),
091    E0510(XLog.OPS, "Unable to get Credential [{0}]"),
092    E0511(XLog.STD, "No HDFS delegation token present, can''t set credentials. [serverPrincipal={0}]"),
093    E0512(XLog.STD, "Could not get RM delegation token: {0}"),
094    E0513(XLog.STD, "No YARN renewer present, can''t get token. [servicePrincipal={0}]"),
095
096    E0550(XLog.OPS, "Could not normalize host name [{0}], {1}"),
097    E0551(XLog.OPS, "Missing [{0}] property"),
098
099    E0600(XLog.OPS, "Could not get connection, {0}"),
100    E0601(XLog.OPS, "Could not close connection, {0}"),
101    E0602(XLog.OPS, "Could not commit connection, {0}"),
102    E0603(XLog.OPS, "SQL error in operation, {0}"),
103    E0604(XLog.STD, "Job does not exist [{0}]"),
104    E0605(XLog.STD, "Action does not exist [{0}]"),
105    E0606(XLog.STD, "Could not get lock [{0}], timed out [{1}]ms"),
106    E0607(XLog.OPS, "Other error in operation [{0}], {1}"),
107    E0608(XLog.OPS, "JDBC setup error [{0}], {1}"),
108    E0609(XLog.OPS, "Missing [{0}] ORM file [{1}]"),
109    E0610(XLog.OPS, "Missing JPAService, StoreService cannot run without a JPAService"),
110    E0611(XLog.OPS, "SQL error in operation [{0}], {1}"),
111    E0612(XLog.OPS, "Could not get coordinator actions"),
112
113    E0700(XLog.STD, "XML error, {0}"),
114    E0701(XLog.STD, "XML schema error, {0}"),
115    E0702(XLog.STD, "IO error, {0}"),
116    E0703(XLog.STD, "Invalid workflow element [{0}]"),
117    E0704(XLog.STD, "Definition already complete, application [{0}]"),
118    E0705(XLog.STD, "Nnode already defined, node [{0}]"),
119    E0706(XLog.STD, "Node cannot transition to itself node [{0}]"),
120    E0707(XLog.STD, "Loop detected at parsing, node [{0}], path [{1}]"),
121    E0708(XLog.STD, "Invalid transition, node [{0}] transition [{1}]"),
122    E0709(XLog.STD, "Loop detected at runtime, node [{0}]"),
123    E0710(XLog.STD, "Could not read the workflow definition, {0}"),
124    E0711(XLog.STD, "Invalid application URI [{0}], {1}"),
125    E0712(XLog.STD, "Could not create lib paths list for application [{0}], {1}"),
126    E0713(XLog.OPS, "SQL error, {0}"),
127    E0714(XLog.OPS, "Workflow lib error, {0}"),
128    E0715(XLog.OPS, "Invalid signal value for the start node, signal [{0}]"),
129    E0716(XLog.OPS, "Workflow not running"),
130    E0717(XLog.OPS, "Workflow not suspended"),
131    E0718(XLog.OPS, "Workflow already completed"),
132    E0719(XLog.OPS, "Job already started"),
133    E0720(XLog.OPS, "Fork/join mismatch, node [{0}]"),
134    E0721(XLog.OPS, "Invalid signal/transition, decision node [{0}] signal [{1}]"),
135    E0722(XLog.OPS, "Action signals can only be OK or ERROR, action node [{0}]"),
136    E0723(XLog.STD, "Unsupported action type, node [{0}] type [{1}]"),
137    E0724(XLog.STD, "Invalid node name, {0}"),
138    E0725(XLog.STD, "Workflow instance can not be killed, {0}"),
139    E0726(XLog.STD, "Workflow action can not be killed, {0}"),
140    E0727(XLog.STD, "Workflow Job can not be suspended as its not in running state, {0}, Status: {1}"),
141    E0728(XLog.STD, "Coordinator Job can not be suspended as job finished or failed or killed, id : {0}, status : {1}"),
142    E0729(XLog.OPS, "Kill node message [{0}]"),
143    E0730(XLog.STD, "Fork/Join not in pair"),
144    E0731(XLog.STD, "Fork node [{0}] cannot have less than two paths"),
145    E0732(XLog.STD, "Fork [{0}]/Join [{1}] not in pair (join should have been [{2}])"),
146    E0733(XLog.STD, "Fork [{0}] without a join"),
147    E0734(XLog.STD, "Invalid transition from node [{0}] to node [{1}] while using fork/join"),
148    E0735(XLog.STD, "There was an invalid \"error to\" transition to node [{1}] while using fork/join"),
149    E0736(XLog.STD, "Workflow definition length [{0}] exceeded maximum allowed length [{1}]"),
150    E0737(XLog.STD, "Invalid transition from node [{0}] to node [{1}] -- nodes of type ''end'' are not allowed within Fork/Join"),
151    E0738(XLog.STD, "The following {0} parameters are required but were not defined and no default values are available: {1}"),
152    E0739(XLog.STD, "Parameter name cannot be empty"),
153    E0740(XLog.STD, "Invalid node type encountered (node [{0}])"),
154    E0741(XLog.STD, "Cycle detected transitioning to [{0}] via path {1}"),
155    E0742(XLog.STD, "No Fork for Join [{0}] to pair with"),
156    E0743(XLog.STD, "Multiple \"ok to\" transitions to the same node, [{0}], are not allowed"),
157    E0744(XLog.STD, "A fork, [{0}], is not allowed to have multiple transitions to the same node, [{1}]"),
158    E0755(XLog.STD, "Workflow Job Rerun Error: {0}"),
159    E0756(XLog.STD, "Exception parsing Kill node message [{0}]"),
160    E0757(XLog.STD, "Fork node [{0}] has multiple joins: [{1}]"),
161    E0758(XLog.STD, "Join node [{0}] has multiple forks: [{1}]"),
162
163    E0800(XLog.STD, "Action it is not running its in [{1}] state, action [{0}]"),
164    E0801(XLog.STD, "Workflow already running, workflow [{0}]"),
165    E0802(XLog.STD, "Invalid action type [{0}]"),
166    E0803(XLog.STD, "IO error, {0}"),
167    E0804(XLog.STD, "Disallowed default property [{0}]"),
168    E0805(XLog.STD, "Workflow job not completed, status [{0}]"),
169    E0806(XLog.STD, "Action did not complete in previous run, action [{0}]"),
170    E0807(XLog.STD, "Some skip actions were not executed [{0}]"),
171    E0808(XLog.STD, "Disallowed user property [{0}]"),
172    E0809(XLog.STD, "Workflow action is not eligible to start [{0}]"),
173    E0810(XLog.STD, "Job state is not [{0}]. Skipping ActionStart Execution"),
174    E0811(XLog.STD, "Job state is not [{0}]. Skipping ActionEnd Execution"),
175    E0812(XLog.STD, "Action pending=[{0}], status=[{1}]. Skipping ActionEnd Execution"),
176    E0813(XLog.STD, "Workflow not RUNNING, current status [{0}]"),
177    E0814(XLog.STD, "SignalCommand for action id=[{0}] is already processed, status=[{1}], , pending=[{2}]"),
178    E0815(XLog.STD, "Action pending=[{0}], status=[{1}]. Skipping ActionCheck Execution"),
179    E0816(XLog.STD, "Action pending=[{0}], status=[{1}]. Skipping ActionStart Execution"),
180    E0817(XLog.STD, "The wf action [{0}] has been updated recently. Ignoring ActionCheck."),
181    E0818(XLog.STD, "Action [{0}] status is running but WF Job [{1}] status is [{2}]. Expected status is RUNNING or SUSPENDED."),
182    E0819(XLog.STD, "Unable to delete the temp dir of job WF Job [{0}]."),
183    E0820(XLog.STD, "Action user retry max [{0}] is over system defined max [{1}], re-assign to use system max."),
184    E0821(XLog.STD, "Received early callback for action still in PREP state; will wait [{0}]ms and requeue up to [{1}] more times"),
185    E0822(XLog.STD, "Received early callback for action [{0}] while still in PREP state and exhausted all requeues"),
186
187    E0900(XLog.OPS, "JobTracker [{0}] not allowed, not in Oozie''s whitelist. Allowed values are: {1}"),
188    E0901(XLog.OPS, "NameNode [{0}] not allowed, not in Oozie''s whitelist. Allowed values are: {1}"),
189    E0902(XLog.OPS, "Exception occurred: [{0}]"),
190    E0903(XLog.OPS, "Invalid JobConf, it has not been created by HadoopAccessorService"),
191    E0904(XLog.STD, "Scheme [{0}] not supported in uri [{1}]"),
192    E0905(XLog.STD, "Scheme not present in uri [{0}]"),
193    E0906(XLog.STD, "URI parsing error : {0}"),
194    E0907(XLog.STD, "Failed to delete uri : {0}"),
195
196    E1001(XLog.STD, "Could not read the coordinator job definition, {0}"),
197    E1002(XLog.STD, "Invalid coordinator application URI [{0}], {1}"),
198    E1003(XLog.STD, "Invalid coordinator application attributes, {0}"),
199    E1004(XLog.STD, "Expression language evaluation error, {0}"),
200    E1005(XLog.STD, "Could not read the coordinator job configuration read from DB, {0}"),
201    E1006(XLog.STD, "Invalid coordinator application [{0}], {1}"),
202    E1007(XLog.STD, "Unable to add record for SLA. [{0}], {1}"),
203    E1008(XLog.STD, "Not implemented. [{0}]"),
204    E1009(XLog.STD, "Unable to parse XML response. [{0}]"),
205    E1010(XLog.STD, "Invalid data in coordinator xml. [{0}]"),
206    E1011(XLog.STD, "Cannot update coordinator job [{0}], {1}"),
207    E1012(XLog.STD, "Coord Job Materialization Error: {0}"),
208    E1013(XLog.STD, "Coord Job Recovery Error: {0}"),
209    E1014(XLog.STD, "Coord job change command not supported"),
210    E1015(XLog.STD, "Invalid coordinator job change value {0}, {1}"),
211    E1016(XLog.STD, "Cannot change a killed coordinator job"),
212    E1017(XLog.STD, "Cannot change a workflow job"),
213    E1018(XLog.STD, "Coord Job Rerun Error: {0}"),
214    E1019(XLog.STD, "Could not submit coord job, [{0}]"),
215    E1020(XLog.STD, "Could not kill coord job, this job either finished successfully or does not exist , [{0}]"),
216    E1021(XLog.STD, "Coord Action Input Check Error: {0}"),
217    E1022(XLog.STD, "Cannot delete running/completed coordinator action: [{0}]"),
218    E1023(XLog.STD, "Coord Job update Error: [{0}]"),
219    E1024(XLog.STD, "Cannot run ignore command: [{0}]"),
220    E1025(XLog.STD, "Coord status transit error: [{0}]"),
221    E1026(XLog.STD, "SLA alert update command failed: {0}"),
222    E1027(XLog.STD, "SLA change command failed. {0}"),
223    E1028(XLog.STD, "Coord input logic error. {0}"),
224    E1029(XLog.STD, "Coord action missing dependencies error. {0}"),
225
226    E1100(XLog.STD, "Command precondition does not hold before execution, [{0}]"),
227
228    E1101(XLog.STD, "SLA <{0}> cannot be empty."),
229
230    E1102(XLog.STD, "Invalid operation [{0}] for bulk command"),
231
232    E1201(XLog.STD, "State [{0}] is invalid for job [{1}]."),
233
234    E1301(XLog.STD, "Could not read the bundle job definition, [{0}]"),
235    E1302(XLog.STD, "Invalid bundle application URI [{0}], {1}"),
236    E1303(XLog.STD, "Invalid bundle application attributes [{0}], {1}"),
237    E1304(XLog.STD, "Duplicate bundle application coordinator name [{0}]"),
238    E1305(XLog.STD, "Empty bundle application coordinator name."),
239    E1306(XLog.STD, "Could not read the bundle job configuration, [{0}]"),
240    E1307(XLog.STD, "Could not read the bundle coord job configuration, [{0}]"),
241    E1308(XLog.STD, "Bundle Action Status  [{0}] is not matching with coordinator previous status [{1}]."),
242    E1309(XLog.STD, "Bundle Action for bundle ID  [{0}] and Coordinator [{1}] could not be update by BundleStatusUpdateXCommand"),
243    E1310(XLog.STD, "Bundle Job submission Error: [{0}]"),
244    E1311(XLog.STD, "Bundle Action for bundle ID  [{0}] not found"),
245    E1312(XLog.STD, "Bundle Job can not be suspended as job finished or failed or killed, id : {0}, status : {1}"),
246    E1313(XLog.STD, "Bundle Job can not be changed as job finished, {0}, Status: {1}"),
247    E1314(XLog.STD, "Bundle Job can not be changed as job does not exist, {0}"),
248    E1315(XLog.STD, "Bundle job can not be paused, {0}"),
249    E1316(XLog.STD, "Bundle job can not be unpaused, {0}"),
250    E1317(XLog.STD, "Invalid bundle job change value {0}, {1}"),
251    E1318(XLog.STD, "No coord jobs for the bundle=[{0}], fail the bundle"),
252    E1319(XLog.STD, "Invalid bundle coord job namespace, [{0}]"),
253    E1320(XLog.STD, "Bundle Job change error, [{0}]"),
254    E1321(XLog.STD, "Error evaluating coord name, [{0}]"),
255    E1322(XLog.STD, "Bundle status transit error: [{0}]"),
256    E1323(XLog.STD, "Could not kill bundle job, this job either finished successfully or does not exist , [{0}]"),
257
258
259    E1400(XLog.STD, "doAs (proxyuser) failure"),
260
261    E1501(XLog.STD, "Error in getting HCat Access [{0}]"),
262
263    E1601(XLog.STD, "Cannot retrieve JMS connection info [{0}]"),
264    E1602(XLog.STD, "Cannot retrieve Topic name [{0}]"),
265    E1603(XLog.STD, "Invalid user request"),
266
267    E1700(XLog.STD, "Issue communicating with ZooKeeper: {0}"),
268    ETEST(XLog.STD, "THIS SHOULD HAPPEN ONLY IN TESTING, invalid job id [{0}]"),;
269
270    private String template;
271    private int logMask;
272
273    /**
274     * Create an error code.
275     *
276     * @param template template for the exception message.
277     * @param logMask log mask for the exception.
278     */
279    private ErrorCode(int logMask, String template) {
280        this.logMask = logMask;
281        this.template = template;
282    }
283
284    /**
285     * Return the message (StringFormat) template for the error code.
286     *
287     * @return message template.
288     */
289    public String getTemplate() {
290        return template;
291    }
292
293    /**
294     * Return the log mask (to which log the exception should be logged) of the error.
295     *
296     * @return error log mask.
297     */
298    public int getLogMask() {
299        return logMask;
300    }
301
302    /**
303     * Return a templatized error message for the error code.
304     *
305     * @param args the parameters for the templatized message.
306     * @return error message.
307     */
308    public String format(Object... args) {
309        return XLog.format("{0}: {1}", toString(), XLog.format(getTemplate(), args));
310    }
311
312}