Posts

Showing posts from December, 2020

ElasticSearch Mapping Visitor Pattern Not Applied on Dynamic Object

The joy of learning new technology is learning new constraints. There is never enough documentation. I need to insert dynamic objects into ElasticSearch. For the sake of consistency, I need some properties mapped to specify types and the rest will be mapped text. One amazing thing is the ElasticSearch automagical conversion called AutoMap. Seems like AutoMap with visitor pattern and properties override will meet my requirements, so I have something like this in my code: public class MapToTextPropertyVisitor : NoopPropertyVisitor {      public override IProperty Visit(PropertyInfo propertyInfo,                ElasticsearchPropertyAttributeBase attribute) => new TextProperty(); } var createIndexResponse = _client.Indices.Create("<index_name>", c => c      .Map<dynamic>(m => m           .AutoMap(new  MapToTextPropertyVisitor() )        ...

Amazon ECR Accessing Private Repository through AWS CLI

 Remote repository is always an easy way to share code. However, I can't seem to find an easy way to access my private repository in ECR. In order to push or pull from ECR, we have to first login via AWS CLI and pass the credentials to docker. The script is pretty straightforward and will work in most cases except mine: aws ecr get-login-password --region <region> | sudo docker login --username AWS --password-stdin <registry_url> The problem is I save my credentials for the registry in a different AWS CLI profile, thus I need to change my script to the following so I can push to and pull from the private repository: aws ecr get-login-password --region <region> --profile <custom_profile> | sudo docker login --username AWS --password-stdin <registry_url>

FTP Access Denied When Attempting to Transfer Files

Permission is, as usual, a double-edged sword. It happened when I tried to transfer files to a remote Linux server. I created a directory on the remote server and attempting to transfer files via FTP client but got an access denied error. It is weird because I do login using the same account and thus as the owner of the directory. The one that solves the problem in my case is by changing ownership of the folder recursively (-R option) and use name of the user as group name such as: sudo chown -R <user>:<user> <directory>