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
|
/*
* Copyright 2017 Google
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#import <Foundation/Foundation.h>
#include <memory>
#import "Firestore/Source/Local/FSTPersistence.h"
#include "Firestore/core/src/firebase/firestore/core/database_info.h"
#include "Firestore/core/src/firebase/firestore/local/leveldb_transaction.h"
#include "leveldb/db.h"
@class FSTLocalSerializer;
NS_ASSUME_NONNULL_BEGIN
/** A LevelDB-backed instance of FSTPersistence. */
// TODO(mikelehen): Rename to FSTLevelDBPersistence.
@interface FSTLevelDB : NSObject <FSTPersistence, FSTTransactional>
/**
* Initializes the LevelDB in the given directory. Note that all expensive startup work including
* opening any database files is deferred until -[FSTPersistence start] is called.
*/
- (instancetype)initWithDirectory:(NSString *)directory
serializer:(FSTLocalSerializer *)serializer NS_DESIGNATED_INITIALIZER;
- (instancetype)init __attribute__((unavailable("Use -initWithDirectory: instead.")));
/** Finds a suitable directory to serve as the root of all Firestore local storage. */
+ (NSString *)documentsDirectory;
/**
* Computes a unique storage directory for the given identifying components of local storage.
*
* @param databaseInfo The identifying information for the local storage instance.
* @param documentsDirectory The root document directory relative to which the storage directory
* will be created. Usually just +[FSTLevelDB documentsDir].
* @return A storage directory unique to the instance identified by databaseInfo.
*/
+ (NSString *)storageDirectoryForDatabaseInfo:
(const firebase::firestore::core::DatabaseInfo &)databaseInfo
documentsDirectory:(NSString *)documentsDirectory;
/**
* Starts LevelDB-backed persistent storage by opening the database files, creating the DB if it
* does not exist.
*
* The leveldb directory is created relative to the appropriate document storage directory for the
* platform: NSDocumentDirectory on iOS or $HOME/.firestore on macOS.
*/
- (BOOL)start:(NSError **)error;
// What follows is the Objective-C++ extension to the API.
/**
* @return A standard set of read options
*/
+ (const leveldb::ReadOptions)standardReadOptions;
/**
* Creates an NSError based on the given status if the status is not ok.
*
* @param status The status of the preceding LevelDB operation.
* @param description A printf-style format string describing what kind of failure happened if
* @a status is not ok. Additional parameters are substituted into the placeholders in this
* format string.
*
* @return An NSError with its localizedDescription composed from the description format and its
* localizedFailureReason composed from any error message embedded in @a status.
*/
+ (nullable NSError *)errorWithStatus:(leveldb::Status)status
description:(NSString *)description, ... NS_FORMAT_FUNCTION(2, 3);
/**
* Converts the given @a status to an NSString describing the status condition, suitable for
* logging or inclusion in an NSError.
*
* @param status The status of the preceding LevelDB operation.
*
* @return An NSString describing the status (even if the status was ok).
*/
+ (NSString *)descriptionOfStatus:(leveldb::Status)status;
/** The native db pointer, allocated during start. */
@property(nonatomic, assign, readonly) leveldb::DB *ptr;
@property(nonatomic, readonly) firebase::firestore::local::LevelDbTransaction *currentTransaction;
@end
NS_ASSUME_NONNULL_END
|