~ubuntu-branches/ubuntu/precise/hbase/precise

« back to all changes in this revision

Viewing changes to src/java/org/apache/hadoop/hbase/rest/DatabaseModel.java

  • Committer: Bazaar Package Importer
  • Author(s): Thomas Koch
  • Date: 2010-05-06 14:20:42 UTC
  • Revision ID: james.westby@ubuntu.com-20100506142042-r3hlvgxdcpb8tynl
Tags: upstream-0.20.4+dfsg1
ImportĀ upstreamĀ versionĀ 0.20.4+dfsg1

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/**
 
2
 * Copyright 2008 The Apache Software Foundation
 
3
 *
 
4
 * Licensed to the Apache Software Foundation (ASF) under one
 
5
 * or more contributor license agreements.  See the NOTICE file
 
6
 * distributed with this work for additional information
 
7
 * regarding copyright ownership.  The ASF licenses this file
 
8
 * to you under the Apache License, Version 2.0 (the
 
9
 * "License"); you may not use this file except in compliance
 
10
 * with the License.  You may obtain a copy of the License at
 
11
 *
 
12
 *     http://www.apache.org/licenses/LICENSE-2.0
 
13
 *
 
14
 * Unless required by applicable law or agreed to in writing, software
 
15
 * distributed under the License is distributed on an "AS IS" BASIS,
 
16
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
17
 * See the License for the specific language governing permissions and
 
18
 * limitations under the License.
 
19
 */
 
20
package org.apache.hadoop.hbase.rest;
 
21
 
 
22
import java.io.IOException;
 
23
 
 
24
import org.apache.commons.logging.Log;
 
25
import org.apache.commons.logging.LogFactory;
 
26
import org.apache.hadoop.hbase.HBaseConfiguration;
 
27
import org.apache.hadoop.hbase.HTableDescriptor;
 
28
import org.apache.hadoop.hbase.client.HBaseAdmin;
 
29
import org.apache.hadoop.hbase.rest.exception.HBaseRestException;
 
30
import org.apache.hadoop.hbase.rest.serializer.IRestSerializer;
 
31
import org.apache.hadoop.hbase.rest.serializer.ISerializable;
 
32
 
 
33
public class DatabaseModel extends AbstractModel {
 
34
 
 
35
  @SuppressWarnings("unused")
 
36
  private Log LOG = LogFactory.getLog(DatabaseModel.class);
 
37
 
 
38
  public DatabaseModel(HBaseConfiguration conf, HBaseAdmin admin) {
 
39
    super.initialize(conf, admin);
 
40
  }
 
41
 
 
42
  public static class DatabaseMetadata implements ISerializable {
 
43
    protected boolean master_running;
 
44
    protected HTableDescriptor[] tables;
 
45
 
 
46
    public DatabaseMetadata(HBaseAdmin a) throws IOException {
 
47
      master_running = a.isMasterRunning();
 
48
      tables = a.listTables();
 
49
    }
 
50
 
 
51
    public boolean isMasterRunning() {
 
52
      return master_running;
 
53
    }
 
54
 
 
55
    public HTableDescriptor[] getTables() {
 
56
      return tables;
 
57
    }
 
58
 
 
59
    public void restSerialize(IRestSerializer serializer)
 
60
        throws HBaseRestException {
 
61
      serializer.serializeDatabaseMetadata(this);
 
62
    }
 
63
  }
 
64
 
 
65
  // Serialize admin ourselves to json object
 
66
  // rather than returning the admin object for obvious reasons
 
67
  public DatabaseMetadata getMetadata() throws HBaseRestException {
 
68
    return getDatabaseMetadata();
 
69
  }
 
70
 
 
71
  protected DatabaseMetadata getDatabaseMetadata() throws HBaseRestException {
 
72
    DatabaseMetadata databaseMetadata = null;
 
73
    try {
 
74
      databaseMetadata = new DatabaseMetadata(this.admin);
 
75
    } catch (IOException e) {
 
76
      throw new HBaseRestException(e);
 
77
    }
 
78
 
 
79
    return databaseMetadata;
 
80
  }
 
81
}