Skip to content

Commit c0de5e9

Browse files
committed
add nixpacks module
1 parent df71264 commit c0de5e9

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

86 files changed

+10761
-1
lines changed

.github/workflows/nixpacks.yml

+37
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,37 @@
1+
name: ci
2+
on:
3+
push:
4+
branches:
5+
- main
6+
paths:
7+
- .github/workflows/nixpacks.yml
8+
- "nixpacks/**"
9+
jobs:
10+
test:
11+
runs-on: ubuntu-latest
12+
steps:
13+
- uses: actions/checkout@v3
14+
- name: Setup Fluent CI
15+
uses: fluentci-io/setup-fluentci@v4
16+
- name: Run Dagger Pipelines
17+
run: |
18+
deno run -A src/dagger/list_jobs.ts
19+
dagger functions
20+
dagger call plan --src . --path example/samples/php-api --output=./plan.json
21+
jq . < ./plan.json
22+
dagger call build --src . --path example/samples/php-api
23+
working-directory: nixpacks
24+
publish:
25+
needs: test
26+
runs-on: ubuntu-latest
27+
permissions:
28+
contents: read
29+
id-token: write
30+
steps:
31+
- uses: actions/checkout@v4
32+
- uses: denoland/setup-deno@v1
33+
with:
34+
deno-version: v1.41
35+
- name: Publish package
36+
run: deno publish --allow-slow-types
37+
working-directory: nixpacks

README.md

