generated from nhcarrigan/template
Compare commits
6 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 3789116d1f | |||
| 6bfcd6b98b | |||
| 7ecdac40db | |||
| 7f311fd7b5 | |||
| b6b3ef01ad | |||
| 8a811b87c3 |
@@ -1,25 +0,0 @@
|
|||||||
# Package Manager Configuration
|
|
||||||
# Force pnpm usage - breaks npm/yarn intentionally
|
|
||||||
node-linker=pnpm
|
|
||||||
|
|
||||||
# Security: Disable all lifecycle scripts
|
|
||||||
ignore-scripts=true
|
|
||||||
enable-pre-post-scripts=false
|
|
||||||
|
|
||||||
# Security: Require packages to be 10+ days old before installation
|
|
||||||
minimum-release-age=14400
|
|
||||||
|
|
||||||
# Security: Verify package integrity hashes
|
|
||||||
verify-store-integrity=true
|
|
||||||
|
|
||||||
# Security: Enforce strict trust policies
|
|
||||||
trust-policy=strict
|
|
||||||
|
|
||||||
# Security: Strict peer dependency resolution
|
|
||||||
strict-peer-dependencies=true
|
|
||||||
|
|
||||||
# Performance: Use symlinks for node_modules
|
|
||||||
symlink=true
|
|
||||||
|
|
||||||
# Lockfile: Ensure lockfile is not modified during install
|
|
||||||
frozen-lockfile=false
|
|
||||||
@@ -0,0 +1,21 @@
|
|||||||
|
# Security
|
||||||
|
|
||||||
|
# Do not execute any scripts of installed packages (project scripts still run)
|
||||||
|
ignoreDepScripts: true
|
||||||
|
# Do not automatically run pre/post scripts (e.g. preinstall, postbuild)
|
||||||
|
enablePrePostScripts: false
|
||||||
|
# Only allow packages published at least 10 days ago (reduces risk of compromised packages)
|
||||||
|
minimumReleaseAge: 14400
|
||||||
|
# Fail if a package's trust level has decreased compared to previous releases
|
||||||
|
trustPolicy: no-downgrade
|
||||||
|
# Ignore trust policy for packages published more than 1 year ago (predates provenance signing)
|
||||||
|
trustPolicyIgnoreAfter: 525960
|
||||||
|
# Fail if there are missing or invalid peer dependencies
|
||||||
|
strictPeerDependencies: true
|
||||||
|
# Prevent transitive dependencies from using exotic sources (git repos, direct tarball URLs)
|
||||||
|
blockExoticSubdeps: true
|
||||||
|
|
||||||
|
# Lockfile
|
||||||
|
|
||||||
|
# Allow the lockfile to be updated during install (set to true in CI for stricter reproducibility)
|
||||||
|
preferFrozenLockfile: false
|
||||||
@@ -180,14 +180,6 @@ export const navigation = [
|
|||||||
label: "Development Environment",
|
label: "Development Environment",
|
||||||
link: "/dev/environment",
|
link: "/dev/environment",
|
||||||
},
|
},
|
||||||
{
|
|
||||||
label: "Server Setup",
|
|
||||||
link: "/dev/servers",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: "Naomi's VTubing Setup",
|
|
||||||
link: "/dev/vtubing",
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
label: "Security Hall of Fame",
|
label: "Security Hall of Fame",
|
||||||
link: "/dev/hall-of-fame",
|
link: "/dev/hall-of-fame",
|
||||||
@@ -857,26 +849,6 @@ export const navigation = [
|
|||||||
].sort((a, b) => a.label.localeCompare(b.label)),
|
].sort((a, b) => a.label.localeCompare(b.label)),
|
||||||
},
|
},
|
||||||
// #endregion
|
// #endregion
|
||||||
// #region Miscellaneous Documents
|
|
||||||
{
|
|
||||||
label: "Miscellaneous Documents",
|
|
||||||
collapsed: true,
|
|
||||||
items: [
|
|
||||||
{
|
|
||||||
label: "Managing Local Music",
|
|
||||||
link: "/misc/music",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: "Templates",
|
|
||||||
link: "/misc/templates",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: "AI Prompts",
|
|
||||||
link: "/misc/prompts",
|
|
||||||
}
|
|
||||||
].sort((a, b) => a.label.localeCompare(b.label)),
|
|
||||||
},
|
|
||||||
// #endregion
|
|
||||||
// #region External Links
|
// #region External Links
|
||||||
{
|
{
|
||||||
label: "Discord",
|
label: "Discord",
|
||||||
|
|||||||
@@ -236,7 +236,7 @@ We offer several email addresses for specific types of inquiries. Please use the
|
|||||||
|
|
||||||
### 5.2. Billing and Financial Matters
|
### 5.2. Billing and Financial Matters
|
||||||
|
|
||||||
:::tip[Preferred Method]{icon=message}
|
:::tip[Preferred Method]{icon=star}
|
||||||
We encourage you to use the [**Billing Questions**](https://support.nhcarrigan.com/c/billing-questions/13) category on our support forum for billing inquiries. This allows for public discussion and faster responses. If you need to share sensitive financial information, you can ask staff to make your thread private, or contact us via email for complete confidentiality.
|
We encourage you to use the [**Billing Questions**](https://support.nhcarrigan.com/c/billing-questions/13) category on our support forum for billing inquiries. This allows for public discussion and faster responses. If you need to share sensitive financial information, you can ask staff to make your thread private, or contact us via email for complete confidentiality.
|
||||||
:::
|
:::
|
||||||
|
|
||||||
@@ -250,7 +250,7 @@ We encourage you to use the [**Billing Questions**](https://support.nhcarrigan.c
|
|||||||
|
|
||||||
### 5.3. Technical Support
|
### 5.3. Technical Support
|
||||||
|
|
||||||
:::tip[Preferred Method]{icon=message}
|
:::tip[Preferred Method]{icon=star}
|
||||||
We encourage you to use the [**Technical Support**](https://support.nhcarrigan.com/c/technical-support/5) category on our support forum for support inquiries. This allows for public discussion and faster responses. If you need to share sensitive information, you can ask staff to make your thread private, or contact us via email for complete confidentiality.
|
We encourage you to use the [**Technical Support**](https://support.nhcarrigan.com/c/technical-support/5) category on our support forum for support inquiries. This allows for public discussion and faster responses. If you need to share sensitive information, you can ask staff to make your thread private, or contact us via email for complete confidentiality.
|
||||||
:::
|
:::
|
||||||
|
|
||||||
@@ -263,7 +263,7 @@ We encourage you to use the [**Technical Support**](https://support.nhcarrigan.c
|
|||||||
|
|
||||||
### 5.4. Privacy Concerns
|
### 5.4. Privacy Concerns
|
||||||
|
|
||||||
:::tip[Preferred Method]{icon=message}
|
:::tip[Preferred Method]{icon=star}
|
||||||
We encourage you to use our **Privacy Request Form** for privacy-related requests: https://forms.nhcarrigan.com/o/docs/forms/qEJgBWGDfyHv6x51VU9aVX/4
|
We encourage you to use our **Privacy Request Form** for privacy-related requests: https://forms.nhcarrigan.com/o/docs/forms/qEJgBWGDfyHv6x51VU9aVX/4
|
||||||
|
|
||||||
This form helps ensure we collect all necessary information to process your request efficiently and in compliance with applicable data protection laws.
|
This form helps ensure we collect all necessary information to process your request efficiently and in compliance with applicable data protection laws.
|
||||||
@@ -279,7 +279,7 @@ This form helps ensure we collect all necessary information to process your requ
|
|||||||
|
|
||||||
### 5.5. Security Matters
|
### 5.5. Security Matters
|
||||||
|
|
||||||
:::tip[Preferred Method]{icon=message}
|
:::tip[Preferred Method]{icon=star}
|
||||||
We encourage you to use our **Security Vulnerability Report Form** for reporting security vulnerabilities: https://forms.nhcarrigan.com/o/docs/forms/wgdbBkS4tjCGoVZTqtmMNx/4
|
We encourage you to use our **Security Vulnerability Report Form** for reporting security vulnerabilities: https://forms.nhcarrigan.com/o/docs/forms/wgdbBkS4tjCGoVZTqtmMNx/4
|
||||||
|
|
||||||
This form helps ensure we collect all necessary information to investigate and address security issues efficiently and securely.
|
This form helps ensure we collect all necessary information to investigate and address security issues efficiently and securely.
|
||||||
@@ -295,7 +295,7 @@ This form helps ensure we collect all necessary information to investigate and a
|
|||||||
|
|
||||||
### 5.6. Legal Inquiries
|
### 5.6. Legal Inquiries
|
||||||
|
|
||||||
:::tip[Preferred Method]{icon=message}
|
:::tip[Preferred Method]{icon=star}
|
||||||
We encourage you to use the [**Legal Notices**](https://support.nhcarrigan.com/c/legal-notices/12) category on our support forum for legal inquiries. This allows for public discussion and transparency. If you need to share sensitive legal information, you can ask staff to make your thread private, or contact us via email for urgent matters requiring immediate confidentiality.
|
We encourage you to use the [**Legal Notices**](https://support.nhcarrigan.com/c/legal-notices/12) category on our support forum for legal inquiries. This allows for public discussion and transparency. If you need to share sensitive legal information, you can ask staff to make your thread private, or contact us via email for urgent matters requiring immediate confidentiality.
|
||||||
:::
|
:::
|
||||||
|
|
||||||
@@ -309,7 +309,7 @@ We encourage you to use the [**Legal Notices**](https://support.nhcarrigan.com/c
|
|||||||
|
|
||||||
### 5.7. Feedback and Suggestions
|
### 5.7. Feedback and Suggestions
|
||||||
|
|
||||||
:::tip[Preferred Method]{icon=message}
|
:::tip[Preferred Method]{icon=star}
|
||||||
We encourage you to use our support forum for different types of feedback:
|
We encourage you to use our support forum for different types of feedback:
|
||||||
- [**Community Feedback**](https://support.nhcarrigan.com/c/community-feedback/8) for general feedback about our community, services, events, and initiatives
|
- [**Community Feedback**](https://support.nhcarrigan.com/c/community-feedback/8) for general feedback about our community, services, events, and initiatives
|
||||||
- [**Policy Ideation**](https://support.nhcarrigan.com/c/policy-ideation/9) for suggestions about community policies and governance
|
- [**Policy Ideation**](https://support.nhcarrigan.com/c/policy-ideation/9) for suggestions about community policies and governance
|
||||||
@@ -329,7 +329,7 @@ We encourage you to use our support forum for different types of feedback:
|
|||||||
|
|
||||||
### 5.8. Press/Media Inquiries
|
### 5.8. Press/Media Inquiries
|
||||||
|
|
||||||
:::tip[Preferred Method]{icon=message}
|
:::tip[Preferred Method]{icon=star}
|
||||||
We encourage you to use the [**Press Inquiries**](https://support.nhcarrigan.com/c/press-inquiries/14) category on our support forum for media inquiries. This allows for public discussion and community visibility. If you need to share sensitive information, you can ask staff to make your thread private, or contact us via email for highly sensitive media matters requiring complete confidentiality.
|
We encourage you to use the [**Press Inquiries**](https://support.nhcarrigan.com/c/press-inquiries/14) category on our support forum for media inquiries. This allows for public discussion and community visibility. If you need to share sensitive information, you can ask staff to make your thread private, or contact us via email for highly sensitive media matters requiring complete confidentiality.
|
||||||
:::
|
:::
|
||||||
|
|
||||||
@@ -351,7 +351,7 @@ We encourage you to use the [**Press Inquiries**](https://support.nhcarrigan.com
|
|||||||
|
|
||||||
### 5.10. Marketing Inquiries
|
### 5.10. Marketing Inquiries
|
||||||
|
|
||||||
:::tip[Preferred Method]{icon=message}
|
:::tip[Preferred Method]{icon=star}
|
||||||
We encourage you to use the [**Marketing Proposals**](https://support.nhcarrigan.com/c/marketing-proposals/15) category on our support forum for marketing inquiries. This allows for public discussion and community input. If you need to share highly confidential business information, you can ask staff to make your thread private, or contact us via email for proposals requiring complete privacy.
|
We encourage you to use the [**Marketing Proposals**](https://support.nhcarrigan.com/c/marketing-proposals/15) category on our support forum for marketing inquiries. This allows for public discussion and community input. If you need to share highly confidential business information, you can ask staff to make your thread private, or contact us via email for proposals requiring complete privacy.
|
||||||
:::
|
:::
|
||||||
|
|
||||||
@@ -374,7 +374,7 @@ We encourage you to use the [**Marketing Proposals**](https://support.nhcarrigan
|
|||||||
|
|
||||||
### 5.12. Partnerships
|
### 5.12. Partnerships
|
||||||
|
|
||||||
:::tip[Preferred Method]{icon=message}
|
:::tip[Preferred Method]{icon=star}
|
||||||
We encourage you to use the [**Partnership Requests**](https://support.nhcarrigan.com/c/partnership-requests/11) category on our support forum for partnership inquiries. This allows for public discussion and community input on potential partnerships. If you need to share sensitive business information, you can ask staff to make your thread private, or contact us via email if you need complete confidentiality from the start.
|
We encourage you to use the [**Partnership Requests**](https://support.nhcarrigan.com/c/partnership-requests/11) category on our support forum for partnership inquiries. This allows for public discussion and community input on potential partnerships. If you need to share sensitive business information, you can ask staff to make your thread private, or contact us via email if you need complete confidentiality from the start.
|
||||||
:::
|
:::
|
||||||
|
|
||||||
|
|||||||
@@ -1,428 +0,0 @@
|
|||||||
---
|
|
||||||
title: Server Setup
|
|
||||||
---
|
|
||||||
|
|
||||||
**ESTABLISHING SERVER CONFIGURATION STANDARDS AND SECURITY REQUIREMENTS**
|
|
||||||
|
|
||||||
## 1. INTRODUCTION AND LEGAL FRAMEWORK
|
|
||||||
|
|
||||||
### 1.1. Policy Overview
|
|
||||||
|
|
||||||
This Server Setup Documentation (hereinafter referred to as "the Documentation") establishes mandatory standards, procedures, and security requirements for configuring remote servers used to host projects maintained by our organisation. This Documentation operates within our comprehensive legal and policy framework, incorporating our Terms of Service, Security Policy, and all applicable legal protections by reference.
|
|
||||||
|
|
||||||
### 1.2. Scope and Applicability
|
|
||||||
|
|
||||||
This Documentation applies to all remote servers used to host projects, services, or infrastructure maintained by our organisation. All personnel responsible for server configuration, deployment, or maintenance must comply with the standards set forth in this Documentation.
|
|
||||||
|
|
||||||
**IMPORTANT: Non-compliance with server security and configuration standards set forth in this Documentation may result in security vulnerabilities, service disruptions, or other serious consequences. All server administrators must strictly adhere to these requirements.**
|
|
||||||
|
|
||||||
### 1.3. Security and Compliance Requirements
|
|
||||||
|
|
||||||
Server configuration must comply with:
|
|
||||||
- Our Security Policy and security standards
|
|
||||||
- Applicable data protection and privacy regulations
|
|
||||||
- Industry best practices for server security
|
|
||||||
- All relevant legal and regulatory requirements
|
|
||||||
|
|
||||||
## 2. PROVISIONING A SERVER
|
|
||||||
|
|
||||||
We use DigitalOcean as our provider. Regardless of your choice, provision a new VPS using the **latest Ubuntu LTS version**. Add your `ssh` key AND Naomi's `ssh` key in the setup process.
|
|
||||||
|
|
||||||
## 3. SETTING UP USER ACCOUNTS
|
|
||||||
|
|
||||||
You should never run applications on root. SSH into the new VPS to prepare your user.
|
|
||||||
|
|
||||||
### 3.1. Creating the User Account
|
|
||||||
|
|
||||||
You'll need to set a password for the `root` account first.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
passwd
|
|
||||||
```
|
|
||||||
|
|
||||||
Once you have set a password, ensure that you have provided it to Naomi to store in the vault.
|
|
||||||
|
|
||||||
Create an `NHCarrigan` user for our organisation.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
adduser NHCarrigan
|
|
||||||
```
|
|
||||||
|
|
||||||
Set a **different** password, and provide that to Naomi as well. For all of the user information, use the default blank values.
|
|
||||||
|
|
||||||
Add the new user to the sudoers file.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
usermod -aG sudo NHCarrigan
|
|
||||||
```
|
|
||||||
|
|
||||||
Then sync the SSH keys so we can authenticate as that user.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
rsync --archive --chown=NHCarrigan:NHCarrigan ~/.ssh /home/NHCarrigan
|
|
||||||
```
|
|
||||||
|
|
||||||
While you are there, set the timezone for the server to our business' local timezone.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo timedatectl set-timezone America/Los_Angeles
|
|
||||||
```
|
|
||||||
|
|
||||||
## 4. PREPARING FOR WEB REQUESTS
|
|
||||||
|
|
||||||
To prepare the server to receive web requests, you'll need to follow a few steps.
|
|
||||||
|
|
||||||
### 4.1. SSL Certificate Configuration
|
|
||||||
|
|
||||||
:::note
|
|
||||||
If the Firewall has been set up, you'll need to temporarily allow port 80 for the certificate to generate.
|
|
||||||
:::
|
|
||||||
|
|
||||||
We use LetsEncrypt to provision our SSL certificates. If it is not installed, install it with:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo snap install --classic certbot
|
|
||||||
```
|
|
||||||
|
|
||||||
Then link the snap to our `usr` directory.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo ln -s /snap/bin/certbot /usr/bin/certbot
|
|
||||||
```
|
|
||||||
|
|
||||||
Generate a certificate with:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo certbot certonly --standalone
|
|
||||||
```
|
|
||||||
|
|
||||||
And allow applications to read it:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo chmod -R a+rwx /etc/letsencrypt
|
|
||||||
```
|
|
||||||
|
|
||||||
When you need to renew the certificate:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo certbot renew
|
|
||||||
```
|
|
||||||
|
|
||||||
### 4.2. NGINX Configuration
|
|
||||||
|
|
||||||
All requests should be routed through NGINX. At no point should an application run directly on ports 80 or 443.
|
|
||||||
|
|
||||||
Install NGINX:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo apt-get install nginx
|
|
||||||
```
|
|
||||||
|
|
||||||
Edit the configuration file:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo emacs /etc/nginx/conf.d/server.conf
|
|
||||||
```
|
|
||||||
|
|
||||||
Use this template to set up a reverse proxy on the standard HTTPS port 443:
|
|
||||||
|
|
||||||
```nginx
|
|
||||||
server {
|
|
||||||
listen 443 ssl;
|
|
||||||
server_name subdomain.domain.tld;
|
|
||||||
ssl_certificate /etc/letsencrypt/live/subdomain.domain.tld/fullchain.pem;
|
|
||||||
ssl_certificate_key /etc/letsencrypt/live/subdomain.domain.tld/privkey.pem;
|
|
||||||
|
|
||||||
location / {
|
|
||||||
proxy_set_header Host $host;
|
|
||||||
proxy_pass https://127.0.0.1:port;
|
|
||||||
proxy_redirect off;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
Validate that the config is correct with:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo nginx -t
|
|
||||||
```
|
|
||||||
|
|
||||||
If so, restart NGINX to apply the changes:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo systemctl restart nginx
|
|
||||||
```
|
|
||||||
|
|
||||||
## 5. SECURING THE SERVER
|
|
||||||
|
|
||||||
We have a minimum level of security that is required on ALL of our servers. This section should not be treated as the best effort, but as the minimal requirements to comply with our policies.
|
|
||||||
|
|
||||||
### 5.1. Firewall Configuration
|
|
||||||
|
|
||||||
We use `ufw` as our firewall. First, enable the SSH port.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo ufw allow "OpenSSH"
|
|
||||||
```
|
|
||||||
|
|
||||||
Then, allow the standard HTTPS port and **deny** the standard HTTP port.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo ufw deny http
|
|
||||||
sudo ufw allow https
|
|
||||||
```
|
|
||||||
|
|
||||||
Enable the firewall. You may get dropped from the SSH connection.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo ufw enable
|
|
||||||
```
|
|
||||||
|
|
||||||
### 5.2. Fail2Ban Configuration
|
|
||||||
|
|
||||||
We also use Fail2Ban to block IP addresses which fail to make requests too often.
|
|
||||||
|
|
||||||
Install the tool:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo apt-get install fail2ban
|
|
||||||
```
|
|
||||||
|
|
||||||
Configure the NGINX jail in `/etc/fail2ban/jail.d/nginx-auth.conf`:
|
|
||||||
|
|
||||||
```ini
|
|
||||||
[nginx-auth]
|
|
||||||
enabled = true
|
|
||||||
filter = nginx-auth
|
|
||||||
logpath = /var/log/nginx/access.log
|
|
||||||
maxretry = 3
|
|
||||||
findtime = 86400
|
|
||||||
bantime = 86400
|
|
||||||
```
|
|
||||||
|
|
||||||
Configure the NGINX filter in `/etc/fail2ban/filter.d/nginx-auth.conf`:
|
|
||||||
|
|
||||||
```ini
|
|
||||||
[Definition]
|
|
||||||
failregex = ^<HOST> - .* \[.*\] ".*" (4\d{2}) .*$
|
|
||||||
```
|
|
||||||
|
|
||||||
Because we use Cloudflare, you'll need to grab the original IP for all requests. Start by creating a file to store Cloudflare's IPs.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo touch /etc/nginx/cloudflare_ips.conf
|
|
||||||
```
|
|
||||||
|
|
||||||
Then create your script:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
nano ~/update_cf_ips.sh
|
|
||||||
```
|
|
||||||
|
|
||||||
```bash
|
|
||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Create a temporary file
|
|
||||||
temp_file=$(mktemp)
|
|
||||||
|
|
||||||
# Download IPv4 ranges and format each line
|
|
||||||
curl -s https://www.cloudflare.com/ips-v4 | while read ip; do
|
|
||||||
echo "set_real_ip_from $ip;" >> "$temp_file"
|
|
||||||
done
|
|
||||||
|
|
||||||
# Download IPv6 ranges and format each line
|
|
||||||
curl -s https://www.cloudflare.com/ips-v6 | while read ip; do
|
|
||||||
echo "set_real_ip_from $ip;" >> "$temp_file"
|
|
||||||
done
|
|
||||||
|
|
||||||
# Add the real_ip_header directive
|
|
||||||
echo "real_ip_header CF-Connecting-IP;" >> "$temp_file"
|
|
||||||
|
|
||||||
# Replace the old file with the new one
|
|
||||||
sudo mv "$temp_file" /etc/nginx/cloudflare_ips.conf
|
|
||||||
|
|
||||||
# Test Nginx configuration
|
|
||||||
sudo nginx -t
|
|
||||||
|
|
||||||
# If the test is successful, reload Nginx
|
|
||||||
if [ $? -eq 0 ]; then
|
|
||||||
sudo systemctl reload nginx
|
|
||||||
echo "Nginx configuration updated and reloaded successfully."
|
|
||||||
else
|
|
||||||
echo "Nginx configuration test failed. Please check your configuration."
|
|
||||||
fi
|
|
||||||
```
|
|
||||||
|
|
||||||
Make it executable and run it:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo chmod +x update_cf_ips.sh
|
|
||||||
sudo ./update_cf_ips.sh
|
|
||||||
```
|
|
||||||
|
|
||||||
If it runs as expected, set it up to run on a CRON.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo crontab -e
|
|
||||||
```
|
|
||||||
|
|
||||||
```bash
|
|
||||||
0 3 * * 1 ~/update_cf_ips.sh
|
|
||||||
```
|
|
||||||
|
|
||||||
Then, update the `/etc/nginx/nginx.conf` to use all of this new logic. This goes at the end of your `http` directive block.
|
|
||||||
|
|
||||||
```nginx
|
|
||||||
# Look at the real IP, not the cloudflare IP.
|
|
||||||
include /etc/nginx/cloudflare_ips.conf;
|
|
||||||
|
|
||||||
log_format custom_format '$remote_addr - $remote_user [$time_local] '
|
|
||||||
'"$request" $status $body_bytes_sent '
|
|
||||||
'"$http_referer" "$http_user_agent" '
|
|
||||||
'"$http_x_forwarded_for"';
|
|
||||||
|
|
||||||
access_log /var/log/nginx/access.log custom_format;
|
|
||||||
```
|
|
||||||
|
|
||||||
Confirm the NGINX configuration is correct:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo nginx -t
|
|
||||||
```
|
|
||||||
|
|
||||||
Then restart everything.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo systemctl restart nginx
|
|
||||||
sudo systemctl restart fail2ban
|
|
||||||
```
|
|
||||||
|
|
||||||
To view banned IPs:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo fail2ban-client status nginx-auth
|
|
||||||
```
|
|
||||||
|
|
||||||
And to unban them:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo fail2ban-client set nginx-auth unbanip <ip>
|
|
||||||
```
|
|
||||||
|
|
||||||
## 6. UPLOADING PROJECTS
|
|
||||||
|
|
||||||
To upload a project, you should **not** use `git` to clone the project to the machine. Instead, start by cloning the project to your local environment and navigating to the directory:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
git clone <url>
|
|
||||||
cd /path/to/project
|
|
||||||
```
|
|
||||||
|
|
||||||
Then sync the project up to the machine, ignoring any installed packages.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
rsync -av --exclude='node_modules' ./ <server name>:/home/NHCarrigan/<project directory>
|
|
||||||
```
|
|
||||||
|
|
||||||
## 7. RUNNING PROJECTS
|
|
||||||
|
|
||||||
Now you are ready to start running the project.
|
|
||||||
|
|
||||||
### 7.1. Node.js Setup
|
|
||||||
|
|
||||||
Most of our projects will run on Node. For a new machine, you'll need to set that up.
|
|
||||||
|
|
||||||
We use `nvm` to manage Node versions. Fetch and run the install script:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.37.2/install.sh | bash
|
|
||||||
```
|
|
||||||
|
|
||||||
The script will automatically update the `.bashrc` file to load `nvm` into the PATH. Reload that:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
source ~/.bashrc
|
|
||||||
```
|
|
||||||
|
|
||||||
Install the long-term support Node version.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
nvm install --lts
|
|
||||||
```
|
|
||||||
|
|
||||||
This should automatically set it as the default. When updating, be sure to remove any older versions!
|
|
||||||
|
|
||||||
Finally, install `pnpm` as the package manager.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
npm i -g pnpm
|
|
||||||
```
|
|
||||||
|
|
||||||
### 7.2. PM2 Process Management
|
|
||||||
|
|
||||||
All of our processes run with PM2 to allow for monitoring and auto-restarts. You'll need to install it.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
pnpm i -g pm2
|
|
||||||
```
|
|
||||||
|
|
||||||
To start a project, use this template:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
pm2 start '<script>' --name '<name>'
|
|
||||||
```
|
|
||||||
|
|
||||||
Then run `pm2 save` to save the application list.
|
|
||||||
|
|
||||||
## 8. LIMITATION OF LIABILITY AND DISCLAIMERS
|
|
||||||
|
|
||||||
### 8.1. Reference to Comprehensive Liability Framework
|
|
||||||
|
|
||||||
**IMPORTANT: Comprehensive liability limitations, damage exclusions, and maximum liability caps are set forth in our Limitation of Liability and Indemnification Policy, which is incorporated herein by reference.**
|
|
||||||
|
|
||||||
### 8.2. Server Configuration Disclaimer
|
|
||||||
|
|
||||||
This Documentation establishes mandatory security and configuration standards. However, compliance with these standards does not guarantee:
|
|
||||||
|
|
||||||
- Complete protection against all security threats or vulnerabilities
|
|
||||||
- Uninterrupted service availability or performance
|
|
||||||
- Compatibility with all applications or use cases
|
|
||||||
- Protection against all forms of attack or compromise
|
|
||||||
|
|
||||||
### 8.3. Security Disclaimer
|
|
||||||
|
|
||||||
While this Documentation establishes security requirements, server administrators are responsible for:
|
|
||||||
|
|
||||||
- Implementing additional security measures appropriate to their specific threat environment
|
|
||||||
- Regularly updating and patching all software and dependencies
|
|
||||||
- Monitoring server logs and security alerts
|
|
||||||
- Responding promptly to security incidents
|
|
||||||
- Maintaining compliance with all applicable security regulations and standards
|
|
||||||
|
|
||||||
### 8.4. Third-Party Services and Tools
|
|
||||||
|
|
||||||
This Documentation references various third-party services, tools, and software packages. Our organisation:
|
|
||||||
|
|
||||||
- Does not guarantee the security, availability, or functionality of third-party services
|
|
||||||
- Is not responsible for issues arising from the use of third-party tools or services
|
|
||||||
- Recommends that administrators review third-party licenses, terms of service, and security practices
|
|
||||||
- Does not provide support for third-party tools beyond what is necessary for project functionality
|
|
||||||
|
|
||||||
### 8.5. Technical Accuracy Disclaimer
|
|
||||||
|
|
||||||
While we strive to maintain accurate and current information in this Documentation, technical standards, software versions, and security best practices evolve continuously. Server administrators are responsible for:
|
|
||||||
|
|
||||||
- Verifying current software versions and compatibility
|
|
||||||
- Adapting configurations to their specific system requirements
|
|
||||||
- Ensuring compliance with current security standards and regulations
|
|
||||||
- Consulting additional resources for the most current security recommendations
|
|
||||||
|
|
||||||
## 9. CONCLUSION
|
|
||||||
|
|
||||||
This Server Setup Documentation establishes mandatory standards and procedures for configuring remote servers used to host projects maintained by our organisation. Strict adherence to these requirements is essential for maintaining security, reliability, and compliance with our organisational policies and legal obligations.
|
|
||||||
|
|
||||||
All personnel responsible for server configuration, deployment, or maintenance must familiarise themselves with and comply with the requirements set forth in this Documentation. Questions about server configuration requirements or security standards should be directed to appropriate technical leadership through designated communication channels.
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
*For questions about server configuration requirements or to suggest improvements, please contact technical leadership through the designated channels outlined in our Security Policy.*
|
|
||||||
@@ -12,10 +12,12 @@ This Style Guide (hereinafter referred to as "the Guide") establishes mandatory
|
|||||||
|
|
||||||
### 1.2. Scope and Applicability
|
### 1.2. Scope and Applicability
|
||||||
|
|
||||||
This Guide applies to all code contributions, regardless of contributor status, project type, or development context. All contributors are required to comply with the standards set forth in this Guide.
|
This Guide applies to all code contributions to NHCarrigan-maintained repositories, regardless of contributor status. All contributors to our projects are required to comply with the standards set forth in this Guide.
|
||||||
|
|
||||||
**IMPORTANT: Non-compliance with this Guide may result in rejection of contributions, requests for modification, or other appropriate actions as determined by project maintainers.**
|
**IMPORTANT: Non-compliance with this Guide may result in rejection of contributions, requests for modification, or other appropriate actions as determined by project maintainers.**
|
||||||
|
|
||||||
|
**Note for Mentorship Programme Participants:** This Guide governs contributions to NHCarrigan-maintained repositories only. It does not apply to your flagship project. Your flagship project is your own intellectual property, and you are entirely free to set your own style standards, choose your own licence, and use your own copyright attribution.
|
||||||
|
|
||||||
### 1.3. Legal Compliance and Intellectual Property
|
### 1.3. Legal Compliance and Intellectual Property
|
||||||
|
|
||||||
All code contributions must comply with:
|
All code contributions must comply with:
|
||||||
|
|||||||
@@ -1,54 +0,0 @@
|
|||||||
---
|
|
||||||
title: Naomi's VTubing Setup
|
|
||||||
---
|
|
||||||
|
|
||||||
Naomi uses her VTuber model for all of her client meetings, as well as streaming. Getting the software to work on Linux is a bit of a nightmare, so this page documents how she does so.
|
|
||||||
|
|
||||||
## 1. OpenSeeFace
|
|
||||||
|
|
||||||
In order to track her webcamera, OpenSeeFace needs to be run independently as a native script.
|
|
||||||
|
|
||||||
### 1.1. Installation
|
|
||||||
|
|
||||||
This should all be done in your home `~` directory.
|
|
||||||
|
|
||||||
- Begin by cloning the repository:
|
|
||||||
- `git clone https://github.com/emilianavt/OpenSeeFace`
|
|
||||||
- `cd OpenSeeFace`
|
|
||||||
- You will need to prepare Python
|
|
||||||
- Install the packages: `yay -Sy python python-virtualenv`
|
|
||||||
- Prepare the environment: `virtualenv -p python3 env`
|
|
||||||
- Source the environment: `source env/bin/activate`
|
|
||||||
- Install the dependencies: `pip3 install onnxruntime opencv-python pillow numpy`
|
|
||||||
|
|
||||||
### 1.2. Running
|
|
||||||
|
|
||||||
```
|
|
||||||
cd OpenSeeFace
|
|
||||||
source env/bin/activate
|
|
||||||
python facetracker.py -c 0 -W 1280 -H 720 --discard-after 0 --scan-every 0 --no-3d-adapt 1 --max-feature-updates 900
|
|
||||||
```
|
|
||||||
|
|
||||||
## 2. VSeeFace
|
|
||||||
|
|
||||||
VSeeFace does not run natively, and will need to run with Wine.
|
|
||||||
|
|
||||||
### 2.1. Installation
|
|
||||||
|
|
||||||
[Download and run the installer](https://www.vseeface.icu/#download). When selecting a directory, put it in `~/VSeeFace`.
|
|
||||||
|
|
||||||
### 2.2. Running
|
|
||||||
|
|
||||||
```bash
|
|
||||||
wine ~/VSeeFace/VSeeFace.exe --background-color "#00FF00"
|
|
||||||
```
|
|
||||||
|
|
||||||
The `--background-color` flag creates a green screen background to be chroma-keyed out by OBS.
|
|
||||||
|
|
||||||
## 3. OBS
|
|
||||||
|
|
||||||
OBS allows for virtual camera, as well as for streaming.
|
|
||||||
|
|
||||||
### 3.1. Installation
|
|
||||||
|
|
||||||
The `obs-studio-git` AUR package is Naomi's current installation.
|
|
||||||
@@ -67,7 +67,7 @@ This FAQ addresses common questions and concerns regarding programme participati
|
|||||||
|
|
||||||
**Response Time Guidelines:**
|
**Response Time Guidelines:**
|
||||||
- Most programme activities can be completed independently using provided documentation
|
- Most programme activities can be completed independently using provided documentation
|
||||||
- If you have questions, feel free to ask in the #mentee-chat channel
|
- If you have questions, feel free to ask in the #⚗️│alchemy-lab channel
|
||||||
- If you have not received a response within 10 business days, you may send a gentle reminder
|
- If you have not received a response within 10 business days, you may send a gentle reminder
|
||||||
- Repeated communications at intervals of less than 10 business days may result in disciplinary action
|
- Repeated communications at intervals of less than 10 business days may result in disciplinary action
|
||||||
- We appreciate your patience and understanding regarding response timelines
|
- We appreciate your patience and understanding regarding response timelines
|
||||||
@@ -140,7 +140,7 @@ All expulsion decisions are made in accordance with our Mentorship Programme Ter
|
|||||||
|
|
||||||
- Review the comprehensive mentorship documentation (01-10) for detailed guidance on each programme stage
|
- Review the comprehensive mentorship documentation (01-10) for detailed guidance on each programme stage
|
||||||
- Check the resource library for templates, examples, and additional materials
|
- Check the resource library for templates, examples, and additional materials
|
||||||
- Contact programme leadership through the designated #mentee-chat channel in our Discord community
|
- Contact programme leadership through the designated #⚗️│alchemy-lab channel in our Discord community
|
||||||
- Ask community members and alumni for peer support and guidance
|
- Ask community members and alumni for peer support and guidance
|
||||||
- Programme leadership is available to answer questions when asked, but most activities can be completed independently
|
- Programme leadership is available to answer questions when asked, but most activities can be completed independently
|
||||||
- Additional information is available in our comprehensive [Mentorship Programme Terms and Conditions](/about/mentorship)
|
- Additional information is available in our comprehensive [Mentorship Programme Terms and Conditions](/about/mentorship)
|
||||||
|
|||||||
@@ -24,7 +24,7 @@ Goal-setting procedures must be initiated following completion of onboarding pro
|
|||||||
|
|
||||||
### 2.2. Goal-Setting Forum Post Creation
|
### 2.2. Goal-Setting Forum Post Creation
|
||||||
|
|
||||||
**Required Action:** Create a thread in the #goal-setting forum channel on our Discord community.
|
**Required Action:** Create a thread in the #🎯│oaths forum channel on our Discord community.
|
||||||
|
|
||||||
**Thread Naming Convention:**
|
**Thread Naming Convention:**
|
||||||
```markdown
|
```markdown
|
||||||
@@ -63,7 +63,7 @@ Goal-setting procedures must be initiated following completion of onboarding pro
|
|||||||
### 2.4. Optional Feedback and Clarification
|
### 2.4. Optional Feedback and Clarification
|
||||||
|
|
||||||
If you would like feedback on your goal-setting post or have questions about creating your roadmap, you can:
|
If you would like feedback on your goal-setting post or have questions about creating your roadmap, you can:
|
||||||
- Ask questions in the #mentee-chat channel in Discord
|
- Ask questions in the #⚗️│alchemy-lab channel in Discord
|
||||||
- Request feedback from programme leadership or community members
|
- Request feedback from programme leadership or community members
|
||||||
- Review roadmap templates and examples in the resource library
|
- Review roadmap templates and examples in the resource library
|
||||||
- Proceed independently if you feel confident in your goals and plan
|
- Proceed independently if you feel confident in your goals and plan
|
||||||
|
|||||||
@@ -24,7 +24,7 @@ Project planning procedures must be initiated following completion of goal-setti
|
|||||||
|
|
||||||
### 2.2. Project Planning Forum Post Creation
|
### 2.2. Project Planning Forum Post Creation
|
||||||
|
|
||||||
**Required Action:** Create a post in the #project-plan forum channel on our Discord community.
|
**Required Action:** Create a post in the #🗺️│quest-board forum channel on our Discord community.
|
||||||
|
|
||||||
**Post Naming Convention:**
|
**Post Naming Convention:**
|
||||||
```markdown
|
```markdown
|
||||||
@@ -51,7 +51,7 @@ Project planning procedures must be initiated following completion of goal-setti
|
|||||||
**Project Idea Assistance:**
|
**Project Idea Assistance:**
|
||||||
- If you do not yet have a project idea, create your post with a statement such as: "I need help brainstorming a project idea"
|
- If you do not yet have a project idea, create your post with a statement such as: "I need help brainstorming a project idea"
|
||||||
- Review project idea examples in the resource library for inspiration
|
- Review project idea examples in the resource library for inspiration
|
||||||
- Ask for help in the #mentee-chat channel if you'd like community input
|
- Ask for help in the #⚗️│alchemy-lab channel if you'd like community input
|
||||||
- Programme leadership and community members can provide feedback if requested
|
- Programme leadership and community members can provide feedback if requested
|
||||||
- You can also proceed independently by researching project ideas online or adapting examples
|
- You can also proceed independently by researching project ideas online or adapting examples
|
||||||
|
|
||||||
@@ -68,7 +68,7 @@ Once your project planning post is created, you will develop your project plan i
|
|||||||
- Create a detailed project plan ready for development work
|
- Create a detailed project plan ready for development work
|
||||||
|
|
||||||
**Optional Support:**
|
**Optional Support:**
|
||||||
- If you need help brainstorming or refining your project idea, ask in the #mentee-chat channel
|
- If you need help brainstorming or refining your project idea, ask in the #⚗️│alchemy-lab channel
|
||||||
- Community members and programme leadership can provide feedback if requested
|
- Community members and programme leadership can provide feedback if requested
|
||||||
- You can proceed independently once you have a project concept you're happy with
|
- You can proceed independently once you have a project concept you're happy with
|
||||||
|
|
||||||
|
|||||||
@@ -93,7 +93,7 @@ Separate issues provide:
|
|||||||
|
|
||||||
**Optional Review:**
|
**Optional Review:**
|
||||||
- If you would like feedback on your user stories, you can:
|
- If you would like feedback on your user stories, you can:
|
||||||
- Request review in the #mentee-chat channel in Discord
|
- Request review in the #⚗️│alchemy-lab channel in Discord
|
||||||
- Ask community members or alumni for peer review
|
- Ask community members or alumni for peer review
|
||||||
- Review user story examples in the resource library for comparison
|
- Review user story examples in the resource library for comparison
|
||||||
- Reviews are optional and available upon request, not required
|
- Reviews are optional and available upon request, not required
|
||||||
|
|||||||
@@ -183,7 +183,7 @@ Complete the technical breakdown template for each user story. Completion includ
|
|||||||
|
|
||||||
**Optional Review:**
|
**Optional Review:**
|
||||||
- If you would like feedback on your technical breakdowns, you can:
|
- If you would like feedback on your technical breakdowns, you can:
|
||||||
- Request review in the #mentee-chat channel in Discord
|
- Request review in the #⚗️│alchemy-lab channel in Discord
|
||||||
- Ask community members or alumni for peer review
|
- Ask community members or alumni for peer review
|
||||||
- Review technical breakdown examples in the resource library for comparison
|
- Review technical breakdown examples in the resource library for comparison
|
||||||
|
|
||||||
|
|||||||
@@ -133,7 +133,7 @@ The purpose of applying effort labels is to help plan work timelines and resourc
|
|||||||
|
|
||||||
**Optional Review:**
|
**Optional Review:**
|
||||||
- If you would like feedback on your priority and effort assignments, you can:
|
- If you would like feedback on your priority and effort assignments, you can:
|
||||||
- Request review in the #mentee-chat channel in Discord
|
- Request review in the #⚗️│alchemy-lab channel in Discord
|
||||||
- Ask community members or alumni for peer review
|
- Ask community members or alumni for peer review
|
||||||
- Review priority and effort examples in the resource library for comparison
|
- Review priority and effort examples in the resource library for comparison
|
||||||
- Reviews are optional and available upon request, not required
|
- Reviews are optional and available upon request, not required
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ This Writing Code Documentation (hereinafter referred to as "the Documentation")
|
|||||||
|
|
||||||
This Documentation applies to all participants in our Mentorship Programme following completion of priority and effort assignment procedures. All participants should comply with the code development procedures set forth in this Documentation.
|
This Documentation applies to all participants in our Mentorship Programme following completion of priority and effort assignment procedures. All participants should comply with the code development procedures set forth in this Documentation.
|
||||||
|
|
||||||
**IMPORTANT: Code development should comply with our Style Guide, Contributor Covenant, and all applicable development standards. Code reviews are optional and available upon request, not mandatory.**
|
**IMPORTANT: Whilst developing your flagship project, you must comply with our [Community Code of Conduct](/community/coc) and [Community Guidelines](/community/guide). Your mentorship repository must not be used for any code or non-code content or behaviour that is illegal, harmful to others, discriminatory, or bigoted. See Section 7.3 for details on intellectual property and style standards. Code reviews are optional and available upon request, not mandatory.**
|
||||||
|
|
||||||
## 2. DEVELOPMENT WORKFLOW REQUIREMENTS
|
## 2. DEVELOPMENT WORKFLOW REQUIREMENTS
|
||||||
|
|
||||||
@@ -63,7 +63,7 @@ Before writing code, participants must consider and address the requirements set
|
|||||||
- Community members and alumni may also provide peer reviews if requested
|
- Community members and alumni may also provide peer reviews if requested
|
||||||
|
|
||||||
**Requesting Reviews:**
|
**Requesting Reviews:**
|
||||||
- If you would like a code review, request one in the #mentee-chat channel or tag programme leadership on your PR
|
- If you would like a code review, request one in the #⚗️│alchemy-lab channel or tag programme leadership on your PR
|
||||||
- Reviews are provided when available, not guaranteed immediately
|
- Reviews are provided when available, not guaranteed immediately
|
||||||
- You can proceed with development while waiting for reviews
|
- You can proceed with development while waiting for reviews
|
||||||
|
|
||||||
@@ -169,9 +169,11 @@ This Documentation establishes code development procedures and requirements. How
|
|||||||
- Programme leadership is not responsible for participants' ability to complete development work
|
- Programme leadership is not responsible for participants' ability to complete development work
|
||||||
- Individual results may vary based on participant skill, effort, and other factors
|
- Individual results may vary based on participant skill, effort, and other factors
|
||||||
|
|
||||||
### 7.3. Intellectual Property Considerations
|
### 7.3. Intellectual Property Ownership
|
||||||
|
|
||||||
All code developed as part of the Mentorship Programme is subject to our Mentorship Programme Terms and Conditions regarding intellectual property rights. Participants should familiarise themselves with these terms before beginning development work.
|
**Your flagship project belongs to you.** NHCarrigan makes no claim to intellectual property rights over projects developed during the Mentorship Programme. You own your project outright and are free to licence it however you choose.
|
||||||
|
|
||||||
|
**Regarding style standards:** Our Style Guide applies only to contributions to NHCarrigan-maintained repositories — it does not apply to your flagship project. You are entirely free to choose your own coding style, linting tools, licence, and copyright attribution for your own project.
|
||||||
|
|
||||||
## 8. CONCLUSION
|
## 8. CONCLUSION
|
||||||
|
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ When you believe your flagship project has reached a state where it can be proud
|
|||||||
- Begin addressing items on the checklist independently
|
- Begin addressing items on the checklist independently
|
||||||
|
|
||||||
**Optional Support:**
|
**Optional Support:**
|
||||||
- If you would like feedback on project readiness, ask in the #mentee-chat channel
|
- If you would like feedback on project readiness, ask in the #⚗️│alchemy-lab channel
|
||||||
- Programme leadership or community members can provide guidance if requested
|
- Programme leadership or community members can provide guidance if requested
|
||||||
- You can proceed independently using the provided resources
|
- You can proceed independently using the provided resources
|
||||||
|
|
||||||
@@ -81,7 +81,7 @@ Use the provided documentation templates and examples in the resource library to
|
|||||||
- End user documentation examples
|
- End user documentation examples
|
||||||
|
|
||||||
**Optional Support:**
|
**Optional Support:**
|
||||||
- If you need help with documentation, ask in the #mentee-chat channel
|
- If you need help with documentation, ask in the #⚗️│alchemy-lab channel
|
||||||
- Programme leadership or community members can provide guidance if requested
|
- Programme leadership or community members can provide guidance if requested
|
||||||
- You can proceed independently using the provided templates
|
- You can proceed independently using the provided templates
|
||||||
|
|
||||||
@@ -163,7 +163,7 @@ You should deploy a live version of your application for professional presentati
|
|||||||
- Free options may not always be viable depending on project requirements
|
- Free options may not always be viable depending on project requirements
|
||||||
|
|
||||||
**Optional Support:**
|
**Optional Support:**
|
||||||
- If you encounter issues during deployment, ask for help in the #mentee-chat channel
|
- If you encounter issues during deployment, ask for help in the #⚗️│alchemy-lab channel
|
||||||
- Programme leadership or community members can provide guidance if requested
|
- Programme leadership or community members can provide guidance if requested
|
||||||
- Most deployment can be completed independently using the provided guides
|
- Most deployment can be completed independently using the provided guides
|
||||||
|
|
||||||
|
|||||||
@@ -63,7 +63,7 @@ Upon reaching the career preparation stage, you have access to comprehensive res
|
|||||||
- Present your project effectively on your resume
|
- Present your project effectively on your resume
|
||||||
|
|
||||||
**Optional Review:**
|
**Optional Review:**
|
||||||
- If you would like feedback on your resume, request a review in the #mentee-chat channel
|
- If you would like feedback on your resume, request a review in the #⚗️│alchemy-lab channel
|
||||||
- Programme leadership or community members can provide feedback if requested
|
- Programme leadership or community members can provide feedback if requested
|
||||||
- Reviews are optional and available upon request
|
- Reviews are optional and available upon request
|
||||||
|
|
||||||
@@ -92,7 +92,7 @@ LinkedIn profile preparation should focus on:
|
|||||||
- Optimizing profile for recruiter visibility
|
- Optimizing profile for recruiter visibility
|
||||||
|
|
||||||
**Optional Review:**
|
**Optional Review:**
|
||||||
- If you would like feedback on your LinkedIn profile, request a review in the #mentee-chat channel
|
- If you would like feedback on your LinkedIn profile, request a review in the #⚗️│alchemy-lab channel
|
||||||
- Programme leadership or community members can provide feedback if requested
|
- Programme leadership or community members can provide feedback if requested
|
||||||
- Reviews are optional and available upon request
|
- Reviews are optional and available upon request
|
||||||
|
|
||||||
@@ -126,7 +126,7 @@ LinkedIn profile preparation should focus on:
|
|||||||
- Review application content using provided checklists
|
- Review application content using provided checklists
|
||||||
|
|
||||||
**Optional Support:**
|
**Optional Support:**
|
||||||
- If you would like feedback on your applications, request a review in the #mentee-chat channel
|
- If you would like feedback on your applications, request a review in the #⚗️│alchemy-lab channel
|
||||||
- Programme leadership or community members can provide feedback if requested
|
- Programme leadership or community members can provide feedback if requested
|
||||||
- Support is limited to guidance and feedback on application content
|
- Support is limited to guidance and feedback on application content
|
||||||
- You are responsible for submitting your own applications
|
- You are responsible for submitting your own applications
|
||||||
@@ -153,7 +153,7 @@ LinkedIn profile preparation should focus on:
|
|||||||
|
|
||||||
**Mock Interview Availability:**
|
**Mock Interview Availability:**
|
||||||
- Mock interviews are available upon request when programme leadership or community members are available
|
- Mock interviews are available upon request when programme leadership or community members are available
|
||||||
- Request mock interviews in the #mentee-chat channel
|
- Request mock interviews in the #⚗️│alchemy-lab channel
|
||||||
- Mock interviews prepare you for real interview situations
|
- Mock interviews prepare you for real interview situations
|
||||||
- Feedback and coaching on interview performance may be provided
|
- Feedback and coaching on interview performance may be provided
|
||||||
|
|
||||||
|
|||||||
@@ -1,94 +0,0 @@
|
|||||||
---
|
|
||||||
title: Managing Local Music
|
|
||||||
---
|
|
||||||
|
|
||||||
**DOCUMENTING LOCAL MUSIC LIBRARY MANAGEMENT PROCEDURES**
|
|
||||||
|
|
||||||
## 1. INTRODUCTION AND LEGAL FRAMEWORK
|
|
||||||
|
|
||||||
### 1.1. Policy Overview
|
|
||||||
|
|
||||||
This Music Management Documentation (hereinafter referred to as "the Documentation") provides technical procedures and instructions for managing local music libraries on Linux systems. This Documentation operates within our comprehensive legal and policy framework, incorporating our Terms of Service, Privacy Policy, and all applicable legal protections by reference.
|
|
||||||
|
|
||||||
### 1.2. Purpose and Scope
|
|
||||||
|
|
||||||
This Documentation describes technical procedures for managing local music libraries. This information is provided for informational purposes and personal use only.
|
|
||||||
|
|
||||||
**IMPORTANT: Users are solely responsible for ensuring that all music acquisition, storage, and management activities comply with applicable copyright laws, licensing agreements, and legal requirements. Our organisation does not condone or support any illegal activities, including copyright infringement or piracy.**
|
|
||||||
|
|
||||||
### 1.3. Legal Compliance Disclaimer
|
|
||||||
|
|
||||||
All users must ensure that their music acquisition and management activities comply with:
|
|
||||||
|
|
||||||
- Applicable copyright laws and regulations
|
|
||||||
- Terms of service of music platforms and services
|
|
||||||
- Licensing agreements for music content
|
|
||||||
- All relevant intellectual property laws
|
|
||||||
|
|
||||||
Our organisation assumes no responsibility for any illegal activities conducted using information from this Documentation.
|
|
||||||
|
|
||||||
## 2. ACQUIRING MUSIC
|
|
||||||
|
|
||||||
You are welcome to use any method you wish to *LEGALLY* acquire music. We would never encourage the criminal act of piracy. But maybe you're an artist and you want to archive or back up your own music - in that case, here you go:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
yt-dlp -x --audio-format mp3 <url> --cookies-from-browser firefox
|
|
||||||
```
|
|
||||||
|
|
||||||
Omit the `--cookies-from-browser firefox` if you do not need authentication (auth is required for age-restricted content, for example).
|
|
||||||
|
|
||||||
## 3. EDITING METADATA
|
|
||||||
|
|
||||||
The specific meta tags you may need to set will vary depending on the music software you use. We have confirmed that `TIT2` is read as the title and `TPE1` is read as the artist when using Amberol on Linux and Musicolet on Android. Using `-t` and `-a` might work.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
id3v2 "/path/to/song" --TIT2 "Song Title" --TPE1 "Song Artist"
|
|
||||||
```
|
|
||||||
|
|
||||||
## 4. ADDING COVER IMAGES
|
|
||||||
|
|
||||||
Download the image (we have confirmed JPEGs work) that you want to apply to the song, then run:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
eyeD3 --add-image="/path/to/img":FRONT_COVER "/path/to/mp3"
|
|
||||||
```
|
|
||||||
|
|
||||||
## 5. COPYING TO ANDROID DEVICES
|
|
||||||
|
|
||||||
You'll need to replace your paths and your device ID to match your local setup, but:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
adb -s 192.168.12.105:5555 push music/* /storage/self/primary/Music
|
|
||||||
```
|
|
||||||
|
|
||||||
## 6. LIMITATION OF LIABILITY AND DISCLAIMERS
|
|
||||||
|
|
||||||
### 6.1. Reference to Comprehensive Liability Framework
|
|
||||||
|
|
||||||
**IMPORTANT: Comprehensive liability limitations, damage exclusions, and maximum liability caps are set forth in our Limitation of Liability and Indemnification Policy, which is incorporated herein by reference.**
|
|
||||||
|
|
||||||
### 6.2. Legal Compliance Disclaimer
|
|
||||||
|
|
||||||
This Documentation provides technical procedures only. Our organisation:
|
|
||||||
|
|
||||||
- Does not provide legal advice regarding music acquisition or copyright compliance
|
|
||||||
- Does not endorse or support any illegal activities, including copyright infringement
|
|
||||||
- Assumes no responsibility for users' compliance with copyright laws or licensing agreements
|
|
||||||
- Recommends that users consult qualified legal counsel for questions about copyright compliance
|
|
||||||
|
|
||||||
### 6.3. Technical Accuracy Disclaimer
|
|
||||||
|
|
||||||
While we strive to maintain accurate and current information in this Documentation, software tools, commands, and procedures may change over time. Users are responsible for:
|
|
||||||
|
|
||||||
- Verifying current software versions and compatibility
|
|
||||||
- Adapting procedures to their specific system configurations
|
|
||||||
- Ensuring their technical setup meets the requirements for these procedures
|
|
||||||
- Consulting additional resources for the most current technical information
|
|
||||||
|
|
||||||
## 7. CONCLUSION
|
|
||||||
|
|
||||||
This Music Management Documentation provides technical procedures for managing local music libraries on Linux systems. All users must ensure that their use of these procedures complies with applicable copyright laws, licensing agreements, and legal requirements.
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
*For questions about music management procedures or legal compliance, please consult qualified legal counsel.*
|
|
||||||
@@ -1,151 +0,0 @@
|
|||||||
---
|
|
||||||
title: AI Prompts
|
|
||||||
---
|
|
||||||
|
|
||||||
**DOCUMENTING STANDARD AI PROMPTS AND WORKFLOW TEMPLATES**
|
|
||||||
|
|
||||||
## 1. INTRODUCTION AND LEGAL FRAMEWORK
|
|
||||||
|
|
||||||
### 1.1. Policy Overview
|
|
||||||
|
|
||||||
This AI Prompts Documentation (hereinafter referred to as "the Documentation") provides standard prompts, templates, and workflow instructions for using artificial intelligence tools in our organisational workflows. This Documentation operates within our comprehensive legal and policy framework, incorporating our Terms of Service, Privacy Policy, and all applicable legal protections by reference.
|
|
||||||
|
|
||||||
### 1.2. Purpose and Scope
|
|
||||||
|
|
||||||
This Documentation serves as a reference for standardised AI prompts used in various organisational contexts. These prompts are provided for convenience and consistency but may require customisation for specific use cases.
|
|
||||||
|
|
||||||
**IMPORTANT: These prompts are provided as starting points and may require modification to meet specific requirements. Users are responsible for ensuring that any use of AI tools complies with applicable laws, regulations, and organisational policies.**
|
|
||||||
|
|
||||||
### 1.3. AI Tool Usage Disclaimer
|
|
||||||
|
|
||||||
Our organisation does not guarantee the accuracy, reliability, or appropriateness of outputs generated using these prompts. Users are responsible for:
|
|
||||||
|
|
||||||
- Reviewing and validating all AI-generated content
|
|
||||||
- Ensuring compliance with applicable laws and regulations
|
|
||||||
- Maintaining appropriate oversight of AI tool usage
|
|
||||||
- Protecting sensitive or confidential information when using AI tools
|
|
||||||
|
|
||||||
## 2. AI PROMPTS
|
|
||||||
|
|
||||||
### 2.1. Documentation Generation Prompt
|
|
||||||
|
|
||||||
Open Claude Code in your project directory, then provide this prompt:
|
|
||||||
|
|
||||||
```md
|
|
||||||
Please go through the entire `src` directory and use the codebase to generate documentation for me, given the following template:
|
|
||||||
|
|
||||||
---
|
|
||||||
title: <app name>
|
|
||||||
---
|
|
||||||
|
|
||||||
<app name> (hereinafter the "Application") is <description>
|
|
||||||
|
|
||||||
## 1. User Documentation
|
|
||||||
|
|
||||||
This section is for those interacting with a live instance of the Application.
|
|
||||||
|
|
||||||
## 2. Technical Documentation
|
|
||||||
|
|
||||||
This section is for those interested in running their own instance of the Application.
|
|
||||||
|
|
||||||
## 3. Legal Documentation
|
|
||||||
|
|
||||||
This section is for expansions to our legal policies specific to the Application.
|
|
||||||
|
|
||||||
## 4. Contributing Documentation
|
|
||||||
|
|
||||||
This section is for documentation related to contributing to the Application's codebase.
|
|
||||||
```
|
|
||||||
|
|
||||||
### 2.2. Comprehension Question Generation Prompt
|
|
||||||
|
|
||||||
We use this for some of our client work, but this is great for creating questions to quiz yourself on any document you've read.
|
|
||||||
|
|
||||||
````md
|
|
||||||
You must create three comprehension check questions for the lecture script the user provides. Do not include any other information. Format the response as a code block so the user can easily copy the syntax.
|
|
||||||
|
|
||||||
Here is the format:
|
|
||||||
|
|
||||||
```
|
|
||||||
### Question 1:
|
|
||||||
|
|
||||||
Which of the following is a key characteristic of relational databases?
|
|
||||||
|
|
||||||
**A.** Flexible schema
|
|
||||||
|
|
||||||
**B.** Document-based structure
|
|
||||||
|
|
||||||
**C.** Key-value pairs
|
|
||||||
|
|
||||||
**D.** Structured data in tables
|
|
||||||
|
|
||||||
Hint: Think about how data is organised in relational databases.
|
|
||||||
|
|
||||||
Answer: **D.** Structured data in tables
|
|
||||||
|
|
||||||
### Question 2:
|
|
||||||
|
|
||||||
Which of the following is a key characteristic of relational databases?
|
|
||||||
|
|
||||||
**A.** Flexible schema
|
|
||||||
|
|
||||||
**B.** Document-based structure
|
|
||||||
|
|
||||||
**C.** Key-value pairs
|
|
||||||
|
|
||||||
**D.** Structured data in tables
|
|
||||||
|
|
||||||
Hint: Think about how data is organised in relational databases.
|
|
||||||
|
|
||||||
Answer: **D.** Structured data in tables
|
|
||||||
|
|
||||||
### Question 3:
|
|
||||||
|
|
||||||
Which of the following is a key characteristic of relational databases?
|
|
||||||
|
|
||||||
**A.** Flexible schema
|
|
||||||
|
|
||||||
**B.** Document-based structure
|
|
||||||
|
|
||||||
**C.** Key-value pairs
|
|
||||||
|
|
||||||
**D.** Structured data in tables
|
|
||||||
|
|
||||||
Hint: Think about how data is organised in relational databases.
|
|
||||||
|
|
||||||
Answer: **D.** Structured data in tables
|
|
||||||
```
|
|
||||||
````
|
|
||||||
|
|
||||||
## 3. LIMITATION OF LIABILITY AND DISCLAIMERS
|
|
||||||
|
|
||||||
### 3.1. Reference to Comprehensive Liability Framework
|
|
||||||
|
|
||||||
**IMPORTANT: Comprehensive liability limitations, damage exclusions, and maximum liability caps are set forth in our Limitation of Liability and Indemnification Policy, which is incorporated herein by reference.**
|
|
||||||
|
|
||||||
### 3.2. AI Tool Usage Disclaimer
|
|
||||||
|
|
||||||
These prompts are provided for informational purposes only. Our organisation:
|
|
||||||
|
|
||||||
- Does not guarantee the accuracy, reliability, or appropriateness of outputs generated using these prompts
|
|
||||||
- Does not warrant that these prompts will produce desired results in all contexts
|
|
||||||
- Assumes no responsibility for outcomes resulting from the use of these prompts with AI tools
|
|
||||||
- Recommends that users review and validate all AI-generated content
|
|
||||||
|
|
||||||
### 3.3. User Responsibilities
|
|
||||||
|
|
||||||
Users are responsible for:
|
|
||||||
|
|
||||||
- Reviewing and validating all AI-generated content before use
|
|
||||||
- Ensuring compliance with applicable laws, regulations, and organisational policies
|
|
||||||
- Protecting sensitive or confidential information when using AI tools
|
|
||||||
- Maintaining appropriate oversight and quality control of AI tool usage
|
|
||||||
- Adapting prompts to meet specific requirements and contexts
|
|
||||||
|
|
||||||
## 4. CONCLUSION
|
|
||||||
|
|
||||||
This AI Prompts Documentation provides standardised prompts and workflow templates for using artificial intelligence tools in our organisational workflows. All users are responsible for ensuring that their use of these prompts complies with applicable laws, regulations, and organisational policies, and for maintaining appropriate oversight of AI tool usage.
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
*For questions about AI prompt usage or to suggest improvements, please contact appropriate organisational leadership through designated communication channels.*
|
|
||||||
@@ -1,852 +0,0 @@
|
|||||||
---
|
|
||||||
title: Templates
|
|
||||||
---
|
|
||||||
|
|
||||||
**PROVIDING STANDARD TEMPLATES AND DOCUMENTATION FORMS**
|
|
||||||
|
|
||||||
## 1. INTRODUCTION AND LEGAL FRAMEWORK
|
|
||||||
|
|
||||||
### 1.1. Policy Overview
|
|
||||||
|
|
||||||
This Templates Documentation (hereinafter referred to as "the Documentation") provides standard templates, forms, and documentation formats used throughout our organisation. This Documentation operates within our comprehensive legal and policy framework, incorporating our Terms of Service, Privacy Policy, and all applicable legal protections by reference.
|
|
||||||
|
|
||||||
### 1.2. Purpose and Scope
|
|
||||||
|
|
||||||
This Documentation serves as a reference for standardised templates used in various organisational contexts. These templates are provided for convenience and consistency but may require customisation for specific use cases.
|
|
||||||
|
|
||||||
**IMPORTANT: These templates are provided as starting points and may require modification to meet specific legal, regulatory, or contextual requirements. Users are responsible for ensuring that any use of these templates complies with applicable laws and regulations.**
|
|
||||||
|
|
||||||
### 1.3. Disclaimer
|
|
||||||
|
|
||||||
Our organisation does not provide legal advice. These templates are provided for informational purposes only. Users should consult with qualified legal counsel when using these templates for legal matters or when compliance with specific regulations is required.
|
|
||||||
|
|
||||||
## 2. TEMPLATES
|
|
||||||
|
|
||||||
### 2.1. Legal Templates
|
|
||||||
|
|
||||||
#### 2.1.1. DMCA Takedown Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
To whom it may concern:
|
|
||||||
|
|
||||||
We are writing to notify you of the copyright infringement and unlawful use of our copyrighted material that appear on the service for which you are the designated agent.
|
|
||||||
|
|
||||||
The infringing material, which we contend belong to us, includes our original visual assets.
|
|
||||||
|
|
||||||
The infringing material appears at the following location(s):
|
|
||||||
|
|
||||||
<url>
|
|
||||||
|
|
||||||
The original material is available at the following location(s):
|
|
||||||
|
|
||||||
<url>
|
|
||||||
|
|
||||||
This letter is the official notification under Section 512(c) of the Digital Millennium Copyright Act of 1998 ("DMCA") and we request the immediate removal of the aforementioned infringing materials from your servers.
|
|
||||||
|
|
||||||
We also request that you immediately notify the infringer of this notice and inform them to cease any further posting of the infringing material to your server in the future.
|
|
||||||
|
|
||||||
We are providing this notice in good faith and with the reasonable belief that we are the copyright holder of the material, and that the use of the described material in the manner complained is not authorised by us, our agents, or the law.
|
|
||||||
|
|
||||||
We swear, under penalty of perjury, that the information in this notification is accurate and that we are the owner of the copyrighted material involved.
|
|
||||||
|
|
||||||
If you have any questions, please feel free to reach out to us.
|
|
||||||
```
|
|
||||||
|
|
||||||
### 2.2. LinkedIn Templates
|
|
||||||
|
|
||||||
#### 2.2.1. LinkedIn Cold Outreach Response Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
I would be more than happy to chat! You can schedule time directly on my calendar:
|
|
||||||
|
|
||||||
https://zcal.co/nhcarrigan/meet
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.2.2. LinkedIn Post-Event Recommendation Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
I had the absolute pleasure of working with [Participant's Name] during our [event name], where [they] consistently impressed me with [their] dedication, technical growth, and collaborative spirit.
|
|
||||||
|
|
||||||
From the start, [Participant's Name] dove into the challenge with enthusiasm, applying [their] skills in [tech stack] to build real, impactful solutions. Whether working independently or as part of a team, [they] brought thoughtful ideas, clear communication, and a passion for learning that elevated everyone around [them].
|
|
||||||
|
|
||||||
The value of [Participant's Name]'s contributions are immeasurable. Throughout the event, they [explain loads of goals here].
|
|
||||||
|
|
||||||
By the end of the [event name], [Participant's Name] had delivered an outstanding project: [project name or brief description]. More than the final product, what stood out was [their] journey—embracing feedback, overcoming obstacles, and supporting others along the way.
|
|
||||||
|
|
||||||
I wholeheartedly recommend [Participant's Name] for any opportunity in tech. [They] bring not just technical ability, but the kind of energy and curiosity that makes any team stronger.
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.2.3. LinkedIn Mentorship Recommendation Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
I had the privilege of mentoring [Mentee's Name] through my 1:1 mentorship programme, and from our very first session, it was clear that [they] approached learning with curiosity, determination, and an eagerness to grow.
|
|
||||||
|
|
||||||
Over the course of the programme, [Mentee's Name] set clear goals and worked diligently towards them—building both technical skills in [specific tech stack, tools, or concepts] and the professional confidence to apply those skills in real-world scenarios. [They] embraced feedback, sought out challenges, and consistently demonstrated the resilience needed to push past obstacles.
|
|
||||||
|
|
||||||
What impressed me most was [their] commitment to personal and professional growth—not just in terms of technical ability, but also in communication, collaboration, and problem-solving. By the end of the mentorship, [Mentee's Name] had successfully delivered [describe final project or achievement], showing not only technical proficiency but also the ability to think critically and adapt to new situations.
|
|
||||||
|
|
||||||
I am confident that [Mentee's Name] will continue to excel in their career. They bring the kind of focus, curiosity, and dedication that make them a valuable asset to any team, and I am proud to have played a part in their journey.
|
|
||||||
```
|
|
||||||
|
|
||||||
### 2.3. Form Response Email Templates
|
|
||||||
|
|
||||||
#### 2.3.1. Appeals Form - Approval Email Template
|
|
||||||
|
|
||||||
Subject Line: `Appeal Decision - [Sanction Type] Appeal Upheld`
|
|
||||||
|
|
||||||
```md
|
|
||||||
Dear [Appellant's Name],
|
|
||||||
|
|
||||||
Thank you for submitting your appeal regarding the disciplinary sanction imposed on [date of original sanction]. We acknowledge receipt of your appeal and have conducted a thorough review in accordance with our Community Disciplinary Appeals Policy.
|
|
||||||
|
|
||||||
After careful consideration by the Appeals Panel, which included examination of all evidence and documentation, review of the original decision and its rationale, and assessment of your submissions and arguments, we have determined that your appeal has merit and meets the grounds for appeal as established in our policy.
|
|
||||||
|
|
||||||
**Decision**: Your appeal has been upheld. The original disciplinary sanction has been [overturned/modified/reduced] as follows: [Insert specific details about the new decision].
|
|
||||||
|
|
||||||
**Reasoning**: [Insert detailed reasoning here, addressing the specific grounds raised in the appeal and explaining why the appeal was successful. This should reference procedural compliance, proportionality of the sanction, factual accuracy, evidence considered, and correct application of community policies.]
|
|
||||||
|
|
||||||
As outlined in Section 8.1 of our Community Disciplinary Appeals Policy, decisions of the Appeals Panel are final and binding. The decision outlined above is effective immediately.
|
|
||||||
|
|
||||||
We appreciate your engagement with our appeals process and your respect for our community standards. We look forward to your continued positive participation in our community.
|
|
||||||
|
|
||||||
Regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.2. Appeals Form - Rejection Email Template
|
|
||||||
|
|
||||||
Subject Line: `Appeal Decision - [Sanction Type] Appeal Dismissed`
|
|
||||||
|
|
||||||
```md
|
|
||||||
Dear [Appellant's Name],
|
|
||||||
|
|
||||||
Thank you for submitting your appeal regarding the disciplinary sanction imposed on [date of original sanction]. We acknowledge receipt of your appeal and have conducted a thorough review in accordance with our Community Disciplinary Appeals Policy.
|
|
||||||
|
|
||||||
After careful consideration by the Appeals Panel, which included examination of all evidence and documentation, review of the original decision and its rationale, and assessment of your submissions and arguments, we have determined that your appeal does not meet the grounds for appeal as established in our policy.
|
|
||||||
|
|
||||||
**Decision**: Your appeal has been dismissed. The original disciplinary sanction remains in full effect.
|
|
||||||
|
|
||||||
**Reasoning**: [Insert detailed reasoning here, addressing the specific grounds raised in the appeal and explaining why the original decision was appropriate. This should reference procedural compliance, proportionality of the sanction, factual accuracy, evidence considered, and correct application of community policies.]
|
|
||||||
|
|
||||||
As outlined in Section 8.1 of our Community Disciplinary Appeals Policy, decisions of the Appeals Panel are final and binding. No further appeals or reviews are available through our internal processes.
|
|
||||||
|
|
||||||
We understand that this decision may be disappointing. Our appeals process is designed to ensure fairness and transparency, and we have given your submission careful consideration. The original sanction was imposed in accordance with our community standards and policies, which are designed to maintain a safe and welcoming environment for all members.
|
|
||||||
|
|
||||||
If you have any questions about this decision, please note that our Appeals Panel's determination is final. We appreciate your understanding and respect for our community standards and processes.
|
|
||||||
|
|
||||||
Regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.3. Commissions Form - Approval Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Requester's Name],
|
|
||||||
|
|
||||||
Thank you for your commission request! We are excited to work with you on [brief description of commission].
|
|
||||||
|
|
||||||
We have reviewed your request and are pleased to accept it. We will begin working on your commission and will keep you updated on our progress.
|
|
||||||
|
|
||||||
**Next Steps:**
|
|
||||||
- [Insert specific next steps, timeline, or requirements here]
|
|
||||||
- You will receive updates via [preferred contact method]
|
|
||||||
- Expected completion date: [date if applicable]
|
|
||||||
|
|
||||||
If you have any questions or need to make changes to your request, please don't hesitate to reach out to us.
|
|
||||||
|
|
||||||
We look forward to creating something amazing for you!
|
|
||||||
|
|
||||||
Best regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.4. Commissions Form - Rejection Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Requester's Name],
|
|
||||||
|
|
||||||
Thank you for your interest in commissioning work from us. We appreciate you taking the time to submit your request.
|
|
||||||
|
|
||||||
After careful review, we have decided not to proceed with your commission request at this time. This decision may be based on factors such as current workload, project scope, timeline constraints, or alignment with our services.
|
|
||||||
|
|
||||||
Please note that due to the volume of requests we receive, we are unable to provide detailed feedback on every declined request.
|
|
||||||
|
|
||||||
We encourage you to stay engaged with our community and projects. If your needs change or you have a different project in mind, we would welcome a new request in the future.
|
|
||||||
|
|
||||||
If you have any questions, please reach out in our Discord community: https://chat.nhcarrigan.com
|
|
||||||
|
|
||||||
Best regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.5. Community Recognition Form - Approval Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Nominator's Name],
|
|
||||||
|
|
||||||
Thank you for taking the time to nominate [Nominee's Name] for community recognition! We truly appreciate you highlighting the positive contributions of community members.
|
|
||||||
|
|
||||||
We are pleased to inform you that your nomination has been accepted and will be considered in our next recognition cycle. The recognition process involves review by our leadership team, and selected nominees will be celebrated through our community recognition programmes.
|
|
||||||
|
|
||||||
**What Happens Next:**
|
|
||||||
- Your nomination will be reviewed by our recognition committee
|
|
||||||
- Selected nominees will be notified and celebrated publicly
|
|
||||||
- Recognition may include awards, spotlights, or other forms of appreciation
|
|
||||||
- All nominations help us build a more appreciative and inclusive community
|
|
||||||
|
|
||||||
Thank you for helping us celebrate the amazing contributions of our community members. Your nomination makes a difference!
|
|
||||||
|
|
||||||
If you have any questions, please reach out in our Discord community: https://chat.nhcarrigan.com
|
|
||||||
|
|
||||||
Warm regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.6. Community Recognition Form - Rejection Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Nominator's Name],
|
|
||||||
|
|
||||||
Thank you for taking the time to submit a nomination for community recognition. We truly appreciate your effort to highlight positive contributions in our community.
|
|
||||||
|
|
||||||
After careful review, we have decided not to proceed with this nomination at this time. This decision may be based on factors such as eligibility criteria, timing, or alignment with our recognition programmes.
|
|
||||||
|
|
||||||
Please note that due to the volume of nominations we receive, we are unable to provide detailed feedback on every declined nomination.
|
|
||||||
|
|
||||||
We encourage you to continue recognising positive contributions in our community. There are many ways to show appreciation, including direct recognition, peer appreciation, and future nominations.
|
|
||||||
|
|
||||||
If you have any questions about our recognition programmes, please reach out in our Discord community: https://chat.nhcarrigan.com
|
|
||||||
|
|
||||||
Thank you again for your engagement with our community.
|
|
||||||
|
|
||||||
Warm regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.7. Contact Form - Approval Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Contact's Name],
|
|
||||||
|
|
||||||
Thank you for reaching out to us through our contact form. We have received your message regarding [brief topic summary].
|
|
||||||
|
|
||||||
We appreciate you taking the time to contact us and are pleased to confirm that we have received your inquiry. [Insert specific response or next steps here, such as:]
|
|
||||||
|
|
||||||
- We will review your request and respond within [timeframe]
|
|
||||||
- A team member will be in touch shortly
|
|
||||||
- We have scheduled a follow-up [meeting/call/response] for [date/time]
|
|
||||||
|
|
||||||
If you have any urgent questions or need immediate assistance, please don't hesitate to reach out in our Discord community: https://chat.nhcarrigan.com
|
|
||||||
|
|
||||||
We look forward to connecting with you!
|
|
||||||
|
|
||||||
Best regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.8. Contact Form - Rejection Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Contact's Name],
|
|
||||||
|
|
||||||
Thank you for reaching out to us through our contact form. We have received your message regarding [brief topic summary].
|
|
||||||
|
|
||||||
After reviewing your inquiry, we are unable to assist with your request at this time. This may be due to factors such as scope of services, current capacity, or alignment with our mission and values.
|
|
||||||
|
|
||||||
Please note that due to the volume of inquiries we receive, we are unable to provide detailed feedback on every declined request.
|
|
||||||
|
|
||||||
If you have questions about our services or policies, we encourage you to review our documentation at https://docs.nhcarrigan.com or join our Discord community: https://chat.nhcarrigan.com
|
|
||||||
|
|
||||||
Thank you for your understanding.
|
|
||||||
|
|
||||||
Best regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.9. Development Review Requests Form - Approval Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Requester's Name],
|
|
||||||
|
|
||||||
Thank you for your development review request! We have reviewed your submission and are pleased to accept your request for review of [project/repository name or description].
|
|
||||||
|
|
||||||
**Review Details:**
|
|
||||||
- Review Type: [Code Review/Project Review/Architecture Review/etc.]
|
|
||||||
- Materials to be Reviewed: [list of materials]
|
|
||||||
- Expected Timeline: [timeline for review completion]
|
|
||||||
|
|
||||||
**Next Steps:**
|
|
||||||
- Our team will begin reviewing your materials
|
|
||||||
- You will receive detailed feedback via [communication method]
|
|
||||||
- We will provide constructive suggestions for improvement
|
|
||||||
|
|
||||||
Please note that development reviews are provided as free services to active community members, and feedback is provided in good faith based on our expertise and best practices.
|
|
||||||
|
|
||||||
If you have any questions or need to provide additional materials, please don't hesitate to reach out.
|
|
||||||
|
|
||||||
We look forward to reviewing your work!
|
|
||||||
|
|
||||||
Best regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.10. Development Review Requests Form - Rejection Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Requester's Name],
|
|
||||||
|
|
||||||
Thank you for your interest in receiving a development review. We appreciate you taking the time to submit your request.
|
|
||||||
|
|
||||||
After careful review, we have decided not to proceed with your development review request at this time. This decision may be based on factors such as:
|
|
||||||
- Current review capacity and workload
|
|
||||||
- Alignment with our review services and expertise
|
|
||||||
- Community membership and engagement requirements
|
|
||||||
- Project scope or complexity
|
|
||||||
|
|
||||||
Please note that development reviews are provided as free services exclusively to active members of our community. If you are not currently an active community member, we encourage you to join our Discord community at https://chat.nhcarrigan.com and become an active participant.
|
|
||||||
|
|
||||||
If you have questions about our development review services or would like to resubmit in the future, please reach out in our Discord community: https://chat.nhcarrigan.com
|
|
||||||
|
|
||||||
Thank you for your understanding.
|
|
||||||
|
|
||||||
Best regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.11. Events Form - Approval Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Event Organiser's Name],
|
|
||||||
|
|
||||||
Thank you for your event request! We are excited about your proposed event: [Event Name].
|
|
||||||
|
|
||||||
We have reviewed your submission and are pleased to approve your event request. We look forward to supporting and promoting this event within our community.
|
|
||||||
|
|
||||||
**Event Details:**
|
|
||||||
- Event Name: [Event Name]
|
|
||||||
- Proposed Date: [Date]
|
|
||||||
- Event Type: [Type of event]
|
|
||||||
|
|
||||||
**Next Steps:**
|
|
||||||
- [Insert specific next steps, such as scheduling, promotion, or coordination details]
|
|
||||||
- We will work with you to finalise event details
|
|
||||||
- Event promotion will begin [timeline]
|
|
||||||
|
|
||||||
If you have any questions or need to make changes to your event details, please don't hesitate to reach out to us.
|
|
||||||
|
|
||||||
Thank you for contributing to our community through this event!
|
|
||||||
|
|
||||||
Best regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.12. Events Form - Rejection Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Event Organiser's Name],
|
|
||||||
|
|
||||||
Thank you for your interest in organising an event with our community. We appreciate you taking the time to submit your event request: [Event Name].
|
|
||||||
|
|
||||||
After careful review, we have decided not to proceed with your event request at this time. This decision may be based on factors such as:
|
|
||||||
- Current event calendar and capacity
|
|
||||||
- Alignment with our community values and mission
|
|
||||||
- Resource availability and support requirements
|
|
||||||
- Event scope or logistics
|
|
||||||
|
|
||||||
Please note that due to the volume of event requests we receive, we are unable to provide detailed feedback on every declined request.
|
|
||||||
|
|
||||||
We encourage you to stay engaged with our community and consider submitting future event proposals. If you have questions about our event policies or would like to discuss alternative event formats, please reach out in our Discord community: https://chat.nhcarrigan.com
|
|
||||||
|
|
||||||
Thank you for your understanding and continued engagement with our community.
|
|
||||||
|
|
||||||
Best regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.13. Mock Interview Requests Form - Approval Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Requester's Name],
|
|
||||||
|
|
||||||
Thank you for your mock interview request! We have reviewed your submission and are pleased to accept your request for a [technical/behavioural/combined] mock interview.
|
|
||||||
|
|
||||||
**Interview Details:**
|
|
||||||
- Interview Type: [Type]
|
|
||||||
- Target Role: [Role if provided]
|
|
||||||
- Interview Format: [Format]
|
|
||||||
|
|
||||||
**Next Steps:**
|
|
||||||
- We will coordinate with you to schedule your mock interview session
|
|
||||||
- Mock interviews are typically conducted via [video call/voice call]
|
|
||||||
- Sessions typically last between 30-60 minutes
|
|
||||||
- You will receive preparation materials and session details via [communication method]
|
|
||||||
|
|
||||||
Please note that mock interviews are provided as free services exclusively to active members of our community. We look forward to helping you prepare for your upcoming interview!
|
|
||||||
|
|
||||||
If you have any questions or need to reschedule, please don't hesitate to reach out to us.
|
|
||||||
|
|
||||||
Best regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.14. Mock Interview Requests Form - Rejection Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Requester's Name],
|
|
||||||
|
|
||||||
Thank you for your interest in receiving a mock interview. We appreciate you taking the time to submit your request.
|
|
||||||
|
|
||||||
After careful review, we have decided not to proceed with your mock interview request at this time. This decision may be based on factors such as:
|
|
||||||
- Current interview capacity and availability
|
|
||||||
- Community membership and engagement requirements
|
|
||||||
- Interview type or scope alignment with our services
|
|
||||||
- Scheduling constraints
|
|
||||||
|
|
||||||
**IMPORTANT**: Mock interviews are provided as free services EXCLUSIVELY to active members of our community. These services are NOT available to the general public. To be eligible, you MUST be an active, engaged member of our community with demonstrated participation and engagement.
|
|
||||||
|
|
||||||
If you are not currently an active community member, we encourage you to join our Discord community at https://chat.nhcarrigan.com and become an active participant. Once you have established active community membership through regular participation and engagement, you will be eligible to request mock interview services.
|
|
||||||
|
|
||||||
If you have questions about our mock interview services or community membership, please reach out in our Discord community: https://chat.nhcarrigan.com
|
|
||||||
|
|
||||||
Thank you for your understanding.
|
|
||||||
|
|
||||||
Best regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.15. Portfolio Review Requests Form - Approval Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Requester's Name],
|
|
||||||
|
|
||||||
Thank you for your portfolio review request! We have reviewed your submission and are pleased to accept your request for review of your [resume/LinkedIn profile/GitHub profile/portfolio website].
|
|
||||||
|
|
||||||
**Review Details:**
|
|
||||||
- Review Type: [Resume/LinkedIn/GitHub/Portfolio Review]
|
|
||||||
- Materials to be Reviewed: [list of materials or links]
|
|
||||||
|
|
||||||
**Next Steps:**
|
|
||||||
- Our team will begin reviewing your materials
|
|
||||||
- You will receive detailed feedback via [communication method]
|
|
||||||
- We will provide constructive suggestions for improvement based on industry best practices
|
|
||||||
|
|
||||||
Please note that portfolio reviews are provided as free services to active community members, and feedback is provided in good faith based on our expertise and professional standards.
|
|
||||||
|
|
||||||
If you have any questions or need to provide additional materials, please don't hesitate to reach out.
|
|
||||||
|
|
||||||
We look forward to reviewing your materials and helping you improve your professional presentation!
|
|
||||||
|
|
||||||
Best regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.16. Portfolio Review Requests Form - Rejection Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Requester's Name],
|
|
||||||
|
|
||||||
Thank you for your interest in receiving a portfolio review. We appreciate you taking the time to submit your request.
|
|
||||||
|
|
||||||
After careful review, we have decided not to proceed with your portfolio review request at this time. This decision may be based on factors such as:
|
|
||||||
- Current review capacity and workload
|
|
||||||
- Community membership and engagement requirements
|
|
||||||
- Material accessibility or completeness
|
|
||||||
- Review type alignment with our services
|
|
||||||
|
|
||||||
**IMPORTANT**: Portfolio reviews are provided as free services EXCLUSIVELY to active members of our community. These services are NOT available to the general public. To be eligible, you MUST be an active, engaged member of our community with demonstrated participation and engagement.
|
|
||||||
|
|
||||||
If you are not currently an active community member, we encourage you to join our Discord community at https://chat.nhcarrigan.com and become an active participant. Once you have established active community membership through regular participation and engagement, you will be eligible to request portfolio review services.
|
|
||||||
|
|
||||||
If you have questions about our portfolio review services or community membership, please reach out in our Discord community: https://chat.nhcarrigan.com
|
|
||||||
|
|
||||||
Thank you for your understanding.
|
|
||||||
|
|
||||||
Best regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.17. Recommendations Form - Approval Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Requester's Name],
|
|
||||||
|
|
||||||
Thank you for your recommendation request! We have reviewed your submission and are pleased to accept your request for a recommendation.
|
|
||||||
|
|
||||||
**Recommendation Details:**
|
|
||||||
- Recommendation Type: [LinkedIn Recommendation/General Recommendation/etc.]
|
|
||||||
- Context: [Brief context if provided]
|
|
||||||
|
|
||||||
**Next Steps:**
|
|
||||||
- We will prepare your recommendation based on our relationship and your contributions
|
|
||||||
- Recommendations are typically provided via [LinkedIn/email/etc.]
|
|
||||||
- You will receive a copy of the recommendation once it is completed
|
|
||||||
- Expected completion: [timeline]
|
|
||||||
|
|
||||||
Please note that recommendations are provided as free services in good faith, based on our relationship and knowledge of your work. We provide honest, accurate recommendations based on our direct experience with you.
|
|
||||||
|
|
||||||
If you have any questions or need to provide additional context, please don't hesitate to reach out.
|
|
||||||
|
|
||||||
We are happy to support you in your professional journey!
|
|
||||||
|
|
||||||
Best regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.18. Recommendations Form - Rejection Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Requester's Name],
|
|
||||||
|
|
||||||
Thank you for your interest in receiving a recommendation. We appreciate you taking the time to submit your request.
|
|
||||||
|
|
||||||
After careful review, we have decided not to proceed with your recommendation request at this time. This decision may be based on factors such as:
|
|
||||||
- Insufficient direct working relationship or interaction
|
|
||||||
- Lack of sufficient context or experience to provide an accurate recommendation
|
|
||||||
- Timeline constraints or capacity limitations
|
|
||||||
- Alignment with our recommendation policy and standards
|
|
||||||
|
|
||||||
Please note that we can only provide recommendations when we have sufficient direct experience and relationship with the requester to provide an honest, accurate, and meaningful recommendation.
|
|
||||||
|
|
||||||
If you believe there has been an error or would like to discuss your request further, please reach out in our Discord community: https://chat.nhcarrigan.com
|
|
||||||
|
|
||||||
Thank you for your understanding.
|
|
||||||
|
|
||||||
Best regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.19. Staff Applications Form - Approval Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Dear [Applicant's Name],
|
|
||||||
|
|
||||||
Thank you so much for taking the time to apply for a volunteer role with NHCarrigan. We truly appreciate your interest in contributing your time and energy to our community.
|
|
||||||
|
|
||||||
After carefully reviewing your application, we are excited to inform you that we would like to move forward with your candidacy! We were impressed by [specific aspects of their application] and believe you would be a valuable addition to our team.
|
|
||||||
|
|
||||||
**Next Steps:**
|
|
||||||
- You will receive a separate email with your contract and onboarding materials
|
|
||||||
- Please review the contract carefully and reach out with any questions or concerns
|
|
||||||
- You can reach out to us on Discord (https://chat.nhcarrigan.com) or reply to this email if you have any questions or concerns
|
|
||||||
|
|
||||||
We are thrilled about the possibility of working with you and look forward to welcoming you to our team. Thank you again for your interest and enthusiasm!
|
|
||||||
|
|
||||||
Warm regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.20. Staff Applications Form - Onboarding Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Dear [New Staff Member's Name],
|
|
||||||
|
|
||||||
Welcome to the NHCarrigan team! We are thrilled to have you join us and are excited to begin working together.
|
|
||||||
|
|
||||||
**Getting Started:**
|
|
||||||
|
|
||||||
1. **Join Our Discord Server:**
|
|
||||||
- Please join our Discord community at: https://chat.nhcarrigan.com
|
|
||||||
- This is where most of our team communication and collaboration happens
|
|
||||||
|
|
||||||
2. **Access Credentials:**
|
|
||||||
- **Email:**
|
|
||||||
- Address:
|
|
||||||
- Password:
|
|
||||||
- Can access email via web at https://mail.nhcarrigan.com/mail or through any email client/app. A reminder that this is only for work-related use. Please do not spam people and get our mail server blocked (I do have logs).
|
|
||||||
- **Gitea:** https://git.nhcarrigan.com
|
|
||||||
- Username:
|
|
||||||
- Password:
|
|
||||||
|
|
||||||
3. **Complete Your Training:**
|
|
||||||
- Please complete the policy assessment form for training: https://forms.nhcarrigan.com/o/docs/forms/nxaJyKBuKH9nrt3m5VC98w/4
|
|
||||||
- This is an important step to ensure you are familiar with our policies and procedures
|
|
||||||
|
|
||||||
**Next Steps:**
|
|
||||||
- Our team will be in touch shortly to discuss your role-specific responsibilities
|
|
||||||
- Feel free to explore our documentation at https://docs.nhcarrigan.com
|
|
||||||
|
|
||||||
If you have any questions or need assistance getting set up, please don't hesitate to reach out to us on Discord or reply to this email.
|
|
||||||
|
|
||||||
We are excited to have you on board and look forward to working with you!
|
|
||||||
|
|
||||||
Warm regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.21. Staff Applications Form - Rejection Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Dear [Applicant's Name],
|
|
||||||
|
|
||||||
Thank you so much for taking the time to apply for a volunteer role with NHCarrigan. We truly appreciate your interest in contributing your time and energy to our community.
|
|
||||||
|
|
||||||
After carefully reviewing your application, we've decided not to move forward with your candidacy for this volunteer position at this time. Please don't take this as a reflection of your value or potential—our selection process is highly competitive, and we often have to make very difficult decisions.
|
|
||||||
|
|
||||||
Please note that due to the large volume of applications we receive, we are unable to provide personalised feedback. Here are some common application issues we see:
|
|
||||||
|
|
||||||
1. Low-effort Application: Please ensure you are taking the time to provide detailed, well-thought responses. The more effort you put in, the more likely we will be able to accept your application.
|
|
||||||
2. Invalid Discord ID: Applications require you to provide your unique Discord ID - this is a 16 to 19 digit number that uniquely identifies your Discord account. If this is incorrect, we are unable to accept an application. If you need help finding yours, please refer to https://dis.gd/findid
|
|
||||||
3. Concerning Responses: If your responses to any of the application questions raise red flags, we decline your application. Remember that you want to paint yourself in the best light here.
|
|
||||||
|
|
||||||
We still encourage you to stay engaged with our community spaces, events, and projects. There are always opportunities to connect, learn, and grow together, and we would love to see you continue to participate.
|
|
||||||
|
|
||||||
We encourage you to take the time to consider these common points of failure, and would welcome a resubmission from you in the future.
|
|
||||||
|
|
||||||
Thank you again for your interest and enthusiasm. We wish you the very best in all your endeavors and hope our paths cross again in the future.
|
|
||||||
|
|
||||||
Warm regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.22. Testimonials Form - Approval Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Contributor's Name],
|
|
||||||
|
|
||||||
Thank you for sharing your testimonial with us! We have reviewed your submission and are pleased to accept it for publication.
|
|
||||||
|
|
||||||
**Testimonial Details:**
|
|
||||||
- Your testimonial will be reviewed and may be featured on our website, social media, or other promotional materials
|
|
||||||
- We may edit your testimonial for length, clarity, or formatting whilst preserving your message and intent
|
|
||||||
- You will be credited as [name/handle as provided]
|
|
||||||
|
|
||||||
**Next Steps:**
|
|
||||||
- Your testimonial will be added to our review queue
|
|
||||||
- We will notify you when it is published (if applicable)
|
|
||||||
- Thank you for helping others learn about our community and services!
|
|
||||||
|
|
||||||
Your words help us build trust and connect with others who might benefit from our community. We truly appreciate you taking the time to share your experience.
|
|
||||||
|
|
||||||
If you have any questions or would like to make changes to your testimonial, please don't hesitate to reach out.
|
|
||||||
|
|
||||||
Best regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.3.23. Testimonials Form - Rejection Email Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello [Contributor's Name],
|
|
||||||
|
|
||||||
Thank you for taking the time to submit a testimonial. We appreciate your interest in sharing your experience with our community.
|
|
||||||
|
|
||||||
After careful review, we have decided not to publish your testimonial at this time. This decision may be based on factors such as:
|
|
||||||
- Content alignment with our community values and standards
|
|
||||||
- Formatting or clarity requirements
|
|
||||||
- Current testimonial collection needs
|
|
||||||
- Verification or authenticity concerns
|
|
||||||
|
|
||||||
Please note that due to the volume of testimonials we receive, we are unable to provide detailed feedback on every declined submission.
|
|
||||||
|
|
||||||
We encourage you to stay engaged with our community and consider submitting a testimonial in the future if your experience changes or if you have additional feedback to share.
|
|
||||||
|
|
||||||
If you have questions about our testimonial process, please reach out in our Discord community: https://chat.nhcarrigan.com
|
|
||||||
|
|
||||||
Thank you for your understanding and continued engagement with our community.
|
|
||||||
|
|
||||||
Best regards,
|
|
||||||
```
|
|
||||||
|
|
||||||
### 2.4. Form Components
|
|
||||||
|
|
||||||
#### 2.4.1. Form Consent for Email Communications
|
|
||||||
|
|
||||||
Description:
|
|
||||||
|
|
||||||
```
|
|
||||||
At NHCarrigan, we are fully committed to respecting and protecting your privacy. We strictly adhere to a policy of non-disclosure regarding your personal data; we do not sell, trade, or transfer your information to outside parties. The contact details you provide will be used exclusively for the purpose of responding to your inquiry or addressing the subject of this form. For a complete overview of our data practices, please review our [Privacy Policy](https://docs.nhcarrigan.com/legal/privacy/).
|
|
||||||
```
|
|
||||||
|
|
||||||
Question:
|
|
||||||
|
|
||||||
```
|
|
||||||
I agree to be contacted via email, solely for the purpose of addressing this submission.
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.4.2. Form Image Header
|
|
||||||
|
|
||||||
```html
|
|
||||||
<div style="width: 100%; text-align: center"><img src="https://cdn.nhcarrigan.com/logo.png" style="width: 250px; height: 250px"></div>
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.4.3. Form Confirmation
|
|
||||||
|
|
||||||
Add this at the end of any form specific text.
|
|
||||||
|
|
||||||
```
|
|
||||||
If you'd like to stay up to date on everything we do, come hang out in our server! https://chat.nhcarrigan.com
|
|
||||||
```
|
|
||||||
|
|
||||||
### 2.5. Community & Communication Templates
|
|
||||||
|
|
||||||
#### 2.5.1. Discord Server Introduction Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
Hello~! I'm Naomi, a 34 year old transfem software engineer and community manager based in Washington. All of my work (and therefore most of my life) is spent online, so I'm always looking for new spaces and people to vibe with. Remote work can feel dreadfully isolating, and this is my attempt to combat that feeling.
|
|
||||||
|
|
||||||
<insert bit about community here>
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.5.2. freeCodeCamp Contributor Sprint Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
## This issue is part of Naomi's sprint initiatives.
|
|
||||||
|
|
||||||
If you are interested in working on this issue, [join our Discord](https://chat.freecodecamp.org) and ping Naomi!
|
|
||||||
|
|
||||||
### Action Items
|
|
||||||
|
|
||||||
- [ ] Prototype created and PRed to https://github.com/freeCodeCamp/curriculumexpansion
|
|
||||||
- [ ] Prototype reviewed + approved + merged by staff
|
|
||||||
- [ ] Break prototype down into steps (if workshop) or individual "step" (if lab) - write description, hint text **only** (no tests yet), and seed code. Refer to https://contribute.freecodecamp.org/how-to-work-on-coding-challenges
|
|
||||||
- [ ] DRAFT PR opened on https://github.com/freeCodeCamp/freeCodeCamp
|
|
||||||
- [ ] Team + Naomi review your steps, confirm the breakdown + user stories look good
|
|
||||||
- [ ] Begin writing the actual test logic, refer to https://contribute.freecodecamp.org/curriculum-help/#basic-usage-pattern for how to write tests for Python challenges
|
|
||||||
- [ ] Mark PR as not a draft, team reviews + approves + merges
|
|
||||||
- [ ] YOU DID IT GO CELEBRATE!
|
|
||||||
|
|
||||||
### Other Details
|
|
||||||
|
|
||||||
- Remember to keep an eye on your PRs and respond to review comments and suggestions
|
|
||||||
- For workshops, refer to: https://contribute.freecodecamp.org/how-to-work-on-coding-challenges/
|
|
||||||
- For labs, refer to: https://contribute.freecodecamp.org/how-to-work-on-labs/
|
|
||||||
|
|
||||||
### Questions
|
|
||||||
|
|
||||||
Ping Naomi in the sprint channel on Discord
|
|
||||||
```
|
|
||||||
|
|
||||||
### 2.6. Gaming Templates
|
|
||||||
|
|
||||||
#### 2.6.1. Guild Wars 2 Recruitment Advertisement Template
|
|
||||||
|
|
||||||
This has to be sent in two chat messages because of the length.
|
|
||||||
|
|
||||||
```
|
|
||||||
Hiya friends~! Naomi's Newbies is a new guild that is really focused on helping newer players come to love the game, and supporting casual players who have busy schedules.
|
|
||||||
```
|
|
||||||
|
|
||||||
```
|
|
||||||
We have no activity requirement, no rep requirement, a Discord community, and more! If you are interested, please whisper me and I will gladly invite you!
|
|
||||||
```
|
|
||||||
|
|
||||||
### 2.7. Donation Templates
|
|
||||||
|
|
||||||
#### 2.7.1. Discord Bot Donation Copy Template
|
|
||||||
|
|
||||||
These go in the bot SKUs:
|
|
||||||
|
|
||||||
##### 2.7.1.1. Subscription Name
|
|
||||||
|
|
||||||
```
|
|
||||||
Sponsor Naomi
|
|
||||||
```
|
|
||||||
|
|
||||||
##### 2.7.1.2. Subscription Description
|
|
||||||
|
|
||||||
```
|
|
||||||
**How Your Support Makes a Difference**
|
|
||||||
|
|
||||||
1. Creating Free Software
|
|
||||||
- Develop open-source tools accessible to everyone
|
|
||||||
- Design Discord bots for community management and safe spaces
|
|
||||||
- Create learning resources and accessibility-focused web applications
|
|
||||||
|
|
||||||
2. Building Inclusive Communities
|
|
||||||
- Manage welcoming online spaces where diverse voices are celebrated
|
|
||||||
- Organise virtual events, workshops, and mentorship programmes
|
|
||||||
- Implement inclusive community guidelines
|
|
||||||
|
|
||||||
3. Guiding Others in Tech
|
|
||||||
- Provide mentorship to aspiring technologists from underrepresented groups
|
|
||||||
- Create educational content (tutorials, blog posts, videos)
|
|
||||||
- Offer career advice and emotional support
|
|
||||||
|
|
||||||
4. Your Contribution's Ripple Effect:
|
|
||||||
- Challenges the status quo of the tech industry
|
|
||||||
- Creates opportunities for underrepresented individuals in STEM
|
|
||||||
- Fosters innovation through diverse perspectives
|
|
||||||
- Builds a tech community that reflects and serves all of society
|
|
||||||
|
|
||||||
Every donation, regardless of size, contributes to this mission. Together, we're creating a more inclusive, accessible, and diverse future for technology.
|
|
||||||
Thank you for considering a donation and being part of this important journey.
|
|
||||||
```
|
|
||||||
|
|
||||||
##### 2.7.1.3. Benefit Name
|
|
||||||
|
|
||||||
```
|
|
||||||
Your donation:
|
|
||||||
```
|
|
||||||
|
|
||||||
##### 2.7.1.4. Benefit Description
|
|
||||||
|
|
||||||
```
|
|
||||||
Helps a transfemme technology witch create free software, build inclusive communities, and guide others on their journey in tech.
|
|
||||||
```
|
|
||||||
|
|
||||||
##### 2.7.1.5. Notes
|
|
||||||
|
|
||||||
- Use my avatar for subscription
|
|
||||||
- Use pentatrans for benefit
|
|
||||||
|
|
||||||
### 2.8. freeCodeCamp Templates
|
|
||||||
|
|
||||||
#### 2.8.1. freeCodeCamp Sprint Issue Template
|
|
||||||
|
|
||||||
```md
|
|
||||||
**Type:** Workshop/Lab/????
|
|
||||||
**Summary:**
|
|
||||||
|
|
||||||
**User Stories**
|
|
||||||
1.
|
|
||||||
2.
|
|
||||||
3.
|
|
||||||
|
|
||||||
**Technical Notes**
|
|
||||||
-
|
|
||||||
-
|
|
||||||
-
|
|
||||||
|
|
||||||
## This issue is part of Naomi's sprint initiatives.
|
|
||||||
|
|
||||||
If you are interested in working on this issue, [join our Discord](https://chat.freecodecamp.org) and ping Naomi!
|
|
||||||
|
|
||||||
### Action Items
|
|
||||||
|
|
||||||
- [ ] Prototype created and PRed to https://github.com/freeCodeCamp/curriculumexpansion
|
|
||||||
- [ ] Prototype reviewed + approved + merged by staff
|
|
||||||
- [ ] Break prototype down into steps (if workshop) or individual "step" (if lab) - write description, hint text **only** (no tests yet), and seed code.
|
|
||||||
- [ ] DRAFT PR opened on https://github.com/freeCodeCamp/freeCodeCamp
|
|
||||||
- [ ] Team + Naomi review your steps, confirm the breakdown + user stories look good
|
|
||||||
- [ ] Begin writing the actual test logic, refer to https://contribute.freecodecamp.org/curriculum-help/#js-helper for how to write tests for JS challenges
|
|
||||||
- [ ] Mark PR as not a draft, team reviews + approves + merges
|
|
||||||
- [ ] YOU DID IT GO CELEBRATE!
|
|
||||||
|
|
||||||
### Other Details
|
|
||||||
|
|
||||||
- Remember to keep an eye on your PRs and respond to review comments and suggestions
|
|
||||||
- For workshops, refer to: https://contribute.freecodecamp.org/how-to-work-on-coding-challenges/
|
|
||||||
- For labs, refer to: https://contribute.freecodecamp.org/how-to-work-on-labs/
|
|
||||||
|
|
||||||
### Questions
|
|
||||||
|
|
||||||
Ping Naomi in the sprint channel on Discord
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 2.8.2. freeCodeCamp Sprint Progress Update
|
|
||||||
|
|
||||||
```md
|
|
||||||
**Progress Update - <date>**
|
|
||||||
|
|
||||||
<summarise what contributor said>
|
|
||||||
```
|
|
||||||
|
|
||||||
## 3. DISCLAIMERS AND USAGE REQUIREMENTS
|
|
||||||
|
|
||||||
### 3.1. Reference to Comprehensive Liability Framework
|
|
||||||
|
|
||||||
**IMPORTANT: Comprehensive liability limitations, damage exclusions, and maximum liability caps are set forth in our Limitation of Liability and Indemnification Policy, which is incorporated herein by reference.**
|
|
||||||
|
|
||||||
### 3.2. Template Usage Disclaimer
|
|
||||||
|
|
||||||
These templates are provided for informational purposes only. Our organisation:
|
|
||||||
|
|
||||||
- Does not provide legal advice or guarantee the legal effectiveness of these templates
|
|
||||||
- Does not warrant that these templates will meet specific legal, regulatory, or contextual requirements
|
|
||||||
- Recommends that users consult with qualified legal counsel when using these templates for legal matters
|
|
||||||
- Assumes no responsibility for outcomes resulting from the use of these templates
|
|
||||||
|
|
||||||
### 3.3. Customisation Requirements
|
|
||||||
|
|
||||||
Users are responsible for:
|
|
||||||
|
|
||||||
- Customising templates to meet their specific needs and requirements
|
|
||||||
- Ensuring compliance with applicable laws, regulations, and organisational policies
|
|
||||||
- Verifying the accuracy and appropriateness of template content for their specific use case
|
|
||||||
- Obtaining appropriate legal review when necessary
|
|
||||||
|
|
||||||
## 4. CONCLUSION
|
|
||||||
|
|
||||||
This Templates Documentation provides standardised templates and forms for use throughout our organisation. All users are responsible for ensuring that their use of these templates complies with applicable laws, regulations, and organisational requirements.
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
*For questions about template usage or to suggest improvements, please contact appropriate organisational leadership through designated communication channels.*
|
|
||||||
@@ -165,7 +165,7 @@ Your Discord bot requires the following Gateway Intents:
|
|||||||
|
|
||||||
Create a `.env` file in the project root with the following variables:
|
Create a `.env` file in the project root with the following variables:
|
||||||
|
|
||||||
```env
|
```sh
|
||||||
# Discord Bot Configuration
|
# Discord Bot Configuration
|
||||||
TOKEN=your_discord_bot_token
|
TOKEN=your_discord_bot_token
|
||||||
|
|
||||||
|
|||||||
@@ -64,7 +64,7 @@ This section is for those interested in running their own instance of the Applic
|
|||||||
```
|
```
|
||||||
|
|
||||||
4. Edit `.env` with your configuration:
|
4. Edit `.env` with your configuration:
|
||||||
```env
|
```sh
|
||||||
DISCORD_TOKEN="your-discord-bot-token"
|
DISCORD_TOKEN="your-discord-bot-token"
|
||||||
SENTRY_DSN="your-sentry-dsn"
|
SENTRY_DSN="your-sentry-dsn"
|
||||||
DEBUG_HOOK="your-discord-webhook-url"
|
DEBUG_HOOK="your-discord-webhook-url"
|
||||||
|
|||||||
@@ -114,7 +114,7 @@ npm install
|
|||||||
|
|
||||||
Create a `prod.env` file in the root directory with the following variables:
|
Create a `prod.env` file in the root directory with the following variables:
|
||||||
|
|
||||||
```env
|
```sh
|
||||||
DISCORD_TOKEN=your_discord_bot_token
|
DISCORD_TOKEN=your_discord_bot_token
|
||||||
AI_TOKEN=your_anthropic_api_key
|
AI_TOKEN=your_anthropic_api_key
|
||||||
LOG_TOKEN=your_logging_token (optional)
|
LOG_TOKEN=your_logging_token (optional)
|
||||||
|
|||||||
@@ -199,7 +199,7 @@ pnpm install
|
|||||||
|
|
||||||
Create a `prod.env` file with the following variables:
|
Create a `prod.env` file with the following variables:
|
||||||
|
|
||||||
```env
|
```sh
|
||||||
DISCORD_TOKEN=your_discord_bot_token
|
DISCORD_TOKEN=your_discord_bot_token
|
||||||
MONGO_URI=your_mongodb_connection_string
|
MONGO_URI=your_mongodb_connection_string
|
||||||
LOG_TOKEN=your_logging_service_token
|
LOG_TOKEN=your_logging_service_token
|
||||||
|
|||||||
@@ -136,7 +136,7 @@ The Application is built with the following technologies:
|
|||||||
|
|
||||||
Create a `prod.env` file in the project root with the following variables:
|
Create a `prod.env` file in the project root with the following variables:
|
||||||
|
|
||||||
```env
|
```sh
|
||||||
# Required: Anthropic API key for Claude AI
|
# Required: Anthropic API key for Claude AI
|
||||||
ANTHROPIC_API_KEY=your_anthropic_api_key_here
|
ANTHROPIC_API_KEY=your_anthropic_api_key_here
|
||||||
|
|
||||||
|
|||||||
@@ -50,7 +50,7 @@ Rosalia Nightsong is built using:
|
|||||||
|
|
||||||
The application requires the following environment variables:
|
The application requires the following environment variables:
|
||||||
|
|
||||||
```env
|
```sh
|
||||||
MATRIX_ACCESS_TOKEN="matrix_access_token"
|
MATRIX_ACCESS_TOKEN="matrix_access_token"
|
||||||
MATRIX_ROOM_ID="matrix_room_id"
|
MATRIX_ROOM_ID="matrix_room_id"
|
||||||
API_AUTH="api_authentication_token"
|
API_AUTH="api_authentication_token"
|
||||||
|
|||||||
@@ -218,7 +218,7 @@ This section is for those interested in running their own instance of the Applic
|
|||||||
4. **Set up environment variables:**
|
4. **Set up environment variables:**
|
||||||
|
|
||||||
Create a `.env` file with required credentials:
|
Create a `.env` file with required credentials:
|
||||||
```env
|
```sh
|
||||||
# Crowdin (for translation scripts)
|
# Crowdin (for translation scripts)
|
||||||
CROWDIN_PROJECT_ID=your_project_id
|
CROWDIN_PROJECT_ID=your_project_id
|
||||||
CROWDIN_API_URL=https://api.crowdin.com/api/v2
|
CROWDIN_API_URL=https://api.crowdin.com/api/v2
|
||||||
|
|||||||
+19
-5
@@ -1,8 +1,22 @@
|
|||||||
@font-face {
|
@import url('https://fonts.googleapis.com/css2?family=Kalam:wght@300;400;700&family=Creepster&family=Griffy&family=Henny+Penny&display=swap');
|
||||||
font-family: "Vampyr";
|
|
||||||
src: url("https://cdn.nhcarrigan.com/fonts/vampyr.ttf") format("truetype");
|
body {
|
||||||
|
font-family: "Kalam", cursive !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
* {
|
h1,
|
||||||
font-family: "Vampyr", monospace !important;
|
h2,
|
||||||
|
h3,
|
||||||
|
h4,
|
||||||
|
h5,
|
||||||
|
h6 {
|
||||||
|
font-family: "Griffy", cursive !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.witchy-accent {
|
||||||
|
font-family: "Creepster", cursive;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mystical-text {
|
||||||
|
font-family: "Henny Penny", cursive;
|
||||||
}
|
}
|
||||||
+87
-13
@@ -1,18 +1,19 @@
|
|||||||
:root {
|
:root {
|
||||||
/* Witch color palette */
|
/* Witch color palette */
|
||||||
--witch-purple: #2B1B3D;
|
--witch-purple: #2b1b3d;
|
||||||
--witch-plum: #44275A;
|
--witch-purple-translucent: hsla(267, 40%, 17%, 0.85);
|
||||||
--witch-rose: #A8577E;
|
--witch-plum: #44275a;
|
||||||
--witch-mauve: #D4A5C7;
|
--witch-rose: #a8577e;
|
||||||
--witch-lavender: #E8D5E8;
|
--witch-mauve: #d4a5c7;
|
||||||
--witch-black: #0A0009;
|
--witch-lavender: #e8d5e8;
|
||||||
--witch-silver: #C0C0C0;
|
--witch-black: #0a0009;
|
||||||
--witch-moon: #F5F5F5;
|
--witch-silver: #c0c0c0;
|
||||||
|
--witch-moon: #f5f5f5;
|
||||||
--witch-shadow: rgba(10, 0, 9, 0.7);
|
--witch-shadow: rgba(10, 0, 9, 0.7);
|
||||||
|
|
||||||
/* Light theme uses lighter colors for background, darker for text */
|
/* Light theme uses lighter colors for background, darker for text */
|
||||||
--primary-color: var(--witch-purple);
|
--primary-color: var(--witch-purple);
|
||||||
--background-color: var(--witch-lavender)DC;
|
--background-color: var(--witch-lavender) DC;
|
||||||
--sl-color-text-accent: var(--witch-purple);
|
--sl-color-text-accent: var(--witch-purple);
|
||||||
|
|
||||||
/* Additional Starlight overrides */
|
/* Additional Starlight overrides */
|
||||||
@@ -22,12 +23,19 @@
|
|||||||
--sl-color-gray-4: var(--witch-rose);
|
--sl-color-gray-4: var(--witch-rose);
|
||||||
--sl-color-gray-5: var(--witch-plum);
|
--sl-color-gray-5: var(--witch-plum);
|
||||||
--sl-color-gray-6: var(--witch-purple);
|
--sl-color-gray-6: var(--witch-purple);
|
||||||
|
|
||||||
|
/* Translucent background */
|
||||||
|
--content-bg: rgba(181, 185, 187, 0.85);
|
||||||
|
--content-blur: 8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
html[data-theme="dark"] {
|
html[data-theme="dark"] {
|
||||||
/* Dark theme uses darker colors for background, lighter for text */
|
/* Dark theme uses darker colors for background, lighter for text */
|
||||||
|
|
||||||
|
.page {
|
||||||
|
--background-color: transparent;
|
||||||
|
}
|
||||||
--primary-color: var(--witch-lavender);
|
--primary-color: var(--witch-lavender);
|
||||||
--background-color: var(--witch-purple)ee;
|
|
||||||
--sl-color-text-accent: var(--witch-lavender);
|
--sl-color-text-accent: var(--witch-lavender);
|
||||||
|
|
||||||
/* Additional Starlight overrides for dark theme */
|
/* Additional Starlight overrides for dark theme */
|
||||||
@@ -62,11 +70,15 @@ html[data-theme="dark"] {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.sidebar-pane,
|
.sidebar-pane,
|
||||||
.right-sidebar-panel {
|
.right-sidebar {
|
||||||
background-color: var(--background-color);
|
background-color: var(--background-color);
|
||||||
color: var(--primary-color);
|
color: var(--primary-color);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.right-sidebar-panel {
|
||||||
|
color: var(--primary-color);
|
||||||
|
}
|
||||||
|
|
||||||
h1,
|
h1,
|
||||||
h2,
|
h2,
|
||||||
h3,
|
h3,
|
||||||
@@ -77,14 +89,31 @@ a {
|
|||||||
color: var(--primary-color) !important;
|
color: var(--primary-color) !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.page {
|
||||||
|
background: var(--content-bg);
|
||||||
|
backdrop-filter: var(--content-blur);
|
||||||
|
}
|
||||||
|
|
||||||
|
html[data-theme="dark"] .page {
|
||||||
|
background: var(--witch-purple-translucent);
|
||||||
|
}
|
||||||
|
|
||||||
a[aria-current="page"] {
|
a[aria-current="page"] {
|
||||||
color: var(--background-color) !important;
|
color: var(--background-color) !important;
|
||||||
background-color: var(--witch-rose) !important;
|
background-color: var(--witch-rose) !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
html[data-theme="dark"] a[aria-current="page"] {
|
||||||
|
color: var(--witch-moon) !important;
|
||||||
|
}
|
||||||
|
|
||||||
header {
|
header {
|
||||||
color: var(--primary-color) !important;
|
color: var(--primary-color) !important;
|
||||||
background-color: var(--background-color) !important;
|
background-color: var(--witch-lavender) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
html[data-theme="dark"] header {
|
||||||
|
background-color: var(--witch-purple) !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.large {
|
.large {
|
||||||
@@ -106,10 +135,26 @@ footer > div > p {
|
|||||||
color: var(--primary-color) !important;
|
color: var(--primary-color) !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
starlight-theme-select, starlight-theme-select > label {
|
starlight-theme-select,
|
||||||
|
starlight-theme-select > label {
|
||||||
color: var(--primary-color) !important;
|
color: var(--primary-color) !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
starlight-theme-select select {
|
||||||
|
color: var(--primary-color) !important;
|
||||||
|
background-color: var(--background-color) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
starlight-theme-select select option {
|
||||||
|
color: var(--primary-color);
|
||||||
|
background-color: var(--background-color);
|
||||||
|
}
|
||||||
|
|
||||||
|
html[data-theme="dark"] starlight-theme-select select option {
|
||||||
|
color: var(--witch-purple) !important;
|
||||||
|
background-color: var(--witch-lavender) !important;
|
||||||
|
}
|
||||||
|
|
||||||
.social-icons::after {
|
.social-icons::after {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
@@ -132,6 +177,35 @@ starlight-theme-select, starlight-theme-select > label {
|
|||||||
background-color: var(--witch-plum) !important;
|
background-color: var(--witch-plum) !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.hero .tagline {
|
||||||
|
color: var(--primary-color) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
site-search button[data-open-modal] {
|
||||||
|
color: var(--primary-color) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
site-search button[data-open-modal] kbd {
|
||||||
|
color: var(--primary-color) !important;
|
||||||
|
background-color: var(--background-color) !important;
|
||||||
|
border-color: var(--primary-color) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
#starlight__search {
|
||||||
|
--pagefind-ui-text: var(--primary-color);
|
||||||
|
--pagefind-ui-primary: var(--witch-rose);
|
||||||
|
}
|
||||||
|
|
||||||
|
#starlight__search input::placeholder {
|
||||||
|
color: var(--primary-color) !important;
|
||||||
|
opacity: 0.8;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pagefind-ui__result-excerpt {
|
||||||
|
color: var(--primary-color) !important;
|
||||||
|
opacity: 0.9;
|
||||||
|
}
|
||||||
|
|
||||||
#extra-footer-content {
|
#extra-footer-content {
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
|
|||||||
+174
-87
@@ -2,62 +2,61 @@
|
|||||||
"$schema": "vscode://schemas/color-theme",
|
"$schema": "vscode://schemas/color-theme",
|
||||||
"type": "dark",
|
"type": "dark",
|
||||||
"colors": {
|
"colors": {
|
||||||
"activityBar.background": "#3a0d22",
|
"activityBar.background": "#150a1e",
|
||||||
"activityBar.foreground": "#ffb6c1",
|
"activityBar.foreground": "#e8d5e8",
|
||||||
"activityBarBadge.background": "#ff69b4",
|
"activityBarBadge.background": "#a8577e",
|
||||||
"activityBarBadge.foreground": "#000000",
|
"activityBarBadge.foreground": "#f5f5f5",
|
||||||
"button.background": "#ff69b4",
|
"button.background": "#44275a",
|
||||||
"button.foreground": "#000000",
|
"button.foreground": "#e8d5e8",
|
||||||
"dropdown.background": "#4a112a",
|
"dropdown.background": "#2b1b3d",
|
||||||
"dropdown.foreground": "#ffb6c1",
|
"dropdown.foreground": "#e8d5e8",
|
||||||
"editor.background": "#2a0a18",
|
"editor.background": "#0a0009",
|
||||||
"editor.foreground": "#ffb6c1",
|
"editor.foreground": "#e8d5e8",
|
||||||
"editor.lineHighlightBackground": "#1073cf2d",
|
"editor.lineHighlightBackground": "#2b1b3d",
|
||||||
"editor.lineHighlightBorder": "#9fced11f",
|
"editor.selectionBackground": "#a8577e",
|
||||||
"editor.selectionBackground": "#e35a8f",
|
"editor.selectionHighlightBackground": "#a8577e50",
|
||||||
"editor.selectionHighlightBackground": "#e35a8f80",
|
"editor.wordHighlightBackground": "#a8577e40",
|
||||||
"editor.wordHighlightBackground": "#e35a8f80",
|
"editorCursor.foreground": "#a8577e",
|
||||||
"editorCursor.foreground": "#ff69b4",
|
"editorGroupHeader.tabsBackground": "#150a1e",
|
||||||
"editorGroupHeader.tabsBackground": "#3a0d22",
|
"editorWhitespace.foreground": "#44275a",
|
||||||
"editorWhitespace.foreground": "#4a112a",
|
"focusBorder": "#a8577e",
|
||||||
"focusBorder": "#ff69b4",
|
"input.background": "#150a1e",
|
||||||
"input.background": "#3a0d22",
|
"input.foreground": "#e8d5e8",
|
||||||
"input.foreground": "#ffb6c1",
|
"input.placeholderForeground": "#d4a5c7",
|
||||||
"input.placeholderForeground": "#e35a8f",
|
"list.activeSelectionBackground": "#44275a",
|
||||||
"list.activeSelectionBackground": "#4a112a",
|
"list.activeSelectionForeground": "#e8d5e8",
|
||||||
"list.activeSelectionForeground": "#ffb6c1",
|
"list.hoverBackground": "#2b1b3d",
|
||||||
"list.hoverBackground": "#3a0d22",
|
"list.hoverForeground": "#e8d5e8",
|
||||||
"list.hoverForeground": "#ffb6c1",
|
"sideBar.background": "#150a1e",
|
||||||
"sideBar.background": "#3a0d22",
|
"sideBar.foreground": "#e8d5e8",
|
||||||
"sideBar.foreground": "#ffb6c1",
|
"sideBarTitle.foreground": "#d4a5c7",
|
||||||
"sideBarTitle.foreground": "#ff69b4",
|
"statusBar.background": "#44275a",
|
||||||
"statusBar.background": "#4a112a",
|
"statusBar.foreground": "#e8d5e8",
|
||||||
"statusBar.foreground": "#ffb6c1",
|
"statusBar.noFolderBackground": "#0a0009",
|
||||||
"statusBar.noFolderBackground": "#2a0a18",
|
"tab.activeBackground": "#2b1b3d",
|
||||||
"tab.activeBackground": "#3a0d22",
|
"tab.activeForeground": "#e8d5e8",
|
||||||
"tab.activeForeground": "#ffb6c1",
|
"tab.inactiveBackground": "#150a1e",
|
||||||
"tab.inactiveBackground": "#4a112a",
|
"tab.inactiveForeground": "#d4a5c7",
|
||||||
"tab.inactiveForeground": "#e35a8f",
|
"terminal.ansiBlack": "#2b1b3d",
|
||||||
"terminal.ansiBlack": "#4a112a",
|
"terminal.ansiBlue": "#7b5ea8",
|
||||||
"terminal.ansiBlue": "#c96385",
|
"terminal.ansiBrightBlack": "#44275a",
|
||||||
"terminal.ansiBrightBlack": "#3a0d22",
|
"terminal.ansiBrightBlue": "#9b7ec8",
|
||||||
"terminal.ansiBrightBlue": "#d87093",
|
"terminal.ansiBrightCyan": "#d0b8e8",
|
||||||
"terminal.ansiBrightCyan": "#ffafc5",
|
"terminal.ansiBrightGreen": "#a898c0",
|
||||||
"terminal.ansiBrightGreen": "#ff77a8",
|
"terminal.ansiBrightMagenta": "#d4a5c7",
|
||||||
"terminal.ansiBrightMagenta": "#ff85a2",
|
"terminal.ansiBrightRed": "#c96b8e",
|
||||||
"terminal.ansiBrightRed": "#ff1493",
|
"terminal.ansiBrightWhite": "#f5f5f5",
|
||||||
"terminal.ansiBrightWhite": "#fff5f7",
|
"terminal.ansiBrightYellow": "#e8d5e8",
|
||||||
"terminal.ansiBrightYellow": "#ffb6c1",
|
"terminal.ansiCyan": "#b8a0d0",
|
||||||
"terminal.ansiCyan": "#ff9aac",
|
"terminal.ansiGreen": "#8a7a9e",
|
||||||
"terminal.ansiGreen": "#e35a8f",
|
"terminal.ansiMagenta": "#a8577e",
|
||||||
"terminal.ansiMagenta": "#e35a8f",
|
"terminal.ansiRed": "#a8577e",
|
||||||
"terminal.ansiRed": "#ff69b4",
|
"terminal.ansiWhite": "#d4a5c7",
|
||||||
"terminal.ansiWhite": "#ffd1dc",
|
"terminal.ansiYellow": "#d4a5c7",
|
||||||
"terminal.ansiYellow": "#d45a88",
|
"terminal.background": "#0a0009",
|
||||||
"terminal.background": "#2a0a18",
|
"terminal.foreground": "#e8d5e8",
|
||||||
"terminal.foreground": "#ffb6c1",
|
"titleBar.activeBackground": "#2b1b3d",
|
||||||
"titleBar.activeBackground": "#4a112a",
|
"titleBar.activeForeground": "#e8d5e8"
|
||||||
"titleBar.activeForeground": "#ffb6c1"
|
|
||||||
},
|
},
|
||||||
"tokenColors": [
|
"tokenColors": [
|
||||||
{
|
{
|
||||||
@@ -66,7 +65,7 @@
|
|||||||
"punctuation.definition.comment"
|
"punctuation.definition.comment"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#E5A3B5",
|
"foreground": "#7A5A8A",
|
||||||
"fontStyle": "italic"
|
"fontStyle": "italic"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@@ -81,7 +80,7 @@
|
|||||||
"constant.other.symbol"
|
"constant.other.symbol"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF69B4"
|
"foreground": "#D4A5C7"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -93,7 +92,7 @@
|
|||||||
"support.constant"
|
"support.constant"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#C96385"
|
"foreground": "#C88FA8"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -105,7 +104,7 @@
|
|||||||
"variable.object.property"
|
"variable.object.property"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#D87093"
|
"foreground": "#E8D5E8"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -119,7 +118,7 @@
|
|||||||
"punctuation.decorator"
|
"punctuation.decorator"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#E35A8F"
|
"foreground": "#A8577E"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -132,7 +131,7 @@
|
|||||||
"meta.function.dart"
|
"meta.function.dart"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#D45A88"
|
"foreground": "#C070A0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -149,7 +148,7 @@
|
|||||||
"meta.return-type"
|
"meta.return-type"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8",
|
"foreground": "#D4A5C7",
|
||||||
"fontStyle": "bold"
|
"fontStyle": "bold"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@@ -160,7 +159,7 @@
|
|||||||
"punctuation.definition.annotation"
|
"punctuation.definition.annotation"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#C96385"
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -169,7 +168,7 @@
|
|||||||
"punctuation.definition.tag"
|
"punctuation.definition.tag"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#E35A8F"
|
"foreground": "#A8577E"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -181,7 +180,7 @@
|
|||||||
"entity.other.attribute-name.class"
|
"entity.other.attribute-name.class"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#D4A5C7"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -194,7 +193,7 @@
|
|||||||
"support.type.primitive.dart"
|
"support.type.primitive.dart"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#D4A5C7"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -203,7 +202,7 @@
|
|||||||
"constant.character.escape.regex"
|
"constant.character.escape.regex"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF69B4"
|
"foreground": "#D4A5C7"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -212,7 +211,7 @@
|
|||||||
"entity.name.section"
|
"entity.name.section"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#D45A88",
|
"foreground": "#A8577E",
|
||||||
"fontStyle": "bold"
|
"fontStyle": "bold"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@@ -239,7 +238,7 @@
|
|||||||
"markup.raw"
|
"markup.raw"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF69B4"
|
"foreground": "#D4A5C7"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -248,7 +247,7 @@
|
|||||||
"support.type.property-name.jsonc"
|
"support.type.property-name.jsonc"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#D4A5C7"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -262,7 +261,7 @@
|
|||||||
"keyword.operator.logical"
|
"keyword.operator.logical"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#E35A8F"
|
"foreground": "#CF8FAE"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -272,7 +271,7 @@
|
|||||||
"meta.template.expression"
|
"meta.template.expression"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#D87093"
|
"foreground": "#E8D5E8"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -283,7 +282,7 @@
|
|||||||
"variable.other.object.property"
|
"variable.other.object.property"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#D4A5C7"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -293,7 +292,7 @@
|
|||||||
"support.variable.object.node"
|
"support.variable.object.node"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#D4A5C7"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -303,7 +302,7 @@
|
|||||||
"source.rust entity.name.type.struct.rust"
|
"source.rust entity.name.type.struct.rust"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#D4A5C7"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -313,7 +312,7 @@
|
|||||||
"source.rust keyword.operator.logical"
|
"source.rust keyword.operator.logical"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#E35A8F"
|
"foreground": "#CF8FAE"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -322,7 +321,7 @@
|
|||||||
"source.python support.function.builtin.python"
|
"source.python support.function.builtin.python"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#D45A88"
|
"foreground": "#C070A0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -331,7 +330,7 @@
|
|||||||
"source.cs storage.type.cs"
|
"source.cs storage.type.cs"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#D4A5C7"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -340,7 +339,7 @@
|
|||||||
"source.dart support.type.dart"
|
"source.dart support.type.dart"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#D4A5C7"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -350,7 +349,7 @@
|
|||||||
"source.prisma keyword.type"
|
"source.prisma keyword.type"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#E35A8F"
|
"foreground": "#A8577E"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -359,7 +358,7 @@
|
|||||||
"source.graphql constant.character"
|
"source.graphql constant.character"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#D4A5C7"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -368,7 +367,7 @@
|
|||||||
"source.sql storage.type"
|
"source.sql storage.type"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#E35A8F"
|
"foreground": "#A8577E"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -378,7 +377,7 @@
|
|||||||
"meta.embedded.block.jsx"
|
"meta.embedded.block.jsx"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#D87093"
|
"foreground": "#E8D5E8"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -388,13 +387,101 @@
|
|||||||
"meta.decorator.angular"
|
"meta.decorator.angular"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#C96385"
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"scope": "ref.matchtext",
|
"scope": [
|
||||||
|
"entity.name.tag.yaml",
|
||||||
|
"string.unquoted.plain.out.yaml"
|
||||||
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FFFFFF"
|
"foreground": "#D4A5C7"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"support.type.property-name.toml",
|
||||||
|
"entity.name.tag.toml"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#D4A5C7"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"markup.underline.link",
|
||||||
|
"string.other.link.title.markdown",
|
||||||
|
"meta.link.inline.markdown"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#A8577E"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"markup.quote"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#7A5A8A",
|
||||||
|
"fontStyle": "italic"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"punctuation.definition.list.begin.markdown",
|
||||||
|
"beginning.punctuation.definition.list.markdown"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#A8577E"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"variable.css",
|
||||||
|
"variable.other.custom-property.css",
|
||||||
|
"support.type.custom-property.css"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#CF8FAE"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"support.macro.rust",
|
||||||
|
"entity.name.function.macro.rust",
|
||||||
|
"meta.macro.rust entity.name.function.rust"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#C070A0"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"storage.modifier.lifetime.rust",
|
||||||
|
"entity.name.lifetime.rust",
|
||||||
|
"punctuation.definition.lifetime.rust"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#9B5878"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"entity.name.package.go"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#C88FA8"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"entity.name.package.java",
|
||||||
|
"support.other.package.java",
|
||||||
|
"entity.name.package.kotlin"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#C88FA8"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|||||||
+181
-88
@@ -2,62 +2,61 @@
|
|||||||
"$schema": "vscode://schemas/color-theme",
|
"$schema": "vscode://schemas/color-theme",
|
||||||
"type": "light",
|
"type": "light",
|
||||||
"colors": {
|
"colors": {
|
||||||
"activityBar.background": "#ffd6e0",
|
"activityBar.background": "#e8d5e8",
|
||||||
"activityBar.foreground": "#d87093",
|
"activityBar.foreground": "#2b1b3d",
|
||||||
"activityBarBadge.background": "#ff69b4",
|
"activityBarBadge.background": "#a8577e",
|
||||||
"activityBarBadge.foreground": "#ffffff",
|
"activityBarBadge.foreground": "#f5f5f5",
|
||||||
"button.background": "#ff69b4",
|
"button.background": "#a8577e",
|
||||||
"button.foreground": "#ffffff",
|
"button.foreground": "#f5f5f5",
|
||||||
"dropdown.background": "#fff0f5",
|
"dropdown.background": "#e8d5e8",
|
||||||
"dropdown.foreground": "#d87093",
|
"dropdown.foreground": "#2b1b3d",
|
||||||
"editor.background": "#ffefef",
|
"editor.background": "#f5f5f5",
|
||||||
"editor.foreground": "#d87093",
|
"editor.foreground": "#2b1b3d",
|
||||||
"editor.lineHighlightBackground": "#1073cf2d",
|
"editor.lineHighlightBackground": "#d4a5c740",
|
||||||
"editor.lineHighlightBorder": "#9fced11f",
|
"editor.selectionBackground": "#d4a5c7",
|
||||||
"editor.selectionBackground": "#ffb6c1",
|
"editor.selectionHighlightBackground": "#d4a5c750",
|
||||||
"editor.selectionHighlightBackground": "#ffb6c180",
|
"editor.wordHighlightBackground": "#d4a5c740",
|
||||||
"editor.wordHighlightBackground": "#ffb6c180",
|
"editorCursor.foreground": "#a8577e",
|
||||||
"editorCursor.foreground": "#ff69b4",
|
"editorGroupHeader.tabsBackground": "#e8d5e8",
|
||||||
"editorGroupHeader.tabsBackground": "#ffe4e8",
|
"editorWhitespace.foreground": "#d4a5c7",
|
||||||
"editorWhitespace.foreground": "#ffe4e8",
|
"focusBorder": "#a8577e",
|
||||||
"focusBorder": "#ff69b4",
|
"input.background": "#f5f5f5",
|
||||||
"input.background": "#fff0f5",
|
"input.foreground": "#2b1b3d",
|
||||||
"input.foreground": "#d87093",
|
"input.placeholderForeground": "#a8577e",
|
||||||
"input.placeholderForeground": "#ff77a8",
|
"list.activeSelectionBackground": "#d4a5c7",
|
||||||
"list.activeSelectionBackground": "#ffefef",
|
"list.activeSelectionForeground": "#2b1b3d",
|
||||||
"list.activeSelectionForeground": "#d87093",
|
"list.hoverBackground": "#e8d5e8",
|
||||||
"list.hoverBackground": "#fff0f5",
|
"list.hoverForeground": "#2b1b3d",
|
||||||
"list.hoverForeground": "#d87093",
|
"sideBar.background": "#e8d5e8",
|
||||||
"sideBar.background": "#fff0f5",
|
"sideBar.foreground": "#2b1b3d",
|
||||||
"sideBar.foreground": "#d87093",
|
"sideBarTitle.foreground": "#a8577e",
|
||||||
"sideBarTitle.foreground": "#ff69b4",
|
"statusBar.background": "#a8577e",
|
||||||
"statusBar.background": "#ffd6e0",
|
"statusBar.foreground": "#f5f5f5",
|
||||||
"statusBar.foreground": "#d87093",
|
"statusBar.noFolderBackground": "#f5f5f5",
|
||||||
"statusBar.noFolderBackground": "#ffefef",
|
"tab.activeBackground": "#f5f5f5",
|
||||||
"tab.activeBackground": "#ffefef",
|
"tab.activeForeground": "#2b1b3d",
|
||||||
"tab.activeForeground": "#d87093",
|
"tab.inactiveBackground": "#e8d5e8",
|
||||||
"tab.inactiveBackground": "#ffd6e0",
|
"tab.inactiveForeground": "#44275a",
|
||||||
"tab.inactiveForeground": "#ff77a8",
|
"terminal.ansiBlack": "#2b1b3d",
|
||||||
"terminal.ansiBlack": "#ffe4e8",
|
"terminal.ansiBlue": "#7b5ea8",
|
||||||
"terminal.ansiBlue": "#db7093",
|
"terminal.ansiBrightBlack": "#44275a",
|
||||||
"terminal.ansiBrightBlack": "#ffefef",
|
"terminal.ansiBrightBlue": "#9b7ec8",
|
||||||
"terminal.ansiBrightBlue": "#f08080",
|
"terminal.ansiBrightCyan": "#d0b8e8",
|
||||||
"terminal.ansiBrightCyan": "#ffc0cb",
|
"terminal.ansiBrightGreen": "#a898c0",
|
||||||
"terminal.ansiBrightGreen": "#ff77a8",
|
"terminal.ansiBrightMagenta": "#d4a5c7",
|
||||||
"terminal.ansiBrightMagenta": "#ff9aac",
|
"terminal.ansiBrightRed": "#c96b8e",
|
||||||
"terminal.ansiBrightRed": "#ff0066",
|
"terminal.ansiBrightWhite": "#f5f5f5",
|
||||||
"terminal.ansiBrightWhite": "#fff5f7",
|
"terminal.ansiBrightYellow": "#e8d5e8",
|
||||||
"terminal.ansiBrightYellow": "#ffa6c9",
|
"terminal.ansiCyan": "#b8a0d0",
|
||||||
"terminal.ansiCyan": "#ffafc5",
|
"terminal.ansiGreen": "#8a7a9e",
|
||||||
"terminal.ansiGreen": "#ff69b4",
|
"terminal.ansiMagenta": "#a8577e",
|
||||||
"terminal.ansiMagenta": "#ff85a2",
|
"terminal.ansiRed": "#a8577e",
|
||||||
"terminal.ansiRed": "#ff1493",
|
"terminal.ansiWhite": "#d4a5c7",
|
||||||
"terminal.ansiWhite": "#ffd1dc",
|
"terminal.ansiYellow": "#d4a5c7",
|
||||||
"terminal.ansiYellow": "#ffb6c1",
|
"terminal.background": "#f5f5f5",
|
||||||
"terminal.background": "#ffefef",
|
"terminal.foreground": "#2b1b3d",
|
||||||
"terminal.foreground": "#d87093",
|
"titleBar.activeBackground": "#e8d5e8",
|
||||||
"titleBar.activeBackground": "#ffd6e0",
|
"titleBar.activeForeground": "#2b1b3d"
|
||||||
"titleBar.activeForeground": "#d87093"
|
|
||||||
},
|
},
|
||||||
"tokenColors": [
|
"tokenColors": [
|
||||||
{
|
{
|
||||||
@@ -66,7 +65,7 @@
|
|||||||
"punctuation.definition.comment"
|
"punctuation.definition.comment"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#E5A3B5",
|
"foreground": "#7A5A8A",
|
||||||
"fontStyle": "italic"
|
"fontStyle": "italic"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@@ -81,7 +80,7 @@
|
|||||||
"constant.other.symbol"
|
"constant.other.symbol"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF69B4"
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -93,7 +92,7 @@
|
|||||||
"support.constant"
|
"support.constant"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#C96385"
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -105,7 +104,7 @@
|
|||||||
"variable.object.property"
|
"variable.object.property"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#D87093"
|
"foreground": "#44275a"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -119,7 +118,7 @@
|
|||||||
"punctuation.decorator"
|
"punctuation.decorator"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#E35A8F"
|
"foreground": "#A8577E"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -132,7 +131,7 @@
|
|||||||
"meta.function.dart"
|
"meta.function.dart"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#D45A88"
|
"foreground": "#C070A0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -149,7 +148,7 @@
|
|||||||
"meta.return-type"
|
"meta.return-type"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8",
|
"foreground": "#9B5878",
|
||||||
"fontStyle": "bold"
|
"fontStyle": "bold"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@@ -160,7 +159,7 @@
|
|||||||
"punctuation.definition.annotation"
|
"punctuation.definition.annotation"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#C96385"
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -169,7 +168,7 @@
|
|||||||
"punctuation.definition.tag"
|
"punctuation.definition.tag"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#E35A8F"
|
"foreground": "#A8577E"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -181,7 +180,7 @@
|
|||||||
"entity.other.attribute-name.class"
|
"entity.other.attribute-name.class"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -194,7 +193,7 @@
|
|||||||
"support.type.primitive.dart"
|
"support.type.primitive.dart"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -203,7 +202,7 @@
|
|||||||
"constant.character.escape.regex"
|
"constant.character.escape.regex"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF69B4"
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -212,7 +211,7 @@
|
|||||||
"entity.name.section"
|
"entity.name.section"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#D45A88",
|
"foreground": "#A8577E",
|
||||||
"fontStyle": "bold"
|
"fontStyle": "bold"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@@ -239,7 +238,7 @@
|
|||||||
"markup.raw"
|
"markup.raw"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF69B4"
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -248,7 +247,7 @@
|
|||||||
"support.type.property-name.jsonc"
|
"support.type.property-name.jsonc"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -262,7 +261,7 @@
|
|||||||
"keyword.operator.logical"
|
"keyword.operator.logical"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#E35A8F"
|
"foreground": "#A8577E"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -272,7 +271,7 @@
|
|||||||
"meta.template.expression"
|
"meta.template.expression"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#D87093"
|
"foreground": "#44275a"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -283,7 +282,7 @@
|
|||||||
"variable.other.object.property"
|
"variable.other.object.property"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -293,7 +292,7 @@
|
|||||||
"support.variable.object.node"
|
"support.variable.object.node"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -303,7 +302,7 @@
|
|||||||
"source.rust entity.name.type.struct.rust"
|
"source.rust entity.name.type.struct.rust"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -313,7 +312,7 @@
|
|||||||
"source.rust keyword.operator.logical"
|
"source.rust keyword.operator.logical"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#E35A8F"
|
"foreground": "#A8577E"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -322,7 +321,7 @@
|
|||||||
"source.python support.function.builtin.python"
|
"source.python support.function.builtin.python"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#D45A88"
|
"foreground": "#C070A0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -331,7 +330,7 @@
|
|||||||
"source.cs storage.type.cs"
|
"source.cs storage.type.cs"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -340,7 +339,7 @@
|
|||||||
"source.dart support.type.dart"
|
"source.dart support.type.dart"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -350,7 +349,7 @@
|
|||||||
"source.prisma keyword.type"
|
"source.prisma keyword.type"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#E35A8F"
|
"foreground": "#A8577E"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -359,7 +358,7 @@
|
|||||||
"source.graphql constant.character"
|
"source.graphql constant.character"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#FF77A8"
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -368,7 +367,7 @@
|
|||||||
"source.sql storage.type"
|
"source.sql storage.type"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#E35A8F"
|
"foreground": "#A8577E"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -378,7 +377,7 @@
|
|||||||
"meta.embedded.block.jsx"
|
"meta.embedded.block.jsx"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#D87093"
|
"foreground": "#44275a"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -388,13 +387,107 @@
|
|||||||
"meta.decorator.angular"
|
"meta.decorator.angular"
|
||||||
],
|
],
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#C96385"
|
"foreground": "#9B5878"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"entity.name.tag.yaml",
|
||||||
|
"string.unquoted.plain.out.yaml"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#9B5878"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"support.type.property-name.toml",
|
||||||
|
"entity.name.tag.toml"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#9B5878"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"markup.underline.link",
|
||||||
|
"string.other.link.title.markdown",
|
||||||
|
"meta.link.inline.markdown"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#A8577E"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"markup.quote"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#7A5A8A",
|
||||||
|
"fontStyle": "italic"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"punctuation.definition.list.begin.markdown",
|
||||||
|
"beginning.punctuation.definition.list.markdown"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#A8577E"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"variable.css",
|
||||||
|
"variable.other.custom-property.css",
|
||||||
|
"support.type.custom-property.css"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#A8577E"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"support.macro.rust",
|
||||||
|
"entity.name.function.macro.rust",
|
||||||
|
"meta.macro.rust entity.name.function.rust"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#C070A0"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"storage.modifier.lifetime.rust",
|
||||||
|
"entity.name.lifetime.rust",
|
||||||
|
"punctuation.definition.lifetime.rust"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#9B5878"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"entity.name.package.go"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#9B5878"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scope": [
|
||||||
|
"entity.name.package.java",
|
||||||
|
"support.other.package.java",
|
||||||
|
"entity.name.package.kotlin"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"foreground": "#9B5878"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"scope": "token.info-token",
|
"scope": "token.info-token",
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#316BCD"
|
"foreground": "#6796E6"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -406,13 +499,13 @@
|
|||||||
{
|
{
|
||||||
"scope": "token.error-token",
|
"scope": "token.error-token",
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#CD3131"
|
"foreground": "#F44747"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"scope": "token.debug-token",
|
"scope": "token.debug-token",
|
||||||
"settings": {
|
"settings": {
|
||||||
"foreground": "#800080"
|
"foreground": "#B267E6"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|||||||
Reference in New Issue
Block a user