mirror of
https://github.com/yusing/godoxy.git
synced 2025-05-20 12:42:34 +02:00

* feat: idle sleep for proxmox LXCs * refactor: replace deprecated docker api types * chore(api): remove debug task list endpoint * refactor: move servemux to gphttp/servemux; favicon.go to v1/favicon * refactor: introduce Pool interface, move agent_pool to agent module * refactor: simplify api code * feat: introduce debug api * refactor: remove net.URL and net.CIDR types, improved unmarshal handling * chore: update Makefile for debug build tag, update README * chore: add gperr.Unwrap method * feat: relative time and duration formatting * chore: add ROOT_DIR environment variable, refactor * migration: move homepage override and icon cache to $BASE_DIR/data, add migration code * fix: nil dereference on marshalling service health * fix: wait for route deletion * chore: enhance tasks debuggability * feat: stdout access logger and MultiWriter * fix(agent): remove agent properly on verify error * fix(metrics): disk exclusion logic and added corresponding tests * chore: update schema and prettify, fix package.json and Makefile * fix: I/O buffer not being shrunk before putting back to pool * feat: enhanced error handling module * chore: deps upgrade * feat: better value formatting and handling --------- Co-authored-by: yusing <yusing@6uo.me>
88 lines
1.9 KiB
TypeScript
88 lines
1.9 KiB
TypeScript
import { DomainOrWildcard, Email } from "../types";
|
|
export declare const AUTOCERT_PROVIDERS: readonly [
|
|
"local",
|
|
"cloudflare",
|
|
"clouddns",
|
|
"duckdns",
|
|
"ovh",
|
|
"porkbun",
|
|
];
|
|
export type AutocertProvider = (typeof AUTOCERT_PROVIDERS)[number];
|
|
export type AutocertConfig =
|
|
| LocalOptions
|
|
| CloudflareOptions
|
|
| CloudDNSOptions
|
|
| DuckDNSOptions
|
|
| OVHOptionsWithAppKey
|
|
| OVHOptionsWithOAuth2Config
|
|
| PorkbunOptions;
|
|
export interface AutocertConfigBase {
|
|
email: Email;
|
|
domains: DomainOrWildcard[];
|
|
cert_path?: string;
|
|
key_path?: string;
|
|
}
|
|
export interface LocalOptions {
|
|
provider: "local";
|
|
cert_path?: string;
|
|
key_path?: string;
|
|
options?: {} | null;
|
|
}
|
|
export interface CloudflareOptions extends AutocertConfigBase {
|
|
provider: "cloudflare";
|
|
options: {
|
|
auth_token: string;
|
|
};
|
|
}
|
|
export interface CloudDNSOptions extends AutocertConfigBase {
|
|
provider: "clouddns";
|
|
options: {
|
|
client_id: string;
|
|
email: Email;
|
|
password: string;
|
|
};
|
|
}
|
|
export interface DuckDNSOptions extends AutocertConfigBase {
|
|
provider: "duckdns";
|
|
options: {
|
|
token: string;
|
|
};
|
|
}
|
|
export interface PorkbunOptions extends AutocertConfigBase {
|
|
provider: "porkbun";
|
|
options: {
|
|
api_key: string;
|
|
secret_api_key: string;
|
|
};
|
|
}
|
|
export declare const OVH_ENDPOINTS: readonly [
|
|
"ovh-eu",
|
|
"ovh-ca",
|
|
"ovh-us",
|
|
"kimsufi-eu",
|
|
"kimsufi-ca",
|
|
"soyoustart-eu",
|
|
"soyoustart-ca",
|
|
];
|
|
export type OVHEndpoint = (typeof OVH_ENDPOINTS)[number];
|
|
export interface OVHOptionsWithAppKey extends AutocertConfigBase {
|
|
provider: "ovh";
|
|
options: {
|
|
application_secret: string;
|
|
consumer_key: string;
|
|
api_endpoint?: OVHEndpoint;
|
|
application_key: string;
|
|
};
|
|
}
|
|
export interface OVHOptionsWithOAuth2Config extends AutocertConfigBase {
|
|
provider: "ovh";
|
|
options: {
|
|
application_secret: string;
|
|
consumer_key: string;
|
|
api_endpoint?: OVHEndpoint;
|
|
oauth2_config: {
|
|
client_id: string;
|
|
client_secret: string;
|
|
};
|
|
};
|
|
}
|