mirror of
https://github.com/unman/shaker.git
synced 2025-01-09 14:29:30 -05:00
80 lines
2.1 KiB
Markdown
80 lines
2.1 KiB
Markdown
This package provides a central git qube, named sys-git.
|
|
By default the qube has no netvm, but you can set one if you wish.
|
|
|
|
Some configuration is needed.
|
|
Repositories must be created under /home/user/repos in sys-git, and
|
|
repository names must be common between sys-git and client qubes.
|
|
|
|
# Setting up a new repository
|
|
|
|
## sys-git
|
|
In sys-git, repositories are stored bare under /home/user/repos
|
|
First, prepare a repository:
|
|
```
|
|
mkdir repos/X
|
|
cd repos/X
|
|
git init --bare
|
|
```
|
|
|
|
## prepare client
|
|
Then prepare a qube by running:
|
|
`qubesctl --skip0-dom0 --targets=QUBE state.apply git.install_client`
|
|
|
|
## Work in the client
|
|
Configure git, as necessary.
|
|
Open a terminal in the qube:
|
|
```
|
|
mkdir X
|
|
cd X
|
|
git init
|
|
add-remote sg
|
|
```
|
|
You can then use that repository as usual, making commits.
|
|
To push to sys-git you must first-
|
|
`git push --set-upstream sg master`
|
|
|
|
After making more commits,
|
|
`git push `
|
|
|
|
# Working with an existing repository
|
|
|
|
## prepare client, if necessary
|
|
Prepare a qube by running:
|
|
`qubesctl --skip0-dom0 --targets=QUBE state.apply git.install_client`
|
|
|
|
## Clone the repository in the client
|
|
Configure git, as necessary.
|
|
Open a terminal in the qube:
|
|
```
|
|
mkdir X
|
|
cd X
|
|
git init
|
|
add-remote sg
|
|
git pull sg master
|
|
```
|
|
|
|
## Work in the client
|
|
You can then use that repository as usual.
|
|
To push to sys-git you must first-
|
|
`git push --set-upstream sg master`
|
|
|
|
After making more commits,
|
|
`git push `
|
|
|
|
|
|
# Access control
|
|
Access to sys-git is governed by policy rules in `/etc/qubes/policy/30-user.policy`
|
|
The default rule allows access from any qube to sys-git, after a confirmation dialog.
|
|
`qubes.Git * @anyvm @anyvm ask default_target=sys-git`
|
|
|
|
You can control access to sys-git by qube, and restrict qubes to specific named repositories:
|
|
```
|
|
qubes.Git +REPO QUBE @anyvm ask default_target=sys-git
|
|
qubes.Git * QUBE2 @anyvm ask default_target=sys-git
|
|
qubes.Git * * sys-git deny
|
|
```
|
|
These rules will allow QUBE to access the REPO repository on sys-git, but no other.
|
|
QUBE2 is allowed to access any repository on sys-git.
|
|
No other qube is allowed access at all.
|
|
|