+1
Original file line numberDiff line numberDiff line change
@@ -40,6 +40,7 @@ See [documentation](https://docs.dagger.io/zenith/) for more information about d
4040
| [kubeconform](./kubeconform/) | Lint Kubernetes files with [kubconform](https://github.com/yannh/kubeconform) |
4141
| [kubeval](./kubeval/) | Lint Kubernetes files with [kubeval](https://github.com/instrumenta/kubeval) |
4242
| [nix](./nix) | Nix package manager |
43+
| [nixpacks](./nixpacks/) | Build an OCI image of your project using [nixpacks](https://nixpacks.com/) |
4344
| [open-policy-agent](./open-policy-agent/) | Daggerized version of [Open Policy Agent](https://www.openpolicyagent.org/) |
4445
| [phpcbf](./phpcbf/) | Daggerized version of [phpcbf](https://github.com/squizlabs/PHP_CodeSniffer) |
4546
| [phpcs](./phpcs/) | PHP Code Sniffer [phpcs](https://github.com/squizlabs/PHP_CodeSniffer) |

nixpacks/.env.example

+2
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
# This file is a "template" of which env vars need to be defined for your Pipeline.
2+
HELLO=123

nixpacks/.gitignore

+3
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
coverage/
2+
coverage.lcov
3+
.env

nixpacks/.vscode/settings.json

+3
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
{
2+
"deno.enable": true
3+
}

nixpacks/CODE_OF_CONDUCT.md

+132
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,132 @@
1+
# Contributor Covenant Code of Conduct
2+
3+
## Our Pledge
4+
5+
We as members, contributors, and leaders pledge to make participation in our
6+
community a harassment-free experience for everyone, regardless of age, body
7+
size, visible or invisible disability, ethnicity, sex characteristics, gender
8+
identity and expression, level of experience, education, socio-economic status,
9+
nationality, personal appearance, race, caste, color, religion, or sexual
10+
identity and orientation.
11+
12+
We pledge to act and interact in ways that contribute to an open, welcoming,
13+
diverse, inclusive, and healthy community.
14+
15+
## Our Standards
16+
17+
Examples of behavior that contributes to a positive environment for our
18+
community include:
19+
20+
* Demonstrating empathy and kindness toward other people
21+
* Being respectful of differing opinions, viewpoints, and experiences
22+
* Giving and gracefully accepting constructive feedback
23+
* Accepting responsibility and apologizing to those affected by our mistakes,
24+
and learning from the experience
25+
* Focusing on what is best not just for us as individuals, but for the overall
26+
community
27+
28+
Examples of unacceptable behavior include:
29+
30+
* The use of sexualized language or imagery, and sexual attention or advances of
31+
any kind
32+
* Trolling, insulting or derogatory comments, and personal or political attacks
33+
* Public or private harassment
34+
* Publishing others' private information, such as a physical or email address,
35+
without their explicit permission
36+
* Other conduct which could reasonably be considered inappropriate in a
37+
professional setting
38+
39+
## Enforcement Responsibilities
40+
41+
Community leaders are responsible for clarifying and enforcing our standards of
42+
acceptable behavior and will take appropriate and fair corrective action in
43+
response to any behavior that they deem inappropriate, threatening, offensive,
44+
or harmful.
45+
46+
Community leaders have the right and responsibility to remove, edit, or reject
47+
comments, commits, code, wiki edits, issues, and other contributions that are
48+
not aligned to this Code of Conduct, and will communicate reasons for moderation
49+
decisions when appropriate.
50+
51+
## Scope
52+
53+
This Code of Conduct applies within all community spaces, and also applies when
54+
an individual is officially representing the community in public spaces.
55+
Examples of representing our community include using an official e-mail address,
56+
posting via an official social media account, or acting as an appointed
57+
representative at an online or offline event.
58+
59+
## Enforcement
60+
61+
Instances of abusive, harassing, or otherwise unacceptable behavior may be
62+
reported to the community leaders responsible for enforcement at
63+
[GitHub Issues](https://github.com/tsirysndr/daggerverse/issues).
64+
All complaints will be reviewed and investigated promptly and fairly.
65+
66+
All community leaders are obligated to respect the privacy and security of the
67+
reporter of any incident.
68+
69+
## Enforcement Guidelines
70+
71+
Community leaders will follow these Community Impact Guidelines in determining
72+
the consequences for any action they deem in violation of this Code of Conduct:
73+
74+
### 1. Correction
75+
76+
**Community Impact**: Use of inappropriate language or other behavior deemed
77+
unprofessional or unwelcome in the community.
78+
79+
**Consequence**: A private, written warning from community leaders, providing
80+
clarity around the nature of the violation and an explanation of why the
81+
behavior was inappropriate. A public apology may be requested.
82+
83+
### 2. Warning
84+
85+
**Community Impact**: A violation through a single incident or series of
86+
actions.
87+
88+
**Consequence**: A warning with consequences for continued behavior. No
89+
interaction with the people involved, including unsolicited interaction with
90+
those enforcing the Code of Conduct, for a specified period of time. This
91+
includes avoiding interactions in community spaces as well as external channels
92+
like social media. Violating these terms may lead to a temporary or permanent
93+
ban.
94+
95+
### 3. Temporary Ban
96+
97+
**Community Impact**: A serious violation of community standards, including
98+
sustained inappropriate behavior.
99+
100+
**Consequence**: A temporary ban from any sort of interaction or public
101+
communication with the community for a specified period of time. No public or
102+
private interaction with the people involved, including unsolicited interaction
103+
with those enforcing the Code of Conduct, is allowed during this period.
104+
Violating these terms may lead to a permanent ban.
105+
106+
### 4. Permanent Ban
107+
108+
**Community Impact**: Demonstrating a pattern of violation of community
109+
standards, including sustained inappropriate behavior, harassment of an
110+
individual, or aggression toward or disparagement of classes of individuals.
111+
112+
**Consequence**: A permanent ban from any sort of public interaction within the
113+
community.
114+
115+
## Attribution
116+
117+
This Code of Conduct is adapted from the [Contributor Covenant][homepage],
118+
version 2.1, available at
119+
[https://www.contributor-covenant.org/version/2/1/code_of_conduct.html][v2.1].
120+
121+
Community Impact Guidelines were inspired by
122+
[Mozilla's code of conduct enforcement ladder][Mozilla CoC].
123+
124+
For answers to common questions about this code of conduct, see the FAQ at
125+
[https://www.contributor-covenant.org/faq][FAQ]. Translations are available at
126+
[https://www.contributor-covenant.org/translations][translations].
127+
128+
[homepage]: https://www.contributor-covenant.org
129+
[v2.1]: https://www.contributor-covenant.org/version/2/1/code_of_conduct.html
130+
[Mozilla CoC]: https://github.com/mozilla/diversity
131+
[FAQ]: https://www.contributor-covenant.org/faq
132+
[translations]: https://www.contributor-covenant.org/translations

nixpacks/CONTRIBUTING.md

+53
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,53 @@
1+
# Contributing Guidelines
2+
3+
Thank you for your interest in contributing to our project. Whether it's a bug report, new feature, correction, or additional
4+
documentation, we greatly value feedback and contributions from our community.
5+
6+
Please read through this document before submitting any issues or pull requests to ensure we have all the necessary
7+
information to effectively respond to your bug report or contribution.
8+
9+
10+
## Reporting Bugs/Feature Requests
11+
12+
We welcome you to use the GitHub issue tracker to report bugs or suggest features.
13+
14+
When filing an issue, please check existing open, or recently closed, issues to make sure somebody else hasn't already
15+
reported the issue. Please try to include as much information as you can. Details like these are incredibly useful:
16+
17+
* A reproducible test case or series of steps
18+
* The version of our code being used
19+
* Any modifications you've made relevant to the bug
20+
* Anything unusual about your environment or deployment
21+
22+
23+
## Contributing via Pull Requests
24+
Contributions via pull requests are much appreciated. Before sending us a pull request, please ensure that:
25+
26+
1. You are working against the latest source on the *master* branch.
27+
2. You check existing open, and recently merged, pull requests to make sure someone else hasn't addressed the problem already.
28+
3. You open an issue to discuss any significant work - we would hate for your time to be wasted.
29+
30+
To send us a pull request, please:
31+
32+
1. Fork the repository.
33+
2. Modify the source; please focus on the specific change you are contributing. If you also reformat all the code, it will be hard for us to focus on your change.
34+
3. Ensure local tests pass.
35+
4. Commit to your fork using clear commit messages.
36+
5. Send us a pull request, answering any default questions in the pull request interface.
37+
6. Pay attention to any automated CI failures reported in the pull request, and stay involved in the conversation.
38+
39+
GitHub provides additional document on [forking a repository](https://help.github.com/articles/fork-a-repo/) and
40+
[creating a pull request](https://help.github.com/articles/creating-a-pull-request/).
41+
42+
43+
## Finding contributions to work on
44+
Looking at the existing issues is a great way to find something to contribute on. As our projects, by default, use the default GitHub issue labels (enhancement/bug/duplicate/help wanted/invalid/question/wontfix), looking at any 'help wanted' issues is a great place to start.
45+
46+
47+
## Code of Conduct
48+
This project has adopted the [Contributor Covenant](https://www.contributor-covenant.org/), version 2.1, available at https://www.contributor-covenant.org/version/2/1/code_of_conduct.html.
49+
50+
51+
## Licensing
52+
53+
See the [LICENSE](LICENSE) file for our project's licensing. We will ask you to confirm the licensing of your contribution.

nixpacks/LICENSE

+19
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,19 @@
1+
Copyright (c) 2023 Tsiry Sandratraina <[email protected]>
2+
3+
Permission is hereby granted, free of charge, to any person obtaining a copy
4+
of this software and associated documentation files (the "Software"), to deal
5+
in the Software without restriction, including without limitation the rights
6+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
7+
copies of the Software, and to permit persons to whom the Software is
8+
furnished to do so, subject to the following conditions:
9+
10+
The above copyright notice and this permission notice shall be included in all
11+
copies or substantial portions of the Software.
12+
13+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
18+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
19+
SOFTWARE.

nixpacks/README.md

+45
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,45 @@
1+
# Module: Nixpacks
2+
3+
![dagger-min-version](https://img.shields.io/badge/dagger-v0.10.0-blue?color=3D66FF)
4+
![deno compatibility](https://shield.deno.dev/deno/^1.41)
5+
[![](https://jsr.io/badges/@daggerverse/nixpacks)](https://jsr.io/@daggerverse/nixpacks)
6+
[![ci](https://github.com/tsirysndr/daggerverse/actions/workflows/ci.yml/badge.svg)](https://github.com/tsirysndr/daggerverse/actions/workflows/nixpacks.yml)
7+
8+
This is [Dagger](https://dagger.io) module for building an OCI image of your project using [nixpacks](https://nixpacks.com/).
9+
10+
## 🚀 Usage
11+
12+
```sh
13+
dagger -m github.com/tsirysndr/daggerverse/nixpacks call \
14+
dev --src <source> terminal
15+
```
16+
17+
## 🧑‍🔬 Example
18+
19+
```sh
20+
dagger -m github.com/tsirysndr/daggerverse/nixpacks call \
21+
dev --src . terminal
22+
23+
dagger -m github.com/tsirysndr/daggerverse/nixpacks call \
24+
plan --src .
25+
26+
dagger -m github.com/tsirysndr/daggerverse/nixpacks call \
27+
build --src . --name my-app
28+
```
29+
30+
## ✨ Jobs
31+
32+
| Name | Description |
33+
| ------- | ----------------------------------- |
34+
| `dev` | Start a development environment |
35+
| `plan` | Generate build plan for the project |
36+
| `build` | Build an OCI image of the project |
37+
38+
## 🧑‍💻 Programmatic usage
39+
40+
```typescript
41+
import { plan, build } from 'jsr:@daggerverse/nixpacks';
42+
43+
await plan(".");
44+
await build(".", "my-app");
45+
```

nixpacks/dagger.json

+4
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,4 @@
1+
{
2+
"name": "nixpacks",
3+
"sdk": "github.com/fluentci-io/daggerverse/deno-sdk@main"
4+
}

nixpacks/deno.json

+33
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,33 @@
1+
{
2+
"name": "@daggerverse/nixpacks",
3+
"version": "0.1.0",
4+
"exports": "./mod.ts",
5+
"importMap": "import_map.json",
6+
"tasks": {
7+
"esm:add": "deno run -A https://esm.sh/v128 add",
8+
"esm:update": "deno run -A https://esm.sh/v128 update",
9+
"esm:remove": "deno run -A https://esm.sh/v128 remove",
10+
"clean": "rm -rf gen schema.graphql"
11+
},
12+
"fmt": {
13+
"exclude": [
14+
"example/",
15+
".fluentci/",
16+
"gen/"
17+
]
18+
},
19+
"lint": {
20+
"exclude": [
21+
"example/",
22+
".fluentci/",
23+
"gen/"
24+
]
25+
},
26+
"test": {
27+
"exclude": [
28+
"example/",
29+
".fluentci/",
30+
"gen/"
31+
]
32+
}
33+
}

0 commit comments

Comments
 (0)