Skip to content

jbethune/maintain_toml

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 
 
 
 
 
 
 

Repository files navigation

maintain.toml - machine readable description of a software project's state

Rationale

Open source projects require maintainers to add new features, fix bugs, write documentation, write tests and much more. Being committed to an open source project requires time and effort. But depending on life situations, a maintainer might not be able to provide the needed attention to a project. Even healthy software projects might start to stagnate and eventually get abandonned.

Modern software typically makes use of many components and dependencies. You probably know about XKCD 2347 (if not, then you are one of the lucky 10000). It is important to keep an eye on your dependencies when developing and deploying software, because software can have confirmed security issues. But apart from confirmed security issues, you probably also want to make sure that the projects you depend on are well-maintained, so that bugs in your dependencies get fixed and don't affect your software.

The issue is: It can be hard to tell if a project is still alive and well. Even if there is recent commit activity in the software repository, the maintainers might only have very little time to process bugs and security issues.

It is possible to communicate issues with the project in a README like this, but when you depend on hundreds of software projects, it is not feasible to review those unstructured READMEs on a regular basis. Therefore it makes sense to have a file format that can be automatically processed so that developers can more effectively determine where dependencies need to be supported.

The maintain.toml

The maintain.toml is a simple declarative TOML file to describe the needs and state of a project. In its most basic form, there are only 2 required fields and the remaining entries have reasonable default values:

version = "0.1.0"

[time]
timestamp = 2023-06-15

The version field describes the version of the maintain.toml standard. It follows semantic versioning 2.0.

The timestamp field describes when maintain.toml was last updated using the native date format supported by TOML. If no time zone was specified for the TOML time, the time zone is assumed to be UTC+0. Naturally, you could determine the same information also from the file in the git log or the local file system entry, but it's also possible to lose this information when downloading a project as a zip file from GitHub.

The next field we are going to discuss is the time.valid_for field which has a special relationship with the timestamp field: The maintain.txt file will be valid until the date that you get when you calculate timestamp + valid_for. The default value for valid_for is 300 days. The maximum value is 366 days. And the minimum value is 2 days.

The combination of the timestamp and the valid_for fields act as a dead man's switch and therefore the maintain.toml file should be updated on a regular basis.

There are more fields that can be set. For example:

version = "0.1.0"

[time]
timestamp = 2023-06-15
valid_for = 100
reminder = 30
timekeepers = ["github:jbethune", "local:hacker"]

The reminder field indicates how many days before the expiry of the maintain.toml you want to receive notifications about the upcoming expiry. These notifications can be implemented by GitHub and other services. GitHub would notice that there is an entry github:jbethune in the list of timekeepers and show a notification to me the next time I log on to GitHub. At the same time, GitHub would ignore the local:hacker entry, but a tool that I run on my local linux machine could pick the entry up and show a local notification to the hacker user.

The default value for reminder is 30 days. But for it to have any effect, there need to be entries in the timekeepers array (which is empty by default).

See the maintain.toml file of this repository for more fields, their descriptions and default values.

Contributing/Standardization

As pointed out in the entry staff.specification in the maintain.toml, I am happy to take suggestions on the file format. Please open an issue to discuss changes.

About

Standard proposal for maintain.toml file format to document software project maintenance states

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published