¿Por qué mis tokens no son visibles para la dirección enviada en etherscan?

Aplané el código y arreglé la advertencia. Pero el problema con el contrato es que los tokens no son visibles en las direcciones cuando se buscan con etherscan pero cuando trato de agregar a través de Metamask, es fácilmente visible.

El segundo problema es que los tokens no se transfieren. No sé la razón de eso también, hubo advertencias estáticas pero de gas, pero no entendí bien eso.

pragma solidity 0.4.25;

library SafeMath {

/**
* @dev Multiplies two numbers, reverts on overflow.
*/
function mul(uint256 a, uint256 b) internal pure returns (uint256) {
// Gas optimization: this is cheaper than requiring 'a' not being zero, but the
// benefit is lost if 'b' is also tested.
// See: https://github.com/OpenZeppelin/openzeppelin-solidity/pull/522
if (a == 0) {
  return 0;
}

uint256 c = a * b;
require(c / a == b);

return c;
}

/**
* @dev Integer division of two numbers truncating the quotient, reverts on division by zero.
*/
function div(uint256 a, uint256 b) internal pure returns (uint256) {
require(b > 0); // Solidity only automatically asserts when dividing by 0
uint256 c = a / b;
// assert(a == b * c + a % b); // There is no case in which this doesn't hold

return c;
}

 /**
 * @dev Subtracts two numbers, reverts on overflow (i.e. if subtrahend is greater than minuend).
 */
 function sub(uint256 a, uint256 b) internal pure returns (uint256) {
require(b <= a);
uint256 c = a - b;

return c;
}

/**
* @dev Adds two numbers, reverts on overflow.
*/
function add(uint256 a, uint256 b) internal pure returns (uint256) {
uint256 c = a + b;
require(c >= a);

return c;
}

/**
* @dev Divides two numbers and returns the remainder (unsigned integer modulo),
* reverts when dividing by zero.
*/
 function mod(uint256 a, uint256 b) internal pure returns (uint256) {
require(b != 0);
return a % b;
}
}


interface IERC20{        
function totalSupply() external constant returns (uint256 tootalSupply);
function balanceOf(address _owner) external constant returns (uint256 baalance);
function transfer(address _to, uint256 _value) external returns (bool success);
function transferFrom(address _from, address _to, uint256 _value) external returns (bool success);
function approve(address _spender, uint256 _value) external returns (bool success);
function allowance(address _owner, address _spender) external constant returns (uint256 remaining);
event Transfer(address indexed _from, address indexed _to, uint256 _value);
event Approval(address indexed _owner, address indexed _spender, uint256 _value);
}

contract FuncToken is IERC20{

using SafeMath for uint256;

uint public constant _totalSupply = 0;

string public constant symbol = "UB";
string public constant name = "UNIFIED BET";
uint8 public constant decimals = 18;

//1 ether = 1 UB
uint256 public constant RATE = 1;

address public owner;

mapping (address => uint256) balances;
mapping (address => mapping(address => uint256)) allowed;

function () payable{
    createToken();
}

constructor () public{
    owner = msg.sender;

}

function createToken() public payable {
    require(msg.value > 0);

    uint256 tokens = msg.value;
    balances[msg.sender] = balances[msg.sender].add(tokens);

    owner.transfer(msg.value);
}

function totalSupply() public constant returns (uint256 totalSupply){
    return _totalSupply;
}

function balanceOf(address _owner) public constant returns (uint256 balance){
    return balances[_owner];
}

function transfer(address _to, uint256 _value) public returns (bool success){
    require (
        balances[msg.sender] >= _value
        && _value > 0
        );
        balances[msg.sender] = balances[msg.sender].sub(_value);
        balances[_to] = balances[_to].add(_value);
        emit Transfer(msg.sender, _to, _value);
        return true;

}

function transferFrom(address _from, address _to, uint256 _value) public returns (bool success){
    require(
        allowed[_from][msg.sender] >= _value
        && balances[_from] >= _value
        && _value > 0
        );

        balances[_from] = balances[_from].sub(_value);
        balances[_to] = balances[_to].add(_value);
        allowed[_from][msg.sender] = allowed[_from][msg.sender].add(_value);
        emit Transfer(_from, _to, _value);
        return true;
}

function approve(address _spender, uint256 _value) public returns (bool success){
    allowed[msg.sender][_spender] = _value;
    emit Approval(msg.sender, _spender, _value);
    return true;
}

function allowance(address _owner, address _spender) public constant returns (uint256 remaining) {
    return allowed[_owner][_spender];
}

}

Cualquier ayuda será apreciada.

¿Cuál es su dirección de token? ¿Tiene un ejemplo de transacción sin eventos? En cualquier caso, Etherscan es un tercero de código cerrado y podría retrasar el proceso de contratos por razones no reveladas.
actualmente implementado en Rinkeby Network. Dirección del contrato: 0x0F051Af45eEdB54aA7d84a2aBF1829BAe82d026C
Dijiste: "Los tokens no se están transfiriendo". si intenta transferir tokens usando la función de transferencia, ¿qué sucede? ¿algún hash de transacción, por favor?
Y "Los tokens no son visibles en etherscan". En primer lugar, toma algún tiempo en etherscan. y en segundo lugar, debe haber algunos eventos de transferencia para ser recogidos en los resultados de búsqueda en etherscan :)

Respuestas (1)

Las páginas de direcciones de tokens indican que no se registró ningún evento de transferencia https://rinkeby.etherscan.io/tokens?q=0x0F051Af45eEdB54aA7d84a2aBF1829BAe82d026C .

Ahora, mirando su función de respaldo, llama createTokeny esa función no genera un evento.

Para generar un evento, debe modificar su función para que se vea así:

function createToken() public payable {
    require(msg.value > 0);

    uint256 tokens = msg.value;
    balances[msg.sender] = balances[msg.sender].add(tokens);

    owner.transfer(msg.value);

    // --------- Generate Transfer event -------------
    emit Transfer(address(0x), msg.sender, tokens);
}
Al mirar primero su respuesta, me preguntaba "pero el evento Transfer se emite allí mismo" hasta que me di cuenta de que había modificado la función original con fines de demostración. Tal vez podría dejar eso más claro.