epp-client is a client library written in Rust for Internet domain registration and management for domain registrars.
It supports the following basic Domain, Contact, Host, and Message management calls, with plans to add more calls and other EPP extensions in the future, and to eventually be RFC compliant with the EPP protocol.
EppDomainCheck
EppDomainCreate
EppDomainInfo
EppDomainUpdate
EppDomainDelete
EppDomainRenew
Domain Transfer - EppDomainTransferRequest
Contact Check - EppContactCheck
EppContactCreate
EppContactInfo
EppContactUpdate
Contact Delete - EppContactDelete
Host Check - EppHostCheck
EppHostCreate
EppHostInfo
EppHostUpdate
Host Delete - EppHostDelete
Message Poll - EppMessagePoll
EppMessageAck
To use the library, you must have an epp-client/epp-client.toml
config file with the relevant registry
credentials in your default user configuration directory on your OS. For Linux, this is the XDG user directory
,
usually located at $HOME/.config
or defined by the XDG_CONFIG_HOME
environment variable.
An example config looks like this:
```toml [registry.verisign] host = 'epp.verisign-grs.com' port = 700 username = 'username' password = 'password'
ext_uris = []
[registry.verisign.tls_files]
cert_chain = '/path/to/certificate/chain/pemfile'
key = '/path/to/private/key/pemfile' ```
Once the config is set correctly, you can create a mut variable of type EppClient
with the domain registry
```rust use eppclient::EppClient; use eppclient::epp::{EppDomainCheck, EppDomainCheckResponse}; use eppclient::epp::generateclienttrid;
async fn main() { // Create an instance of EppClient, specifying the name of the registry as in // the config file let mut client = match EppClient::new("verisign").await { Ok(client) => client, Err(e) => panic!("Failed to create EppClient: {}", e) };
// Make a domain check call, which returns an object of type EppDomainCheckResponse
// that contains the result of the call
let domain_check = EppDomainCheck::new(
vec!["eppdev.com", "eppdev.net"
generate_client_tr_id(&client).as_str()
);
let response = client.transact::<_, EppDomainCheckResponse>(&domain_check).await.unwrap();
// print the availability results
response.data.res_data.unwrap().check_data.domain_list
.iter()
.for_each(|chk| println!("Domain: {}, Available: {}", chk.domain.name, chk.domain.available));
} ```
Currently I don't have access to a registry's OT&E account to do extensive testing. I am using hexonet's EPP Gateway for testing, but access to a registry's OT&E account would be very helpful, so if anyone can help me out with one it would be very helpful!