@clarionhq/recorder 0.0.1 → 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +110 -0
- package/android/build.gradle +97 -0
- package/android/gradle.properties +4 -0
- package/android/src/main/AndroidManifest.xml +4 -0
- package/android/src/main/cpp/cpp-adapter.cpp +7 -0
- package/android/src/main/java/com/clarionhq/recorder/AudioLevelMeter.kt +38 -0
- package/android/src/main/java/com/clarionhq/recorder/ClarionRecorderPackage.kt +27 -0
- package/android/src/main/java/com/clarionhq/recorder/EncodeFile.kt +62 -0
- package/android/src/main/java/com/clarionhq/recorder/RecorderConfig.kt +33 -0
- package/android/src/main/java/com/clarionhq/recorder/RecorderConstants.kt +16 -0
- package/android/src/main/java/com/clarionhq/recorder/RecorderSession.kt +336 -0
- package/android/src/main/java/com/clarionhq/recorder/RecorderTypes.kt +29 -0
- package/android/src/main/java/com/margelo/nitro/clarion/recorder/HybridClarionRecorder.kt +174 -0
- package/clarionhq-recorder.podspec +31 -0
- package/ios/AudioLevelMeter.swift +37 -0
- package/ios/EncodeFile.swift +69 -0
- package/ios/HybridClarionRecorder.swift +186 -0
- package/ios/RecorderConstants.swift +11 -0
- package/ios/RecorderSession.swift +278 -0
- package/ios/RecorderTypes.swift +41 -0
- package/lib/RecorderEngine.d.ts +31 -0
- package/lib/RecorderEngine.d.ts.map +1 -0
- package/lib/RecorderEngine.js +245 -0
- package/lib/RecorderEngine.js.map +1 -0
- package/lib/index.d.ts +4 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +2 -0
- package/lib/index.js.map +1 -0
- package/lib/native.d.ts +3 -0
- package/lib/native.d.ts.map +1 -0
- package/lib/native.js +3 -0
- package/lib/native.js.map +1 -0
- package/lib/specs/ClarionRecorder.nitro.d.ts +49 -0
- package/lib/specs/ClarionRecorder.nitro.d.ts.map +1 -0
- package/lib/specs/ClarionRecorder.nitro.js +2 -0
- package/lib/specs/ClarionRecorder.nitro.js.map +1 -0
- package/nitro.json +24 -0
- package/nitrogen/generated/android/ClarionRecorder+autolinking.cmake +81 -0
- package/nitrogen/generated/android/ClarionRecorder+autolinking.gradle +27 -0
- package/nitrogen/generated/android/ClarionRecorderOnLoad.cpp +62 -0
- package/nitrogen/generated/android/ClarionRecorderOnLoad.hpp +34 -0
- package/nitrogen/generated/android/c++/JFunc_void_NativeRecorderError.hpp +78 -0
- package/nitrogen/generated/android/c++/JFunc_void_double_double.hpp +75 -0
- package/nitrogen/generated/android/c++/JFunc_void_std__string.hpp +76 -0
- package/nitrogen/generated/android/c++/JFunc_void_std__string_double_double_double.hpp +76 -0
- package/nitrogen/generated/android/c++/JHybridClarionRecorderSpec.cpp +207 -0
- package/nitrogen/generated/android/c++/JHybridClarionRecorderSpec.hpp +75 -0
- package/nitrogen/generated/android/c++/JNativeRecorderConfig.hpp +90 -0
- package/nitrogen/generated/android/c++/JNativeRecorderError.hpp +65 -0
- package/nitrogen/generated/android/c++/JNativeRecorderResult.hpp +77 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/clarion/recorder/ClarionRecorderOnLoad.kt +35 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/clarion/recorder/Func_void_NativeRecorderError.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/clarion/recorder/Func_void_double_double.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/clarion/recorder/Func_void_std__string.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/clarion/recorder/Func_void_std__string_double_double_double.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/clarion/recorder/HybridClarionRecorderSpec.kt +125 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/clarion/recorder/NativeRecorderConfig.kt +91 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/clarion/recorder/NativeRecorderError.kt +61 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/clarion/recorder/NativeRecorderResult.kt +76 -0
- package/nitrogen/generated/ios/ClarionRecorder+autolinking.rb +62 -0
- package/nitrogen/generated/ios/ClarionRecorder-Swift-Cxx-Bridge.cpp +89 -0
- package/nitrogen/generated/ios/ClarionRecorder-Swift-Cxx-Bridge.hpp +297 -0
- package/nitrogen/generated/ios/ClarionRecorder-Swift-Cxx-Umbrella.hpp +56 -0
- package/nitrogen/generated/ios/ClarionRecorderAutolinking.mm +33 -0
- package/nitrogen/generated/ios/ClarionRecorderAutolinking.swift +26 -0
- package/nitrogen/generated/ios/c++/HybridClarionRecorderSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridClarionRecorderSpecSwift.hpp +188 -0
- package/nitrogen/generated/ios/swift/Func_void.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_NativeRecorderError.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_NativeRecorderResult.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_double_double.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_std__exception_ptr.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_std__string.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_std__string_double_double_double.swift +46 -0
- package/nitrogen/generated/ios/swift/HybridClarionRecorderSpec.swift +67 -0
- package/nitrogen/generated/ios/swift/HybridClarionRecorderSpec_cxx.swift +354 -0
- package/nitrogen/generated/ios/swift/NativeRecorderConfig.swift +108 -0
- package/nitrogen/generated/ios/swift/NativeRecorderError.swift +39 -0
- package/nitrogen/generated/ios/swift/NativeRecorderResult.swift +54 -0
- package/nitrogen/generated/shared/c++/HybridClarionRecorderSpec.cpp +34 -0
- package/nitrogen/generated/shared/c++/HybridClarionRecorderSpec.hpp +84 -0
- package/nitrogen/generated/shared/c++/NativeRecorderConfig.hpp +116 -0
- package/nitrogen/generated/shared/c++/NativeRecorderError.hpp +91 -0
- package/nitrogen/generated/shared/c++/NativeRecorderResult.hpp +103 -0
- package/package.json +66 -8
- package/src/RecorderEngine.ts +298 -0
- package/src/index.ts +8 -0
- package/src/native.ts +5 -0
- package/src/specs/ClarionRecorder.nitro.ts +58 -0
- package/index.js +0 -1
|
@@ -0,0 +1,245 @@
|
|
|
1
|
+
import { ClarionEmitter, ClarionError, DEFAULT_AUDIO_FORMAT, assertTransition, } from '@clarionhq/core';
|
|
2
|
+
import { createNativeRecorder } from './native';
|
|
3
|
+
const VALID_STATES = [
|
|
4
|
+
'idle',
|
|
5
|
+
'preparing',
|
|
6
|
+
'ready',
|
|
7
|
+
'starting',
|
|
8
|
+
'recording',
|
|
9
|
+
'paused',
|
|
10
|
+
'stopping',
|
|
11
|
+
'error',
|
|
12
|
+
'released',
|
|
13
|
+
];
|
|
14
|
+
const isEngineState = (s) => VALID_STATES.includes(s);
|
|
15
|
+
// 32 kbps is the highest AAC-LC bitrate universally supported across iOS
|
|
16
|
+
// (Simulator + device) and Android for 16 kHz mono. Higher bitrates work
|
|
17
|
+
// on Android but iOS's AAC encoder rejects them with
|
|
18
|
+
// kAudioFormatUnsupportedDataFormatError. Callers can override for higher
|
|
19
|
+
// sample rates / stereo where larger values are accepted.
|
|
20
|
+
const DEFAULT_AAC_BITRATE = 32_000;
|
|
21
|
+
const DEFAULT_AUDIO_LEVEL_INTERVAL_MS = 50;
|
|
22
|
+
export class RecorderEngine {
|
|
23
|
+
kind = 'recorder';
|
|
24
|
+
emitter = new ClarionEmitter();
|
|
25
|
+
native;
|
|
26
|
+
listenerIds = [];
|
|
27
|
+
options;
|
|
28
|
+
currentState = 'idle';
|
|
29
|
+
constructor(options = {}) {
|
|
30
|
+
this.options = options;
|
|
31
|
+
this.native = createNativeRecorder();
|
|
32
|
+
this.bindNativeListeners();
|
|
33
|
+
}
|
|
34
|
+
get state() {
|
|
35
|
+
return this.currentState;
|
|
36
|
+
}
|
|
37
|
+
on(listener) {
|
|
38
|
+
return this.emitter.on(listener);
|
|
39
|
+
}
|
|
40
|
+
async prepare() {
|
|
41
|
+
this.transitionTo('preparing');
|
|
42
|
+
try {
|
|
43
|
+
const config = this.buildNativeConfig();
|
|
44
|
+
await this.native.prepare(config);
|
|
45
|
+
// Native side fires state='ready' via the state listener — no JS-side transition needed.
|
|
46
|
+
}
|
|
47
|
+
catch (err) {
|
|
48
|
+
this.handleNativeError(err, 'prepare');
|
|
49
|
+
throw err;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
async start() {
|
|
53
|
+
// Auto-recover from a previous error — caller can retry without manual reset.
|
|
54
|
+
if (this.currentState === 'error') {
|
|
55
|
+
this.setState('idle');
|
|
56
|
+
}
|
|
57
|
+
// Auto-prepare if no session yet — callers don't need to know about prepare().
|
|
58
|
+
if (this.currentState === 'idle') {
|
|
59
|
+
await this.prepare();
|
|
60
|
+
}
|
|
61
|
+
if (this.currentState !== 'ready') {
|
|
62
|
+
throw new ClarionError({
|
|
63
|
+
code: 'INVALID_STATE',
|
|
64
|
+
message: `Cannot start from state '${this.currentState}'`,
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
this.transitionTo('starting');
|
|
68
|
+
try {
|
|
69
|
+
await this.native.start();
|
|
70
|
+
// Native side fires state='recording' via the state listener.
|
|
71
|
+
}
|
|
72
|
+
catch (err) {
|
|
73
|
+
this.handleNativeError(err, 'start');
|
|
74
|
+
throw err;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
async pause() {
|
|
78
|
+
if (this.currentState !== 'recording') {
|
|
79
|
+
throw new ClarionError({
|
|
80
|
+
code: 'INVALID_STATE',
|
|
81
|
+
message: `Cannot pause from state '${this.currentState}'`,
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
try {
|
|
85
|
+
await this.native.pause();
|
|
86
|
+
}
|
|
87
|
+
catch (err) {
|
|
88
|
+
this.handleNativeError(err, 'pause');
|
|
89
|
+
throw err;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
async resume() {
|
|
93
|
+
if (this.currentState !== 'paused') {
|
|
94
|
+
throw new ClarionError({
|
|
95
|
+
code: 'INVALID_STATE',
|
|
96
|
+
message: `Cannot resume from state '${this.currentState}'`,
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
try {
|
|
100
|
+
await this.native.resume();
|
|
101
|
+
}
|
|
102
|
+
catch (err) {
|
|
103
|
+
this.handleNativeError(err, 'resume');
|
|
104
|
+
throw err;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
async stop() {
|
|
108
|
+
this.transitionTo('stopping');
|
|
109
|
+
try {
|
|
110
|
+
const result = await this.native.stop();
|
|
111
|
+
this.emitter.emit({
|
|
112
|
+
type: 'recording-complete',
|
|
113
|
+
result: this.toRecorderResult(result),
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
catch (err) {
|
|
117
|
+
this.handleNativeError(err, 'stop');
|
|
118
|
+
throw err;
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
async discard() {
|
|
122
|
+
try {
|
|
123
|
+
await this.native.discard();
|
|
124
|
+
}
|
|
125
|
+
catch (err) {
|
|
126
|
+
this.handleNativeError(err, 'discard');
|
|
127
|
+
throw err;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
async release() {
|
|
131
|
+
try {
|
|
132
|
+
this.native.removeAllListeners();
|
|
133
|
+
await this.native.release();
|
|
134
|
+
}
|
|
135
|
+
finally {
|
|
136
|
+
this.listenerIds.length = 0;
|
|
137
|
+
this.emitter.removeAll();
|
|
138
|
+
this.currentState = 'released';
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
buildNativeConfig() {
|
|
142
|
+
const format = DEFAULT_AUDIO_FORMAT;
|
|
143
|
+
const cfg = {
|
|
144
|
+
sampleRate: format.sampleRate,
|
|
145
|
+
channels: format.channels,
|
|
146
|
+
bitDepth: format.bitDepth,
|
|
147
|
+
emitAudioLevel: this.options.emitAudioLevel ?? false,
|
|
148
|
+
audioLevelIntervalMs: this.options.audioLevelIntervalMs ?? DEFAULT_AUDIO_LEVEL_INTERVAL_MS,
|
|
149
|
+
aacBitrate: this.options.aacBitrate ?? DEFAULT_AAC_BITRATE,
|
|
150
|
+
};
|
|
151
|
+
if (this.options.outputDirectory !== undefined) {
|
|
152
|
+
cfg.outputDirectory = this.options.outputDirectory;
|
|
153
|
+
}
|
|
154
|
+
if (this.options.filenamePrefix !== undefined) {
|
|
155
|
+
cfg.filenamePrefix = this.options.filenamePrefix;
|
|
156
|
+
}
|
|
157
|
+
if (this.options.rotateAfterMs !== undefined) {
|
|
158
|
+
cfg.rotateAfterMs = this.options.rotateAfterMs;
|
|
159
|
+
}
|
|
160
|
+
return cfg;
|
|
161
|
+
}
|
|
162
|
+
bindNativeListeners() {
|
|
163
|
+
this.listenerIds.push(this.native.addStateListener((nativeState) => {
|
|
164
|
+
if (!isEngineState(nativeState))
|
|
165
|
+
return;
|
|
166
|
+
this.setState(nativeState);
|
|
167
|
+
}));
|
|
168
|
+
this.listenerIds.push(this.native.addAudioLevelListener((rms, peak) => {
|
|
169
|
+
this.emitter.emit({ type: 'audio-level', rms, peak });
|
|
170
|
+
}));
|
|
171
|
+
this.listenerIds.push(this.native.addChunkListener((uri, startMs, endMs, sizeBytes) => {
|
|
172
|
+
this.emitter.emit({
|
|
173
|
+
type: 'chunk',
|
|
174
|
+
uri,
|
|
175
|
+
startMs,
|
|
176
|
+
endMs,
|
|
177
|
+
sizeBytes,
|
|
178
|
+
});
|
|
179
|
+
}));
|
|
180
|
+
this.listenerIds.push(this.native.addErrorListener((err) => {
|
|
181
|
+
this.emitter.emit({
|
|
182
|
+
type: 'error',
|
|
183
|
+
error: this.toClarionError(err),
|
|
184
|
+
});
|
|
185
|
+
}));
|
|
186
|
+
}
|
|
187
|
+
transitionTo(next) {
|
|
188
|
+
if (this.currentState === next)
|
|
189
|
+
return;
|
|
190
|
+
assertTransition(this.currentState, next);
|
|
191
|
+
this.setState(next);
|
|
192
|
+
}
|
|
193
|
+
setState(next) {
|
|
194
|
+
if (this.currentState === next)
|
|
195
|
+
return;
|
|
196
|
+
this.currentState = next;
|
|
197
|
+
this.emitter.emit({ type: 'state', state: next });
|
|
198
|
+
}
|
|
199
|
+
toRecorderResult(r) {
|
|
200
|
+
return {
|
|
201
|
+
uri: r.uri,
|
|
202
|
+
durationMs: r.durationMs,
|
|
203
|
+
sizeBytes: r.sizeBytes,
|
|
204
|
+
container: 'm4a',
|
|
205
|
+
audioFormat: {
|
|
206
|
+
sampleRate: r.sampleRate,
|
|
207
|
+
channels: r.channels,
|
|
208
|
+
bitDepth: r.bitDepth,
|
|
209
|
+
},
|
|
210
|
+
};
|
|
211
|
+
}
|
|
212
|
+
toClarionError(err) {
|
|
213
|
+
return new ClarionError({
|
|
214
|
+
code: this.mapErrorCode(err.code),
|
|
215
|
+
message: err.message,
|
|
216
|
+
recoverable: err.recoverable,
|
|
217
|
+
});
|
|
218
|
+
}
|
|
219
|
+
mapErrorCode(code) {
|
|
220
|
+
const known = {
|
|
221
|
+
PERMISSION_DENIED: 'PERMISSION_DENIED',
|
|
222
|
+
AUDIO_BUSY: 'AUDIO_BUSY',
|
|
223
|
+
IO_ERROR: 'IO_ERROR',
|
|
224
|
+
INTERRUPTED: 'INTERRUPTED',
|
|
225
|
+
CANCELLED: 'CANCELLED',
|
|
226
|
+
ENGINE_NOT_READY: 'ENGINE_NOT_READY',
|
|
227
|
+
INVALID_STATE: 'INVALID_STATE',
|
|
228
|
+
UNSUPPORTED_FORMAT: 'UNSUPPORTED_FORMAT',
|
|
229
|
+
INTERNAL_ERROR: 'INTERNAL_ERROR',
|
|
230
|
+
};
|
|
231
|
+
return known[code] ?? 'UNKNOWN';
|
|
232
|
+
}
|
|
233
|
+
handleNativeError(err, where) {
|
|
234
|
+
const error = err instanceof ClarionError
|
|
235
|
+
? err
|
|
236
|
+
: new ClarionError({
|
|
237
|
+
code: 'INTERNAL_ERROR',
|
|
238
|
+
message: `Recorder ${where} failed: ${String(err)}`,
|
|
239
|
+
cause: err,
|
|
240
|
+
});
|
|
241
|
+
this.emitter.emit({ type: 'error', error });
|
|
242
|
+
this.setState('error');
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
//# sourceMappingURL=RecorderEngine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RecorderEngine.js","sourceRoot":"","sources":["../src/RecorderEngine.ts"],"names":[],"mappings":"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"}
|
package/lib/index.d.ts
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { RecorderEngine } from './RecorderEngine';
|
|
2
|
+
export type { RecorderEngineOptions } from './RecorderEngine';
|
|
3
|
+
export type { ClarionRecorder, NativeRecorderConfig, NativeRecorderResult, NativeRecorderError, } from './specs/ClarionRecorder.nitro';
|
|
4
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,YAAY,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAC9D,YAAY,EACV,eAAe,EACf,oBAAoB,EACpB,oBAAoB,EACpB,mBAAmB,GACpB,MAAM,+BAA+B,CAAC"}
|
package/lib/index.js
ADDED
package/lib/index.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC"}
|
package/lib/native.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"native.d.ts","sourceRoot":"","sources":["../src/native.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAErE,eAAO,MAAM,oBAAoB,QAAO,eAC6B,CAAC"}
|
package/lib/native.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"native.js","sourceRoot":"","sources":["../src/native.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAG1D,MAAM,CAAC,MAAM,oBAAoB,GAAG,GAAoB,EAAE,CACxD,YAAY,CAAC,kBAAkB,CAAkB,iBAAiB,CAAC,CAAC"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import type { HybridObject } from 'react-native-nitro-modules';
|
|
2
|
+
export interface NativeRecorderConfig {
|
|
3
|
+
sampleRate: number;
|
|
4
|
+
channels: number;
|
|
5
|
+
bitDepth: number;
|
|
6
|
+
outputDirectory?: string;
|
|
7
|
+
filenamePrefix?: string;
|
|
8
|
+
rotateAfterMs?: number;
|
|
9
|
+
emitAudioLevel: boolean;
|
|
10
|
+
audioLevelIntervalMs: number;
|
|
11
|
+
aacBitrate: number;
|
|
12
|
+
}
|
|
13
|
+
export interface NativeRecorderResult {
|
|
14
|
+
uri: string;
|
|
15
|
+
durationMs: number;
|
|
16
|
+
sizeBytes: number;
|
|
17
|
+
sampleRate: number;
|
|
18
|
+
channels: number;
|
|
19
|
+
bitDepth: number;
|
|
20
|
+
}
|
|
21
|
+
export interface NativeRecorderError {
|
|
22
|
+
code: string;
|
|
23
|
+
message: string;
|
|
24
|
+
recoverable: boolean;
|
|
25
|
+
}
|
|
26
|
+
export type StateListener = (state: string) => void;
|
|
27
|
+
export type AudioLevelListener = (rms: number, peak: number) => void;
|
|
28
|
+
export type ChunkListener = (uri: string, startMs: number, endMs: number, sizeBytes: number) => void;
|
|
29
|
+
export type ErrorListener = (error: NativeRecorderError) => void;
|
|
30
|
+
export interface ClarionRecorder extends HybridObject<{
|
|
31
|
+
ios: 'swift';
|
|
32
|
+
android: 'kotlin';
|
|
33
|
+
}> {
|
|
34
|
+
readonly state: string;
|
|
35
|
+
prepare(config: NativeRecorderConfig): Promise<void>;
|
|
36
|
+
start(): Promise<void>;
|
|
37
|
+
pause(): Promise<void>;
|
|
38
|
+
resume(): Promise<void>;
|
|
39
|
+
stop(): Promise<NativeRecorderResult>;
|
|
40
|
+
discard(): Promise<void>;
|
|
41
|
+
release(): Promise<void>;
|
|
42
|
+
addStateListener(listener: StateListener): number;
|
|
43
|
+
addAudioLevelListener(listener: AudioLevelListener): number;
|
|
44
|
+
addChunkListener(listener: ChunkListener): number;
|
|
45
|
+
addErrorListener(listener: ErrorListener): number;
|
|
46
|
+
removeListener(id: number): void;
|
|
47
|
+
removeAllListeners(): void;
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=ClarionRecorder.nitro.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ClarionRecorder.nitro.d.ts","sourceRoot":"","sources":["../../src/specs/ClarionRecorder.nitro.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAE/D,MAAM,WAAW,oBAAoB;IACnC,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,cAAc,EAAE,OAAO,CAAC;IACxB,oBAAoB,EAAE,MAAM,CAAC;IAC7B,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,oBAAoB;IACnC,GAAG,EAAE,MAAM,CAAC;IACZ,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,mBAAmB;IAClC,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,OAAO,CAAC;CACtB;AAED,MAAM,MAAM,aAAa,GAAG,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;AACpD,MAAM,MAAM,kBAAkB,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;AACrE,MAAM,MAAM,aAAa,GAAG,CAC1B,GAAG,EAAE,MAAM,EACX,OAAO,EAAE,MAAM,EACf,KAAK,EAAE,MAAM,EACb,SAAS,EAAE,MAAM,KACd,IAAI,CAAC;AACV,MAAM,MAAM,aAAa,GAAG,CAAC,KAAK,EAAE,mBAAmB,KAAK,IAAI,CAAC;AAEjE,MAAM,WAAW,eACf,SAAQ,YAAY,CAAC;IAAE,GAAG,EAAE,OAAO,CAAC;IAAC,OAAO,EAAE,QAAQ,CAAA;CAAE,CAAC;IACzD,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IAEvB,OAAO,CAAC,MAAM,EAAE,oBAAoB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACrD,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IACvB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IACvB,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IACxB,IAAI,IAAI,OAAO,CAAC,oBAAoB,CAAC,CAAC;IACtC,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IACzB,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEzB,gBAAgB,CAAC,QAAQ,EAAE,aAAa,GAAG,MAAM,CAAC;IAClD,qBAAqB,CAAC,QAAQ,EAAE,kBAAkB,GAAG,MAAM,CAAC;IAC5D,gBAAgB,CAAC,QAAQ,EAAE,aAAa,GAAG,MAAM,CAAC;IAClD,gBAAgB,CAAC,QAAQ,EAAE,aAAa,GAAG,MAAM,CAAC;IAClD,cAAc,CAAC,EAAE,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,kBAAkB,IAAI,IAAI,CAAC;CAC5B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ClarionRecorder.nitro.js","sourceRoot":"","sources":["../../src/specs/ClarionRecorder.nitro.ts"],"names":[],"mappings":""}
|
package/nitro.json
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "https://nitro.margelo.com/nitro.schema.json",
|
|
3
|
+
"cxxNamespace": ["clarion", "recorder"],
|
|
4
|
+
"ios": {
|
|
5
|
+
"iosModuleName": "ClarionRecorder"
|
|
6
|
+
},
|
|
7
|
+
"android": {
|
|
8
|
+
"androidNamespace": ["clarion", "recorder"],
|
|
9
|
+
"androidCxxLibName": "ClarionRecorder"
|
|
10
|
+
},
|
|
11
|
+
"autolinking": {
|
|
12
|
+
"ClarionRecorder": {
|
|
13
|
+
"ios": {
|
|
14
|
+
"language": "swift",
|
|
15
|
+
"implementationClassName": "HybridClarionRecorder"
|
|
16
|
+
},
|
|
17
|
+
"android": {
|
|
18
|
+
"language": "kotlin",
|
|
19
|
+
"implementationClassName": "HybridClarionRecorder"
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
"ignorePaths": ["node_modules", "lib"]
|
|
24
|
+
}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
#
|
|
2
|
+
# ClarionRecorder+autolinking.cmake
|
|
3
|
+
# This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
# https://github.com/mrousavy/nitro
|
|
5
|
+
# Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
#
|
|
7
|
+
|
|
8
|
+
# This is a CMake file that adds all files generated by Nitrogen
|
|
9
|
+
# to the current CMake project.
|
|
10
|
+
#
|
|
11
|
+
# To use it, add this to your CMakeLists.txt:
|
|
12
|
+
# ```cmake
|
|
13
|
+
# include(${CMAKE_SOURCE_DIR}/../nitrogen/generated/android/ClarionRecorder+autolinking.cmake)
|
|
14
|
+
# ```
|
|
15
|
+
|
|
16
|
+
# Define a flag to check if we are building properly
|
|
17
|
+
add_definitions(-DBUILDING_CLARIONRECORDER_WITH_GENERATED_CMAKE_PROJECT)
|
|
18
|
+
|
|
19
|
+
# Enable Raw Props parsing in react-native (for Nitro Views)
|
|
20
|
+
add_definitions(-DRN_SERIALIZABLE_STATE)
|
|
21
|
+
|
|
22
|
+
# Add all headers that were generated by Nitrogen
|
|
23
|
+
include_directories(
|
|
24
|
+
"../nitrogen/generated/shared/c++"
|
|
25
|
+
"../nitrogen/generated/android/c++"
|
|
26
|
+
"../nitrogen/generated/android/"
|
|
27
|
+
)
|
|
28
|
+
|
|
29
|
+
# Add all .cpp sources that were generated by Nitrogen
|
|
30
|
+
target_sources(
|
|
31
|
+
# CMake project name (Android C++ library name)
|
|
32
|
+
ClarionRecorder PRIVATE
|
|
33
|
+
# Autolinking Setup
|
|
34
|
+
../nitrogen/generated/android/ClarionRecorderOnLoad.cpp
|
|
35
|
+
# Shared Nitrogen C++ sources
|
|
36
|
+
../nitrogen/generated/shared/c++/HybridClarionRecorderSpec.cpp
|
|
37
|
+
# Android-specific Nitrogen C++ sources
|
|
38
|
+
../nitrogen/generated/android/c++/JHybridClarionRecorderSpec.cpp
|
|
39
|
+
)
|
|
40
|
+
|
|
41
|
+
# From node_modules/react-native/ReactAndroid/cmake-utils/folly-flags.cmake
|
|
42
|
+
# Used in node_modules/react-native/ReactAndroid/cmake-utils/ReactNative-application.cmake
|
|
43
|
+
target_compile_definitions(
|
|
44
|
+
ClarionRecorder PRIVATE
|
|
45
|
+
-DFOLLY_NO_CONFIG=1
|
|
46
|
+
-DFOLLY_HAVE_CLOCK_GETTIME=1
|
|
47
|
+
-DFOLLY_USE_LIBCPP=1
|
|
48
|
+
-DFOLLY_CFG_NO_COROUTINES=1
|
|
49
|
+
-DFOLLY_MOBILE=1
|
|
50
|
+
-DFOLLY_HAVE_RECVMMSG=1
|
|
51
|
+
-DFOLLY_HAVE_PTHREAD=1
|
|
52
|
+
# Once we target android-23 above, we can comment
|
|
53
|
+
# the following line. NDK uses GNU style stderror_r() after API 23.
|
|
54
|
+
-DFOLLY_HAVE_XSI_STRERROR_R=1
|
|
55
|
+
)
|
|
56
|
+
|
|
57
|
+
# Add all libraries required by the generated specs
|
|
58
|
+
find_package(fbjni REQUIRED) # <-- Used for communication between Java <-> C++
|
|
59
|
+
find_package(ReactAndroid REQUIRED) # <-- Used to set up React Native bindings (e.g. CallInvoker/TurboModule)
|
|
60
|
+
find_package(react-native-nitro-modules REQUIRED) # <-- Used to create all HybridObjects and use the Nitro core library
|
|
61
|
+
|
|
62
|
+
# Link all libraries together
|
|
63
|
+
target_link_libraries(
|
|
64
|
+
ClarionRecorder
|
|
65
|
+
fbjni::fbjni # <-- Facebook C++ JNI helpers
|
|
66
|
+
ReactAndroid::jsi # <-- RN: JSI
|
|
67
|
+
react-native-nitro-modules::NitroModules # <-- NitroModules Core :)
|
|
68
|
+
)
|
|
69
|
+
|
|
70
|
+
# Link react-native (different prefab between RN 0.75 and RN 0.76)
|
|
71
|
+
if(ReactAndroid_VERSION_MINOR GREATER_EQUAL 76)
|
|
72
|
+
target_link_libraries(
|
|
73
|
+
ClarionRecorder
|
|
74
|
+
ReactAndroid::reactnative # <-- RN: Native Modules umbrella prefab
|
|
75
|
+
)
|
|
76
|
+
else()
|
|
77
|
+
target_link_libraries(
|
|
78
|
+
ClarionRecorder
|
|
79
|
+
ReactAndroid::react_nativemodule_core # <-- RN: TurboModules Core
|
|
80
|
+
)
|
|
81
|
+
endif()
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// ClarionRecorder+autolinking.gradle
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
/// This is a Gradle file that adds all files generated by Nitrogen
|
|
9
|
+
/// to the current Gradle project.
|
|
10
|
+
///
|
|
11
|
+
/// To use it, add this to your build.gradle:
|
|
12
|
+
/// ```gradle
|
|
13
|
+
/// apply from: '../nitrogen/generated/android/ClarionRecorder+autolinking.gradle'
|
|
14
|
+
/// ```
|
|
15
|
+
|
|
16
|
+
logger.warn("[NitroModules] 🔥 ClarionRecorder is boosted by nitro!")
|
|
17
|
+
|
|
18
|
+
android {
|
|
19
|
+
sourceSets {
|
|
20
|
+
main {
|
|
21
|
+
java.srcDirs += [
|
|
22
|
+
// Nitrogen files
|
|
23
|
+
"${project.projectDir}/../nitrogen/generated/android/kotlin"
|
|
24
|
+
]
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// ClarionRecorderOnLoad.cpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#ifndef BUILDING_CLARIONRECORDER_WITH_GENERATED_CMAKE_PROJECT
|
|
9
|
+
#error ClarionRecorderOnLoad.cpp is not being built with the autogenerated CMakeLists.txt project. Is a different CMakeLists.txt building this?
|
|
10
|
+
#endif
|
|
11
|
+
|
|
12
|
+
#include "ClarionRecorderOnLoad.hpp"
|
|
13
|
+
|
|
14
|
+
#include <jni.h>
|
|
15
|
+
#include <fbjni/fbjni.h>
|
|
16
|
+
#include <NitroModules/HybridObjectRegistry.hpp>
|
|
17
|
+
|
|
18
|
+
#include "JHybridClarionRecorderSpec.hpp"
|
|
19
|
+
#include "JFunc_void_std__string.hpp"
|
|
20
|
+
#include "JFunc_void_double_double.hpp"
|
|
21
|
+
#include "JFunc_void_std__string_double_double_double.hpp"
|
|
22
|
+
#include "JFunc_void_NativeRecorderError.hpp"
|
|
23
|
+
#include <NitroModules/DefaultConstructableObject.hpp>
|
|
24
|
+
|
|
25
|
+
namespace margelo::nitro::clarion::recorder {
|
|
26
|
+
|
|
27
|
+
int initialize(JavaVM* vm) {
|
|
28
|
+
return facebook::jni::initialize(vm, []() {
|
|
29
|
+
::margelo::nitro::clarion::recorder::registerAllNatives();
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
struct JHybridClarionRecorderSpecImpl: public jni::JavaClass<JHybridClarionRecorderSpecImpl, JHybridClarionRecorderSpec::JavaPart> {
|
|
34
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/clarion/recorder/HybridClarionRecorder;";
|
|
35
|
+
static std::shared_ptr<JHybridClarionRecorderSpec> create() {
|
|
36
|
+
static const auto constructorFn = javaClassStatic()->getConstructor<JHybridClarionRecorderSpecImpl::javaobject()>();
|
|
37
|
+
jni::local_ref<JHybridClarionRecorderSpec::JavaPart> javaPart = javaClassStatic()->newObject(constructorFn);
|
|
38
|
+
return javaPart->getJHybridClarionRecorderSpec();
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
void registerAllNatives() {
|
|
43
|
+
using namespace margelo::nitro;
|
|
44
|
+
using namespace margelo::nitro::clarion::recorder;
|
|
45
|
+
|
|
46
|
+
// Register native JNI methods
|
|
47
|
+
margelo::nitro::clarion::recorder::JHybridClarionRecorderSpec::CxxPart::registerNatives();
|
|
48
|
+
margelo::nitro::clarion::recorder::JFunc_void_std__string_cxx::registerNatives();
|
|
49
|
+
margelo::nitro::clarion::recorder::JFunc_void_double_double_cxx::registerNatives();
|
|
50
|
+
margelo::nitro::clarion::recorder::JFunc_void_std__string_double_double_double_cxx::registerNatives();
|
|
51
|
+
margelo::nitro::clarion::recorder::JFunc_void_NativeRecorderError_cxx::registerNatives();
|
|
52
|
+
|
|
53
|
+
// Register Nitro Hybrid Objects
|
|
54
|
+
HybridObjectRegistry::registerHybridObjectConstructor(
|
|
55
|
+
"ClarionRecorder",
|
|
56
|
+
[]() -> std::shared_ptr<HybridObject> {
|
|
57
|
+
return JHybridClarionRecorderSpecImpl::create();
|
|
58
|
+
}
|
|
59
|
+
);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
} // namespace margelo::nitro::clarion::recorder
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// ClarionRecorderOnLoad.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#include <jni.h>
|
|
9
|
+
#include <functional>
|
|
10
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
11
|
+
|
|
12
|
+
namespace margelo::nitro::clarion::recorder {
|
|
13
|
+
|
|
14
|
+
[[deprecated("Use registerNatives() instead.")]]
|
|
15
|
+
int initialize(JavaVM* vm);
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Register the native (C++) part of ClarionRecorder, and autolinks all Hybrid Objects.
|
|
19
|
+
* Call this in your `JNI_OnLoad` function (probably inside `cpp-adapter.cpp`),
|
|
20
|
+
* inside a `facebook::jni::initialize(vm, ...)` call.
|
|
21
|
+
* Example:
|
|
22
|
+
* ```cpp (cpp-adapter.cpp)
|
|
23
|
+
* JNIEXPORT jint JNICALL JNI_OnLoad(JavaVM* vm, void*) {
|
|
24
|
+
* return facebook::jni::initialize(vm, []() {
|
|
25
|
+
* // register all ClarionRecorder HybridObjects
|
|
26
|
+
* margelo::nitro::clarion::recorder::registerNatives();
|
|
27
|
+
* // any other custom registrations go here.
|
|
28
|
+
* });
|
|
29
|
+
* }
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
32
|
+
void registerAllNatives();
|
|
33
|
+
|
|
34
|
+
} // namespace margelo::nitro::clarion::recorder
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// JFunc_void_NativeRecorderError.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#include <fbjni/fbjni.h>
|
|
11
|
+
#include <functional>
|
|
12
|
+
|
|
13
|
+
#include "NativeRecorderError.hpp"
|
|
14
|
+
#include <functional>
|
|
15
|
+
#include <NitroModules/JNICallable.hpp>
|
|
16
|
+
#include "JNativeRecorderError.hpp"
|
|
17
|
+
#include <string>
|
|
18
|
+
|
|
19
|
+
namespace margelo::nitro::clarion::recorder {
|
|
20
|
+
|
|
21
|
+
using namespace facebook;
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* Represents the Java/Kotlin callback `(error: NativeRecorderError) -> Unit`.
|
|
25
|
+
* This can be passed around between C++ and Java/Kotlin.
|
|
26
|
+
*/
|
|
27
|
+
struct JFunc_void_NativeRecorderError: public jni::JavaClass<JFunc_void_NativeRecorderError> {
|
|
28
|
+
public:
|
|
29
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/clarion/recorder/Func_void_NativeRecorderError;";
|
|
30
|
+
|
|
31
|
+
public:
|
|
32
|
+
/**
|
|
33
|
+
* Invokes the function this `JFunc_void_NativeRecorderError` instance holds through JNI.
|
|
34
|
+
*/
|
|
35
|
+
void invoke(const NativeRecorderError& error) const {
|
|
36
|
+
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<JNativeRecorderError> /* error */)>("invoke");
|
|
37
|
+
method(self(), JNativeRecorderError::fromCpp(error));
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* An implementation of Func_void_NativeRecorderError that is backed by a C++ implementation (using `std::function<...>`)
|
|
43
|
+
*/
|
|
44
|
+
class JFunc_void_NativeRecorderError_cxx final: public jni::HybridClass<JFunc_void_NativeRecorderError_cxx, JFunc_void_NativeRecorderError> {
|
|
45
|
+
public:
|
|
46
|
+
static jni::local_ref<JFunc_void_NativeRecorderError::javaobject> fromCpp(const std::function<void(const NativeRecorderError& /* error */)>& func) {
|
|
47
|
+
return JFunc_void_NativeRecorderError_cxx::newObjectCxxArgs(func);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
public:
|
|
51
|
+
/**
|
|
52
|
+
* Invokes the C++ `std::function<...>` this `JFunc_void_NativeRecorderError_cxx` instance holds.
|
|
53
|
+
*/
|
|
54
|
+
void invoke_cxx(jni::alias_ref<JNativeRecorderError> error) {
|
|
55
|
+
_func(error->toCpp());
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
public:
|
|
59
|
+
[[nodiscard]]
|
|
60
|
+
inline const std::function<void(const NativeRecorderError& /* error */)>& getFunction() const {
|
|
61
|
+
return _func;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
public:
|
|
65
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/clarion/recorder/Func_void_NativeRecorderError_cxx;";
|
|
66
|
+
static void registerNatives() {
|
|
67
|
+
registerHybrid({makeNativeMethod("invoke_cxx", JFunc_void_NativeRecorderError_cxx::invoke_cxx)});
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
private:
|
|
71
|
+
explicit JFunc_void_NativeRecorderError_cxx(const std::function<void(const NativeRecorderError& /* error */)>& func): _func(func) { }
|
|
72
|
+
|
|
73
|
+
private:
|
|
74
|
+
friend HybridBase;
|
|
75
|
+
std::function<void(const NativeRecorderError& /* error */)> _func;
|
|
76
|
+
};
|
|
77
|
+
|
|
78
|
+
} // namespace margelo::nitro::clarion::recorder
|