2014-05-14 05:20:58 +00:00
|
|
|
// Copyright (c) 2014, Facebook, Inc. All rights reserved.
|
|
|
|
// This source code is licensed under the BSD-style license found in the
|
|
|
|
// LICENSE file in the root directory of this source tree. An additional grant
|
|
|
|
// of patent rights can be found in the PATENTS file in the same directory.
|
|
|
|
//
|
|
|
|
// This file implements the "bridge" between Java and C++ and enables
|
2014-05-19 05:40:48 +00:00
|
|
|
// calling c++ rocksdb::RestoreBackupableDB and rocksdb::RestoreOptions methods
|
2014-05-14 05:20:58 +00:00
|
|
|
// from Java side.
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <jni.h>
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
#include "include/org_rocksdb_RestoreOptions.h"
|
|
|
|
#include "include/org_rocksdb_RestoreBackupableDB.h"
|
|
|
|
#include "rocksjni/portal.h"
|
2014-07-23 18:15:14 +00:00
|
|
|
#include "rocksdb/utilities/backupable_db.h"
|
2014-05-14 05:20:58 +00:00
|
|
|
/*
|
|
|
|
* Class: org_rocksdb_RestoreOptions
|
|
|
|
* Method: newRestoreOptions
|
2014-05-19 05:40:48 +00:00
|
|
|
* Signature: (Z)J
|
2014-05-14 05:20:58 +00:00
|
|
|
*/
|
2014-05-19 05:40:48 +00:00
|
|
|
jlong Java_org_rocksdb_RestoreOptions_newRestoreOptions(JNIEnv* env,
|
2014-05-14 05:20:58 +00:00
|
|
|
jobject jobj, jboolean keep_log_files) {
|
|
|
|
auto ropt = new rocksdb::RestoreOptions(keep_log_files);
|
2014-05-19 05:40:48 +00:00
|
|
|
return reinterpret_cast<jlong>(ropt);
|
2014-05-14 05:20:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Class: org_rocksdb_RestoreOptions
|
|
|
|
* Method: dispose
|
|
|
|
* Signature: (J)V
|
|
|
|
*/
|
|
|
|
void Java_org_rocksdb_RestoreOptions_dispose(JNIEnv* env, jobject jobj,
|
|
|
|
jlong jhandle) {
|
|
|
|
auto ropt = reinterpret_cast<rocksdb::RestoreOptions*>(jhandle);
|
|
|
|
assert(ropt);
|
|
|
|
delete ropt;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Class: org_rocksdb_RestoreBackupableDB
|
|
|
|
* Method: newRestoreBackupableDB
|
2014-05-19 05:40:48 +00:00
|
|
|
* Signature: (J)J
|
2014-05-14 05:20:58 +00:00
|
|
|
*/
|
2014-05-19 05:40:48 +00:00
|
|
|
jlong Java_org_rocksdb_RestoreBackupableDB_newRestoreBackupableDB(JNIEnv* env,
|
2014-05-14 05:20:58 +00:00
|
|
|
jobject jobj, jlong jopt_handle) {
|
|
|
|
auto opt = reinterpret_cast<rocksdb::BackupableDBOptions*>(jopt_handle);
|
|
|
|
auto rdb = new rocksdb::RestoreBackupableDB(rocksdb::Env::Default(), *opt);
|
2014-05-19 05:40:48 +00:00
|
|
|
return reinterpret_cast<jlong>(rdb);
|
2014-05-14 05:20:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Class: org_rocksdb_RestoreBackupableDB
|
|
|
|
* Method: restoreDBFromBackup0
|
|
|
|
* Signature: (JJLjava/lang/String;Ljava/lang/String;J)V
|
|
|
|
*/
|
|
|
|
void Java_org_rocksdb_RestoreBackupableDB_restoreDBFromBackup0(JNIEnv* env,
|
|
|
|
jobject jobj, jlong jhandle, jlong jbackup_id, jstring jdb_dir,
|
|
|
|
jstring jwal_dir, jlong jopt_handle) {
|
|
|
|
auto opt = reinterpret_cast<rocksdb::RestoreOptions*>(jopt_handle);
|
2014-05-19 05:40:48 +00:00
|
|
|
|
2014-05-14 05:20:58 +00:00
|
|
|
const char* cdb_dir = env->GetStringUTFChars(jdb_dir, 0);
|
|
|
|
const char* cwal_dir = env->GetStringUTFChars(jwal_dir, 0);
|
2014-05-19 05:40:48 +00:00
|
|
|
|
2014-05-14 05:20:58 +00:00
|
|
|
auto rdb = reinterpret_cast<rocksdb::RestoreBackupableDB*>(jhandle);
|
2014-11-11 21:47:22 +00:00
|
|
|
rocksdb::Status s = rdb->RestoreDBFromBackup(
|
|
|
|
static_cast<rocksdb::BackupID>(jbackup_id), cdb_dir, cwal_dir, *opt);
|
2014-05-19 05:40:48 +00:00
|
|
|
|
2014-05-14 05:20:58 +00:00
|
|
|
env->ReleaseStringUTFChars(jdb_dir, cdb_dir);
|
|
|
|
env->ReleaseStringUTFChars(jwal_dir, cwal_dir);
|
2014-05-19 05:40:48 +00:00
|
|
|
|
2014-10-09 21:16:41 +00:00
|
|
|
if (!s.ok()) {
|
2014-05-14 05:20:58 +00:00
|
|
|
rocksdb::RocksDBExceptionJni::ThrowNew(env, s);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Class: org_rocksdb_RestoreBackupableDB
|
|
|
|
* Method: restoreDBFromLatestBackup0
|
|
|
|
* Signature: (JLjava/lang/String;Ljava/lang/String;J)V
|
|
|
|
*/
|
|
|
|
void Java_org_rocksdb_RestoreBackupableDB_restoreDBFromLatestBackup0(
|
|
|
|
JNIEnv* env, jobject jobj, jlong jhandle, jstring jdb_dir, jstring jwal_dir,
|
|
|
|
jlong jopt_handle) {
|
|
|
|
auto opt = reinterpret_cast<rocksdb::RestoreOptions*>(jopt_handle);
|
2014-05-19 05:40:48 +00:00
|
|
|
|
2014-05-14 05:20:58 +00:00
|
|
|
const char* cdb_dir = env->GetStringUTFChars(jdb_dir, 0);
|
|
|
|
const char* cwal_dir = env->GetStringUTFChars(jwal_dir, 0);
|
2014-05-19 05:40:48 +00:00
|
|
|
|
2014-05-14 05:20:58 +00:00
|
|
|
auto rdb = reinterpret_cast<rocksdb::RestoreBackupableDB*>(jhandle);
|
|
|
|
rocksdb::Status s =
|
|
|
|
rdb->RestoreDBFromLatestBackup(cdb_dir, cwal_dir, *opt);
|
2014-05-19 05:40:48 +00:00
|
|
|
|
2014-05-14 05:20:58 +00:00
|
|
|
env->ReleaseStringUTFChars(jdb_dir, cdb_dir);
|
|
|
|
env->ReleaseStringUTFChars(jwal_dir, cwal_dir);
|
2014-05-19 05:40:48 +00:00
|
|
|
|
2014-10-09 21:16:41 +00:00
|
|
|
if (!s.ok()) {
|
2014-05-14 05:20:58 +00:00
|
|
|
rocksdb::RocksDBExceptionJni::ThrowNew(env, s);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Class: org_rocksdb_RestoreBackupableDB
|
|
|
|
* Method: purgeOldBackups0
|
|
|
|
* Signature: (JI)V
|
|
|
|
*/
|
|
|
|
void Java_org_rocksdb_RestoreBackupableDB_purgeOldBackups0(JNIEnv* env,
|
|
|
|
jobject jobj, jlong jhandle, jint jnum_backups_to_keep) {
|
|
|
|
auto rdb = reinterpret_cast<rocksdb::RestoreBackupableDB*>(jhandle);
|
|
|
|
rocksdb::Status s = rdb->PurgeOldBackups(jnum_backups_to_keep);
|
2014-05-19 05:40:48 +00:00
|
|
|
|
2014-10-09 21:16:41 +00:00
|
|
|
if (!s.ok()) {
|
2014-05-14 05:20:58 +00:00
|
|
|
rocksdb::RocksDBExceptionJni::ThrowNew(env, s);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Class: org_rocksdb_RestoreBackupableDB
|
|
|
|
* Method: deleteBackup0
|
2014-10-28 17:42:30 +00:00
|
|
|
* Signature: (JI)V
|
2014-05-14 05:20:58 +00:00
|
|
|
*/
|
|
|
|
void Java_org_rocksdb_RestoreBackupableDB_deleteBackup0(JNIEnv* env,
|
2014-10-28 17:42:30 +00:00
|
|
|
jobject jobj, jlong jhandle, jint jbackup_id) {
|
2014-05-14 05:20:58 +00:00
|
|
|
auto rdb = reinterpret_cast<rocksdb::RestoreBackupableDB*>(jhandle);
|
|
|
|
rocksdb::Status s = rdb->DeleteBackup(jbackup_id);
|
2014-05-19 05:40:48 +00:00
|
|
|
|
2014-10-09 21:16:41 +00:00
|
|
|
if (!s.ok()) {
|
2014-05-14 05:20:58 +00:00
|
|
|
rocksdb::RocksDBExceptionJni::ThrowNew(env, s);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-10-26 22:23:06 +00:00
|
|
|
/*
|
|
|
|
* Class: org_rocksdb_RestoreBackupableDB
|
|
|
|
* Method: getBackupInfo
|
|
|
|
* Signature: (J)Ljava/util/List;
|
|
|
|
*/
|
|
|
|
jobject Java_org_rocksdb_RestoreBackupableDB_getBackupInfo(
|
|
|
|
JNIEnv* env, jobject jbdb, jlong jhandle) {
|
|
|
|
std::vector<rocksdb::BackupInfo> backup_infos;
|
|
|
|
reinterpret_cast<rocksdb::RestoreBackupableDB*>(jhandle)->
|
|
|
|
GetBackupInfo(&backup_infos);
|
|
|
|
return rocksdb::BackupInfoListJni::getBackupInfo(env,
|
|
|
|
backup_infos);
|
|
|
|
}
|
|
|
|
|
2014-11-15 22:42:03 +00:00
|
|
|
/*
|
|
|
|
* Class: org_rocksdb_RestoreBackupableDB
|
|
|
|
* Method: getCorruptedBackups
|
|
|
|
* Signature: (J)Ljava/util/List;
|
|
|
|
*/
|
|
|
|
jobject Java_org_rocksdb_RestoreBackupableDB_getCorruptedBackups(
|
|
|
|
JNIEnv* env, jobject jbdb, jlong jhandle) {
|
|
|
|
std::vector<rocksdb::BackupID> backup_ids;
|
|
|
|
reinterpret_cast<rocksdb::RestoreBackupableDB*>(jhandle)->
|
|
|
|
GetCorruptedBackups(&backup_ids);
|
|
|
|
|
|
|
|
jclass jclazz = env->FindClass("java/util/ArrayList");
|
|
|
|
jmethodID mid = rocksdb::ListJni::getArrayListConstructorMethodId(
|
|
|
|
env, jclazz);
|
|
|
|
jobject jbackup_id_handle_list = env->NewObject(jclazz, mid,
|
|
|
|
backup_ids.size());
|
|
|
|
// insert in java list
|
|
|
|
for (std::vector<rocksdb::BackupID>::size_type i = 0;
|
|
|
|
i != backup_ids.size(); i++) {
|
|
|
|
// convert BackupID to Integer
|
|
|
|
jclass jIntClazz = env->FindClass("java/lang/Integer");
|
|
|
|
jmethodID midLong = env->GetMethodID(jIntClazz, "<init>", "(I)V");
|
|
|
|
jobject obj = env->NewObject(jIntClazz, midLong,
|
|
|
|
(backup_ids[i]));
|
|
|
|
// add Integer to List
|
|
|
|
env->CallBooleanMethod(jbackup_id_handle_list,
|
|
|
|
rocksdb::ListJni::getListAddMethodId(env), obj);
|
|
|
|
}
|
|
|
|
return jbackup_id_handle_list;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Class: org_rocksdb_RestoreBackupableDB
|
|
|
|
* Method: garbageCollect
|
|
|
|
* Signature: (J)V
|
|
|
|
*/
|
|
|
|
void Java_org_rocksdb_RestoreBackupableDB_garbageCollect(
|
|
|
|
JNIEnv* env, jobject jobj, jlong jhandle) {
|
|
|
|
auto db = reinterpret_cast<rocksdb::RestoreBackupableDB*>(
|
|
|
|
jhandle);
|
|
|
|
rocksdb::Status s = db->GarbageCollect();
|
|
|
|
|
|
|
|
if (!s.ok()) {
|
|
|
|
rocksdb::RocksDBExceptionJni::ThrowNew(env, s);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-05-14 05:20:58 +00:00
|
|
|
/*
|
|
|
|
* Class: org_rocksdb_RestoreBackupableDB
|
|
|
|
* Method: dispose
|
|
|
|
* Signature: (J)V
|
|
|
|
*/
|
|
|
|
void Java_org_rocksdb_RestoreBackupableDB_dispose(JNIEnv* env, jobject jobj,
|
|
|
|
jlong jhandle) {
|
|
|
|
auto ropt = reinterpret_cast<rocksdb::RestoreBackupableDB*>(jhandle);
|
|
|
|
assert(ropt);
|
|
|
|
delete ropt;
|
2014-05-14 05:34:29 +00:00
|
|
|
}
|