forked from agorise/c-ipfs
156 lines
5 KiB
C
156 lines
5 KiB
C
#include <stdlib.h>
|
|
#include <stdio.h>
|
|
#include <pthread.h>
|
|
|
|
#include "ipfs/cmd/ipfs/init.h"
|
|
#include "ipfs/commands/request.h"
|
|
#include "ipfs/commands/command_option.h"
|
|
#include "libp2p/os/utils.h"
|
|
#include "ipfs/core/ipfs_node.h"
|
|
#include "ipfs/core/builder.h"
|
|
#include "ipfs/repo/config/config.h"
|
|
#include "ipfs/repo/fsrepo/fs_repo.h"
|
|
|
|
const int nBitsForKeypairDefault = 2048;
|
|
|
|
/***
|
|
* runs before major processing during initialization
|
|
* @param request the request
|
|
* @returns 0 if a problem, otherwise a 1
|
|
*/
|
|
int init_pre_run(struct Request* request) {
|
|
//TODO: make sure daemon is not running
|
|
return 1;
|
|
}
|
|
|
|
/**
|
|
* This actually opens the repo and gets things set up
|
|
* @param repo the repo information
|
|
* @returns true(1) on success
|
|
*/
|
|
int initialize_ipns_keyspace(struct FSRepo* repo) {
|
|
//open fs repo
|
|
int retVal = ipfs_repo_fsrepo_open(repo);
|
|
if (retVal == 0)
|
|
return 0;
|
|
//TODO: make a new node, then close it
|
|
//TODO: setup offline routing on new node
|
|
struct IpfsNode* ipfs_node = NULL;
|
|
struct Context* ctx = NULL;
|
|
struct BuildCfg* bld_cfg = NULL;
|
|
//TODO: see line 185 of init.go, what does core.BldCfg{Repo: r} do? BldCfg is a structure
|
|
retVal = ipfs_core_builder_new_node(ctx, bld_cfg, ipfs_node);
|
|
//return namesys_initialize_keyspace(ctx, ipfs_node->DAG, ipfs_node->Namesys, ipfs_node->pinning, ipfs_node->private_key);
|
|
return retVal;
|
|
}
|
|
|
|
/**
|
|
* called by init_run, to do the heavy lifting
|
|
* @param out_file an output stream (stdout)
|
|
* @param repo_root a path that is where the .ipfs directory will be put
|
|
* @param empty true(1) if empty, false(0) if not
|
|
* @param num_bits_for_keypair number of bits for key pair
|
|
* @param conf the configuration struct
|
|
* @returns 0 on error, 1 on success
|
|
*/
|
|
int do_init(FILE* out_file, char* repo_root, int empty, int num_bits_for_keypair, struct RepoConfig* conf) {
|
|
// make sure the directory is writable
|
|
if (!os_utils_directory_writeable(repo_root))
|
|
return 0;
|
|
// verify that it is not already initialized
|
|
if (fs_repo_is_initialized(repo_root))
|
|
return 0;
|
|
//TODO: If the conf is null, make one
|
|
if ( conf->identity->peer == NULL || conf->identity->peer->id == NULL) {
|
|
int retVal = ipfs_repo_config_init(conf, num_bits_for_keypair, repo_root, 4001, NULL);
|
|
if (retVal == 0)
|
|
return 0;
|
|
}
|
|
// initialize the fs repo
|
|
struct FSRepo* repo;
|
|
int retVal = ipfs_repo_fsrepo_new(repo_root, conf, &repo);
|
|
if (retVal == 0)
|
|
return 0;
|
|
retVal = ipfs_repo_fsrepo_init(repo);
|
|
if (retVal == 0)
|
|
return 0;
|
|
|
|
//TODO: add default assets
|
|
return initialize_ipns_keyspace(repo);
|
|
}
|
|
|
|
/***
|
|
* does major processing during initialization
|
|
* @param request the request
|
|
* @returns 0 if a problem, otherwise a 1
|
|
*/
|
|
int init_run(struct Request* request) {
|
|
// TODO: make sure offline
|
|
// TODO: check parameters for logic errors
|
|
// TODO: Initialize
|
|
struct RepoConfig* conf;
|
|
if (ipfs_repo_config_new(&conf) == 0)
|
|
return 0;
|
|
// TODO: handle files in request
|
|
// do the heavy lifting
|
|
int num_bits_for_key_pair = request->cmd.options[0]->default_int_val;
|
|
return do_init(stdout, request->invoc_context->config_root, 1, num_bits_for_key_pair, conf);
|
|
}
|
|
|
|
/***
|
|
* does the cleanup after major processing during initialization
|
|
* @param request the request
|
|
* @returns 0 if a problem, otherwise a 1
|
|
*/
|
|
int init_post_run(struct Request* request) {
|
|
// nothing to do
|
|
return 1;
|
|
}
|
|
|
|
int ipfs_cmd_ipfs_init_command_new(struct Command* cmd) {
|
|
int retVal = 1;
|
|
|
|
// help text
|
|
cmd->help_text.tagline = "Initializes IPFS config file.";
|
|
cmd->help_text.short_description = "\nInitializes IPFS configuration files and generates a new keypair.\n\nipfs uses a repository in the local file system. By default, the repo is\nlocated at ~/.ipfs. To change the repo location, set the $IPFS_PATH\nenvironment variable.:\n\n export IPFS_PATH=/path/to/ipfsrepo";
|
|
|
|
cmd->argument_count = 1;
|
|
cmd->option_count = 2;
|
|
commands_command_init(cmd);
|
|
// allocate memory for array of pointers
|
|
retVal = commands_argument_init(cmd->arguments[0], "default-config", 0, 0, "Initialize with the given configuration");
|
|
if (retVal == 0)
|
|
return 0;
|
|
cmd->arguments[0]->enable_stdin = 1;
|
|
|
|
// options
|
|
cmd->options[0]->name_count = 2;
|
|
retVal = commands_command_option_init(cmd->options[0], "Number of bits to use in the generated RSA private key");
|
|
cmd->options[0]->names[0] = "bits";
|
|
cmd->options[0]->names[1] = "b";
|
|
cmd->options[0]->kind = integer;
|
|
cmd->options[0]->default_int_val = nBitsForKeypairDefault;
|
|
cmd->options[1]->name_count = 2;
|
|
retVal = commands_command_option_init(cmd->options[1], "Don't add and pin help files to the local storage");
|
|
cmd->options[1]->default_bool_val = 0;
|
|
cmd->options[1]->names[0] = "empty-repo";
|
|
cmd->options[1]->names[1] = "e";
|
|
|
|
// function pointers
|
|
cmd->pre_run = init_pre_run;
|
|
cmd->run = init_run;
|
|
cmd->post_run = init_post_run;
|
|
|
|
return retVal;
|
|
}
|
|
|
|
/***
|
|
* Uninitializes all the dynamic memory caused by get_init_command
|
|
* @param command the struct
|
|
* @returns 0 on failure, otherwise 1
|
|
*/
|
|
int ipfs_cmd_ipfs_init_command_free(struct Command* command) {
|
|
// NOTE: commands_command_free takes care of arguments and command_options
|
|
commands_command_free(command);
|
|
return 1;
|
|
}
|