-
Notifications
You must be signed in to change notification settings - Fork 888
/
Copy pathREADME.md
63 lines (49 loc) · 2.93 KB
/
README.md
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
<!--
Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements. See the NOTICE file
distributed with this work for additional information
regarding copyright ownership. The ASF licenses this file
to you 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.
-->
## API conventions
In previous versions, the driver relied solely on Java visibility rules: everything was either
private or part of the public API. This made it hard to cleanly organize the code, and things ended
up all together in one monolithic package; it also created a dilemma between providing useful hooks
for advanced users, or keeping them hidden to limit the API surface.
Starting with 4.0, we adopt a package naming convention to address those issues:
* Everything under `com.datastax.oss.driver.api` is part of the "official" public API of the driver,
intended for regular client applications to execute queries. It follows [semantic versioning]:
binary compatibility is guaranteed across minor and patch versions.
* Everything under `com.datastax.oss.driver.internal` is the "internal" API, intended primarily for
internal communication between driver components, and secondarily for advanced customization. If
you use it from your code, the rules are:
1. with great power comes great responsibility: this stuff is more involved, and has the
potential to break the driver. You should probably have some familiarity with the source
code.
2. backward compatibility is "best-effort" only: we'll try to preserve it as much as possible,
but it's not formally guaranteed.
The public API never exposes internal types (this is enforced automatically by our build). You'll
generally have to go through an explicit cast:
```java
import com.datastax.oss.driver.api.core.context.DriverContext;
import com.datastax.oss.driver.internal.core.context.InternalDriverContext;
import com.datastax.oss.driver.internal.core.metadata.TopologyEvent;
// Public API:
DriverContext context = session.getContext();
// Switch to the internal API to force a node down:
InternalDriverContext internalContext = (InternalDriverContext) context;
InetSocketAddress address = new InetSocketAddress("127.0.0.1", 9042);
internalContext.getEventBus().fire(TopologyEvent.forceDown(address));
```
So the risk of unintentionally using the internal API is very low. To double-check, you can always
grep `import com.datastax.oss.driver.internal` in your source files.
[semantic versioning]: http://semver.org/