Pré-requisitos
- O que é um contrato inteligente de serviço baseado em assinatura?
- Principais recursos e componentes de um contrato inteligente de serviço baseado em assinatura.
- Casos de uso de um contrato inteligente de serviço baseado em assinatura.
- Escrevendo um contrato inteligente de serviço baseado em assinatura.
- Implantação com QuickNode RPC.
O QUE É UM CONTRATO INTELIGENTE DE SERVIÇO BASEADO EM ASSINATURA?
Um contrato inteligente de serviço baseado em assinatura é um acordo digital autoexecutável que rege a prestação de um serviço aos usuários em troca de pagamentos periódicos, normalmente chamados de assinaturas. Opera em plataforma blockchain, o que garante transparência, segurança e automação do processo de assinatura.
PRINCIPAIS RECURSOS E COMPONENTES DE UM CONTRATO INTELIGENTE DE SERVIÇO BASEADO EM ASSINATURA.
- Acordo automatizado: o contrato inteligente é um código autoexecutável executado em uma blockchain. Contém regras e condições predefinidas que regem o serviço baseado em assinatura.
- Pagamentos recorrentes: facilita pagamentos regulares dos assinantes ao provedor de serviços. Esses pagamentos ocorrem em intervalos especificados (por exemplo, mensalmente, trimestralmente, anualmente), conforme descrito no contrato.
- Transparente e confiável: todos os termos e condições da assinatura, incluindo cronogramas de pagamento, condições de renovação e regras de acesso, estão codificados de forma transparente no contrato. Isso garante a confiança entre o provedor de serviços e os assinantes.
- Elimina intermediários: elimina a necessidade de intermediários ou processadores de pagamento terceirizados. Os pagamentos são tratados diretamente pelo contrato, reduzindo custos e possíveis pontos de falha.
- Controle de acesso: o contrato gerencia o acesso ao serviço. Somente assinantes com assinaturas ativas e atualizadas têm acesso.
- Gerenciamento de assinantes: ele monitora os assinantes registrados, seu status de pagamento e datas de vencimento da assinatura.
- Tratamento de renovação e expiração: define o processo de renovação de assinaturas assim que expirarem. Isso pode incluir renovações automáticas, notificações ou um período de carência para renovação manual.
- Função de administrador: normalmente, existe um administrador ou proprietário do contrato que define os termos, gerencia as assinaturas e retira taxas de assinatura. Essa função garante o bom funcionamento do serviço.
- Eventos e notificações: o contrato pode acionar eventos ou notificações para diversas ações, como pagamentos bem-sucedidos, renovações de assinaturas ou expirações.
- Mecanismo de Fallback: o contrato pode ter planos de contingência para cenários inesperados, como falhas nos pagamentos ou interrupções no serviço.
- Medidas de segurança: inclui salvaguardas para evitar o acesso não autorizado ou a adulteração de parâmetros contratuais.
- Política de reembolso e resolução de desacordo (se aplicável): o contrato pode definir condições para reembolsos e mecanismos para lidar com desacordos entre o provedor de serviços e os assinantes.
CASOS DE USO DE UM CONTRATO INTELIGENTE DE SERVIÇO BASEADO EM ASSINATURA
Esses contratos inteligentes têm uma ampla gama de potenciais casos de uso em vários setores. Vejamos alguns exemplos abaixo:
- Plataformas de streaming: os contratos inteligentes podem gerenciar assinaturas de serviços de streaming, como plataformas de vídeo, música ou jogos. Os usuários pagam uma taxa mensal pelo acesso ao conteúdo.
- Software como um serviço (SaaS): empresas que oferecem soluções de software por assinatura podem usar contratos inteligentes para automatizar o faturamento e o controle de acesso.
- Assinaturas de revistas e notícias: os editores podem utilizar contratos inteligentes para gerenciar assinaturas digitais de revistas, jornais ou meios de comunicação online.
- Assinaturas de academias: as academias de ginástica podem implementar contratos inteligentes para gerenciar as associações. Os usuários pagam uma taxa recorrente pelo acesso às instalações da academia.
- Serviços de armazenamento em nuvem: os provedores de soluções de armazenamento em nuvem podem automatizar renovações de assinaturas e controle de acesso usando contratos inteligentes.
- Comunidades baseadas em membros: comunidades ou fóruns online que exigem taxas de adesão para acesso podem empregar contratos inteligentes para lidar com assinaturas.
- Plataformas de e-learning: plataformas educacionais que oferecem cursos por assinatura podem usar contratos inteligentes para processamento de pagamentos e controle de acesso.
- Caixas de assinatura: empresas que oferecem caixas de assinatura selecionadas com produtos ou serviços podem automatizar o faturamento e a entrega usando contratos inteligentes.
- Utilidades e serviços: contratos inteligentes podem ser usados para gerenciar serviços públicos baseados em assinatura, como internet, eletricidade ou serviços de água.
- Assinaturas VIP: as empresas do setor de hospedagem ou entretenimento podem usar contratos inteligentes para gerenciar assinaturas VIP com benefícios exclusivos.
- Serviços de telecomunicações: as empresas de telecomunicações podem empregar contratos inteligentes para faturar e gerenciar assinaturas de serviços móveis ou de internet.
- Aplicativos de saúde e bem-estar: aplicativos que fornecem conteúdo ou serviços premium de saúde e bem-estar por assinatura podem automatizar pagamentos usando contratos inteligentes.
- Licenciamento de software: empresas que oferecem licenças de software por assinatura podem utilizar contratos inteligentes para lidar com renovações e controle de acesso.
- Plataformas freelancers: as plataformas que conectam freelancers a clientes podem implementar contratos inteligentes para gerenciar assinaturas premium ou níveis de acesso.
- Serviços de consultoria: consultores que oferecem serviços baseados em assinatura podem usar contratos inteligentes para cobrança e gerenciamento de acesso de clientes.
Escrevendo um Contrato Inteligente de Serviço Baseado em Assinatura
Ei, chega de fundamentos, é hora de ir para a parte técnica!
Abaixo está um código de contrato inteligente de serviço baseado em assinatura:
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
contract SubscriptionService {
address public owner;
uint256 public subscriptionFee;
uint256 public interval;
mapping(address => uint256) public subscriptionExpiry;
event SubscriptionRenewed(address subscriber, uint256 expiryTimestamp);
modifier onlyOwner() {
require(msg.sender == owner, "Somente o proprietário pode chamar esta função");
_;
}
constructor(uint256 _subscriptionFee, uint256 _interval) {
owner = msg.sender;
subscriptionFee = _subscriptionFee;
interval = _interval;
}
function setSubscriptionFee(uint256 _newFee) external onlyOwner {
subscriptionFee = _newFee;
}
function subscribe() external payable {
require(msg.value >= subscriptionFee, "Pagamento insuficiente para a assinatura");
uint256 expiryTimestamp = block.timestamp + interval;
subscriptionExpiry[msg.sender] = expiryTimestamp;
emit SubscriptionRenewed(msg.sender, expiryTimestamp);
}
function checkSubscription() external view returns (bool) {
return block.timestamp <= subscriptionExpiry[msg.sender];
}
function renewSubscription() external payable {
require(block.timestamp > subscriptionExpiry[msg.sender], "A assinatura ainda está ativa");
require(msg.value >= subscriptionFee, "Pagamento insuficiente para a assinatura");
uint256 expiryTimestamp = block.timestamp + interval;
subscriptionExpiry[msg.sender] = expiryTimestamp;
emit SubscriptionRenewed(msg.sender, expiryTimestamp);
}
function withdrawFunds() external onlyOwner {
uint256 balance = address(this).balance;
require(balance > 0, "Sem saldo para sacar");
payable(owner).transfer(balance);
}
}
Uma explicação detalhada do código:
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
-
// SPDX-License-Identifier: MIT
: este é um comentário especial que indica a licença sob a qual o código é lançado (licença MIT, neste caso). Permite que outros usem, modifiquem e distribuam o código com a devida atribuição. -
pragma solidity ^0.8.0;
: esta instrução Pragma especifica a versão do compilador Solidity a ser usada. Diz ao compilador para usar uma versão igual ou superior a 0.8.0. do Solidity, que é a linguagem de programação usada para escrever contratos inteligentes Ethereum.
contract SubscriptionService {
address public owner;
uint256 public subscriptionFee;
uint256 public interval;
mapping(address => uint256) public subscriptionExpiry;
event SubscriptionRenewed(address subscriber, uint256 expiryTimestamp);
modifier onlyOwner() {
require(msg.sender == owner, "Somente o proprietário pode chamar esta função");
_;
}
-
contract SubscriptionService { ... }
: define um novo contrato inteligente denominadoSubscriptionService
. -
address public owner;
: declara uma variável de estado públicaowner
do tipoaddress
. Ela armazenará o endereço do proprietário ou criador do contrato. -
uint256 public subscriptionFee;
: declara uma variável de estado públicasubscriptionFee
do tipouint256
. Representa a taxa exigida para a assinatura. -
uint256 public interval;
: declara uma variável de estado públicainterval
do tipouint256
. Representa a duração da assinatura em segundos. -
mapping(address => uint256) public subscriptionExpiry;
: declara uma variável de estado públicasubscriptionExpiry
como um mapeamento. Associa os endereços de assinantes às respectivas marcas temporais (timestamps) de expiração da assinatura. -
event SubscriptionRenewed(address subscriber, uint256 expiryTimestamp);
: é um evento que será emitido sempre que uma assinatura for renovada. Fornece informações sobre o assinante e a nova marca temporal de expiração. -
modifier onlyOwner() { ... }
: define um modificador chamadoonlyOwner
. Modificadores são usados para alterar o comportamento das funções. Este modificador restringe o acesso às funções apenas ao proprietário (owner
). -
require(msg.sender == owner, "Somente o proprietário pode chamar esta função");
: verifica se o endereço que chama a função (msg.sender
) é igual ao endereço doowner
. Caso contrário, gera uma exceção com a mensagem "Somente o proprietário pode chamar esta função". -
_;
: é um espaço reservado para o código real da função. Indica onde o código da função modificada será executado.
constructor(uint256 _subscriptionFee, uint256 _interval) {
owner = msg.sender;
subscriptionFee = _subscriptionFee;
interval = _interval;
}
-
constructor(uint256 _subscriptionFee, uint256 _interval) { ... }
: é a função do construtor do contrato. É executada uma vez quando o contrato é implantado. Recebe dois parâmetros:_subscriptionFee
e_interval
. -
owner = msg.sender;
: define a variávelowner
para o endereço do remetente (aquele que implanta o contrato). Estabelece-se assim o proprietário inicial do contrato. -
subscriptionFee = _subscriptionFee;
: definesubscriptionFee
para o valor fornecido ao implantar o contrato. -
interval = _interval;
: define o inervalo (interval
) para o valor fornecido ao implantar o contrato.
function setSubscriptionFee(uint256 _newFee) external onlyOwner {
subscriptionFee = _newFee;
}
-
function setSubscriptionFee(uint256 _newFee) external onlyOwner { ... }
: define uma função chamadasetSubscriptionFee
. Permite que o proprietário atualize a taxa de assinatura. -
require(msg.sender == owner, "Somente o proprietário pode chamar esta função");
: verifica se o endereço que chama a função é oowner
. Caso contrário, gera uma exceção com a mensagem "Somente o proprietário pode chamar esta função". -
subscriptionFee = _newFee;
: isso atualiza osubscriptionFee
com o novo valor fornecido.
function subscribe() external payable {
require(msg.value >= subscriptionFee, "Pagamento insuficiente para a assinatura");
uint256 expiryTimestamp = block.timestamp + interval;
subscriptionExpiry[msg.sender] = expiryTimestamp;
emit SubscriptionRenewed(msg.sender, expiryTimestamp);
}
-
function subscribe() external payable { ... }
: define uma função chamadasubscribe
. Permite que um usuário se inscreva enviando a taxa exigida. -
require(msg.value >= subscriptionFee, "Pagamento insuficiente para a assinatura");
: verifica se o valor (Ether) enviado com a transação é maior ou igual àsubscriptionFee
. Caso contrário, gera uma exceção com a mensagem “Pagamento insuficiente para a assinatura”. -
uint256 expiryTimestamp = block.timestamp + interval;
: calcula a marca temporal em que a assinatura expirará. Adiciona a marca temporal atual (block.timestamp
) aointerval
. -
subscriptionExpiry[msg.sender] = expiryTimestamp;
: define a marca temporal de expiração para o endereço do assinante no mapeamentosubscriptionExpiry
. -
emit SubscriptionRenewed(msg.sender, expiryTimestamp);
: emite o eventoSubscriptionRenewed
, indicando que uma assinatura foi renovada. Fornece informações sobre o assinante e a nova marca temporal de expiração.
function checkSubscription() external view returns (bool) {
return block.timestamp <= subscriptionExpiry[msg.sender];
}
-
function checkSubscription() external view returns (bool) { ... }
: define a função chamadacheckSubscription
. Permite que qualquer pessoa possa verificar se sua assinatura ainda está ativa. -
return block.timestamp <= subscriptionExpiry[msg.sender];
: retorna um valor booleano que indica se a marca temporal atual é menor ou igual à marca temporal de expiração da assinatura do endereço do chamador.
function renewSubscription() external payable {
require(block.timestamp > subscriptionExpiry[msg.sender], "A assinatura ainda está ativa");
require(msg.value >= subscriptionFee, "Pagamento insuficiente para a assinatura");
uint256 expiryTimestamp = block.timestamp + interval;
subscriptionExpiry[msg.sender] = expiryTimestamp;
emit SubscriptionRenewed(msg.sender, expiryTimestamp);
}
-
function renewSubscription() external payable { ... }
: define uma função chamadarenewSubscription
. Permite que um usuário renove sua assinatura enviando a taxa exigida. -
require(block.timestamp > subscriptionExpiry[msg.sender], "A assinatura ainda está ativa");
: verifica se a marca temporal atual é maior que a marca temporal de expiração da assinatura do endereço do chamador. Caso contrário, gera uma exceção com a mensagem "A assinatura ainda está ativa". -
require(msg.value >= subscriptionFee, "Pagamento insuficiente para a assinatura");
: verifica se o valor (Ether) enviado com a transação é maior ou igual àsubscriptionFee
. Caso contrário, gera uma exceção com a mensagem “Pagamento insuficiente para a assinatura”. -
uint256 expiryTimestamp = block.timestamp + interval;
: calcula a nova marca temporal de expiração adicionando a marca temporal atual aointerval
. -
subscriptionExpiry[msg.sender] = expiryTimestamp;
: atualiza a marca temporal de expiração do endereço do assinante no mapeamentosubscriptionExpiry
. -
emit SubscriptionRenewed(msg.sender, expiryTimestamp);
: emite o eventoSubscriptionRenewed
. Fornece informações sobre o assinante e a nova marca temporal de expiração.
function withdrawFunds() external onlyOwner {
uint256 balance = address(this).balance;
require(balance > 0, "Sem saldo para sacar");
payable(owner).transfer(balance);
}
}
-
function withdrawFunds() external onlyOwner { ... }
: define uma função chamadawithdrawFunds
. Permite ao proprietário retirar qualquer saldo Ether armazenado no contrato. -
uint256 balance = address(this).balance;
: recupera o saldo atual (em Wei) do contrato. -
require(balance > 0, "Sem saldo para sacar");
: verifica se o saldo é maior que zero. Caso contrário, gera uma exceção com a mensagem “Sem saldo para sacar”. -
payable(owner).transfer(balance);
: transfere todo o saldo para oowner
.
Este contrato inteligente fornece serviços baseados em assinatura onde os usuários podem assinar, renovar suas assinaturas e verificar o status de suas assinaturas. O proprietário pode definir e atualizar a taxa de assinatura, bem como retirar quaisquer fundos acumulados.
Vamos escrever este código em nosso REMIX IDE.
IMPLANTAÇÃO COM RPC QUICKNODE
PASSO 1.
Crie um novo nó Sepolia no QuickNode. Você terá que navegar até o painel QuickNode e clicar em “Criar” (create).
Depois, certifique-se de clicar na cadeia Ethereum. Confira uma captura de tela abaixo:
Clique em “Sepolia”:
Em seguida, clique em “Continuar” (continue) para prosseguir. Por fim, clique em “Criar ponto de extremidade” (criar endpoint) para obter seu URL da Sepolia.
PASSO 2.
Clique em “Adicionar rede” (add network). Siga as instruções sobre como adicionar o URL RPC ao navegador da sua carteira.
Clique em “Adicionar rede manualmente” (add network manually).
PASSO 3.
Insira um nome (qualquer), já que você está usando QuickNode, você pode usar “QKN”, copie/cole seu ponto de extremidade Web3 (certifique-se de incluir “/” no final!), insira o ChainID e clique em “Salvar” (save).
Estamos usando a rede de testes Sepolia, então é aconselhável usar o ID da cadeia Sepolia, que é “11155111”.
Finalmente, você obterá o resultado abaixo.
Perfeito! Estamos quase terminando, agora solicitamos um pouco de Eth da rede de testes Sepolia para podermos implantar nosso contrato inteligente.
PASSO 4.
Agora, para obter taxas de gás, usaremos https://faucet.quicknode.com/drip. Abaixo está o procedimento.
Em seguida, conecte a carteira e obtenha um pouco de Eth.
Depois de fazer isso, você obterá o resultado abaixo:
Com isso, estamos prontos para implantar nosso contrato inteligente de serviço baseado em assinatura.
Implantação do Código de Contrato Inteligente na Rede de Testes Sepolia
Clique em “Confirmar” (confirm) para finalizar as transações.
Conclusão
Parabéns por criar com sucesso seu próprio contrato inteligente de serviço baseado em assinatura na rede Ethereum!
Assine o boletim informativo QuickNode para mais artigos e guias sobre Ethereum. Se você tiver algum comentário, sinta-se à vontade para entrar em contato conosco através do Twitter. Você sempre pode conversar conosco em nosso servidor da comunidade Discord, que conta com alguns dos desenvolvedores mais legais que você já conheceu :)
Este artigo foi escrito por Playboi.eth e traduzido por Isabela Curado Nehme. Seu original pode ser lido aqui.
Top comments (0)