-
Notifications
You must be signed in to change notification settings - Fork 1.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #1038 from casionone/restful-api
#993 [For Infra]Modify the restful api style & replace codehaus json with fastxml json
- Loading branch information
Showing
191 changed files
with
1,505 additions
and
1,539 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,180 @@ | ||
# Contributing | ||
|
||
| **Version Management Information Form** | | | ||
| ----------- | --------------------------------- | | ||
| Current version | Version 1.1, May 2021 | | ||
| Current version release date | May 6, 2021 | | ||
| Revision Information | 1. Add Issue submission guidelines and modify some descriptions | | ||
|
||
Thank you very much for contributing to the Linkis project! Before participating in the contribution, please read the following guidelines carefully. | ||
|
||
## 1. Contribution category | ||
|
||
### 1.1 Bug feedback and repair | ||
|
||
We recommend that whether it is a bug feedback or a fix, an issue is first created to describe the bug's status in detail, so that the community can find and review the problem and code through the issue record. Bug feedback Issues usually need to include **complete description of the bug information** and **reproducible scenarios** so that the community can quickly locate the cause of the bug and fix it. All open issues that contain the `#bug` tag need to be fixed. | ||
|
||
### 1.2 Functional communication, implementation, refactoring | ||
|
||
In the communication process, a detailed description of the details, mechanisms and usage scenarios of the new function (or refactoring) can promote it to be implemented better and faster (including test cases and codes, and CI/CD related work). **If you plan to implement a major feature (or refactoring), be sure to communicate with the core development team through Issue or other means** so that everyone can promote it in the most efficient way. Issues opened with the label of `#feature` are all new features that need to be implemented, and issues opened with the label of `#enhancement` are all features that need to be improved and refactored. | ||
|
||
### 1.3 Issue Q&A | ||
|
||
Helping to answer the usage questions in the Issue is a very valuable way to contribute to the Linkis community; there will always be new users in the community that will keep coming in. While helping new users, you can also show your expertise. | ||
|
||
### 1.4 Documentation improvements | ||
|
||
The Linkis document is located at [Linkis-Doc](https://github.com/WeBankFinTech/Linkis-Doc), and the supplement of the document is also crucial to the development of Linkis. | ||
|
||
### 1.5 Other | ||
Including participating in and helping to organize community exchanges, community operation activities, etc., and other activities that can help the Linkis project and the community. | ||
|
||
--- | ||
|
||
## 2. Contribution process | ||
|
||
### 2.1 Branch structure | ||
|
||
The Linkis source code may produce some temporary branches, but the only ones that are really meaningful are the following three branches: | ||
|
||
- master: The source code of the last stable release, and occasionally hotfix submissions; | ||
- release-*: stable release version;* | ||
- *dev-*: main development branch; | ||
- feature-*: Development branches for some larger new features that need to be jointly developed by the community | ||
|
||
Please note: The dev branch of major features will be named with corresponding naming instructions in addition to the version number, such as: dev-0.10.0-flink, which refers to the flink feature development branch of 0.10.0. | ||
|
||
### 2.2 Development Guidelines | ||
|
||
Linkis front-end and back-end code share the same code base, but they are separated in development. Before starting the development, please fork the Linkis project to your Github Repositories. When developing, please develop based on the Linkis code base in your Github Repositories. | ||
|
||
We recommend cloning the dev-* branch for development, so that the possibility of merge conflicts when submitting a PR to the main Linkis project will be much smaller | ||
|
||
```bash | ||
git clone https://github.com/yourname/Linkis.git --branch dev-* | ||
``` | ||
|
||
#### 2.2.1 Backend | ||
|
||
The user configuration is in the project root directory /config/, the project startup script and the upgrade patch script are in the project root directory /bin/, the back-end code and core configuration are in the server/ directory, and the log is in the project root directory /log/. Note: The project root directory referred to here refers to the directory configured by the environment variable LINKIS_HOME, and environment variables need to be configured during IDE development. For example, Idea's priority regarding environment variable loading: Configured in `Run/Debug Configurations` `Environment variables` —> System environment variables cached by IDE. | ||
|
||
##### 2.2.1.1 Directory structure | ||
|
||
1. Script | ||
|
||
``` | ||
├── bin # script directory | ||
├── install.sh # One-click deployment script | ||
├── start-all.sh # One-click start script | ||
└── stop-all.sh # One-click stop script | ||
``` | ||
|
||
2. Configuration | ||
|
||
``` | ||
├── config # User configuration directory | ||
├── config.sh # One-click deployment configuration file | ||
├── db.sh # One-click deployment database configuration | ||
``` | ||
|
||
3. Code directory structure | ||
|
||
For details, see [Linkis Code Directory Structure](https://github.com/WeBankFinTech/Linkis/wiki/Linkis%E6%BA%90%E7%A0%81%E5%B1%82%E7%BA%A7%E7 %BB%93%E6%9E%84%E8%AF%A6%E8%A7%A3) | ||
|
||
4. Log directory | ||
|
||
``` | ||
├── logs # log root directory | ||
``` | ||
|
||
##### 2.2.1.2 Environment Variables | ||
|
||
Configure system environment variable or IDE environment variable LINKIS_HOME, it is recommended to use IDE environment variable first. | ||
|
||
##### 2.2.1.3 Database | ||
|
||
1. Create the Linkis system database by yourself; | ||
2. Modify the corresponding information of the database in conf/db.sh and execute bin/install.sh or directly import db/linkis_*.sql on the database client. | ||
|
||
##### 2.2.1.4 Configuration file | ||
|
||
Modify the `application.yml` file in the resources/ directory of each microservice to configure related properties. | ||
|
||
##### 2.2.1.5 Packaging | ||
|
||
1. To open a complete release package, you need to modify the relevant version information in /assembly/src/main/assembly/assembly.xml in the root directory, and then execute: `mvn clean package` in the root directory; | ||
2. Open the package of each module and execute `mvn clean package` directly in the module directory. | ||
|
||
### 2.3 Issue submission guidelines | ||
- If you still don’t know how to initiate a PR to an open source project, please refer to [About issues](https://docs.github.com/en/github/managing-your-work-on-github/about-issues) | ||
- Issue name, which should briefly describe your problem or suggestion in one sentence; for the international promotion of the project, please write the issue in English or both Chinese and English. | ||
- For each Issue, please bring at least two labels, component and type, such as component=Computation Governance/EngineConn, type=Improvement. Reference: [issue #590](https://github.com/WeBankFinTech/Linkis/issues/ 590) | ||
|
||
### 2.3 Pull Request(PR) Submission Guidelines | ||
|
||
- If you still don’t know how to initiate a PR to an open source project, please refer to [About pull requests](https://docs.github.com/en/github/collaborating-with-issues-and-pull-requests/about-pull -requests) | ||
Whether it is a bug fix or a new feature development, please submit a PR to the dev-* branch. | ||
- PR and submission name follow the principle of `<type>(<scope>): <subject>`, for details, please refer to Ruan Yifeng's [Commit message and Change log writing guide](http://www.ruanyifeng.com/blog/ 2016/01/commit_message_change_log.html) this article. | ||
- If the PR contains new features, the document update should be included in this PR. | ||
- If this PR is not ready to merge, please add [WIP] prefix to the head of the name (WIP = work-in-progress). | ||
- All submissions to dev-* branches need to go through at least one review before they can be merged | ||
|
||
### 2.4 Review Standard | ||
|
||
Before contributing code, you can find out what kind of submissions are popular in Review. Simply put, if a submission can bring as many gains as possible and as few side effects or risks as possible, the higher the probability of it being merged, the faster the review will be. Submissions with high risk and low value are almost impossible to merge, and may be rejected Review. | ||
|
||
#### 2.4.1 Gain | ||
|
||
- Fix the main cause of the bug | ||
- Add or fix a function or problem that a large number of users urgently need | ||
- Simple and effective | ||
- Easy to test, with test cases | ||
- Reduce complexity and amount of code | ||
- Issues that have been discussed by the community and identified for improvement | ||
|
||
#### 2.4.2 Side effects and risks | ||
|
||
- Only fix the surface phenomenon of the bug | ||
- Introduce new features with high complexity | ||
- Add complexity to meet niche needs | ||
- Change stable existing API or semantics | ||
- Cause other functions to not operate normally | ||
- Add a lot of dependencies | ||
- Change the dependency version at will | ||
- Submit a large number of codes or changes at once | ||
|
||
#### 2.4.3 Reviewer notes | ||
|
||
- Please use a constructive tone to write comments | ||
- If you need to make changes by the submitter, please clearly state all the content that needs to be modified to complete the Pull Request | ||
- If a PR is found to have brought new problems after the merger, the Reviewer needs to contact the PR author and communicate to solve the problem; if the PR author cannot be contacted, the Reviewer needs to restore the PR | ||
|
||
--- | ||
|
||
## Three, advanced contribution | ||
|
||
### 3.1 About Committers (Collaborators) | ||
|
||
#### 3.1.1 How to become Committer | ||
|
||
If you have submitted a valuable PR to Linkis and have been merged, or contributed continuously for more than half a year, and have led the release of at least one version, you can find a PMC of the Linkis project through the official WeChat group, if he is willing to nominate you as a committer , And are willing to state your contribution to all PMC and Committer, then a vote will be initiated next; PMC and other Committers will vote together to decide whether to allow you to join, if you get enough votes, you will become Committer of the Linkis project . | ||
|
||
#### 3.1.2 Committer rights | ||
|
||
- You can join the official developer WeChat group to participate in discussions and formulate Linkis development plans | ||
- Can manage Issues, including closing and adding tags | ||
- Can create and manage project branches, except for master and dev-* branches | ||
- You can review the PR submitted to the dev-* branch | ||
- Can apply to become a Committee member | ||
|
||
### 3.2 About Committee | ||
|
||
#### 3.2.1 How to become a Committee member | ||
|
||
If you are the Committer of the Linkis project, and all your contributions have been approved by other Committee members, you can apply to become a member of the Linkis Committee, and other Committee members will vote together to decide whether to allow you to join. If you pass unanimously, you will Become a member of the Linkis Committee. | ||
|
||
#### 3.2.2 Rights of Committee members | ||
|
||
- You can merge PRs submitted by other Committers and contributors to the dev-** branch | ||
- Participate in determining the roadmap and development direction of the Linkis project | ||
- Can participate in the new version release |
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
Apache Linkis is an effort undergoing incubation at The Apache Software Foundation (ASF), | ||
sponsored by the Apache Incubator PMC.Incubation is required of all newly accepted projects | ||
until a further review indicates that the infrastructure,communications, and decision-making | ||
process have stabilized in a manner consistent with other successful ASF projects.While | ||
incubation status is not necessarily a reflection of the completeness or stability of the code, | ||
it does indicate that the project has yet to be fully endorsed by the ASF. | ||
|
||
Some of the incubating project’s releases may not be fully compliant with ASF policy. | ||
For example, releases may have incomplete or un-reviewed licensing conditions. | ||
What follows is a list of issues the project is currently aware of (this list is likely to be incomplete): | ||
|
||
1- Releases may have incomplete licensing conditions | ||
|
||
If you are planning to incorporate this work into your product/project,please be aware that | ||
you will need to conduct a thorough licensing review to determine the overall implications of | ||
including this work.For the current status of this project through the Apache Incubator, | ||
visit: https://incubator.apache.org/projects/linkis.html |
Oops, something went wrong.