Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nielsbasjes/codeowners
A library to use and verify the CODEOWNERS and .gitignore files
https://github.com/nielsbasjes/codeowners
codeowners codeowners-validator maven-enforcer-plugin
Last synced: about 2 months ago
JSON representation
A library to use and verify the CODEOWNERS and .gitignore files
- Host: GitHub
- URL: https://github.com/nielsbasjes/codeowners
- Owner: nielsbasjes
- License: apache-2.0
- Created: 2023-05-28T14:57:42.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-04-22T02:14:04.000Z (9 months ago)
- Last Synced: 2024-04-22T12:01:11.031Z (9 months ago)
- Topics: codeowners, codeowners-validator, maven-enforcer-plugin
- Language: Java
- Homepage:
- Size: 350 KB
- Stars: 5
- Watchers: 2
- Forks: 1
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Codeowners: codeowners-reader/pom.xml
- Security: .github/SECURITY.md
Awesome Lists containing this project
README
[![Github actions Build status](https://img.shields.io/github/actions/workflow/status/nielsbasjes/codeowners/build.yml?branch=main)](https://github.com/nielsbasjes/codeowners/actions)
[![Coverage Status](https://img.shields.io/codecov/c/github/nielsbasjes/codeowners)](https://app.codecov.io/gh/nielsbasjes/codeowners)
[![License](https://img.shields.io/:license-apache-blue.svg)](https://www.apache.org/licenses/LICENSE-2.0.html)
[![Maven Central: codeowners-reader](https://img.shields.io/maven-central/v/nl.basjes.codeowners/codeowners-reader.svg?label=codeowners-reader)](https://central.sonatype.com/namespace/nl.basjes.codeowners)
[![Maven Central: gitignore-reader](https://img.shields.io/maven-central/v/nl.basjes.gitignore/gitignore-reader.svg?label=gitignore-reader)](https://central.sonatype.com/namespace/nl.basjes.gitignore)
[![Maven Central: codeowners-enforcer-rules](https://img.shields.io/maven-central/v/nl.basjes.maven.enforcer.codeowners/codeowners-enforcer-rules.svg?label=codeowners-enforcer-rules)](https://central.sonatype.com/namespace/nl.basjes.maven.enforcer.codeowners)
[![GitHub stars](https://img.shields.io/github/stars/nielsbasjes/codeowners?label=GitHub%20stars)](https://github.com/nielsbasjes/codeowners/stargazers)
[![If this project has business value for you then don't hesitate to support me with a small donation.](https://img.shields.io/badge/Sponsor%20me-via%20Github-red.svg)](https://github.com/sponsors/nielsbasjes)
[![If this project has business value for you then don't hesitate to support me with a small donation.](https://img.shields.io/badge/Donations-via%20Paypal-red.svg)](https://www.paypal.me/nielsbasjes)# CodeOwners
In several systems (like GitHub and Gitlab) you can have a CODEOWNERS file which is used to ensure all changes are approved by the right people.Reality: The syntax of these files can be tricky, and it is quite easy to write a config that has the effect that not all files are covered.
# What is this
1) A Java library to read a CODEOWNERS file.
2) A Java library to read a/all .gitignore file(s) in directory.
3) An extra rule for the Maven Enforcer plugin to check the CODEOWNERS against the actual project files. (See Usage below)The intended goal is to make the build fail if the codeowners file does not cover all files and directories in the project.
# CodeOwners Enforcer rule
## Configuration parameters- **baseDir**
- In case you run the plugin from a child module.
- **codeOwnersFile**
- The name of the codeowners file when you are not using a common standard.
- **allExisingFilesMustHaveCodeOwner**
- Check that all existing files have at least one mandatory codeowner.
- Gitlab also supports "Optional" code owners but that is useless to check for.
- **allNewlyCreatedFilesMustHaveCodeOwner**
- Check that if a new file is created in any of the directories in the project that it would automatically have a mandatory code owner.
- Note when a specific filename exception is used in the gitignore rules then this check is not perfect.
- **allFilesMustHaveCodeOwner**
- Do both allExisingFilesMustHaveCodeOwner and allNewlyCreatedFilesMustHaveCodeOwner
- **verbose**
- Make the rule output much more details than you would normally like to see.
- **showApprovers**
- Make the rule output show the approvers for all non-ignored files in the entire project. The intended usage is that with this you can debug the CODEOWNERS result and manually see for every file in your project if you are happy with the resulting approvers.## Example
In one of my projects it looks like this:
org.apache.maven.plugins
maven-enforcer-plugin
3.4.1
nl.basjes.maven.enforcer.codeowners
codeowners-enforcer-rules
1.9.0
Ensure the CODEOWNERS is correct
verify
enforce
false
${maven.multiModuleProjectDirectory}
${maven.multiModuleProjectDirectory}/CODEOWNERS
true
# GitIgnore library
## Basic use
Simply create an instance of the GitIgnoreFileSet and pass the root directory of the project as a parameter
```java
GitIgnoreFileSet ignoreFileSet = new GitIgnoreFileSet(new File("/home/niels/workspace/project"));
```
You can then check for each file in the project if it is ignored or not
```java
if (ignoreFileSet.ignoreFile("/home/niels/workspace/project/something/something/README.md")) {
...
}
```## Full path or just or a project relative filename
The directory name with which you initialize the `GitIgnoreFileSet` is considered to be the directory name of the project root.
By default, if you ask for a file if it is ignored or not, this library assumes you are specifying all files within the SAME base directory structure.So loading the gitignore files from `workspace/project` then a file in the root of the project must (by default) be specified as `workspace/project/pom.xml` and a file deeper in the project as for example `workspace/project/src/main/java/nl/basjes/Something.java`
Something like this:
```java
GitIgnoreFileSet ignoreFileSet = new GitIgnoreFileSet(new File("workspace/project"));if (ignoreFileSet.ignoreFile("workspace/project/pom.xml")) {
...
}
```
So comming from the default situation the `ignoreFileSet.assumeQueriesIncludeProjectBaseDir()` does nothing.You can **optionally specify** that the files you request are **relative to the project root**.
So loading the gitignore files from `workspace/project` then a file in the root of the project must be specified as `/pom.xml` and a file deeper in the project as for example `/src/main/java/nl/basjes/Something.java`
Something like this:
```java
GitIgnoreFileSet ignoreFileSet = new GitIgnoreFileSet(new File("workspace/project"));if (ignoreFileSet.ignoreFile("/pom.xml", true)) {
...
}
```Or you can set it as the default assumption.
```java
GitIgnoreFileSet ignoreFileSet = new GitIgnoreFileSet(new File("workspace/project"));
ignoreFileSet.assumeQueriesAreProjectRelative();if (ignoreFileSet.ignoreFile("/pom.xml")) {
...
}
```## GitIgnore edge case
This [tutorial page](https://www.atlassian.com/git/tutorials/saving-changes/gitignore) documents this edge case that this library also follows.I see this as unexpected behaviour yet this is really what git does !
**Pattern**
logs/
!logs/important.log**Matches**
logs/debug.log
logs/important.log**Explanation**
Wait a minute! Shouldn't logs/important.log be negated in the example on the left
Nope! Due to a performance-related quirk in Git, you can not negate a file that is ignored due to a pattern matching a directory# Building
The maven build must be run under Java 17 or newer (because of plugins) and will use toolchains to actually build the software using JDK 21.This means that you must also ensure you have a `~/.m2/toolchains.xml` containing at least this entry (where the path on your system is likely to be different, this path is on my Ubuntu 24.04 LTS system)
```xml
jdk
21
/usr/lib/jvm/java-21-openjdk-amd64
```
# License
CodeOwners Tools
Copyright (C) 2023-2024 Niels BasjesLicensed 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 athttps://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.